This is a live mirror of the Perl 5 development currently hosted at https://github.com/perl/perl5
2329d483bc0aa1d704c19ead71005ca5ec705fc9
[perl5.git] / pod / perldelta.pod
1 =encoding utf8
2
3 =head1 NAME
4
5 perldelta - what is new for perl v5.25.4
6
7 =head1 DESCRIPTION
8
9 This document describes differences between the 5.25.3 release and the 5.25.4
10 release.
11
12 If you are upgrading from an earlier release such as 5.25.2, first read
13 L<perl5253delta>, which describes differences between 5.25.2 and 5.25.3.
14
15 =head1 Core Enhancements
16
17 XXX New core language features go here.  Summarize user-visible core language
18 enhancements.  Particularly prominent performance optimisations could go
19 here, but most should go in the L</Performance Enhancements> section.
20
21 [ List each enhancement as a =head2 entry ]
22
23 =head1 Security
24
25 XXX Any security-related notices go here.  In particular, any security
26 vulnerabilities closed should be noted here rather than in the
27 L</Selected Bug Fixes> section.
28
29 [ List each security issue as a =head2 entry ]
30
31 =head1 Performance Enhancements
32
33 =over 4
34
35 =item *
36
37 The rather slow implementation for the experimental subroutine signatures
38 feature has been made much faster; it is now comparable in speed with the
39 old-style C<my ($a, $b, @c) = @_>.
40
41 =back
42
43 =head1 Documentation
44
45 =head2 Changes to Existing Documentation
46
47 =head3 L<perlcall>
48
49 =over 4
50
51 =item *
52
53 Removed redundant C<dSP> from an example.
54
55 =back
56
57 =head1 Modules and Pragmata
58
59 XXX All changes to installed files in F<cpan/>, F<dist/>, F<ext/> and F<lib/>
60 go here.  If Module::CoreList is updated, generate an initial draft of the
61 following sections using F<Porting/corelist-perldelta.pl>.  A paragraph summary
62 for important changes should then be added by hand.  In an ideal world,
63 dual-life modules would have a F<Changes> file that could be cribbed.
64
65 [ Within each section, list entries as a =item entry ]
66
67 =head2 New Modules and Pragmata
68
69 =over 4
70
71 =item *
72
73 XXX
74
75 =back
76
77 =head2 Updated Modules and Pragmata
78
79 =over 4
80
81 =item *
82
83 L<XXX> has been upgraded from version A.xx to B.yy.
84
85 =item *
86
87 L<NEXT> has been upgraded from version 0.65 to 0.67.
88
89 =back
90
91 =head2 Removed Modules and Pragmata
92
93 =over 4
94
95 =item *
96
97 XXX
98
99 =back
100
101 =head1 Diagnostics
102
103 The following additions or changes have been made to diagnostic output,
104 including warnings and fatal error messages.  For the complete list of
105 diagnostic messages, see L<perldiag>.
106
107 XXX New or changed warnings emitted by the core's C<C> code go here.  Also
108 include any changes in L<perldiag> that reconcile it to the C<C> code.
109
110 =head2 New Diagnostics
111
112 XXX Newly added diagnostic messages go under here, separated into New Errors
113 and New Warnings
114
115 =head3 New Errors
116
117 =over 4
118
119 =item *
120
121 XXX L<message|perldiag/"message">
122
123 =back
124
125 =head3 New Warnings
126
127 =over 4
128
129 =item *
130
131 XXX L<message|perldiag/"message">
132
133 =back
134
135 =head2 Changes to Existing Diagnostics
136
137 XXX Changes (i.e. rewording) of diagnostic messages go here
138
139 =over 4
140
141 =item *
142
143 XXX Describe change here
144
145 =back
146
147 =head1 Utility Changes
148
149 XXX Changes to installed programs such as F<perlbug> and F<xsubpp> go here.
150 Most of these are built within the directory F<utils>.
151
152 [ List utility changes as a =head2 entry for each utility and =item
153 entries for each change
154 Use L<XXX> with program names to get proper documentation linking. ]
155
156 =head2 L<XXX>
157
158 =over 4
159
160 =item *
161
162 XXX
163
164 =back
165
166 =head1 Configuration and Compilation
167
168 XXX Changes to F<Configure>, F<installperl>, F<installman>, and analogous tools
169 go here.  Any other changes to the Perl build process should be listed here.
170 However, any platform-specific changes should be listed in the
171 L</Platform Support> section, instead.
172
173 [ List changes as a =item entry ].
174
175 =over 4
176
177 =item *
178
179 XXX
180
181 =back
182
183 =head1 Testing
184
185 XXX Any significant changes to the testing of a freshly built perl should be
186 listed here.  Changes which create B<new> files in F<t/> go here as do any
187 large changes to the testing harness (e.g. when parallel testing was added).
188 Changes to existing files in F<t/> aren't worth summarizing, although the bugs
189 that they represent may be covered elsewhere.
190
191 [ List each test improvement as a =item entry ]
192
193 =over 4
194
195 =item *
196
197 XXX
198
199 =back
200
201 =head1 Platform Support
202
203 XXX Any changes to platform support should be listed in the sections below.
204
205 [ Within the sections, list each platform as a =item entry with specific
206 changes as paragraphs below it. ]
207
208 =head2 New Platforms
209
210 XXX List any platforms that this version of perl compiles on, that previous
211 versions did not.  These will either be enabled by new files in the F<hints/>
212 directories, or new subdirectories and F<README> files at the top level of the
213 source tree.
214
215 =over 4
216
217 =item XXX-some-platform
218
219 XXX
220
221 =back
222
223 =head2 Discontinued Platforms
224
225 XXX List any platforms that this version of perl no longer compiles on.
226
227 =over 4
228
229 =item XXX-some-platform
230
231 XXX
232
233 =back
234
235 =head2 Platform-Specific Notes
236
237 XXX List any changes for specific platforms.  This could include configuration
238 and compilation changes or changes in portability/compatibility.  However,
239 changes within modules for platforms should generally be listed in the
240 L</Modules and Pragmata> section.
241
242 =over 4
243
244 =item Hurd
245
246 The hints for Hurd have been improved enabling malloc wrap and reporting the
247 GNU libc used (previously it was an empty string when reported).
248
249 =back
250
251 =head1 Internal Changes
252
253 XXX Changes which affect the interface available to C<XS> code go here.  Other
254 significant internal changes for future core maintainers should be noted as
255 well.
256
257 [ List each change as a =item entry ]
258
259 =over 4
260
261 =item *
262
263 Three new ops, C<OP_ARGELEM>, C<OP_ARGDEFELEM> and C<OP_ARGCHECK> have
264 been added. These are intended principally to implement the individual
265 elements of a subroutine signature, plus any overall checking required.
266
267 =back
268
269 =head1 Selected Bug Fixes
270
271 XXX Important bug fixes in the core language are summarized here.  Bug fixes in
272 files in F<ext/> and F<lib/> are best summarized in L</Modules and Pragmata>.
273
274 [ List each fix as a =item entry ]
275
276 =over 4
277
278 =item *
279
280 Problems with in-place array sorts: code like C<@a = sort { ... } @a>,
281 where the source and destination of the sort are the same plain array, are
282 optimised to do less copying around. Two side-effects of this optimisation
283 were that the contents of C<@a> as visible to to sort routine were
284 partially sorted, and under some circumstances accessing C<@a> during the
285 sort could crash the interpreter. Both these issues have been fixed, and
286 Sort functions see the original value of C<@a>.
287
288 =item *
289
290 Non-ASCII string delimiters are now reported correctly in error messages
291 for unterminated strings.  [perl #128701]
292
293 =item *
294
295 C<pack("p", ...)> used to emit its warning ("Attempt to pack pointer to
296 temporary value") erroneously in some cases, but has been fixed.
297
298 =item *
299
300 C<@DB::args> is now exempt from "used once" warnings.  The warnings only
301 occurred under B<-w>, because F<warnings.pm> itself uses C<@DB::args>
302 multiple times.
303
304 =item *
305
306 The use of built-in arrays or hash slices in a double-quoted string no
307 longer issues a warning ("Possible unintended interpolation...") if the
308 variable has not been mentioned before.  This affected code like
309 C<qq|@DB::args|> and C<qq|@SIG{'CHLD', 'HUP'}|>.  (The special variables
310 C<@-> and C<@+> were already exempt from the warning.)
311
312 =item *
313
314 C<gethostent> and similar functions now perform a null check internally, to
315 avoid crashing with torsocks.  This was a regression from 5.22.  [perl
316 #128740]
317
318 =item *
319
320 C<defined *{'!'}>, C<defined *{'['}>, and C<defined *{'-'}> no longer leak
321 memory if the typeglob in question has never been accessed before.
322
323 =item *
324
325 In 5.25.4 fchown() was changed not to accept negative one as an argument
326 because in some platforms that is an error.  However, in some other platforms
327 that is an acceptable argument.  This change has been reverted [perl #128967].
328
329 =item *
330
331 Mentioning the same constant twice in a row (which is a syntax error) no
332 longer fails an assertion under debugging builds.  This was a regression
333 from 5.20.  [perl #126482]
334
335 =item *
336
337 Many issues relating to C<printf "%a"> of hexadecimal floating point
338 were fixed.  In addition, the "subnormals" (formerly known as "denormals")
339 floating point anumbers are now supported both with the plain IEEE 754
340 floating point numbers (64-bit or 128-bit) and the x86 80-bit
341 "extended precision".  Note that subnormal hexadecimal floating
342 point literals will give a warning about "exponent underflow".
343 [perl #128843, #128889, #128890, #128893, #128909, #128919]
344
345 =item *
346
347 A regression in 5.24 with C<tr/\N{U+...}/foo/> when the code point was between
348 128 and 255 has been fixed. [perl #128734].
349
350 =item *
351
352 A regression from the previous development release, 5.23.3, where
353 compiling a regular expression could crash the interpreter has been
354 fixed. [perl #128686].
355
356 =item *
357
358 Use of a string delimiter whose code point is above 2**31 now works
359 correctly on platforms that allow this.  Previously, certain characters,
360 due to truncation, would be confused with other delimiter characters
361 with special meaning (such as C<?> in C<m?...?>), resulting
362 in inconsistent behaviour.  Note that this is non-portable,
363 and is based on Perl's extension to UTF-8, and is probably not
364 displayable nor enterable by any editor. [perl #128738]
365
366 =item *
367
368 C<@{x> followed by a newline where C<x> represents a control or non-ASCII
369 character no longer produces a garbled syntax error message or a crash.
370 [perl #128951]
371
372 =back
373
374 =head1 Known Problems
375
376 XXX Descriptions of platform agnostic bugs we know we can't fix go here.  Any
377 tests that had to be C<TODO>ed for the release would be noted here.  Unfixed
378 platform specific bugs also go here.
379
380 [ List each fix as a =item entry ]
381
382 =over 4
383
384 =item *
385
386 XXX
387
388 =back
389
390 =head1 Errata From Previous Releases
391
392 =over 4
393
394 =item *
395
396 XXX Add anything here that we forgot to add, or were mistaken about, in
397 the perldelta of a previous release.
398
399 =back
400
401 =head1 Obituary
402
403 XXX If any significant core contributor has died, we've added a short obituary
404 here.
405
406 =head1 Acknowledgements
407
408 XXX Generate this with:
409
410   perl Porting/acknowledgements.pl v5.25.3..HEAD
411
412 =head1 Reporting Bugs
413
414 If you find what you think is a bug, you might check the perl bug database
415 at L<https://rt.perl.org/> .  There may also be information at
416 L<http://www.perl.org/> , the Perl Home Page.
417
418 If you believe you have an unreported bug, please run the L<perlbug> program
419 included with your release.  Be sure to trim your bug down to a tiny but
420 sufficient test case.  Your bug report, along with the output of C<perl -V>,
421 will be sent off to perlbug@perl.org to be analysed by the Perl porting team.
422
423 If the bug you are reporting has security implications which make it
424 inappropriate to send to a publicly archived mailing list, then see
425 L<perlsec/SECURITY VULNERABILITY CONTACT INFORMATION>
426 for details of how to report the issue.
427
428 =head1 SEE ALSO
429
430 The F<Changes> file for an explanation of how to view exhaustive details on
431 what changed.
432
433 The F<INSTALL> file for how to build Perl.
434
435 The F<README> file for general stuff.
436
437 The F<Artistic> and F<Copying> files for copyright information.
438
439 =cut