Exporter-5.72 is now on the CPAN
[perl.git] / pod / perldelta.pod
1 =encoding utf8
2
3 =head1 NAME
4
5 [ this is a template for a new perldelta file.  Any text flagged as XXX needs
6 to be processed before release. ]
7
8 perldelta - what is new for perl v5.23.0
9
10 =head1 DESCRIPTION
11
12 This document describes differences between the 5.22.0 release and the 5.23.0
13 release.
14
15 =head1 Notice
16
17 XXX Any important notices here
18
19 =head1 Core Enhancements
20
21 XXX New core language features go here.  Summarize user-visible core language
22 enhancements.  Particularly prominent performance optimisations could go
23 here, but most should go in the L</Performance Enhancements> section.
24
25 [ List each enhancement as a =head2 entry ]
26
27 =head1 Security
28
29 XXX Any security-related notices go here.  In particular, any security
30 vulnerabilities closed should be noted here rather than in the
31 L</Selected Bug Fixes> section.
32
33 [ List each security issue as a =head2 entry ]
34
35 =head1 Incompatible Changes
36
37 XXX For a release on a stable branch, this section aspires to be:
38
39     There are no changes intentionally incompatible with 5.XXX.XXX
40     If any exist, they are bugs, and we request that you submit a
41     report.  See L</Reporting Bugs> below.
42
43 [ List each incompatible change as a =head2 entry ]
44
45 =head1 Deprecations
46
47 XXX Any deprecated features, syntax, modules etc. should be listed here.
48
49 =head2 Module removals
50
51 XXX Remove this section if inapplicable.
52
53 The following modules will be removed from the core distribution in a
54 future release, and will at that time need to be installed from CPAN.
55 Distributions on CPAN which require these modules will need to list them as
56 prerequisites.
57
58 The core versions of these modules will now issue C<"deprecated">-category
59 warnings to alert you to this fact.  To silence these deprecation warnings,
60 install the modules in question from CPAN.
61
62 Note that these are (with rare exceptions) fine modules that you are encouraged
63 to continue to use.  Their disinclusion from core primarily hinges on their
64 necessity to bootstrapping a fully functional, CPAN-capable Perl installation,
65 not usually on concerns over their design.
66
67 =over
68
69 =item XXX
70
71 XXX Note that deprecated modules should be listed here even if they are listed
72 as an updated module in the L</Modules and Pragmata> section.
73
74 =back
75
76 [ List each other deprecation as a =head2 entry ]
77
78 =head1 Performance Enhancements
79
80 XXX Changes which enhance performance without changing behaviour go here.
81 There may well be none in a stable release.
82
83 [ List each enhancement as a =item entry ]
84
85 =over 4
86
87 =item *
88
89 XXX
90
91 =back
92
93 =head1 Modules and Pragmata
94
95 XXX All changes to installed files in F<cpan/>, F<dist/>, F<ext/> and F<lib/>
96 go here.  If Module::CoreList is updated, generate an initial draft of the
97 following sections using F<Porting/corelist-perldelta.pl>.  A paragraph summary
98 for important changes should then be added by hand.  In an ideal world,
99 dual-life modules would have a F<Changes> file that could be cribbed.
100
101 [ Within each section, list entries as a =item entry ]
102
103 =head2 New Modules and Pragmata
104
105 =over 4
106
107 =item *
108
109 XXX
110
111 =back
112
113 =head2 Updated Modules and Pragmata
114
115 =over 4
116
117 =item *
118
119 L<CPAN::Meta::Requirements> has been upgraded from version 2.132 to 2.133.
120
121 =item *
122
123 L<CPAN::Meta::YAML> has been upgraded from version 0.014 to 0.016.
124
125 =item *
126
127 L<Getopt::Long> has been upgraded from version 2.45 to 2.46.
128
129 =item *
130
131 L<HTTP::Tiny> has been upgraded from version 0.054 to 0.056.
132
133 =item *
134
135 The libnet distribution has been upgraded from version 3.05 to 3.06.
136
137 =item *
138
139 L<Math::BigInt> has been upgraded from version 1.9997 to 1.999701.
140
141 Correct the behaviour of bdiv() and bmod() in list context. [perl #124300]
142
143 Correct C<< Math::BigInt->new() >> for non-integer input.  [perl #124325]
144
145 Speed up Math::BigFloat -> blog(). [perl #124382]
146
147 Fix bug in Math::BigFloat's bceil() and bint() methods. [perl #124412]
148
149 =item *
150
151 L<Math::BigRat> has been upgraded from version 0.2608 to 0.260801.
152
153 Correct the behaviour of bdiv() and bmod() in list context. [perl #124303]
154
155 =item *
156
157 L<Module::Metadata> has been upgraded from version 1.000026 to 1.000027.
158
159 =item *
160
161 L<parent> has been upgraded from version 0.232 to 0.234.
162
163 =item *
164
165 L<perl5db.pl> has been upgraded from version 1.49 to 1.49_01.
166
167 User actions are no longer evaluated after the script under the
168 debugger finishes.  [perl #71678]
169
170 =item *
171
172 The Scalar-List-Utils distribution has been upgraded from version 1.41 to 1.42.
173
174 =back
175
176 =head2 Removed Modules and Pragmata
177
178 =over 4
179
180 =item *
181
182 XXX
183
184 =back
185
186 =head1 Documentation
187
188 XXX Changes to files in F<pod/> go here.  Consider grouping entries by
189 file and be sure to link to the appropriate page, e.g. L<perlfunc>.
190
191 =head2 New Documentation
192
193 XXX Changes which create B<new> files in F<pod/> go here.
194
195 =head3 L<XXX>
196
197 XXX Description of the purpose of the new file here
198
199 =head2 Changes to Existing Documentation
200
201 XXX Changes which significantly change existing files in F<pod/> go here.
202 However, any changes to F<pod/perldiag.pod> should go in the L</Diagnostics>
203 section.
204
205 =head3 L<XXX>
206
207 =over 4
208
209 =item *
210
211 XXX Description of the change here
212
213 =back
214
215 =head1 Diagnostics
216
217 The following additions or changes have been made to diagnostic output,
218 including warnings and fatal error messages.  For the complete list of
219 diagnostic messages, see L<perldiag>.
220
221 XXX New or changed warnings emitted by the core's C<C> code go here.  Also
222 include any changes in L<perldiag> that reconcile it to the C<C> code.
223
224 =head2 New Diagnostics
225
226 XXX Newly added diagnostic messages go under here, separated into New Errors
227 and New Warnings
228
229 =head3 New Errors
230
231 =over 4
232
233 =item *
234
235 XXX L<message|perldiag/"message">
236
237 =back
238
239 =head3 New Warnings
240
241 =over 4
242
243 =item *
244
245 XXX L<message|perldiag/"message">
246
247 =back
248
249 =head2 Changes to Existing Diagnostics
250
251 XXX Changes (i.e. rewording) of diagnostic messages go here
252
253 =over 4
254
255 =item *
256
257 XXX Describe change here
258
259 =back
260
261 =head1 Utility Changes
262
263 XXX Changes to installed programs such as F<perlbug> and F<xsubpp> go here.
264 Most of these are built within the directory F<utils>.
265
266 [ List utility changes as a =head2 entry for each utility and =item
267 entries for each change
268 Use L<XXX> with program names to get proper documentation linking. ]
269
270 =head2 L<XXX>
271
272 =over 4
273
274 =item *
275
276 XXX
277
278 =back
279
280 =head1 Configuration and Compilation
281
282 XXX Changes to F<Configure>, F<installperl>, F<installman>, and analogous tools
283 go here.  Any other changes to the Perl build process should be listed here.
284 However, any platform-specific changes should be listed in the
285 L</Platform Support> section, instead.
286
287 [ List changes as a =item entry ].
288
289 =over 4
290
291 =item *
292
293 XXX
294
295 =back
296
297 =head1 Testing
298
299 XXX Any significant changes to the testing of a freshly built perl should be
300 listed here.  Changes which create B<new> files in F<t/> go here as do any
301 large changes to the testing harness (e.g. when parallel testing was added).
302 Changes to existing files in F<t/> aren't worth summarizing, although the bugs
303 that they represent may be covered elsewhere.
304
305 [ List each test improvement as a =item entry ]
306
307 =over 4
308
309 =item *
310
311 XXX
312
313 =back
314
315 =head1 Platform Support
316
317 XXX Any changes to platform support should be listed in the sections below.
318
319 [ Within the sections, list each platform as a =item entry with specific
320 changes as paragraphs below it. ]
321
322 =head2 New Platforms
323
324 XXX List any platforms that this version of perl compiles on, that previous
325 versions did not.  These will either be enabled by new files in the F<hints/>
326 directories, or new subdirectories and F<README> files at the top level of the
327 source tree.
328
329 =over 4
330
331 =item XXX-some-platform
332
333 XXX
334
335 =back
336
337 =head2 Discontinued Platforms
338
339 XXX List any platforms that this version of perl no longer compiles on.
340
341 =over 4
342
343 =item XXX-some-platform
344
345 XXX
346
347 =back
348
349 =head2 Platform-Specific Notes
350
351 XXX List any changes for specific platforms.  This could include configuration
352 and compilation changes or changes in portability/compatibility.  However,
353 changes within modules for platforms should generally be listed in the
354 L</Modules and Pragmata> section.
355
356 =over 4
357
358 =item Win32
359
360 =over
361
362 =item *
363
364 Visual C++ 2013 builds will now execute on XP and higher. Previously they would
365 only execute on Vista and higher.
366
367 =item *
368
369 You can now build perl with GNU Make and GCC.  [perl #123440]
370
371 =item *
372
373 C<truncate($filename, $size)> now works for files over 4GB in size.
374 [perl #125347]
375
376 =back
377
378 =back
379
380 =head1 Internal Changes
381
382 XXX Changes which affect the interface available to C<XS> code go here.  Other
383 significant internal changes for future core maintainers should be noted as
384 well.
385
386 [ List each change as a =item entry ]
387
388 =over 4
389
390 =item *
391
392 XXX
393
394 =back
395
396 =head1 Selected Bug Fixes
397
398 XXX Important bug fixes in the core language are summarized here.  Bug fixes in
399 files in F<ext/> and F<lib/> are best summarized in L</Modules and Pragmata>.
400
401 [ List each fix as a =item entry ]
402
403 =over 4
404
405 =item *
406
407 Duplicating a closed file handle for write no longer creates a
408 filename of the form F<GLOB(0xXXXXXXXX)>.  [perl #125115]
409
410 =item *
411
412 Warning fatality is now ignored when rewinding the stack.  This
413 prevents infinite recursion when the now fatal error also causes
414 rewinding of the stack.  [perl #123398]
415
416 =back
417
418 =head1 Known Problems
419
420 XXX Descriptions of platform agnostic bugs we know we can't fix go here.  Any
421 tests that had to be C<TODO>ed for the release would be noted here.  Unfixed
422 platform specific bugs also go here.
423
424 [ List each fix as a =item entry ]
425
426 =over 4
427
428 =item *
429
430 XXX
431
432 =back
433
434 =head1 Errata From Previous Releases
435
436 =over 4
437
438 =item *
439
440 XXX Add anything here that we forgot to add, or were mistaken about, in
441 the perldelta of a previous release.
442
443 =back
444
445 =head1 Obituary
446
447 XXX If any significant core contributor has died, we've added a short obituary
448 here.
449
450 =head1 Acknowledgements
451
452 XXX Generate this with:
453
454   perl Porting/acknowledgements.pl v5.23.0..HEAD
455
456 =head1 Reporting Bugs
457
458 If you find what you think is a bug, you might check the articles recently
459 posted to the comp.lang.perl.misc newsgroup and the perl bug database at
460 https://rt.perl.org/ .  There may also be information at
461 http://www.perl.org/ , the Perl Home Page.
462
463 If you believe you have an unreported bug, please run the L<perlbug> program
464 included with your release.  Be sure to trim your bug down to a tiny but
465 sufficient test case.  Your bug report, along with the output of C<perl -V>,
466 will be sent off to perlbug@perl.org to be analysed by the Perl porting team.
467
468 If the bug you are reporting has security implications, which make it
469 inappropriate to send to a publicly archived mailing list, then please send it
470 to perl5-security-report@perl.org.  This points to a closed subscription
471 unarchived mailing list, which includes all the core committers, who will be
472 able to help assess the impact of issues, figure out a resolution, and help
473 co-ordinate the release of patches to mitigate or fix the problem across all
474 platforms on which Perl is supported.  Please only use this address for
475 security issues in the Perl core, not for modules independently distributed on
476 CPAN.
477
478 =head1 SEE ALSO
479
480 The F<Changes> file for an explanation of how to view exhaustive details on
481 what changed.
482
483 The F<INSTALL> file for how to build Perl.
484
485 The F<README> file for general stuff.
486
487 The F<Artistic> and F<Copying> files for copyright information.
488
489 =cut