This is a live mirror of the Perl 5 development currently hosted at https://github.com/perl/perl5
c0a7512ef8b2b9f96afa32a8d1e5fb04b32c792c
[perl5.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
6 XXX needs to be processed before release. ]
7
8 perldelta - what is new for perl v5.13.9
9
10 =head1 DESCRIPTION
11
12 This document describes differences between the 5.13.8 release and
13 the 5.13.9 release.
14
15 If you are upgrading from an earlier release such as 5.13.7, first read
16 L<perl5138delta>, which describes differences between 5.13.7 and
17 5.13.8.
18
19 =head1 Notice
20
21 XXX Any important notices here
22
23 =head1 Core Enhancements
24
25 XXX New core language features go here. Summarise user-visible core language
26 enhancements. Particularly prominent performance optimisations could go
27 here, but most should go in the L</Performance Enhancements> section.
28
29 [ List each enhancement as a =head2 entry ]
30
31 =head2 New regular expression modifier C</a>
32
33 The C</a> regular expression modifier restricts C<\s> to match precisely
34 the five characters C<[ \f\n\r\t]>, C<\d> to match precisely the 10
35 characters C<[0-9]>, C<\w> to match precisely the 63 characters
36 C<[A-Za-z0-9_]>, and the Posix (C<[[:posix:]]>) character classes to
37 match only the appropriate ASCII characters.  The complements, of
38 course, match everything but; and C<\b> and C<\B> are correspondingly
39 affected.  Otherwise, C</a> behaves like the C</u> modifier, in that
40 case-insensitive matching uses Unicode semantics; for example, "k" will
41 match the Unicode C<\N{KELVIN SIGN}> under C</i> matching, and code
42 points in the Latin1 range, above ASCII will have Unicode semantics when
43 it comes to case-insensitive matching.  Like its cousins (C</u>, C</l>,
44 and C</d>), and in spite of the terminology, C</a> in 5.14 will not
45 actually be able to be used as a suffix at the end of a regular
46 expression (this restriction is planned to be lifted in 5.16).  It must
47 occur either as an infix modifier, such as C<(?a:...)> or (C<(?a)...>,
48 or it can be turned on within the lexical scope of C<use re '/a'>.
49 Turning on C</a> turns off the other "character set" modifiers.
50
51 =head2 Any unsigned value can be encoded as a character
52
53 With this release, Perl is adopting a model that any unsigned value can
54 be treated as a code point and encoded internally (as utf8) without
55 warnings -- not just the code points that are legal in Unicode.
56 However, unless utf8 warnings have been
57 explicitly lexically turned off, outputting or performing a
58 Unicode-defined operation (such as upper-casing) on such a code point
59 will generate a warning.  Attempting to input these using strict rules
60 (such as with the C<:encoding('UTF-8')> layer) will continue to fail.
61 Prior to this release the handling was very inconsistent, and incorrect
62 in places.  Also, the Unicode non-characters, some of which previously were
63 erroneously considered illegal in places by Perl, contrary to the Unicode
64 standard, are now always legal internally.  But inputting or outputting
65 them will work the same as for the non-legal Unicode code points, as the
66 Unicode standard says they are illegal for "open interchange".
67
68 =head2 Regular expression debugging output improvement
69
70 Regular expression debugging output (turned on by C<use re 'debug';>) now
71 uses hexadecimal when escaping non-ASCII characters, instead of octal.
72
73 =head1 Security
74
75 XXX Any security-related notices go here.  In particular, any security
76 vulnerabilities closed should be noted here rather than in the
77 L</Selected Bug Fixes> section.
78
79 [ List each security issue as a =head2 entry ]
80
81 =head1 Incompatible Changes
82
83 XXX For a release on a stable branch, this section aspires to be:
84
85     There are no changes intentionally incompatible with 5.XXX.XXX. If any
86     exist, they are bugs and reports are welcome.
87
88 [ List each incompatible change as a =head2 entry ]
89
90 =head2 All objects are destroyed
91
92 It used to be possible to prevent a destructor from being called during
93 global destruction by artificially increasing the reference count of an
94 object.
95
96 Now such objects I<will> will be destroyed, as a result of a bug fix
97 L<[perl #81230]|http://rt.perl.org/rt3/Public/Bug/Display.html?id=81230>.
98
99 This has the potential to break some XS modules. (In fact, it break some.
100 See L</Known Problems>, below.)
101
102 =head1 Deprecations
103
104 XXX Any deprecated features, syntax, modules etc. should be listed here.
105 In particular, deprecated modules should be listed here even if they are
106 listed as an updated module in the L</Modules and Pragmata> section.
107
108 [ List each deprecation as a =head2 entry ]
109
110 =head1 Performance Enhancements
111
112 XXX Changes which enhance performance without changing behaviour go here. There
113 may well be none in a stable release.
114
115 [ List each enhancement as a =item entry ]
116
117 =over 4
118
119 =item *
120
121 XXX
122
123 =back
124
125 =head1 Modules and Pragmata
126
127 XXX All changes to installed files in F<cpan/>, F<dist/>, F<ext/> and F<lib/>
128 go here.  If Module::CoreList is updated, generate an initial draft of the
129 following sections using F<Porting/corelist-perldelta.pl>, which prints stub
130 entries to STDOUT.  Results can be pasted in place of the '=head2' entries
131 below.  A paragraph summary for important changes should then be added by hand.
132 In an ideal world, dual-life modules would have a F<Changes> file that could be
133 cribbed.
134
135 [ Within each section, list entries as a =item entry ]
136
137 =head2 New Modules and Pragmata
138
139 =over 4
140
141 =item *
142
143 L<CPAN::Meta::YAML> 0.003 has been added as a dual-life module.  It supports a
144 subset of YAML sufficient for reading and writing META.yml and MYMETA.yml files
145 included with CPAN distributions or generated by the module installation
146 toolchain. It should not be used for any other general YAML parsing or
147 generation task.
148
149 =item *
150
151 L<HTTP::Tiny> 0.009 has been added as a dual-life module.  It is a very
152 small, simple HTTP/1.1 client designed for simple GET requests and file
153 mirroring.  It has has been added to enable CPAN.pm and CPANPLUS to
154 "bootstrap" HTTP access to CPAN using pure Perl without relying on external
155 binaries like F<curl> or F<wget>.
156
157 =item *
158
159 L<Module::Metadata> 1.000003 has been added as a dual-life module.  It gathers
160 package and POD information from Perl module files.  It is a standalone module
161 based on Module::Build::ModuleInfo for use by other module installation
162 toolchain components.  Module::Build::ModuleInfo has been deprecated in
163 favor of this module instead.
164
165 =item *
166
167 L<Perl::OSType> 1.002 has been added as a dual-life module.  It maps Perl
168 operating system names (e.g. 'dragonfly' or 'MSWin32') to more generic types
169 with standardized names (e.g.  "Unix" or "Windows").  It has been refactored
170 out of Module::Build and ExtUtils::CBuilder and consolidates such mappings into
171 a single location for easier maintenance.
172
173 =back
174
175 =head2 Updated Modules and Pragmata
176
177 =over 4
178
179 =item *
180
181 C<Archive::Extract> has been upgraded from version 0.46 to 0.48
182
183 =item *
184
185 C<Archive::Tar> has been upgraded from version 1.74 to 1.76
186
187 =item *
188
189 C<CGI> has been upgraded from version 3.50 to 3.51
190
191 =item *
192
193 C<Compress::Raw::Bzip2> has been upgraded from version 2.031 to 2.033
194
195 =item *
196
197 C<Compress::Raw::Zlib> has been upgraded from version 2.030 to 2.033
198
199 =item *
200
201 C<CPAN> has been upgraded from version 1.94_62 to 1.94_63
202
203 =item *
204
205 C<CPANPLUS> has been upgraded from version 0.9010 to 0.9011
206
207 =item *
208
209 C<CPANPLUS::Dist::Build> has been upgraded from version 0.50 to 0.52
210
211 =item *
212
213 C<DB_File> has been upgraded from version 1.820 to 1.821
214
215 =item *
216
217 C<Encode> has been upgraded from version 2.40 to 2.42.
218 Now, all 66 Unicode non-characters are treated the same way U+FFFF has
219 always been treated; if it was disallowed, all 66 are disallowed; if it
220 warned, all 66 warn.
221
222 =item *
223
224 C<File::Fetch> has been upgraded from version 0.28 to 0.32
225
226 =item *
227
228 C<IO::Compress> has been upgraded from version 2.030 to 2.033
229
230 =item *
231
232 C<IPC::Cmd> has been upgraded from version 0.66 to 0.68
233
234 =item *
235
236 C<Log::Message> has been upgraded from version 0.02 to 0.04
237
238 =item *
239
240 C<Log::Message::Simple> has been upgraded from version 0.06 to 0.08
241
242 =item *
243
244 C<Module::Load::Conditional> has been upgraded from version 0.38 to 0.40
245
246 =item *
247
248 C<Object::Accessor> has been upgraded from version 0.36 to 0.38
249
250 =item *
251
252 C<Params::Check> has been upgraded from version 0.26 to 0.28
253
254 =item *
255
256 C<Pod::LaTeX> has been upgraded from version 0.58 to 0.59
257
258 =item *
259
260 C<Term::UI> has been upgraded from version 0.20 to 0.24
261
262 =item *
263
264 C<Thread::Queue> has been upgraded from version 2.11 to 2.12.
265
266 =item *
267
268 C<Thread::Semaphore> has been upgraded from version 2.11 to 2.12.
269
270 =item *
271
272 C<threads> has been upgraded from version 1.81_03 to 1.82
273
274 =item *
275
276 C<threads::shared> has been upgraded from version 1.35 to 1.36
277
278 =item *
279
280 C<Time::Local> has been upgraded from version 1.1901_01 to 1.2000.
281
282 =item *
283
284 C<Unicode::Normalize> has been upgraded from version 1.07 to 1.10
285
286 =back
287
288 =head2 Removed Modules and Pragmata
289
290 =over 4
291
292 =item *
293
294 XXX
295
296 =back
297
298 =head1 Documentation
299
300 XXX Changes to files in F<pod/> go here.  Consider grouping entries by
301 file and be sure to link to the appropriate page, e.g. L<perlfunc>.
302
303 =head2 New Documentation
304
305 XXX Changes which create B<new> files in F<pod/> go here.
306
307 =head3 L<XXX>
308
309 XXX Description of the purpose of the new file here
310
311 =head2 Changes to Existing Documentation
312
313 XXX Changes which significantly change existing files in F<pod/> go here.
314 However, any changes to F<pod/perldiag.pod> should go in the L</Diagnostics>
315 section.
316
317 =head3 L<perlfunc>
318
319 =over 4
320
321 =item *
322
323 It has now been documented that C<ord> returns 0 for an empty string.
324
325 =back
326
327 =head1 Diagnostics
328
329 The following additions or changes have been made to diagnostic output,
330 including warnings and fatal error messages.  For the complete list of
331 diagnostic messages, see L<perldiag>.
332
333 XXX New or changed warnings emitted by the core's C<C> code go here. Also
334 include any changes in L<perldiag> that reconcile it to the C<C> code.
335
336 [ Within each section, list entries as a =item entry ]
337
338 =head2 New Diagnostics
339
340 XXX Newly added diagnostic messages go here
341
342 =over 4
343
344 =item *
345
346 XXX
347
348 =back
349
350 =head2 Changes to Existing Diagnostics
351
352 XXX Changes (i.e. rewording) of diagnostic messages go here
353
354 =over 4
355
356 =item *
357
358 XXX
359
360 =back
361
362 =head1 Utility Changes
363
364 XXX Changes to installed programs such as F<perlbug> and F<xsubpp> go
365 here. Most of these are built within the directories F<utils> and F<x2p>.
366
367 [ List utility changes as a =head3 entry for each utility and =item
368 entries for each change
369 Use L<XXX> with program names to get proper documentation linking. ]
370
371 =head3 L<perlbug>
372
373 =over 4
374
375 =item *
376
377 C<perlbug> did not previously generate a From: header, potentially
378 resulting in dropped mail. Now it does include that header.
379
380 =back
381
382 =head1 Configuration and Compilation
383
384 XXX Changes to F<Configure>, F<installperl>, F<installman>, and analogous tools
385 go here.  Any other changes to the Perl build process should be listed here.
386 However, any platform-specific changes should be listed in the
387 L</Platform Support> section, instead.
388
389 [ List changes as a =item entry ].
390
391 =over 4
392
393 =item *
394
395 XXX
396
397 =back
398
399 =head1 Testing
400
401 XXX Any significant changes to the testing of a freshly built perl should be
402 listed here.  Changes which create B<new> files in F<t/> go here as do any
403 large changes to the testing harness (e.g. when parallel testing was added).
404 Changes to existing files in F<t/> aren't worth summarising, although the bugs
405 that they represent may be covered elsewhere.
406
407 [ List each test improvement as a =item entry ]
408
409 =over 4
410
411 =item *
412
413 XXX
414
415 =back
416
417 =head1 Platform Support
418
419 XXX Any changes to platform support should be listed in the sections below.
420
421 [ Within the sections, list each platform as a =item entry with specific
422 changes as paragraphs below it. ]
423
424 =head2 New Platforms
425
426 XXX List any platforms that this version of perl compiles on, that previous
427 versions did not. These will either be enabled by new files in the F<hints/>
428 directories, or new subdirectories and F<README> files at the top level of the
429 source tree.
430
431 =over 4
432
433 =item XXX-some-platform
434
435 XXX
436
437 =back
438
439 =head2 Discontinued Platforms
440
441 XXX List any platforms that this version of perl no longer compiles on.
442
443 =over 4
444
445 =item XXX-some-platform
446
447 XXX
448
449 =back
450
451 =head2 Platform-Specific Notes
452
453 XXX List any changes for specific platforms. This could include configuration
454 and compilation changes or changes in portability/compatibility.  However,
455 changes within modules for platforms should generally be listed in the
456 L</Modules and Pragmata> section.
457
458 =over 4
459
460 =item Solaris
461
462 DTrace is now supported on Solaris. There used to be build failures, but
463 these have been fixed
464 L<[perl #73630]|http://rt.perl.org/rt3/Public/Bug/Display.html?id=73630>.
465
466 =back
467
468 =head1 Internal Changes
469
470 XXX Changes which affect the interface available to C<XS> code go here.
471 Other significant internal changes for future core maintainers should
472 be noted as well.
473
474 [ List each test improvement as a =item entry ]
475
476 =over 4
477
478 =item *
479
480 The opcode bodies for C<chop> and C<chomp> and for C<schop> and C<schomp> have
481 been merged. The implementation functions C<Perl_do_chop()> and
482 C<Perl_do_chomp()>, never part of the public API, have been merged and moved to
483 a static function in F<pp.c>. This shrinks the perl binary slightly, and should
484 not affect any code outside the core (unless it is relying on the order of side
485 effects when C<chomp> is passed a I<list> of values).
486
487 =item *
488
489 Some of the flags parameters to the uvuni_to_utf8_flags() and
490 utf8n_to_uvuni() have changed.  This is a result of Perl now allowing
491 internal storage and manipulation of code points that are problematic
492 in some situations.  Hence, the default actions for these functions has
493 been complemented to allow these code points.  The new flags are
494 documented in L<perlapi>.  Code that requires the problematic code
495 points to be rejected needs to change to use these flags.  Some flag
496 names are retained for backward source compatibility, though they do
497 nothing, as they are now the default.  However the flags
498 C<UNICODE_ALLOW_FDD0>, C<UNICODE_ALLOW_FFFF>, C<UNICODE_ILLEGAL>, and
499 C<UNICODE_IS_ILLEGAL> have been removed, as they stem from a
500 fundamentally broken model of how the Unicode non-character code points
501 should be handled, which is now described in
502 L<perlunicode/Non-character code points>.  See also L</Selected Bug Fixes>.
503
504 =item *
505
506 Certain shared flags in the C<pmop.op_pmflags> and C<regexp.extflags>
507 structures have been removed.  These are: C<Rxf_Pmf_LOCALE>,
508 C<Rxf_Pmf_UNICODE>, and C<PMf_LOCALE>.  Instead there are encodes and
509 three static in-line functions for accessing the information:
510 C<get_regex_charset()>, C<set_regex_charset()>, and C<get_regex_charset_name()>,
511 which are defined in the places where the orginal flags were.
512
513 =item *
514
515 A new option has been added to C<pv_escape> to dump all characters above
516 ASCII in hexadecimal. Before, one could get all characters as hexadecimal
517 or the Latin1 non-ASCII as octal
518
519 =back
520
521 =head1 Selected Bug Fixes
522
523 XXX Important bug fixes in the core language are summarised here.
524 Bug fixes in files in F<ext/> and F<lib/> are best summarised in
525 L</Modules and Pragmata>.
526
527 [ List each fix as a =item entry ]
528
529 =over 4
530
531 =item *
532
533 The handling of Unicode non-characters has changed.
534 Previously they were mostly considered illegal, except that only one of
535 the 66 of them was known about in places.  The Unicode standard
536 considers them legal, but forbids the "open interchange" of them.
537 This is part of the change to allow the internal use of any code point
538 (see L</Core Enhancements>).  Together, these changes resolve
539 L<# 38722|https://rt.perl.org/rt3/Ticket/Display.html?id=38722>,
540 L<# 51918|http://rt.perl.org/rt3/Ticket/Display.html?id=51918>,
541 L<# 51936|http://rt.perl.org/rt3/Ticket/Display.html?id=51936>,
542 L<# 63446|http://rt.perl.org/rt3/Ticket/Display.html?id=63446>
543
544 =item *
545
546 Sometimes magic (ties, tainted, etc.) attached to variables could cause an
547 object to last longer than it should, or cause a crash if a tied variable
548 were freed from within a tie method. These have been fixed
549 L<[perl #81230]|http://rt.perl.org/rt3/Public/Bug/Display.html?id=81230>.
550
551 =item *
552
553 Most I/O functions were not warning for unopened handles unless the
554 'closed' and 'unopened' warnings categories were both enabled. Now only
555 C<use warnings 'unopened'> is necessary to trigger these warnings (as was
556 always meant to be the case.
557
558 =item *
559
560 C<< <expr> >> always respects overloading now if the expression is
561 overloaded.
562
563 Due to the way that '<> as glob' was parsed differently from
564 '<> as filehandle' from 5.6 onwards, something like C<< <$foo[0]> >> did
565 not handle overloading, even if C<$foo[0]> was an overloaded object. This
566 was contrary to the documentation for overload, and meant that C<< <> >>
567 could not be used as a general overloaded iterator operator.
568
569 =item *
570
571 Destructors on objects were not called during global destruction on objects
572 that were not referenced by any scalars. This could happen if an array
573 element were blessed (e.g., C<bless \$a[0]>) or if a closure referenced a
574 blessed variable (C<bless \my @a; sub foo { @a }>).
575
576 Now there is an extra pass during global destruction to fire destructors on
577 any objects that might be left after the usual passes that check for
578 objects referenced by scalars
579 L<[perl #36347]|http://rt.perl.org/rt3/Public/Bug/Display.html?id=36347>.
580
581 =back
582
583 =head1 Known Problems
584
585 XXX Descriptions of platform agnostic bugs we know we can't fix go here. Any
586 tests that had to be C<TODO>ed for the release would be noted here, unless
587 they were specific to a particular platform (see below).
588
589 This is a list of some significant unfixed bugs, which are regressions
590 from either 5.XXX.XXX or 5.XXX.XXX.
591
592 [ List each fix as a =item entry ]
593
594 =over 4
595
596 =item *
597
598 The fix for [perl #81230] causes test failures for C<Tk> version 804.029.
599 This is still being investigated.
600
601 =back
602
603 =head1 Obituary
604
605 XXX If any significant core contributor has died, we've added a short obituary
606 here.
607
608 =head1 Acknowledgements
609
610 XXX The list of people to thank goes here.
611
612 =head1 Reporting Bugs
613
614 If you find what you think is a bug, you might check the articles
615 recently posted to the comp.lang.perl.misc newsgroup and the perl
616 bug database at http://rt.perl.org/perlbug/ .  There may also be
617 information at http://www.perl.org/ , the Perl Home Page.
618
619 If you believe you have an unreported bug, please run the L<perlbug>
620 program included with your release.  Be sure to trim your bug down
621 to a tiny but sufficient test case.  Your bug report, along with the
622 output of C<perl -V>, will be sent off to perlbug@perl.org to be
623 analysed by the Perl porting team.
624
625 If the bug you are reporting has security implications, which make it
626 inappropriate to send to a publicly archived mailing list, then please send
627 it to perl5-security-report@perl.org. This points to a closed subscription
628 unarchived mailing list, which includes all the core committers, who be able
629 to help assess the impact of issues, figure out a resolution, and help
630 co-ordinate the release of patches to mitigate or fix the problem across all
631 platforms on which Perl is supported. Please only use this address for
632 security issues in the Perl core, not for modules independently
633 distributed on CPAN.
634
635 =head1 SEE ALSO
636
637 The F<Changes> file for an explanation of how to view exhaustive details
638 on what changed.
639
640 The F<INSTALL> file for how to build Perl.
641
642 The F<README> file for general stuff.
643
644 The F<Artistic> and F<Copying> files for copyright information.
645
646 =cut
647
648 =for later
649
650 Below, you'll find a cut-down version of the git log from 5.13.8 to 1b9043bb.
651 Jesse went through and took a first pass at cutting out non-changelog items. He may have been over-(or under-)zealous.
652
653 It hasn't yet been deduped with the entries that _are_ in the perldelta.
654
655
656     Major spell-checking pass throughout the core
657
658     Remove references to compat3.sym and interp.sym, deleted over 10 years ago.
659
660     Remove Mac OS classic code from numerous places throughout the core
661
662 commit 7fe50b8b8a4dc38fc341e3b403545aaca937f50e
663 Author: Leon Timmermans <fawaka@gmail.com>
664 Date:   Tue Jan 18 16:40:07 2011 +0100
665
666     Also unblock signal handlers throwing an exception
667
668     Also handle and test the edge case of a signal handler throwing an
669     exception
670
671
672
673
674 Numberous POD warnings fixed
675
676
677
678     Update Unicode-Collate to CPAN version 0.71
679
680
681 internals
682
683
684     regexec.c: Remove break statements from macros
685
686     This is so future coders won't be tempted to rely on them.
687
688     regexec.c: Don't rely on break stmts in macros
689
690     It is safer and clearer to have the break statement in each case statement at
691     the source level
692
693 commit b57e41186b2ceb48bef4f0588dcd19e105cc8a38
694 Author: Karl Williamson <public@khwilliamson.com>
695 Date:   Tue Jan 18 15:03:41 2011 -0700
696
697     regcomp: Disallow multi-char folds in lookbehind
698
699     The addition of the ANYOFV regnode to treat multi-char folds in a bracketed
700     character class has exposed a bug, in which those classes have long been able
701     to be varying length (due to the multi-char fold), but the compiler wasn't
702     aware of it.  Now it is, and hence won't allow those which have multi-char
703     folds to be part of a lookbehind pattern, which requires a constant length.
704
705     This patch disallows multi-char folds in a lookbehind bracketed character
706     class.
707
708 Author: Nicholas Clark <nick@ccl4.org>
709 Date:   Tue Jan 18 16:14:43 2011 +0000
710
711     Remove Mac OS classic code from scripts in utils/
712
713
714     Convert DosGlob.t to Test::More.
715
716 commit d6dc8a6dc95226ddff7719cd1e0bd053c4e5725e
717 Author: Nicholas Clark <nick@ccl4.org>
718 Date:   Tue Jan 18 13:08:11 2011 +0000
719
720     Remove Mac OS Classic docs from DirHandle and File::{Copy,DosGlob,Find}
721
722     The documentation for the different behaviour on Mac OS Classic was not
723     removed when the relevant code was removed in 862f843bac3434c2. That commit
724     also remove all callers to several Mac OS classic support functions, but not
725     the functions themselves. Rectify this.
726
727 commit 8254cbf193c939338449097a80163197fc755150
728 Author: Nicholas Clark <nick@ccl4.org>
729 Date:   Tue Jan 18 11:10:41 2011 +0000
730
731     Build perltoc.pod with pragmata sorted by name.
732
733     Previously they were actually sorted by full pathname, which isn't logical.
734     I presume that this is an artefact of all pragmata being in lib/ when
735     pod/buildtoc was originally written.
736
737 commit 1d45ec279e4e105512a2803e3d0bd974a151a0f6
738 Author: Father Chrysostomos <sprout@cpan.org>
739 Date:   Mon Jan 17 22:32:52 2011 -0800
740
741     perlcall: Fixes for various grammatical errors
742
743 commit faaf68361923e4bb95d1eb919bc724a0dcc5a4ce
744 Author: Leon Timmermans <fawaka@gmail.com>
745 Date:   Mon Jan 17 17:59:33 2011 +0100
746
747     Clarify limitation in safe signals.
748
749 commit 0c1bf4c7d433bb0ad80bfe5511b1301db32b7b95
750 Author: Leon Timmermans <fawaka@gmail.com>
751 Date:   Mon Jan 17 16:29:11 2011 +0100
752
753     Added tests for conditional unblocking
754
755 commit 555344425f04e96a72e4d29eab96b34bff8f96ae
756 Author: Leon Timmermans <fawaka@gmail.com>
757 Date:   Thu Jan 13 18:30:29 2011 +0100
758
759     Conditionally unblock after signal handler[#82040]
760
761     Only unblock signal after a safe-signal handler is executed if that signal was
762     also unblocked before the handler.
763 commit 435aa301127ed481169903cb35187bde1ea44928
764 Author: David Golden <dagolden@cpan.org>
765 Date:   Mon Jan 17 20:39:14 2011 -0500
766
767     Update HTTP::Tiny to CPAN version 0.009
768
769 commit 78cd53afbb1923bf0a68f361040ad8fe93a7d0d5
770 Author: David Mitchell <davem@iabyn.com>
771 Date:   Tue Jan 18 00:46:30 2011 +0000
772
773     vastly speed up t/porting/diag.t
774
775     This used to take about 3 minutes of CPU. Reduce this to around
776     6 seconds (!!) by coalescing and pre-compiling various patterns
777     that get applied to nearly every line of every source file.
778
779 commit cfaf538b6276c6a8ef80ff6c66e106c6a4f1caaa
780 Author: Karl Williamson <public@khwilliamson.com>
781 Date:   Mon Jan 17 08:58:53 2011 -0700
782
783     Add /a regex modifier
784
785     This restricts certain constructs, like \w, to matching in the ASCII range only.
786
787 commit 56ae17b45d2513d65903d13468e8f6a16b20f916
788 Author: Karl Williamson <public@khwilliamson.com>
789 Date:   Sun Jan 16 17:41:30 2011 -0700
790
791     regcomp.c: Convert \d \D to a switch{}
792
793 commit eee47ba661717bca7751443be1b6ac8f8f64585a
794 Author: Chris 'BinGOs' Williams <chris@bingosnet.co.uk>
795 Date:   Mon Jan 17 12:35:54 2011 +0000
796
797     Update File-Fetch to CPAN version 0.32
798
799 commit e66820012d29519f903709f005e56a2c334ae183
800 Author: Tony Cook <tony@develop-help.com>
801 Date:   Mon Jan 17 19:22:08 2011 +1100
802
803     test_prep now depends on the pods needed for porting/buildtoc.t
804
805     In the other makefiles test_prep (or test-prep) depends on all, so
806     they shouldn't need updating.
807
808
809 commit a52237f3a547cdefddd4c4be6224bfdf67c84263
810 Author: David Golden <dagolden@cpan.org>
811 Date:   Sun Jan 16 21:32:21 2011 -0500
812
813     Update CPAN to CPAN version 1.94_63
814
815 commit 63ac0dadb1aafcf0c171d3c1422c1923b611b2fc
816 Author: Karl Williamson <public@khwilliamson.com>
817 Date:   Tue Dec 28 16:13:49 2010 -0700
818
819     regex: Use BOUNDU regnodes
820
821     This refactors one area in regexec.c to use BOUNDU, NBOUNDU for
822     efficiciency, and easier adding of the future BOUNDA.
823
824 commit 980866de2cf8ecdb4bb72b7f9294763057008f50
825 Author: Karl Williamson <public@khwilliamson.com>
826 Date:   Mon Dec 27 12:04:58 2010 -0700
827
828     regex: Separate nodes for Unicode semantics \s \w
829
830     This patch converts the \s, \w and complements Unicode semantics to
831     instead of using the flags field of their nodes to instead use separate
832     nodes.  This gains some efficiency, especially useful in tight loops and
833     backtracking of regexec.c, and prepares the way for easily adding other
834     semantic variations, such as /a.
835
836     It refactors the CCC_TRY... macros.  I tried to break this piece up into
837     smaller chunks, but found it much easier to get to this in one step.
838     Further patches will do some more refactoring of these.
839
840     As part of the CCC_TRY macro refactoring, the lines that include the
841     test if (! nextchr) are changed to just look for the end-of-string by
842     position instead of it being NUL.  In locales, it could be (however
843     unlikely), that NUL is a real alphabetic, digit, or space character.
844 commit 50e911483ad5c29e25c54c9f81f92df974dd2cc0
845 Author: Karl Williamson <public@khwilliamson.com>
846 Date:   Sun Dec 26 10:35:58 2010 -0700
847
848     Change name of /d to DEPENDS
849
850     I much prefer David Golden's name for /d whose meaning 'depends' on
851     circumstances, instead of 'dual' meaning it could be one or another.
852     Change it before this gets out in a stable release, and we're stuck with
853     the old name.
854
855 commit 73134a2eb4055c76fe5b154da95e09118f716fd8
856 Author: Karl Williamson <public@khwilliamson.com>
857 Date:   Sun Dec 26 10:35:20 2010 -0700
858
859     CH] Change usage of regex/op common to common names
860
861     This patch changes the core functions to use the common names for the
862     fields that are shared between op.c and regcomp.c, just for consistency
863     of using one name throughout the core for the same thing.
864
865     A grep of cpan shows that both names are used in various modules; so
866     both names must be retained.
867
868 commit a3ab329f3fc9494e700f51c38cef42021c130b6e
869 Author: David Golden <dagolden@cpan.org>
870 Date:   Sun Jan 16 20:57:02 2011 -0500
871
872     Add HTTP::Tiny as a dual-life core module
873
874     HTTP::Tiny has been added as a dual-life module.  It is a very
875     small, simple HTTP/1.1 client designed for simple GET requests and file
876     mirroring.  It has has been added to enable CPAN.pm and CPANPLUS to
877     "bootstrap" HTTP access to CPAN using pure Perl without relying on external
878     binaries like F<curl> or F<wget>.
879
880 commit 211cc5012284f4bd900fcaa630adbcac69ca6112
881 Author: Chris 'BinGOs' Williams <chris@bingosnet.co.uk>
882 Date:   Sun Jan 16 23:23:03 2011 +0000
883
884     Update Unicode-Collate to CPAN version 0.70 and enable XS version
885
886 commit a62b1201c068dc7b099bcb7182e188c4d2fbf34c
887 Author: Karl Williamson <public@khwilliamson.com>
888 Date:   Sun Dec 26 10:31:16 2010 -0700
889
890     Use multi-bit field for regex character set
891
892     The /d, /l, and /u regex modifiers are mutually exclusive.  This patch
893     changes the field that stores the character set to use more than one bit
894     with an enum determining which one.  This data structure more
895     closely follows the semantics of their being mutually exclusive, and
896     conserves bits as well, and is better expandable.
897
898     A small API is added to set and query the bit field.
899
900     This patch is not .xs source backwards compatible.  A handful of cpan
901     programs are affected.
902
903
904 tools
905
906     Significant updates to buildtoc
907
908     Update Unicode-Normalize to CPAN version 1.10
909
910 commit 11454c594f22abc5945e69a46fc965363dbf326e
911 Author: Karl Williamson <public@khwilliamson.com>
912 Date:   Sat Jan 15 13:42:58 2011 -0700
913
914     Fix \xa0 matching both [\s] [\S], et.al.
915
916     This bug stemmed from Latin1 characters not matching any (non-complemented)
917     character class in /d semantics when the target string is no utf8; but having
918     unicode semantics when it isn't.  The solution here is to add a special flag.
919
920     There were several tests that relied on the broken behavior, specifically they
921     tested that \xff isn't a printable word character even in utf8.  I changed the
922     deparse test to instead use a non-printable code point, and I changed the ones
923     in re_tests to be TODOs, and will change them back using /a when that is
924     shortly added.
925
926
927 SECURITY
928
929     restrict \p{IsUserDefined} to In\w+ and In\w+
930
931     In L<perlunicode/"User-Defined Character Properties">, it says you can
932     create custom properties by defining subroutines whose names begin with
933     "In" or "Is". However, perl doesn't actually enforce that naming
934     restriction, so \p{foo::bar} will call foo::Bar() if it exists.
935
936     This commit finally enforces this convention. Note that this broke a
937     number of existing tests for properties, since they didn't always use an
938     Is/In prefix.
939
940 TESTING
941
942     test that perl.pod, pod.lst, MANIFEST and the file system are consistent
943
944 commit f56b6394f7cf57733135f56e4e4ac49abe9ac9cc
945 Author: Karl Williamson <public@khwilliamson.com>
946 Date:   Thu Jan 13 22:36:36 2011 -0700
947
948     regex: Use ANYOFV
949
950     This patch restructures the regex ANYOF code to generate ANYOFV nodes instead
951     when there is a possibility that it could match more than one character.   Note
952     that this doesn't affect the optimizer, as it essentially ignores things that
953     fit into this category.  (But it means that the optimizer will no longer reject
954     these when it shouldn't have.)
955
956     The handling of the LATIN SHARP s is modified to correspond with this new node
957     type.
958
959     The initial handling of ANYOFV is placed in regexec.c.  More analysis will come
960     on that.  But there was significant change to the part that handles matching
961     multi-char strings.  This has long been buggy, with it previously comparing a
962     folded-version on one side with a non-folded version on the other.
963
964     This patch fixes about 60% of the problems that my undelivered test suite gives
965     for multi-char folds.  But there are still 17K test failures left, so I'm still
966     not delivering that.  The TODOs that this fixes will be cleaned up in a later commit
967
968
969     Update Pod-LaTeX to CPAN version 0.59
970
971 commit 680818c0361b180bb6f09d4bb11c4d5cd467fe62
972 Author: Nicholas Clark <nick@ccl4.org>
973 Date:   Thu Jan 13 16:24:52 2011 +0000
974
975     ithread_create() was relying on the stack not moving. Fix this.
976
977     4cf5eae5e58faebb changed S_ithread_create() to avoid creating an AV, by
978     passing the thread creation arguments as pointers to a block of memory
979     holding SVs. Unfortunately, this inadvertently introduced a subtle bug,
980     because the block of memory is on the Perl stack, which can move as a side
981     effect of being reallocated to extend it. Hence pass in the offset on the
982     stack instead, read the current value of the relevant interpreter's stack
983     at the point of access, and copy all the SVs away before making any further
984     calls which might cause reallocation.
985
986     Update to Win32-0.44 from CPAN
987     Update Term-UI to CPAN version 0.24
988     Update IO-Compress to CPAN version 2.033
989     Update Compress-Raw-Zlib to CPAN version 2.033
990     Update Compress-Raw-Bzip2 to CPAN version 2.033
991     Update DB_File to CPAN version 1.821
992
993 DIAGNOSTICS
994     Correct the "unimplemented" message for get{host,net,proto,serv}ent aliases.
995
996     Previously, if all of gethost{byaddr,byname,ent} were unimplemented on a
997     platform, they would all return 'Unsupported socket function "gethostent"
998     called', with the analogous results for getnet{byaddr,byname,ent},
999     getproto{byname,bynumber,ent} and getserv{byname,byport,ent}. This bug was
1000     introduced by change af51a00e97d5c559 - prior to this, all 12 functions would
1001     report their own name when unimplemented.
1002
1003 commit 9ae3ac1a84c63b0eadf5baf47ce7096482280f32
1004 Author: Karl Williamson <public@khwilliamson.com>
1005 Date:   Sun Jan 9 15:33:28 2011 -0700
1006
1007     Add warnings for use of problematic code points
1008
1009     The non-Unicode code points have no Unicode semantics, so applying operations
1010     such as casing on them warns.
1011
1012     This patch also includes the changes to test the warnings added by recent
1013     commits for handling the surrogates and above-Unicode code points
1014
1015 commit 949cf4983af707fbd15e422845f4f3df20505f97
1016 Author: Karl Williamson <public@khwilliamson.com>
1017 Date:   Sun Jan 9 13:50:18 2011 -0700
1018
1019     utf8.c(): Default to allow problematic code points
1020
1021     Surrogates, non-character code points, and code points that aren't in Unicode
1022     are now allowed by default, instead of having to specify a flag to allow them.
1023     (Most code did specify those flags anyway.)
1024
1025     This affects uvuni_to_utf8_flags(), utf8n_to_uvuni() and various routines that
1026     are specialized interfaces to them.
1027
1028     Now there is a new set of flags to disallow those code points.  Further, all 66
1029     of the non-character code points are known about and handled consistently,
1030     instead of just U+FFFF.
1031
1032     Code that requires these code points to be forbidden will have to change to use
1033     the new flags.  I have looked at all the (few) instances in CPAN where these
1034     routines are used, and the only one I found that appears to have need to do
1035     this, Encode, has already been patched to accommodate this change.  Of course,
1036     I may have overlooked some subtleties.
1037
1038
1039 commit 7627e6d0fe772ac90fce9e03fea273109521e261
1040 Author: Nicholas Clark <nick@ccl4.org>
1041 Date:   Sat Jan 8 15:56:22 2011 +0000
1042
1043     Generate "Unsupported socket function" stubs using PL_ppaddr.
1044
1045     Instead of having each socket op conditionally compile as either the
1046     implementation or a DIE() depending on #HAS_SOCKET
1047
1048     1: remove the conditional code from the ops themselves
1049     2: only compile the ops if HAS_SOCKET is defined
1050     3: general conditional code for the intialisation of PL_ppaddr - as appropriate
1051        either the ops, or Perl_unimplemented_op
1052     4: Amend Perl_unimplemented_op to generate the appropriate DIE() for socket
1053        ops (ie not the "panic"... message)
1054
1055     Whilst this complicates the support code in regen/opcode.pl, it's already a
1056     net saving of 5 lines in the C code.
1057
1058 commit 897d398936dd2fc088a265fba2a7b62fa97ed458
1059 Author: Nicholas Clark <nick@ccl4.org>
1060 Date:   Sun Jan 9 10:54:58 2011 +0000
1061
1062     Generate pp_* prototypes in pp_proto.h, and remove pp.sym
1063
1064     Eliminate the #define pp_foo Perl_pp_foo(pTHX) macros, and update the 13
1065     locations that relied on them.
1066
1067     regen/opcode.pl now generates prototypes for the PP functions directly, into
1068     pp_proto.h. It no longer writes pp.sym, and regen/embed.pl no longer reads
1069     this, removing the only ordering dependency in the regen scripts. opcode.pl
1070     is now responsible for prototypes for pp_* functions. (embed.pl remains
1071     responsible for ck_* functions, reading from regen/opcodes)
1072
1073 commit f1aaabf80b19a3cc6dc435510732b561ab46361e
1074 Author: Chris 'BinGOs' Williams <chris@bingosnet.co.uk>
1075 Date:   Sun Jan 9 00:16:46 2011 +0000
1076
1077     Update CPANPLUS to CPAN version 0.9011
1078     Update CPANPLUS-Dist-Build to CPAN version 0.52
1079     Update Term-UI to CPAN version 0.22
1080     Update Params-Check to CPAN version 0.28
1081
1082 commit a4a4c9e2c086dd5f7b7b05789161614dbbe8385b
1083 Author: Karl Williamson <public@khwilliamson.com>
1084 Date:   Sat Jan 8 14:44:05 2011 -0700
1085
1086     perldiag.pod: Add missing message severities
1087
1088 commit 0019012ad86d597fb507f71577d70ecd4c416bba
1089 Author: Chris 'BinGOs' Williams <chris@bingosnet.co.uk>
1090 Date:   Sat Jan 8 23:09:04 2011 +0000
1091
1092     Update Object-Accessor to CPAN version 0.38
1093     Update Module-Load-Conditional to CPAN version 0.40
1094     Update Log-Message to CPAN version 0.04
1095     Update IPC-Cmd to CPAN version 0.68
1096
1097
1098 TESTING
1099     add test for split without a pattern
1100
1101     Add some while tests, about the context of the last statement in a block and about reinitializaiton of lexical variables.
1102
1103     modernise t/cmd/while.t
1104
1105     Add t/base/while.t testing the basic of a while loop with minimal dependencies.  Change t/cmd/while.t into a non-base test using "test.pl".
1106
1107 commit ac066c2ab5bc31260104aeee778921b186894769
1108
1109     Update File-Fetch to CPAN version 0.30
1110     Update Archive-Tar to CPAN version 1.76
1111     Update Archive-Extract to CPAN version 0.48
1112
1113 commit b86b68b4eefa1069dabc8ea0401d712b24a67857
1114 Author: Jesse Vincent <jesse@bestpractical.com>
1115 Date:   Sat Jan 8 00:14:29 2011 +0800
1116
1117     Update the policy on doc patches to maint
1118
1119
1120 commit e8b333e679eb9a7a62c1d86b647515f01821eb60
1121 Author: David Golden <dagolden@cpan.org>
1122 Date:   Wed Jan 5 22:47:41 2011 -0500
1123
1124     Add Module::Metadata as a dual-life core module
1125
1126     This commit adds Module::Metadata 1.000002 as a dual-life module.  It
1127     gathers package and POD information from Perl module files.  It is a
1128     standalone module based on Module::Build::ModuleInfo for use by other
1129     module installation toolchain components.  Module::Build::ModuleInfo
1130     has been deprecated in favor of this module instead.
1131
1132 commit a8fb8d791b74ff90850140d94407aad99ec86fe3
1133 Author: John Peacock <jpeacock@jpeacock-hp.doesntexist.org>
1134 Date:   Thu Jan 6 20:02:37 2011 -0500
1135
1136     Sync with version 0.88 on CPAN
1137
1138 commit c1b879e57aecbfe520b3f44dd28472d1862f037d
1139 Author: Craig A. Berry <craigberry@mac.com>
1140 Date:   Wed Jan 5 19:14:06 2011 -0600
1141
1142     Make newline on last record explicit.
1143
1144     On VMS, the last line written to a file will get a trailing newline
1145     willy nilly.  This has its advantages insofar as you never get the
1146     "no newline at end of file" warnings from various utilities, but
1147     reality conflicts with expectations when you explicitly test for
1148     the last (or only) line *not* ending with newline, which is what
1149     the recent addtion to ref.t (5e3072707906cc4cb8a364c4cf7c487df0300caa)
1150     was doing.  Adding an explicit newline makes everyone happy.
1151
1152 commit 935c8d19ecf9ad3ea7589ffd1721e6ba1c671ed9
1153 Author: David Golden <dagolden@cpan.org>
1154 Date:   Wed Jan 5 22:25:23 2011 -0500
1155
1156     Add Perl::OSType as a dual-life core module
1157
1158     This commit adds Perl::OSType 1.002 as a dual-life module.  It maps Perl
1159     operating system names (e.g. 'dragonfly' or 'MSWin32') to more generic
1160     types with standardized names (e.g.  "Unix" or "Windows").  It has been
1161     refactored out of Module::Build and ExtUtils::CBuilder and consolidates
1162     such mappings into a single location for easier maintenance.
1163
1164     c.f.
1165     http://www.nntp.perl.org/group/perl.perl5.porters/2010/05/msg160280.html
1166
1167 commit 2a1594f630b57637ddd7a38daaa1e17f66da396a
1168 Author: Chris 'BinGOs' Williams <chris@bingosnet.co.uk>
1169 Date:   Wed Jan 5 23:35:15 2011 +0000
1170
1171     Update CGI to CPAN version 3.51
1172
1173       [SECURITY]
1174       - Further improvements have been made to guard against newline injections
1175         in headers. (Thanks to Max Kanat-Alexander, Yanick Champoux, Mark Stosberg)
1176
1177
1178 commit 0b5e625bc99f5cb78697faf03b297b6cacadf60b
1179 Author: Reini Urban <rurban@x-ray.at>
1180 Date:   Tue Sep 14 18:04:22 2010 +0200
1181
1182     build man pages on cygwin too
1183
1184 commit 172830635ea7813c85e51e4ae2b4bed56ddbab83
1185 Author: Reini Urban <rurban@x-ray.at>
1186 Date:   Tue Sep 14 17:54:15 2010 +0200
1187
1188     Improve cygwin rebase behaviour
1189
1190     If a dll is updated on cygwin reuse the old imagebase address.
1191     This solves most rebase errors, esp when updating on core dll's.
1192     See http://www.tishler.net/jason/software/rebase/rebase-2.4.2.README
1193
1194
1195 NEW TESTS
1196
1197     t/porting/filenames.t to make sure that filenames and paths are reasonably portable
1198
1199
1200 Platforms
1201
1202     Actually excise 'Apollo DomainOS' support. We officially killed it in 5.11.0. It
1203     hadn't worked for years before that.
1204
1205 commit cc7e77fd5a0ee9f1498e54dddf566117da62754b
1206 Author: Reini Urban <rurban@x-ray.at>
1207 Date:   Tue Sep 14 17:48:32 2010 +0200
1208
1209     CYG14 Dynaloader without USEIMPORTLIB, and search cyg prefix
1210
1211     part1: Support the standard cyg dll prefix, which is e.g. needed for FFI's.
1212     Ctypes and C::DynaLib use DynaLoader to find dlls.
1213
1214     part2: With -DUSEIMPORTLIB DynaLoader symbols link against the prefixed
1215     symbol names for the .dll.a importlib, but we need to link against the
1216     symbols directly. We don't link Dynaloader against libperl.dll.a.
1217
1218     Otherwise:
1219     $ g++-4 -o cygperl5_13_4.dll --shared perlsrc.o cygwin.o  DynaLoader.o -ldl -lcrypt
1220       Creating library file: libperl.dll.a
1221       DynaLoader.o: In function `XS_DynaLoader_dl_undef_symbols':
1222       ext/DynaLoader/DynaLoader.c:346: undefined reference to `__imp__PL_stack_sp'
1223       ext/DynaLoader/DynaLoader.c:346: undefined reference to `__imp__PL_markstack_ptr'
1224       ext/DynaLoader/DynaLoader.c:346: undefined reference to `__imp__PL_stack_base'
1225
1226 commit c0a149a90b8b6e1c18de7294ca974265fb559cf5
1227 Author: Reini Urban <rurban@x-ray.at>
1228 Date:   Tue Sep 14 18:06:38 2010 +0200
1229
1230     Update cygwin hints
1231     do not use usemymalloc (double size + slow)
1232     remove deprecated libcygipc info
1233     remove overlarge stack size
1234
1235 commit ac0650a4c9f69cdc9e7af31df29011c42b42b770
1236 Author: Father Chrysostomos <sprout@cpan.org>
1237 Date:   Sun Jan 2 23:14:37 2011 -0800
1238
1239     Restore the old description of $[
1240
1241     The new entry is a bit too futuristic: assignment to $[ still works
1242     and it is not read-only.
1243
1244     This does not fully restore the old description, as it contained
1245     grammatical errors and parts of it were not updated when 5.10 changed
1246     the scoping.
1247
1248 commit 2831a86cee065b53b74fd19ddcc6a4257484646d
1249 Author: Zsb√°n Ambrus <ambrus@math.bme.hu>
1250 Date:   Sun Jan 2 20:25:55 2011 -0800
1251
1252     [perl #81032] Overhaul Porting/epigraphs.pod
1253
1254     This patch makes multiple changes to Porting/epigraphs.pod and
1255     pod/perlhist.pod.
1256
1257     For those that don't know, Porting/epigraphs.pod is a new document that
1258     collects the quotes (chosen by Pumpkins) in perl release announcements.
1259
1260     The changes are the following.
1261
1262     1. Add a link pointing to each release announcement in the mailing
1263     list archives.  These are from ysth's list, the source from which
1264     Porting/epigraphs.pod was originally compiled, but they weren't in
1265     Porting/epigraphs.pod so far.
1266     2. Reorder Porting/epigraphs.pod chronologically, because I believe
1267     that makes more sense -- pod/perlhist.pod is still sorted by version numbers.
1268     3. Incidentally, some missing releases are added to pod/perlhist.pod too.
1269     4. Fix a mistake where Porting/epigraphs.pod gives the wrong version number.
1270     5. Add some epigraphs that appear in ysth's list but not in
1271     Porting/epigraphs.pod.
1272     6. I did some research in perl history before the part that ysth's list
1273     covers, and added older perl announcements I found.  This work is not
1274     complete: I stopped somewhere in 2000.
1275
1276 commit eccda089fc3dcaafc1ae0aac6b428f799231b824
1277 Author: Paul "LeoNerd" Evans <leonerd@leonerd.org.uk>
1278 Date:   Mon Dec 13 17:50:06 2010 +0000
1279
1280     Implement Socket::getaddrinfo() and Socket::getnameinfo(), with related constants
1281
1282 commit d54243158c0e4ba0127eb487c5b2e2a10484e8d0
1283 Author: David Golden <dagolden@cpan.org>
1284 Date:   Thu Dec 30 23:43:44 2010 -0500
1285
1286     Add JSON::PP to the Perl core
1287
1288     Per discussions with Jesse Vincent, JSON::PP has been added
1289     to the Perl core to support the new CPAN meta file specification
1290
1291 commit edcf105d70e5423fd928c776e086fe31a4a543f4
1292 Author: Jesse Vincent <jesse@bestpractical.com>
1293 Date:   Sat Jan 1 18:46:20 2011 +0800
1294
1295     Document 'test_porting' and start a section on how committing to blead
1296
1297 commit cce04bebd8af026c2a6731940ddb895d3c1fc3e4
1298 Author: David Golden <dagolden@cpan.org>
1299 Date:   Mon Dec 13 17:36:33 2010 -0500
1300
1301     Reorganize perlhack.pod
1302
1303     Following on an IRC conversation, I've attempted to reorganize
1304     perlhack for greater clarity.  I have only cut and paste blocks
1305     of text and amended section titles and levels.  (I have not addressed
1306     any of the numerous factual issues which remain.)
1307
1308     The resulting guide should be clearer for those trying to skim the
1309     table of contents to understand what is covered in perlhack and
1310     whether it is worth an in-depth read.
1311
1312     I see this change as the first step towards future improvements.
1313
1314 =cut