Spaces:
Running
Running
=encoding utf8 | |
=head1 NAME | |
perl5221delta - what is new for perl v5.22.1 | |
=head1 DESCRIPTION | |
This document describes differences between the 5.22.0 release and the 5.22.1 | |
release. | |
If you are upgrading from an earlier release such as 5.20.0, first read | |
L<perl5220delta>, which describes differences between 5.20.0 and 5.22.0. | |
=head1 Incompatible Changes | |
There are no changes intentionally incompatible with 5.20.0 other than the | |
following single exception, which we deemed to be a sensible change to make in | |
order to get the new C<\b{wb}> and (in particular) C<\b{sb}> features sane | |
before people decided they're worthless because of bugs in their Perl 5.22.0 | |
implementation and avoided them in the future. | |
If any others exist, they are bugs, and we request that you submit a report. | |
See L</Reporting Bugs> below. | |
=head2 Bounds Checking Constructs | |
Several bugs, including a segmentation fault, have been fixed with the bounds | |
checking constructs (introduced in Perl 5.22) C<\b{gcb}>, C<\b{sb}>, C<\b{wb}>, | |
C<\B{gcb}>, C<\B{sb}>, and C<\B{wb}>. All the C<\B{}> ones now match an empty | |
string; none of the C<\b{}> ones do. | |
L<[GH #14976]|https://github.com/Perl/perl5/issues/14976> | |
=head1 Modules and Pragmata | |
=head2 Updated Modules and Pragmata | |
=over 4 | |
=item * | |
L<Module::CoreList> has been upgraded from version 5.20150520 to 5.20151213. | |
=item * | |
L<PerlIO::scalar> has been upgraded from version 0.22 to 0.23. | |
=item * | |
L<POSIX> has been upgraded from version 1.53 to 1.53_01. | |
If C<POSIX::strerror> was passed C<$!> as its argument then it accidentally | |
cleared C<$!>. This has been fixed. | |
L<[GH #14951]|https://github.com/Perl/perl5/issues/14951> | |
=item * | |
L<Storable> has been upgraded from version 2.53 to 2.53_01. | |
=item * | |
L<warnings> has been upgraded from version 1.32 to 1.34. | |
The C<warnings::enabled> example now actually uses C<warnings::enabled>. | |
L<[GH #14905]|https://github.com/Perl/perl5/issues/14905> | |
=item * | |
L<Win32> has been upgraded from version 0.51 to 0.52. | |
This has been updated for Windows 8.1, 10 and 2012 R2 Server. | |
=back | |
=head1 Documentation | |
=head2 Changes to Existing Documentation | |
=head3 L<perltie> | |
=over 4 | |
=item * | |
The usage of C<FIRSTKEY> and C<NEXTKEY> has been clarified. | |
=back | |
=head3 L<perlvar> | |
=over 4 | |
=item * | |
The specific true value of C<$!{E...}> is now documented, noting that it is | |
subject to change and not guaranteed. | |
=back | |
=head1 Diagnostics | |
The following additions or changes have been made to diagnostic output, | |
including warnings and fatal error messages. For the complete list of | |
diagnostic messages, see L<perldiag>. | |
=head2 Changes to Existing Diagnostics | |
=over 4 | |
=item * | |
The C<printf> and C<sprintf> builtins are now more careful about the warnings | |
they emit: argument reordering now disables the "redundant argument" warning in | |
all cases. | |
L<[GH #14772]|https://github.com/Perl/perl5/issues/14772> | |
=back | |
=head1 Configuration and Compilation | |
=over 4 | |
=item * | |
Using the C<NO_HASH_SEED> define in combination with the default hash algorithm | |
C<PERL_HASH_FUNC_ONE_AT_A_TIME_HARD> resulted in a fatal error while compiling | |
the interpreter, since Perl 5.17.10. This has been fixed. | |
=item * | |
Configuring with ccflags containing quotes (e.g. | |
C<< -Accflags='-DAPPLLIB_EXP=\"/usr/libperl\"' >>) was broken in Perl 5.22.0 | |
but has now been fixed again. | |
L<[GH #14732]|https://github.com/Perl/perl5/issues/14732> | |
=back | |
=head1 Platform Support | |
=head2 Platform-Specific Notes | |
=over 4 | |
=item IRIX | |
=over | |
=item * | |
Under some circumstances IRIX stdio fgetc() and fread() set the errno to | |
C<ENOENT>, which made no sense according to either IRIX or POSIX docs. Errno | |
is now cleared in such cases. | |
L<[GH #14557]|https://github.com/Perl/perl5/issues/14557> | |
=item * | |
Problems when multiplying long doubles by infinity have been fixed. | |
L<[GH #14993]|https://github.com/Perl/perl5/issues/14993> | |
=item * | |
All tests pass now on IRIX with the default build configuration. | |
=back | |
=back | |
=head1 Selected Bug Fixes | |
=over 4 | |
=item * | |
C<qr/(?[ () ])/> no longer segfaults, giving a syntax error message instead. | |
L<[GH #14851]|https://github.com/Perl/perl5/issues/14851> | |
=item * | |
Regular expression possessive quantifier Perl 5.20 regression now fixed. | |
C<qr/>I<PAT>C<{>I<min>,I<max>C<}+>C</> is supposed to behave identically to | |
C<qr/(?E<gt>>I<PAT>C<{>I<min>,I<max>C<})/>. Since Perl 5.20, this didn't work | |
if I<min> and I<max> were equal. | |
L<[GH #14857]|https://github.com/Perl/perl5/issues/14857> | |
=item * | |
Certain syntax errors in | |
L<perlrecharclass/Extended Bracketed Character Classes> caused panics instead | |
of the proper error message. This has now been fixed. | |
L<[GH #15016]|https://github.com/Perl/perl5/issues/15016> | |
=item * | |
C<< BEGIN <> >> no longer segfaults and properly produces an error message. | |
L<[GH #13546]|https://github.com/Perl/perl5/issues/13546> | |
=item * | |
A regression from Perl 5.20 has been fixed, in which some syntax errors in | |
L<C<(?[...])>|perlrecharclass/Extended Bracketed Character Classes> constructs | |
within regular expression patterns could cause a segfault instead of a proper | |
error message. | |
L<[GH #14933]|https://github.com/Perl/perl5/issues/14933> | |
=item * | |
Another problem with | |
L<C<(?[...])>|perlrecharclass/Extended Bracketed Character Classes> | |
constructs has been fixed wherein things like C<\c]> could cause panics. | |
L<[GH #14934]|https://github.com/Perl/perl5/issues/14934> | |
=item * | |
In Perl 5.22.0, the logic changed when parsing a numeric parameter to the -C | |
option, such that the successfully parsed number was not saved as the option | |
value if it parsed to the end of the argument. | |
L<[GH #14748]|https://github.com/Perl/perl5/issues/14748> | |
=item * | |
Warning fatality is now ignored when rewinding the stack. This prevents | |
infinite recursion when the now fatal error also causes rewinding of the stack. | |
L<[GH #14319]|https://github.com/Perl/perl5/issues/14319> | |
=item * | |
A crash with C<< %::=(); J->${\"::"} >> has been fixed. | |
L<[GH #14790]|https://github.com/Perl/perl5/issues/14790> | |
=item * | |
Nested quantifiers such as C</.{1}??/> should cause perl to throw a fatal | |
error, but were being silently accepted since Perl 5.20.0. This has been | |
fixed. | |
L<[GH #14960]|https://github.com/Perl/perl5/issues/14960> | |
=item * | |
Regular expression sequences such as C</(?i/> (and similarly with other | |
recognized flags or combination of flags) should cause perl to throw a fatal | |
error, but were being silently accepted since Perl 5.18.0. This has been | |
fixed. | |
L<[GH #14931]|https://github.com/Perl/perl5/issues/14931> | |
=item * | |
A bug in hexadecimal floating point literal support meant that high-order bits | |
could be lost in cases where mantissa overflow was caused by too many trailing | |
zeros in the fractional part. This has been fixed. | |
L<[GH #15032]|https://github.com/Perl/perl5/issues/15032> | |
=item * | |
Another hexadecimal floating point bug, causing low-order bits to be lost in | |
cases where the last hexadecimal digit of the mantissa has bits straddling the | |
limit of the number of bits allowed for the mantissa, has also been fixed. | |
L<[GH #15033]|https://github.com/Perl/perl5/issues/15033> | |
=item * | |
Further hexadecimal floating point bugs have been fixed: In some circumstances, | |
the C<%a> format specifier could variously lose the sign of the negative zero, | |
fail to display zeros after the radix point with the requested precision, or | |
even lose the radix point after the leftmost hexadecimal digit completely. | |
=item * | |
A crash caused by incomplete expressions within C<< /(?[ ])/ >> (e.g. | |
C<< /(?[[0]+()+])/ >>) has been fixed. | |
L<[GH #15045]|https://github.com/Perl/perl5/issues/15045> | |
=back | |
=head1 Acknowledgements | |
Perl 5.22.1 represents approximately 6 months of development since Perl 5.22.0 | |
and contains approximately 19,000 lines of changes across 130 files from 27 | |
authors. | |
Excluding auto-generated files, documentation and release tools, there were | |
approximately 1,700 lines of changes to 44 .pm, .t, .c and .h files. | |
Perl continues to flourish into its third decade thanks to a vibrant community | |
of users and developers. The following people are known to have contributed | |
the improvements that became Perl 5.22.1: | |
Aaron Crane, Abigail, Andy Broad, Aristotle Pagaltzis, Chase Whitener, Chris | |
'BinGOs' Williams, Craig A. Berry, Daniel Dragan, David Mitchell, Father | |
Chrysostomos, Herbert Breunung, Hugo van der Sanden, James E Keenan, Jan | |
Dubois, Jarkko Hietaniemi, Karen Etheridge, Karl Williamson, Lukas Mai, Matthew | |
Horsfall, Peter Martini, Rafael Garcia-Suarez, Ricardo Signes, Shlomi Fish, | |
Sisyphus, Steve Hay, Tony Cook, Victor Adam. | |
The list above is almost certainly incomplete as it is automatically generated | |
from version control history. In particular, it does not include the names of | |
the (very much appreciated) contributors who reported issues to the Perl bug | |
tracker. | |
Many of the changes included in this version originated in the CPAN modules | |
included in Perl's core. We're grateful to the entire CPAN community for | |
helping Perl to flourish. | |
For a more complete list of all of Perl's historical contributors, please see | |
the F<AUTHORS> file in the Perl source distribution. | |
=head1 Reporting Bugs | |
If you find what you think is a bug, you might check the articles recently | |
posted to the comp.lang.perl.misc newsgroup and the perl bug database at | |
https://rt.perl.org/ . There may also be information at | |
http://www.perl.org/ , the Perl Home Page. | |
If you believe you have an unreported bug, please run the L<perlbug> program | |
included with your release. Be sure to trim your bug down to a tiny but | |
sufficient test case. Your bug report, along with the output of C<perl -V>, | |
will be sent off to [email protected] to be analysed by the Perl porting team. | |
If the bug you are reporting has security implications, which make it | |
inappropriate to send to a publicly archived mailing list, then please send it | |
to [email protected]. This points to a closed subscription | |
unarchived mailing list, which includes all the core committers, who will be | |
able to help assess the impact of issues, figure out a resolution, and help | |
co-ordinate the release of patches to mitigate or fix the problem across all | |
platforms on which Perl is supported. Please only use this address for | |
security issues in the Perl core, not for modules independently distributed on | |
CPAN. | |
=head1 SEE ALSO | |
The F<Changes> file for an explanation of how to view exhaustive details on | |
what changed. | |
The F<INSTALL> file for how to build Perl. | |
The F<README> file for general stuff. | |
The F<Artistic> and F<Copying> files for copyright information. | |
=cut | |