mirror of
https://github.com/Perl/perl5.git
synced 2026-01-27 01:44:43 +00:00
New perldelta for 5.41.7
This commit is contained in:
parent
a6614ab804
commit
0b89c82e79
1
MANIFEST
1
MANIFEST
@ -5739,6 +5739,7 @@ pod/perl5412delta.pod Perl changes in version 5.41.2
|
||||
pod/perl5413delta.pod Perl changes in version 5.41.3
|
||||
pod/perl5414delta.pod Perl changes in version 5.41.4
|
||||
pod/perl5415delta.pod Perl changes in version 5.41.5
|
||||
pod/perl5416delta.pod Perl changes in version 5.41.6
|
||||
pod/perl561delta.pod Perl changes in version 5.6.1
|
||||
pod/perl56delta.pod Perl changes in version 5.6
|
||||
pod/perl581delta.pod Perl changes in version 5.8.1
|
||||
|
||||
@ -627,7 +627,7 @@ esac
|
||||
|
||||
$spitshell >>$Makefile <<'!NO!SUBS!'
|
||||
|
||||
perltoc_pod_prereqs = extra.pods pod/perl5416delta.pod pod/perlapi.pod pod/perlintern.pod pod/perlmodlib.pod pod/perluniprops.pod
|
||||
perltoc_pod_prereqs = extra.pods pod/perl5417delta.pod pod/perlapi.pod pod/perlintern.pod pod/perlmodlib.pod pod/perluniprops.pod
|
||||
generated_pods = pod/perltoc.pod $(perltoc_pod_prereqs)
|
||||
generated_headers = uudmap.h bitcount.h mg_data.h
|
||||
|
||||
@ -1136,9 +1136,9 @@ pod/perlintern.pod: $(MINIPERL_EXE) autodoc.pl embed.fnc
|
||||
pod/perlmodlib.pod: $(MINIPERL_EXE) pod/perlmodlib.PL MANIFEST
|
||||
$(MINIPERL) pod/perlmodlib.PL -q
|
||||
|
||||
pod/perl5416delta.pod: pod/perldelta.pod
|
||||
$(RMS) pod/perl5416delta.pod
|
||||
$(LNS) perldelta.pod pod/perl5416delta.pod
|
||||
pod/perl5417delta.pod: pod/perldelta.pod
|
||||
$(RMS) pod/perl5417delta.pod
|
||||
$(LNS) perldelta.pod pod/perl5417delta.pod
|
||||
|
||||
extra.pods: $(MINIPERL_EXE)
|
||||
-@test ! -f extra.pods || rm -f `cat extra.pods`
|
||||
|
||||
2
pod/.gitignore
vendored
2
pod/.gitignore
vendored
@ -47,7 +47,7 @@
|
||||
/roffitall
|
||||
|
||||
# generated
|
||||
/perl5416delta.pod
|
||||
/perl5417delta.pod
|
||||
/perlapi.pod
|
||||
/perlintern.pod
|
||||
/perlmodlib.pod
|
||||
|
||||
@ -181,6 +181,7 @@ aux h2ph h2xs perlbug pl2pm pod2html pod2man splain xsubpp
|
||||
|
||||
perlhist Perl history records
|
||||
perldelta Perl changes since previous version
|
||||
perl5416delta Perl changes in version 5.41.6
|
||||
perl5415delta Perl changes in version 5.41.5
|
||||
perl5414delta Perl changes in version 5.41.4
|
||||
perl5413delta Perl changes in version 5.41.3
|
||||
|
||||
295
pod/perl5416delta.pod
Normal file
295
pod/perl5416delta.pod
Normal file
@ -0,0 +1,295 @@
|
||||
=encoding utf8
|
||||
|
||||
=head1 NAME
|
||||
|
||||
perl5416delta - what is new for perl v5.41.6
|
||||
|
||||
=head1 DESCRIPTION
|
||||
|
||||
This document describes differences between the 5.41.5 release and the 5.41.6
|
||||
release.
|
||||
|
||||
If you are upgrading from an earlier release such as 5.41.4, first read
|
||||
L<perl5415delta>, which describes differences between 5.41.4 and 5.41.5.
|
||||
|
||||
=head1 Performance Enhancements
|
||||
|
||||
=over 4
|
||||
|
||||
=item *
|
||||
|
||||
Code that uses the C<indexed> function from the L<builtin> module to generate
|
||||
a list of index/value pairs out of array which is then passed into a
|
||||
two-variable C<foreach> list to unpack those again is now optimised to be more
|
||||
efficient.
|
||||
|
||||
my @array = (...);
|
||||
|
||||
foreach my ($idx, $val) (builtin::indexed @array) {
|
||||
...
|
||||
}
|
||||
|
||||
In particular, a temporary list twice the size of the original
|
||||
array is no longer generated. Instead, the list iterates down the array
|
||||
in-place directly, in the same way that C<foreach (@array)> would do.
|
||||
|
||||
=back
|
||||
|
||||
=head1 Modules and Pragmata
|
||||
|
||||
=head2 Updated Modules and Pragmata
|
||||
|
||||
=over 4
|
||||
|
||||
=item *
|
||||
|
||||
L<B::Deparse> has been upgraded from version 1.78 to 1.80.
|
||||
|
||||
It now retains parens around logical negations on the left-hand side of
|
||||
comparisons (such as C<(!$x) == $y>) because omitting them would trigger a
|
||||
C<Possible precedence problem> warning since perl v5.41.4. [L<GH #22661|https://github.com/Perl/perl5/issues/22661>]
|
||||
|
||||
=item *
|
||||
|
||||
L<builtin> has been upgraded from version 0.015 to 0.016.
|
||||
|
||||
=item *
|
||||
|
||||
L<CPAN> has been upgraded from version 2.37 to 2.38.
|
||||
|
||||
=item *
|
||||
|
||||
L<DB> has been upgraded from version 1.08 to 1.09.
|
||||
|
||||
=item *
|
||||
|
||||
L<ExtUtils::ParseXS> has been upgraded from version 3.55 to 3.56.
|
||||
|
||||
=item *
|
||||
|
||||
L<ExtUtils::Typemaps> has been upgraded from version 3.55 to 3.56.
|
||||
|
||||
=item *
|
||||
|
||||
L<feature> has been upgraded from version 1.91 to 1.92.
|
||||
|
||||
=item *
|
||||
|
||||
L<fields> has been upgraded from version 2.25 to 2.26.
|
||||
|
||||
=item *
|
||||
|
||||
L<HTTP::Tiny> has been upgraded from version 0.088 to 0.090.
|
||||
|
||||
=item *
|
||||
|
||||
L<IPC::Open3> has been upgraded from version 1.23 to 1.24.
|
||||
L<IPC::Open2> has been upgraded from version 1.07 to 1.08.
|
||||
|
||||
There is now a way to pass lexical filehandles to child processes directly
|
||||
(instead of having the module create a pipe internally). Previously, only
|
||||
bareword filehandles could be used in "dup mode".
|
||||
|
||||
=item *
|
||||
|
||||
L<Math::Complex> has been upgraded from version 1.62 to 1.63.
|
||||
|
||||
The complex number parser for string inputs has been improved. In particular,
|
||||
C<1+i>, C<123i>, C<inf>, C<-inf>, C<infi>, and C<-infi> are now handled
|
||||
correctly.
|
||||
|
||||
=item *
|
||||
|
||||
L<Memoize> has been upgraded from version 1.16 to 1.17.
|
||||
|
||||
=item *
|
||||
|
||||
L<Module::CoreList> has been upgraded from version 5.20241020 to 5.20241120.
|
||||
|
||||
=item *
|
||||
|
||||
L<NDBM_File> has been upgraded from version 1.17 to 1.18.
|
||||
|
||||
=item *
|
||||
|
||||
L<ODBM_File> has been upgraded from version 1.18 to 1.19.
|
||||
|
||||
=item *
|
||||
|
||||
L<parent> has been upgraded from version 0.242 to 0.242_001.
|
||||
|
||||
=item *
|
||||
|
||||
L<POSIX> has been upgraded from version 2.22 to 2.23.
|
||||
|
||||
=item *
|
||||
|
||||
L<Scalar::Util> has been upgraded from version 1.68 to 1.68_01.
|
||||
|
||||
=item *
|
||||
|
||||
L<Term::Table> has been upgraded from version 0.022 to 0.023.
|
||||
|
||||
=item *
|
||||
|
||||
L<warnings> has been upgraded from version 1.70 to 1.71.
|
||||
|
||||
=back
|
||||
|
||||
=head1 Platform Support
|
||||
|
||||
=head2 Platform-Specific Notes
|
||||
|
||||
=over 4
|
||||
|
||||
=item arm64 DARWIN
|
||||
|
||||
Fix arm64 darwin hints when using use64bitall with Configure [L<GH #22672|https://github.com/Perl/perl5/issues/22672>]
|
||||
|
||||
=item Android
|
||||
|
||||
Changes to perl_langinfo.h for Android [L<GH #22650|https://github.com/Perl/perl5/issues/22650>] related to [L<GH #22627|https://github.com/Perl/perl5/issues/22627>]
|
||||
|
||||
=item Cygwin
|
||||
|
||||
cygwin.c: fix several silly/terrible C errors [L<GH #22724|https://github.com/Perl/perl5/issues/22724>]
|
||||
|
||||
workaround DLL load address conflict [L<GH #22696|https://github.com/Perl/perl5/issues/22696>]
|
||||
|
||||
=back
|
||||
|
||||
=head1 Internal Changes
|
||||
|
||||
=over 4
|
||||
|
||||
=item *
|
||||
|
||||
Enable removing most of mathoms.c and stub functions [L<GH #22691|https://github.com/Perl/perl5/issues/22691>] and [L<GH #22714|https://github.com/Perl/perl5/issues/22714>]
|
||||
|
||||
=item *
|
||||
|
||||
reinstate apostrophe as package separator behind a default enabled feature,
|
||||
which is disabled from feature bundle 5.41.
|
||||
|
||||
=item *
|
||||
|
||||
pp_reverse: don't COW buffer just to then un-COW it [L<GH #22729|https://github.com/Perl/perl5/issues/22729>]
|
||||
|
||||
=back
|
||||
|
||||
=head1 Selected Bug Fixes
|
||||
|
||||
=over 4
|
||||
|
||||
=item *
|
||||
|
||||
The perl parser would erroneously parse like C<=cut> some other POD directives
|
||||
whose names start with I<cut>, prematurely terminating an embedded POD section.
|
||||
The following cases were affected: I<cut> followed by a digit (e.g.
|
||||
C<=cut2studio>), I<cut> followed by an underscore (e.g. C<=cut_grass>), and in
|
||||
string C<eval>, any identifier starting with I<cut> (e.g. C<=cute>).
|
||||
[L<GH #22759|https://github.com/Perl/perl5/issues/22759>]
|
||||
|
||||
=item *
|
||||
|
||||
Builds with C<-msse> and quadmath on 32-bit x86 systems would crash
|
||||
with a misaligned access early in the build. [L<GH #22577|https://github.com/Perl/perl5/issues/22577>]
|
||||
|
||||
=item *
|
||||
|
||||
On threaded builds on POSIX-like systems, if the perl signal handler
|
||||
receives we now resend the signal to the main perl thread. Previously
|
||||
this would crash. [GH #22487]
|
||||
|
||||
=back
|
||||
|
||||
=head1 Known Problems
|
||||
|
||||
=over 4
|
||||
|
||||
=item *
|
||||
|
||||
C<cygwin> builds may fail during testing due to a conflict between the
|
||||
load addresses of F<cygperl5_41_6.dll> and
|
||||
F<olib/auto/I18N/Langinfo/Langinfo.dll>. This will also be visible
|
||||
for anything that attempts to fork() with C<I18N::LangInfo> loaded.
|
||||
|
||||
This is known to fail for builds with options that increase the size
|
||||
of the binary, such as C<-DDEBUGGING>, C<-Doptimize="-O0 -g"> or
|
||||
C<-Doptimize="-O2 -g -march=x86-64-v2">.
|
||||
|
||||
This can be avoided by building perl with
|
||||
C<-Astatic_ext=I18N/Langinfo>.
|
||||
|
||||
The base addresses are generated by the linker based on the names of
|
||||
the DLLs, so this is expected to clear up for 5.41.7.
|
||||
|
||||
[L<GH #22695|https://github.com/Perl/perl5/issues/22695>]
|
||||
|
||||
=back
|
||||
|
||||
=head1 Acknowledgements
|
||||
|
||||
Perl 5.41.6 represents approximately 4 weeks of development since Perl
|
||||
5.41.5 and contains approximately 8,400 lines of changes across 180 files
|
||||
from 14 authors.
|
||||
|
||||
Excluding auto-generated files, documentation and release tools, there were
|
||||
approximately 6,700 lines of changes to 120 .pm, .t, .c and .h files.
|
||||
|
||||
Perl continues to flourish into its fourth decade thanks to a vibrant
|
||||
community of users and developers. The following people are known to have
|
||||
contributed the improvements that became Perl 5.41.6:
|
||||
|
||||
Chad Granum, Chris 'BinGOs' Williams, Daniel Dragan, David Mitchell, Graham
|
||||
Knop, James E Keenan, Karl Williamson, Lukas Mai, Marin Tsanov, Paul Evans,
|
||||
pyrrhlin, Richard Leach, Thibault Duponchelle, Tony Cook.
|
||||
|
||||
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 perl bug database
|
||||
at L<https://github.com/Perl/perl5/issues>. There may also be information at
|
||||
L<https://www.perl.org/>, the Perl Home Page.
|
||||
|
||||
If you believe you have an unreported bug, please open an issue at
|
||||
L<https://github.com/Perl/perl5/issues>. Be sure to trim your bug down to a
|
||||
tiny but sufficient test case.
|
||||
|
||||
If the bug you are reporting has security implications which make it
|
||||
inappropriate to send to a public issue tracker, then see
|
||||
L<perlsec/SECURITY VULNERABILITY CONTACT INFORMATION>
|
||||
for details of how to report the issue.
|
||||
|
||||
=head1 Give Thanks
|
||||
|
||||
If you wish to thank the Perl 5 Porters for the work we had done in Perl 5,
|
||||
you can do so by running the C<perlthanks> program:
|
||||
|
||||
perlthanks
|
||||
|
||||
This will send an email to the Perl 5 Porters list with your show of thanks.
|
||||
|
||||
=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
|
||||
@ -2,260 +2,411 @@
|
||||
|
||||
=head1 NAME
|
||||
|
||||
perldelta - what is new for perl v5.41.6
|
||||
[ this is a template for a new perldelta file. Any text flagged as XXX needs
|
||||
to be processed before release. ]
|
||||
|
||||
perldelta - what is new for perl v5.41.7
|
||||
|
||||
=head1 DESCRIPTION
|
||||
|
||||
This document describes differences between the 5.41.5 release and the 5.41.6
|
||||
This document describes differences between the 5.41.6 release and the 5.41.7
|
||||
release.
|
||||
|
||||
If you are upgrading from an earlier release such as 5.41.4, first read
|
||||
L<perl5415delta>, which describes differences between 5.41.4 and 5.41.5.
|
||||
If you are upgrading from an earlier release such as 5.41.5, first read
|
||||
L<perl5416delta>, which describes differences between 5.41.5 and 5.41.6.
|
||||
|
||||
=head1 Notice
|
||||
|
||||
XXX Any important notices here
|
||||
|
||||
=head1 Core Enhancements
|
||||
|
||||
XXX New core language features go here. Summarize user-visible core language
|
||||
enhancements. Particularly prominent performance optimisations could go
|
||||
here, but most should go in the L</Performance Enhancements> section.
|
||||
|
||||
[ List each enhancement as a =head2 entry ]
|
||||
|
||||
=head1 Security
|
||||
|
||||
XXX Any security-related notices go here. In particular, any security
|
||||
vulnerabilities closed should be noted here rather than in the
|
||||
L</Selected Bug Fixes> section.
|
||||
|
||||
[ List each security issue as a =head2 entry ]
|
||||
|
||||
=head1 Incompatible Changes
|
||||
|
||||
XXX For a release on a stable branch, this section aspires to be:
|
||||
|
||||
There are no changes intentionally incompatible with 5.XXX.XXX
|
||||
If any exist, they are bugs, and we request that you submit a
|
||||
report. See L</Reporting Bugs> below.
|
||||
|
||||
[ List each incompatible change as a =head2 entry ]
|
||||
|
||||
=head1 Deprecations
|
||||
|
||||
XXX Any deprecated features, syntax, modules etc. should be listed here.
|
||||
|
||||
=head2 Module removals
|
||||
|
||||
XXX Remove this section if not applicable.
|
||||
|
||||
The following modules will be removed from the core distribution in a
|
||||
future release, and will at that time need to be installed from CPAN.
|
||||
Distributions on CPAN which require these modules will need to list them as
|
||||
prerequisites.
|
||||
|
||||
The core versions of these modules will now issue C<deprecated>-category
|
||||
warnings to alert you to this fact. To silence these deprecation warnings,
|
||||
install the modules in question from CPAN.
|
||||
|
||||
Note that these are (with rare exceptions) fine modules that you are encouraged
|
||||
to continue to use. Their disinclusion from core primarily hinges on their
|
||||
necessity to bootstrapping a fully functional, CPAN-capable Perl installation,
|
||||
not usually on concerns over their design.
|
||||
|
||||
=over
|
||||
|
||||
=item XXX
|
||||
|
||||
XXX Note that deprecated modules should be listed here even if they are listed
|
||||
as an updated module in the L</Modules and Pragmata> section.
|
||||
|
||||
=back
|
||||
|
||||
[ List each other deprecation as a =head2 entry ]
|
||||
|
||||
=head1 Performance Enhancements
|
||||
|
||||
XXX Changes which enhance performance without changing behaviour go here.
|
||||
There may well be none in a stable release.
|
||||
|
||||
[ List each enhancement as an =item entry ]
|
||||
|
||||
=over 4
|
||||
|
||||
=item *
|
||||
|
||||
Code that uses the C<indexed> function from the L<builtin> module to generate
|
||||
a list of index/value pairs out of array which is then passed into a
|
||||
two-variable C<foreach> list to unpack those again is now optimised to be more
|
||||
efficient.
|
||||
|
||||
my @array = (...);
|
||||
|
||||
foreach my ($idx, $val) (builtin::indexed @array) {
|
||||
...
|
||||
}
|
||||
|
||||
In particular, a temporary list twice the size of the original
|
||||
array is no longer generated. Instead, the list iterates down the array
|
||||
in-place directly, in the same way that C<foreach (@array)> would do.
|
||||
XXX
|
||||
|
||||
=back
|
||||
|
||||
=head1 Modules and Pragmata
|
||||
|
||||
XXX All changes to installed files in F<cpan/>, F<dist/>, F<ext/> and F<lib/>
|
||||
go here. If L<Module::CoreList> is updated, generate an initial draft of the
|
||||
following sections using F<Porting/corelist-perldelta.pl>. A paragraph summary
|
||||
for important changes should then be added by hand. In an ideal world,
|
||||
dual-life modules would have a F<Changes> file that could be cribbed.
|
||||
|
||||
The list of new and updated modules is modified automatically as part of
|
||||
preparing a Perl release, so the only reason to manually add entries here is if
|
||||
you're summarising the important changes in the module update. (Also, if the
|
||||
manually-added details don't match the automatically-generated ones, the
|
||||
release manager will have to investigate the situation carefully.)
|
||||
|
||||
[ Within each section, list entries as an =item entry ]
|
||||
|
||||
=head2 New Modules and Pragmata
|
||||
|
||||
=over 4
|
||||
|
||||
=item *
|
||||
|
||||
XXX Remove this section if F<Porting/corelist-perldelta.pl> did not add any content here.
|
||||
|
||||
=back
|
||||
|
||||
=head2 Updated Modules and Pragmata
|
||||
|
||||
=over 4
|
||||
|
||||
=item *
|
||||
|
||||
L<B::Deparse> has been upgraded from version 1.78 to 1.80.
|
||||
L<XXX> has been upgraded from version A.xx to B.yy.
|
||||
|
||||
It now retains parens around logical negations on the left-hand side of
|
||||
comparisons (such as C<(!$x) == $y>) because omitting them would trigger a
|
||||
C<Possible precedence problem> warning since perl v5.41.4. [L<GH #22661|https://github.com/Perl/perl5/issues/22661>]
|
||||
XXX If there was something important to note about this change, include that here.
|
||||
|
||||
=back
|
||||
|
||||
=head2 Removed Modules and Pragmata
|
||||
|
||||
=over 4
|
||||
|
||||
=item *
|
||||
|
||||
L<builtin> has been upgraded from version 0.015 to 0.016.
|
||||
XXX Remove this section if F<Porting/corelist-perldelta.pl> did not add any content here.
|
||||
|
||||
=back
|
||||
|
||||
=head1 Documentation
|
||||
|
||||
XXX Changes to files in F<pod/> go here. Consider grouping entries by
|
||||
file and be sure to link to the appropriate page, e.g. L<perlfunc>.
|
||||
|
||||
=head2 New Documentation
|
||||
|
||||
XXX Changes which create B<new> files in F<pod/> go here.
|
||||
|
||||
=head3 L<XXX>
|
||||
|
||||
XXX Description of the purpose of the new file here
|
||||
|
||||
=head2 Changes to Existing Documentation
|
||||
|
||||
We have attempted to update the documentation to reflect the changes
|
||||
listed in this document. If you find any we have missed, open an issue
|
||||
at L<https://github.com/Perl/perl5/issues>.
|
||||
|
||||
XXX Changes which significantly change existing files in F<pod/> go here.
|
||||
However, any changes to F<pod/perldiag.pod> should go in the L</Diagnostics>
|
||||
section.
|
||||
|
||||
Additionally, the following selected changes have been made:
|
||||
|
||||
=head3 L<XXX>
|
||||
|
||||
=over 4
|
||||
|
||||
=item *
|
||||
|
||||
L<CPAN> has been upgraded from version 2.37 to 2.38.
|
||||
XXX Description of the change here
|
||||
|
||||
=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>.
|
||||
|
||||
XXX New or changed warnings emitted by the core's C<C> code go here. Also
|
||||
include any changes in L<perldiag> that reconcile it to the C<C> code.
|
||||
|
||||
=head2 New Diagnostics
|
||||
|
||||
XXX Newly added diagnostic messages go under here, separated into L</New Errors>
|
||||
and L</New Warnings>
|
||||
|
||||
=head3 New Errors
|
||||
|
||||
=over 4
|
||||
|
||||
=item *
|
||||
|
||||
L<DB> has been upgraded from version 1.08 to 1.09.
|
||||
XXX L<message|perldiag/"message">
|
||||
|
||||
=back
|
||||
|
||||
=head3 New Warnings
|
||||
|
||||
=over 4
|
||||
|
||||
=item *
|
||||
|
||||
L<ExtUtils::ParseXS> has been upgraded from version 3.55 to 3.56.
|
||||
XXX L<message|perldiag/"message">
|
||||
|
||||
=back
|
||||
|
||||
=head2 Changes to Existing Diagnostics
|
||||
|
||||
XXX Changes (i.e. rewording) of diagnostic messages go here
|
||||
|
||||
=over 4
|
||||
|
||||
=item *
|
||||
|
||||
L<ExtUtils::Typemaps> has been upgraded from version 3.55 to 3.56.
|
||||
XXX Describe change here
|
||||
|
||||
=back
|
||||
|
||||
=head1 Utility Changes
|
||||
|
||||
XXX Changes to installed programs such as F<perldoc> and F<xsubpp> go here.
|
||||
Most of these are built within the directory F<utils>.
|
||||
|
||||
[ List utility changes as a =head2 entry for each utility and =item
|
||||
entries for each change
|
||||
Use F<XXX> with program names to get proper documentation linking. ]
|
||||
|
||||
=head2 F<XXX>
|
||||
|
||||
=over 4
|
||||
|
||||
=item *
|
||||
|
||||
L<feature> has been upgraded from version 1.91 to 1.92.
|
||||
XXX
|
||||
|
||||
=back
|
||||
|
||||
=head1 Configuration and Compilation
|
||||
|
||||
XXX Changes to F<Configure>, F<installperl>, F<installman>, and analogous tools
|
||||
go here. Any other changes to the Perl build process should be listed here.
|
||||
However, any platform-specific changes should be listed in the
|
||||
L</Platform Support> section, instead.
|
||||
|
||||
[ List changes as an =item entry ].
|
||||
|
||||
=over 4
|
||||
|
||||
=item *
|
||||
|
||||
L<fields> has been upgraded from version 2.25 to 2.26.
|
||||
XXX
|
||||
|
||||
=back
|
||||
|
||||
=head1 Testing
|
||||
|
||||
XXX Any significant changes to the testing of a freshly built perl should be
|
||||
listed here. Changes which create B<new> files in F<t/> go here as do any
|
||||
large changes to the testing harness (e.g. when parallel testing was added).
|
||||
Changes to existing files in F<t/> aren't worth summarizing, although the bugs
|
||||
that they represent may be covered elsewhere.
|
||||
|
||||
XXX If there were no significant test changes, say this:
|
||||
|
||||
Tests were added and changed to reflect the other additions and changes
|
||||
in this release.
|
||||
|
||||
XXX If instead there were significant changes, say this:
|
||||
|
||||
Tests were added and changed to reflect the other additions and
|
||||
changes in this release. Furthermore, these significant changes were
|
||||
made:
|
||||
|
||||
[ List each test improvement as an =item entry ]
|
||||
|
||||
=over 4
|
||||
|
||||
=item *
|
||||
|
||||
L<HTTP::Tiny> has been upgraded from version 0.088 to 0.090.
|
||||
|
||||
=item *
|
||||
|
||||
L<IPC::Open3> has been upgraded from version 1.23 to 1.24.
|
||||
L<IPC::Open2> has been upgraded from version 1.07 to 1.08.
|
||||
|
||||
There is now a way to pass lexical filehandles to child processes directly
|
||||
(instead of having the module create a pipe internally). Previously, only
|
||||
bareword filehandles could be used in "dup mode".
|
||||
|
||||
=item *
|
||||
|
||||
L<Math::Complex> has been upgraded from version 1.62 to 1.63.
|
||||
|
||||
The complex number parser for string inputs has been improved. In particular,
|
||||
C<1+i>, C<123i>, C<inf>, C<-inf>, C<infi>, and C<-infi> are now handled
|
||||
correctly.
|
||||
|
||||
=item *
|
||||
|
||||
L<Memoize> has been upgraded from version 1.16 to 1.17.
|
||||
|
||||
=item *
|
||||
|
||||
L<Module::CoreList> has been upgraded from version 5.20241020 to 5.20241120.
|
||||
|
||||
=item *
|
||||
|
||||
L<NDBM_File> has been upgraded from version 1.17 to 1.18.
|
||||
|
||||
=item *
|
||||
|
||||
L<ODBM_File> has been upgraded from version 1.18 to 1.19.
|
||||
|
||||
=item *
|
||||
|
||||
L<parent> has been upgraded from version 0.242 to 0.242_001.
|
||||
|
||||
=item *
|
||||
|
||||
L<POSIX> has been upgraded from version 2.22 to 2.23.
|
||||
|
||||
=item *
|
||||
|
||||
L<Scalar::Util> has been upgraded from version 1.68 to 1.68_01.
|
||||
|
||||
=item *
|
||||
|
||||
L<Term::Table> has been upgraded from version 0.022 to 0.023.
|
||||
|
||||
=item *
|
||||
|
||||
L<warnings> has been upgraded from version 1.70 to 1.71.
|
||||
XXX
|
||||
|
||||
=back
|
||||
|
||||
=head1 Platform Support
|
||||
|
||||
=head2 Platform-Specific Notes
|
||||
XXX Any changes to platform support should be listed in the sections below.
|
||||
|
||||
[ Within the sections, list each platform as an =item entry with specific
|
||||
changes as paragraphs below it. ]
|
||||
|
||||
=head2 New Platforms
|
||||
|
||||
XXX List any platforms that this version of perl compiles on, that previous
|
||||
versions did not. These will either be enabled by new files in the F<hints/>
|
||||
directories, or new subdirectories and F<README> files at the top level of the
|
||||
source tree.
|
||||
|
||||
=over 4
|
||||
|
||||
=item arm64 DARWIN
|
||||
=item XXX-some-platform
|
||||
|
||||
Fix arm64 darwin hints when using use64bitall with Configure [L<GH #22672|https://github.com/Perl/perl5/issues/22672>]
|
||||
XXX
|
||||
|
||||
=item Android
|
||||
=back
|
||||
|
||||
Changes to perl_langinfo.h for Android [L<GH #22650|https://github.com/Perl/perl5/issues/22650>] related to [L<GH #22627|https://github.com/Perl/perl5/issues/22627>]
|
||||
=head2 Discontinued Platforms
|
||||
|
||||
=item Cygwin
|
||||
XXX List any platforms that this version of perl no longer compiles on.
|
||||
|
||||
cygwin.c: fix several silly/terrible C errors [L<GH #22724|https://github.com/Perl/perl5/issues/22724>]
|
||||
=over 4
|
||||
|
||||
workaround DLL load address conflict [L<GH #22696|https://github.com/Perl/perl5/issues/22696>]
|
||||
=item XXX-some-platform
|
||||
|
||||
XXX
|
||||
|
||||
=back
|
||||
|
||||
=head2 Platform-Specific Notes
|
||||
|
||||
XXX List any changes for specific platforms. This could include configuration
|
||||
and compilation changes or changes in portability/compatibility. However,
|
||||
changes within modules for platforms should generally be listed in the
|
||||
L</Modules and Pragmata> section.
|
||||
|
||||
=over 4
|
||||
|
||||
=item XXX-some-platform
|
||||
|
||||
XXX
|
||||
|
||||
=back
|
||||
|
||||
=head1 Internal Changes
|
||||
|
||||
XXX Changes which affect the interface available to C<XS> code go here. Other
|
||||
significant internal changes for future core maintainers should be noted as
|
||||
well.
|
||||
|
||||
[ List each change as an =item entry ]
|
||||
|
||||
=over 4
|
||||
|
||||
=item *
|
||||
|
||||
Enable removing most of mathoms.c and stub functions [L<GH #22691|https://github.com/Perl/perl5/issues/22691>] and [L<GH #22714|https://github.com/Perl/perl5/issues/22714>]
|
||||
|
||||
=item *
|
||||
|
||||
reinstate apostrophe as package separator behind a default enabled feature,
|
||||
which is disabled from feature bundle 5.41.
|
||||
|
||||
=item *
|
||||
|
||||
pp_reverse: don't COW buffer just to then un-COW it [L<GH #22729|https://github.com/Perl/perl5/issues/22729>]
|
||||
XXX
|
||||
|
||||
=back
|
||||
|
||||
=head1 Selected Bug Fixes
|
||||
|
||||
XXX Important bug fixes in the core language are summarized here. Bug fixes in
|
||||
files in F<ext/> and F<lib/> are best summarized in L</Modules and Pragmata>.
|
||||
|
||||
XXX Include references to GitHub issues and PRs as: [GH #12345] and the release
|
||||
manager will later use a regex to expand these into links.
|
||||
|
||||
[ List each fix as an =item entry ]
|
||||
|
||||
=over 4
|
||||
|
||||
=item *
|
||||
|
||||
The perl parser would erroneously parse like C<=cut> some other POD directives
|
||||
whose names start with I<cut>, prematurely terminating an embedded POD section.
|
||||
The following cases were affected: I<cut> followed by a digit (e.g.
|
||||
C<=cut2studio>), I<cut> followed by an underscore (e.g. C<=cut_grass>), and in
|
||||
string C<eval>, any identifier starting with I<cut> (e.g. C<=cute>).
|
||||
[L<GH #22759|https://github.com/Perl/perl5/issues/22759>]
|
||||
|
||||
=item *
|
||||
|
||||
Builds with C<-msse> and quadmath on 32-bit x86 systems would crash
|
||||
with a misaligned access early in the build. [L<GH #22577|https://github.com/Perl/perl5/issues/22577>]
|
||||
|
||||
=item *
|
||||
|
||||
On threaded builds on POSIX-like systems, if the perl signal handler
|
||||
receives we now resend the signal to the main perl thread. Previously
|
||||
this would crash. [GH #22487]
|
||||
XXX
|
||||
|
||||
=back
|
||||
|
||||
=head1 Known Problems
|
||||
|
||||
XXX Descriptions of platform agnostic bugs we know we can't fix go here. Any
|
||||
tests that had to be C<TODO>ed for the release would be noted here. Unfixed
|
||||
platform specific bugs also go here.
|
||||
|
||||
[ List each fix as an =item entry ]
|
||||
|
||||
=over 4
|
||||
|
||||
=item *
|
||||
|
||||
C<cygwin> builds may fail during testing due to a conflict between the
|
||||
load addresses of F<cygperl5_41_6.dll> and
|
||||
F<olib/auto/I18N/Langinfo/Langinfo.dll>. This will also be visible
|
||||
for anything that attempts to fork() with C<I18N::LangInfo> loaded.
|
||||
|
||||
This is known to fail for builds with options that increase the size
|
||||
of the binary, such as C<-DDEBUGGING>, C<-Doptimize="-O0 -g"> or
|
||||
C<-Doptimize="-O2 -g -march=x86-64-v2">.
|
||||
|
||||
This can be avoided by building perl with
|
||||
C<-Astatic_ext=I18N/Langinfo>.
|
||||
|
||||
The base addresses are generated by the linker based on the names of
|
||||
the DLLs, so this is expected to clear up for 5.41.7.
|
||||
|
||||
[L<GH #22695|https://github.com/Perl/perl5/issues/22695>]
|
||||
XXX
|
||||
|
||||
=back
|
||||
|
||||
=head1 Errata From Previous Releases
|
||||
|
||||
=over 4
|
||||
|
||||
=item *
|
||||
|
||||
XXX Add anything here that we forgot to add, or were mistaken about, in
|
||||
the F<perldelta> of a previous release.
|
||||
|
||||
=back
|
||||
|
||||
=head1 Obituary
|
||||
|
||||
XXX If any significant core contributor or member of the CPAN community has
|
||||
died, add a short obituary here.
|
||||
|
||||
=head1 Acknowledgements
|
||||
|
||||
Perl 5.41.6 represents approximately 4 weeks of development since Perl
|
||||
5.41.5 and contains approximately 8,400 lines of changes across 180 files
|
||||
from 14 authors.
|
||||
XXX Generate this with:
|
||||
|
||||
Excluding auto-generated files, documentation and release tools, there were
|
||||
approximately 6,700 lines of changes to 120 .pm, .t, .c and .h files.
|
||||
|
||||
Perl continues to flourish into its fourth decade thanks to a vibrant
|
||||
community of users and developers. The following people are known to have
|
||||
contributed the improvements that became Perl 5.41.6:
|
||||
|
||||
Chad Granum, Chris 'BinGOs' Williams, Daniel Dragan, David Mitchell, Graham
|
||||
Knop, James E Keenan, Karl Williamson, Lukas Mai, Marin Tsanov, Paul Evans,
|
||||
pyrrhlin, Richard Leach, Thibault Duponchelle, Tony Cook.
|
||||
|
||||
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.
|
||||
perl Porting/acknowledgements.pl v5.41.6..HEAD
|
||||
|
||||
=head1 Reporting Bugs
|
||||
|
||||
|
||||
@ -298,7 +298,7 @@ utils : $(utils1) $(utils2) $(utils3) $(utils4) $(utils5)
|
||||
extra.pods : miniperl
|
||||
@ @extra_pods.com
|
||||
|
||||
PERLDELTA_CURRENT = [.pod]perl5416delta.pod
|
||||
PERLDELTA_CURRENT = [.pod]perl5417delta.pod
|
||||
|
||||
$(PERLDELTA_CURRENT) : [.pod]perldelta.pod
|
||||
Copy/NoConfirm/Log $(MMS$SOURCE) $(PERLDELTA_CURRENT)
|
||||
|
||||
@ -1643,7 +1643,7 @@ utils: $(HAVEMINIPERL) ..\utils\Makefile
|
||||
copy ..\README.tw ..\pod\perltw.pod
|
||||
copy ..\README.vos ..\pod\perlvos.pod
|
||||
copy ..\README.win32 ..\pod\perlwin32.pod
|
||||
copy ..\pod\perldelta.pod ..\pod\perl5416delta.pod
|
||||
copy ..\pod\perldelta.pod ..\pod\perl5417delta.pod
|
||||
$(MINIPERL) -I..\lib $(PL2BAT) $(UTILS)
|
||||
$(MINIPERL) -I..\lib ..\autodoc.pl -c "win32\$(CONFIG_H)" ..
|
||||
$(MINIPERL) -I..\lib ..\pod\perlmodlib.PL -q ..
|
||||
@ -1743,7 +1743,7 @@ distclean: realclean
|
||||
-if exist $(LIBDIR)\Win32API rmdir /s /q $(LIBDIR)\Win32API
|
||||
-if exist $(LIBDIR)\XS rmdir /s /q $(LIBDIR)\XS
|
||||
-cd $(PODDIR) && del /f *.html *.bat roffitall \
|
||||
perl5416delta.pod perlaix.pod perlamiga.pod perlandroid.pod \
|
||||
perl5417delta.pod perlaix.pod perlamiga.pod perlandroid.pod \
|
||||
perlapi.pod perlbs2000.pod perlcn.pod perlcygwin.pod \
|
||||
perlfreebsd.pod perlhaiku.pod perlhpux.pod perlhurd.pod \
|
||||
perlintern.pod perlirix.pod perljp.pod perlko.pod perllinux.pod \
|
||||
|
||||
@ -1165,7 +1165,7 @@ utils: $(PERLEXE) ..\utils\Makefile
|
||||
copy ..\README.tw ..\pod\perltw.pod
|
||||
copy ..\README.vos ..\pod\perlvos.pod
|
||||
copy ..\README.win32 ..\pod\perlwin32.pod
|
||||
copy ..\pod\perldelta.pod ..\pod\perl5416delta.pod
|
||||
copy ..\pod\perldelta.pod ..\pod\perl5417delta.pod
|
||||
cd ..\win32
|
||||
$(PERLEXE) $(PL2BAT) $(UTILS)
|
||||
$(MINIPERL) -I..\lib ..\autodoc.pl -c "win32\$(CONFIG_H)" ..
|
||||
@ -1266,7 +1266,7 @@ distclean: realclean
|
||||
-if exist $(LIBDIR)\Win32API rmdir /s /q $(LIBDIR)\Win32API
|
||||
-if exist $(LIBDIR)\XS rmdir /s /q $(LIBDIR)\XS
|
||||
-cd $(PODDIR) && del /f *.html *.bat roffitall \
|
||||
perl5416delta.pod perlaix.pod perlamiga.pod perlandroid.pod \
|
||||
perl5417delta.pod perlaix.pod perlamiga.pod perlandroid.pod \
|
||||
perlapi.pod perlbs2000.pod perlcn.pod perlcygwin.pod \
|
||||
perlfreebsd.pod perlhaiku.pod perlhpux.pod perlhurd.pod \
|
||||
perlintern.pod perlirix.pod perljp.pod perlko.pod perllinux.pod \
|
||||
|
||||
@ -83,6 +83,7 @@ POD = perl.pod \
|
||||
perl5414delta.pod \
|
||||
perl5415delta.pod \
|
||||
perl5416delta.pod \
|
||||
perl5417delta.pod \
|
||||
perl561delta.pod \
|
||||
perl56delta.pod \
|
||||
perl581delta.pod \
|
||||
@ -266,6 +267,7 @@ MAN = perl.man \
|
||||
perl5414delta.man \
|
||||
perl5415delta.man \
|
||||
perl5416delta.man \
|
||||
perl5417delta.man \
|
||||
perl561delta.man \
|
||||
perl56delta.man \
|
||||
perl581delta.man \
|
||||
@ -449,6 +451,7 @@ HTML = perl.html \
|
||||
perl5414delta.html \
|
||||
perl5415delta.html \
|
||||
perl5416delta.html \
|
||||
perl5417delta.html \
|
||||
perl561delta.html \
|
||||
perl56delta.html \
|
||||
perl581delta.html \
|
||||
@ -632,6 +635,7 @@ TEX = perl.tex \
|
||||
perl5414delta.tex \
|
||||
perl5415delta.tex \
|
||||
perl5416delta.tex \
|
||||
perl5417delta.tex \
|
||||
perl561delta.tex \
|
||||
perl56delta.tex \
|
||||
perl581delta.tex \
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user