termcol: scalar colour shorthand
[sheet.git] / perl.inc.pl
1 use utf8;
2
3 +{
4         v5.6 => {
5                 new => [
6                         ['<code>use warnings</code>', 'pragma to enable warnings in lexical scope'],
7                         ['<code>use utf8</code>', 'experimental unicode semantics <small>(completed in v5.8)</small>', v5.8],
8                         ['<code>use charnames</code>', 'string escape <code>\N{}</code> to insert named character'],
9                         ['<code>our</code>', 'declare global variables'],
10                         ['<code>v1.2.3</code>', q"represent strings as vector of ordinals, useful in version numbers (<code>printf '%vd'</code> to display)"],
11                         ['<code>0b0</code>', q"binary numbers in literals, <code>printf '%b'</code>, and <code>oct</code>"],
12                         ['<code>sub :lvalue</code>', 'subroutine attribute to return a modifiable value', v5.20],
13 #                       ['<code>sub :locked :method</code>', 'syntax to declare subroutine attributes'], # can be inferred from :lvalue support
14                         ['<code>open my $fh, $mode, $expr</code>', 'file handles in scoped scalars, third argument for unambiguous file name'],
15                         [q"<code>pack 'q'</code>", '64-bit integer support (also large files &gt;2GiB)', v5.8.1],
16                         ['<code>sort $coderef ()</code>', 'comparison function can be a subroutine reference; prototype <code>($$)</code> to pass elements as normal <code>@_</code>'],
17                         ['<code>CHECK {}</code>', 'special block called at end of compilation'],
18                         ['<code>/[[:…:]]/</code>', 'POSIX character class syntax such as <code>/[[:alpha:]]/</code>'],
19                         # quite a lot more, but leave it at this
20                 ],
21                 release => '2000-03-23',
22                 distro => {
23                         debian => 'woody',
24                         rhel => '2', # v5.6.0; also in red hat 7.0
25                         solaris => '9', # v5.6.1; 2002-05 eol 2014-10
26                         aix => '5.1', # 2001-05 eol 2006-04
27                 },
28                 unicode => '3.0.1',
29         },
30
31         v5.8 => {
32                 new => [
33                         [q"<code>no utf8</code>", 'full unicode support, <code>utf8</code> pragma only for script encoding'],
34                         [q"<code>binmode $fh, ':perlio'</code>", 'file handle behaviour altered by PerlIO layers'],
35                         [q"<code>open $fh, '-|', @cmd</code>", 'open list to fork a command without spawning a shell'],
36                         [q"<code>open $fh, '>', \$var</code>", 'perl scalars as virtual files'],
37                         [q"<code>printf '%1$s', @args</code>", 'syntax to use parameters out of order'],
38                         [q"<code>1_2_3 == 123</code>", 'underscores between digits allowed in numeric constants'],
39 #                       [q"<code>use if</code>", 'conditional module inclusion'], # also installable in earlier versions
40                 ],
41                 release => '2002-07-18',
42                 distro => {
43                         debian => 'sarge',
44                         rhel => '3', # v5.8.0; v5.8.8 in RHEL6 (2007-2014)
45                         solaris => '10', # v5.8.4; 2005-01 eol 2021-01
46                         centos => '3-5', # v5.8.0 in v3 (2004-03); v5.8.8 in v5 (eol 2017-03)
47                         ubuntu => '4.10',
48                         aix => '5.2', # v5.8.0; v5.8.2 in 5.3 and 6.1 (eol 2017-04-30)
49                 },
50                 unicode => '3.2.0',
51         },
52
53         v5.10 => {
54                 new => [
55                         ['<code>//</code>', 'defined-or operator'],
56                         ['<code>~~</code>', 'smart-match operator to compare different data types <small>(updated in v5.10.1)</small>', 'experimental::smartmatch'],
57                         ['<code>given</code>', 'switch statement to smart-match with <code>when</code>/<code>default</code>', 'experimental::smartmatch'],
58                         ['<code>/(?&lt;name>)/</code>', 'named capture buffers into <code>%+</code>'],
59                         ['<code>s/keep\K//</code>', 'floating positive lookbehind, efficient alternative for <code>s/(keep)/$1/</code>'],
60                         ['<code>/\v/, /\h/</code>', 'vertical and horizontal whitespace escapes'],
61                         ['<code>my $_</code>', 'lexically scoped version of the default variable', v0.5.23.4, 'experimental::lexical_topic'],
62                 ],
63                 release => '2007-12-18',
64                 distro => {
65                         debian => 'lenny',
66                         rhel => '6', # v5.10.1
67                         centos => '6', # v5.10.1 (2011-07 eol 2020-11)
68                         ubuntu => '8.10', # v5.10.1 in 10.04 LTS
69                         aix => '7.1', # v5.10.1 (2010-09 eol 2020?)
70                 },
71                 unicode => '5.0.0',
72         },
73
74         v5.12 => {
75                 new => [
76                         ['<code>package</code> version', '<code>package</code> NAME VERSION shorthand for <code>our $VERSION</code>'],
77                         ['<code>...</code>', 'yada-yada operator: code placeholder'],
78                         ['<code>use 5.012</code>', 'implicit <code>strict</code> if use VERSION >= v5.12'],
79                         ['<code>… when</code>', '<code>when</code> is now allowed to be used as a statement modifier'],
80                         [q"<code>use overload 'qr'</code>", 'customisable conversion to regular expressions'],
81                         ['<code>/\N/</code>', 'inverse \n to match any character except newline regardless of <code>/s</code>', v5.18],
82                 ],
83                 release => '2010-04-12',
84                 unicode => '5.2',
85                 distro => {
86                         solaris => '11', # also v5.8.4; 2010-11 eol 2024-11
87                         ubuntu => '11.10',
88                 },
89         },
90
91         v5.14 => {
92                 new => [
93                         ['<code>s///r</code>', 'non-destructive substitution'],
94                         ['<code>/(?^)/</code>', 'construct to reset to default modifiers'],
95                         ['<code>/(?{ m() })/</code>', 'regular expressions can be nested in <code>/(?{})/</code> and <code>/(??{})/</code>', v5.20],
96                         [q"<code>use re '/flags'</code>", 'customise default modifiers'],
97                         ['<code>each $ref</code> e.a.', 'array and hash container functions accept references', v0.5.23.1],
98                         ['<code>FH->method</code>', 'filehandle method calls load IO::File on demand (eg. <code>STDOUT->flush</code>)'],
99                 ],
100                 release => '2011-05-14',
101                 distro => {
102                         debian => 'wheezy',
103                         ubuntu => '12.04',
104                 },
105                 unicode => '6.0+#8',
106         },
107
108         v5.16 => {
109                 new => [
110                         ['<code>__SUB__</code>', 'current subroutine reference'],
111                         ['<code>fc, "\F"</code>', 'unicode foldcase to compare case-insensitively'],
112                         ['<code>"\N{}"</code>', 'automatic <code>use charnames qw( :full :short )</code>'],
113                 ],
114                 release => '2012-05-20',
115                 distro => {
116                         rhel => '7', # v5.16.3
117                         centos => '7', # v5.16.3 (2014-07 eol 2024-06)
118                 },
119                 unicode => '6.1',
120         },
121
122         v5.18 => {
123                 new => [
124                         ['<code>${^LAST_FH}</code>', 'last read filehandle (used by <code>$.</code>)'],
125                         ['<code>/(?[ a + b ])/</code>', 'regex set operations (character substraction <code>-</code>, unions <code>&amp;</code>)', 'experimental::regex_sets'],
126                         ['<code>my sub</code>', 'lexical subroutines (also <code>state</code>, <code>our</code>); buggy before v5.22', 'experimental::lexical_subs'],
127                         ['<code>next $expression</code>', 'loop controls allow runtime expressions'],
128                         [q"<code>no warnings 'experimental::…'</code>", 'mechanism for experimental features, as of now required for smartmatch'],
129                 ],
130                 release => '2013-05-18',
131                 distro => {
132                         ubuntu => '14.04',
133                 },
134                 unicode => '6.2',
135         },
136
137         v5.20 => {
138                 new => [
139                         ['<code>sub ($var)</code>', 'subroutine signatures', 'experimental::signatures'],
140                         ['<code>%hash{…}</code>', 'hash slices return key+value pairs'],
141                         ['<code>[]->@*</code>', 'postfix dereferencing (also e.g. <code>$scalar->$*</code> for <code>$$scalar</code>)', v5.23.1, 'experimental::postderef'],
142                         [q"<code>use warnings 'once'; $a</code>", 'variables $a and $b are exempt from <em>used once</em> warnings'],
143                 ],
144                 unicode => '6.3',
145                 release => '2014-05-27',
146                 distro => {
147                         debian => 'jessie',
148                         ubuntu => '14.10',
149                         aix => '7.2',
150                 },
151         },
152
153         v5.22 => {
154                 new => [
155                         ['<code>\$alias =</code>', 'aliasing via reference'],
156                         ['<code>&lt;&lt;>></code>', 'safe <code>readline</code> ignoring open flags in arguments'],
157                         ['<code>/()/n</code>', 'flag to disable numbered capturing, turning <code>()</code> into <code>(?:)</code>'],
158                         ['<code>/\b{}/</code>', 'boundary types: <em>gcb</em> (grapheme cluster), <em>sb</em> (sentence), <em>wb</em> (word)'],
159                         ['<code>&.</code>', '<code>& | ^ ~</code> consistently numeric, dotted operators for strings', 'experimental::bitwise'],
160                         [q"<code>use re 'strict'</code>", 'apply stricter syntax rules to regular expression patterns', 'experimental::re_strict'],
161                         ['<code>0x.beep+0</code>', q"hexadecimal floating point notation with binary power; <code>printf '%a'</code> to display"],
162                 ],
163                 unicode => '7.0',
164                 release => '2015-06-01',
165                 distro => {
166                         ubuntu => '16.04',
167                 },
168         },
169
170         v5.24 => {
171                 new => [
172                         [q"<code>printf '%.*2$x'</code>", 'reordered precision arguments'],
173                         ['<code>/\b{lb}/</code>', 'line break boundary type (position suitable for hyphenation)'],
174                         ['<code>/faster/</code>', 'various significant speedups, notably matching fixed substrings, <code>/i</code> on caseless languages, 64-bit arithmetic, scope overhead'],
175                 ],
176                 unicode => '8.0',
177                 release => '2016-05-09',
178         },
179 }