Commit | Line | Data |
e4754a8e |
1 | ------------- |
2 | Version 5.000 |
3 | ------------- |
4 | |
5 | New things |
6 | ---------- |
7 | The -w switch is much more informative. |
8 | |
9 | References. See t/op/ref.t for examples. All entities in Perl 5 are |
10 | reference counted so that it knows when each item should be destroyed. |
11 | |
12 | Objects. See t/op/ref.t for examples. |
13 | |
14 | => is now a synonym for comma. This is useful as documentation for |
15 | arguments that come in pairs, such as initializers for associative arrays, |
16 | or named arguments to a subroutine. |
17 | |
18 | All functions have been turned into list operators or unary operators, |
19 | meaning the parens are optional. Even subroutines may be called as |
20 | list operators if they've already been declared. |
21 | |
22 | More embeddible. See main.c and embed_h.sh. Multiple interpreters |
23 | in the same process are supported (though not with interleaved |
24 | execution yet). |
25 | |
26 | The interpreter is now flattened out. Compare Perl 4's eval.c with |
27 | the perl 5's pp.c. Compare Perl 4's 900 line interpreter loop in cmd.c |
28 | with Perl 5's 1 line interpreter loop in run.c. Eventually we'll make |
29 | everything non-blocking so we can interface nicely with a scheduler. |
30 | |
31 | eval is now treated more like a subroutine call. Among other things, |
32 | this means you can return from it. |
33 | |
34 | Format value lists may be spread over multiple lines by enclosing in |
35 | a do {} block. |
36 | |
37 | You may now define BEGIN and END subroutines for each package. The BEGIN |
38 | subroutine executes the moment it's parsed. The END subroutine executes |
39 | just before exiting. |
40 | |
41 | Flags on the #! line are interpreted even if the script wasn't |
42 | executed directly. (And even if the script was located by "perl -x"!) |
43 | |
44 | The ?: operator is now legal as an lvalue. |
45 | |
46 | List context now propagates to the right side of && and ||, as well |
47 | as the 2nd and 3rd arguments to ?:. |
48 | |
49 | The "defined" function can now take a general expression. |
50 | |
51 | Lexical scoping available via "my". eval can see the current lexical |
52 | variables. |
53 | |
54 | The preferred package delimiter is now :: rather than '. |
55 | |
56 | tie/untie are now preferred to dbmopen/dbmclose. Multiple DBM |
57 | implementations are allowed in the same executable, so you can |
58 | write scripts to interchange data among different formats. |
59 | |
60 | New "and" and "or" operators work just like && and || but with |
61 | a precedence lower than comma, so they work better with list operators. |
62 | |
63 | New functions include: abs(), chr(), uc(), ucfirst(), lc(), lcfirst(), |
64 | chomp(), glob() |
65 | |
66 | require with a number checks to see that the version of Perl that is |
67 | currently running is at least that number. |
68 | |
69 | Dynamic loading of external modules is now supported. |
70 | |
71 | There is a new quote form qw//, which is equivalent to split(' ', q//). |
72 | |
73 | Assignment of a reference to a glob value now just replaces the |
74 | single element of the glob corresponding to the reference type: |
75 | *foo = \$bar, *foo = \&bletch; |
76 | |
77 | Filehandle methods are now supported: |
78 | output_autoflush STDOUT 1; |
79 | |
80 | There is now an "English" module that provides human readable translations |
81 | for cryptic variable names. |
82 | |
83 | Autoload stubs can now call the replacement subroutine with goto &realsub. |
84 | |
85 | Subroutines can be defined lazily in any package by declaring an AUTOLOAD |
86 | routine, which will be called if a non-existent subroutine is called in |
87 | that package. |
88 | |
89 | Several previously added features have been subsumed under the new |
90 | keywords "use" and "no". Saying "use Module LIST" is short for |
91 | BEGIN { require Module; import Module LIST; } |
92 | The "no" keyword is identical except that it calls "unimport" instead. |
93 | The earlier pragma mechanism now uses this mechanism, and two new |
94 | modules have been added to the library to implement "use integer" |
95 | and variations of "use strict vars, refs, subs". |
96 | |
97 | Variables may now be interpolated literally into a pattern by prefixing |
98 | them with \Q, which works just like \U, but backwhacks non-alphanumerics |
99 | instead. There is also a corresponding quotemeta function. |
100 | |
101 | Any quantifier in a regular expression may now be followed by a ? to |
102 | indicate that the pattern is supposed to match as little as possible. |
103 | |
104 | Pattern matches may now be followed by an m or s modifier to explicitly |
105 | request multiline or singleline semantics. An s modifier makes . match |
106 | newline. |
107 | |
108 | Patterns may now contain \A to match only at the beginning of the string, |
109 | and \Z to match only at the end. These differ from ^ and $ in that |
110 | they ignore multiline semantics. In addition, \G matches where the |
111 | last interation of m//g or s///g left off. |
112 | |
113 | Non-backreference-producing parens of various sorts may now be |
114 | indicated by placing a ? directly after the opening parenthesis, |
115 | followed by a character that indicates the purpose of the parens. |
116 | An :, for instance, indicates simple grouping. (?:a|b|c) will |
117 | match any of a, b or c without producing a backreference. It does |
118 | "eat" the input. There are also assertions which do not eat the |
119 | input but do lookahead for you. (?=stuff) indicates that the next |
120 | thing must be "stuff". (?!nonsense) indicates that the next thing |
121 | must not be "nonsense". |
122 | |
123 | The negation operator now treats non-numeric strings specially. |
124 | A -"text" is turned into "-text", so that -bareword is the same |
125 | as "-bareword". If the string already begins with a + or -, it |
126 | is flipped to the other sign. |
127 | |
128 | Incompatibilities |
129 | ----------------- |
130 | @ now always interpolates an array in double-quotish strings. Some programs |
131 | may now need to use backslash to protect any @ that shouldn't interpolate. |
132 | |
133 | Ordinary variables starting with underscore are no longer forced into |
134 | package main. |
135 | |
136 | s'$lhs'$rhs' now does no interpolation on either side. It used to |
137 | interplolate $lhs but not $rhs. |
138 | |
139 | The second and third arguments of splice are now evaluated in scalar |
140 | context (like the book says) rather than list context. |
141 | |
142 | Saying "shift @foo + 20" is now a semantic error because of precedence. |
143 | |
144 | "open FOO || die" is now incorrect. You need parens around the filehandle. |
145 | |
146 | The elements of argument lists for formats are now evaluated in list |
147 | context. This means you can interpolate list values now. |
148 | |
149 | You can't do a goto into a block that is optimized away. Darn. |
150 | |
151 | It is no longer syntactically legal to use whitespace as the name |
152 | of a variable, or as a delimiter for any kind of quote construct. |
153 | |
154 | Some error messages will be different. |
155 | |
156 | The caller function now returns a false value in a scalar context if there |
157 | is no caller. This lets library files determine if they're being required. |
158 | |
159 | m//g now attaches its state to the searched string rather than the |
160 | regular expression. |
161 | |
162 | "reverse" is no longer allowed as the name of a sort subroutine. |
163 | |
164 | taintperl is no longer a separate executable. There is now a -T |
165 | switch to turn on tainting when it isn't turned on automatically. |
166 | |
167 | Symbols starting with _ are no longer forced into package main, except |
168 | for $_ itself (and @_, etc.). |
169 | |
170 | Double-quoted strings may no longer end with an unescaped $ or @. |
171 | |
172 | Negative array subscripts now count from the end of the array. |
173 | |
174 | The comma operator in a scalar context is now guaranteed to give a |
175 | scalar context to its arguments. |
176 | |
177 | The ** operator now binds more tightly than unary minus. |
178 | |
179 | Setting $#array lower now discards array elements so that destructors |
180 | work reasonably. |
181 | |
182 | delete is not guaranteed to return the old value for tied arrays, |
183 | since this capability may be onerous for some modules to implement. |
184 | |
185 | Attempts to set $1 through $9 now result in a run-time error. |