NAME
perldelta - what is new for perl v5.39.4
DESCRIPTION
This document describes differences between the 5.39.3 release and the 5.39.4 release.
If you are upgrading from an earlier release such as 5.39.2, first read perl5393delta, which describes differences between 5.39.2 and 5.39.3.
Modules and Pragmata
New Modules and Pragmata
Term::Table 0.017 has been added to the Perl core.
This module is a dependency of Test2::Suite.
Test2::Suite 0.000156 has been added to the Perl core.
This distribution contains a comprehensive set of test tools for writing unit tests. It is the successor to Test::More and similar modules. Its inclusion in the Perl core means that CPAN module tests can be written using this suite of tools without extra dependencies.
Updated Modules and Pragmata
builtin has been upgraded from version 0.010 to 0.011.
builtin now accepts a version bundle as an input argument, requesting it to import all of the functions that are considered a stable part of the module at the given Perl version. For example:
use builtin ':5.40';
feature has been upgraded from version 1.84 to 1.85.
It now documents the
:all
feature bundle, and suggests a reason why you may not wish to use it.File::Find has been upgraded from version 1.43 to 1.44.
File::stat has been upgraded from version 1.13 to 1.14.
Math::BigInt has been upgraded from version 1.999839 to 1.999842.
Math::BigInt::FastCalc has been upgraded from version 0.5014 to 0.5015.
Module::CoreList has been upgraded from version 5.20230920 to 5.20231025.
perl5db.pl has been upgraded from version 1.77 to 1.78.
Made parsing of the
l
command arguments saner. [GH #21350]POSIX has been upgraded from version 2.15 to 2.16.
The
mktime
function now works correctly on 32-bit platforms even if the platform'stime_t
type is larger than 32 bits. [GH #21551]The
T_SIGNO
andT_FD
typemap entries have been fixed so they work with any variable name, rather than just the hardcodedsig
andfd
.The mappings for
Mode_t
,pid_t
,Uid_t
,Gid_t
andTime_t
have been updated to be integer types; previously they wereNV
floating-point.Test::Harness has been upgraded from version 3.47 to 3.48.
Time::gmtime has been upgraded from version 1.04 to 1.05.
Time::localtime has been upgraded from version 1.03 to 1.04.
Time::tm has been upgraded from version 1.00 to 1.01.
User::grent has been upgraded from version 1.04 to 1.05.
User::pwent has been upgraded from version 1.02 to 1.03.
version has been upgraded from version 0.9929 to 0.9930.
XS::APItest has been upgraded from version 1.33 to 1.34.
XS::Typemap has been upgraded from version 0.19 to 0.20.
Documentation
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 https://github.com/Perl/perl5/issues.
Additionally, the following selected changes have been made:
perlre
Removed statement suggesting
/p
is a no-op.
perlapi
Several internal functions now have documentation - the various
newSUB
functions,newANONLIST()
,newANONHASH()
,newSVREF()
and similar.
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 perldiag.
New Diagnostics
New Errors
Builtin version bundle "%s" is not supported by Perl
(F) You attempted to
use builtin :ver
for a version number that is either older than 5.39 (when the ability was added), or newer than the current perl version.-
(F) A version number that is used to specify an import bundle during a
use builtin ...
statement must be formatted as:MAJOR.MINOR
with an optional third component, which is ignored. Each component must be a number of 1 to 3 digits. No other characters are permitted. The value that was specified does not conform to these rules.
Testing
Tests were added and changed to reflect the other additions and changes in this release.
Platform Support
Platform-Specific Notes
- VMS
-
Fixed the configure "installation prefix" prompt to accept a string rather than yes/no.
Fixed compilation by defining proper value for
perl_lc_all_category_positions_init
.Increased buffer size when reading config_H.SH to fix compilation under clang.
Internal Changes
PERL_VERSION_LE
has been fixed to properly check for "less than or equal" rather than "less than".
Selected Bug Fixes
Lexical names from the enclosing scope in a lexical sub or closure weren't visible to code executed by calling
eval EXPR;
from theDB
package. This was introduced in 5.18 in an attempt to prevent subs from retaining a reference to their outer scope, but this broke the special behaviour ofeval EXPR;
in package DB.This incidentally fixed a TODO test for
B::Deparse
. [GH #19370]Optionally support an argument stack over 2**32 entries on 64-bit platforms. This requires 32GB of memory just for the argument stack pointers itself, so you will require a significantly more memory to take advantage of this.
To enable this add
-Accflags=-DPERL_STACK_OFFSET_SSIZET
or equivalent to theConfigure
command-line.Fixed various problems with join() where modifications to the separator could be handled inconsistently, or could access released memory. Changes to the separator from magic or overloading for values in the
LIST
no longer have an effect on the resulting joined string. [GH #21458]Don't clear the integer flag
IOK
from lines in the@{"_<$sourcefile"}
array when adbstate
op is removed for that line. This was broken when fixing [GH #19198]. [GH #21564]Many bug fixes have been made for using locales under threads and in embedded perls. And workarounds for libc bugs have been added. As a result thread-safe locale handling is now the default under OpenBSD, and MingW when compiled with UCRT.
However, testing has shown that Darwin's implementation of thread-safe locale handling has bugs. So now Perl doesn't attempt to use the thread-safe operations when compiled on Darwin.
As before, you can check to see if your program is running with thread-safe locales by checking if the value of
${^SAFE_LOCALES}
is 1.Various bugs have been fixed when perl is configured with
-Accflags=-DNO_LOCALE_NUMERIC
or any other locale category (or categories).Not all locale categories need be set to the same locale. Perl now works around bugs in the libc implementations of locale handling on some platforms that previously could result in mojibake.
LC_ALL
is represented in one of two ways when not all locale categories are set to the same locale. On some platforms, such as Linux and Windows, the representation is of the form of a series of'category=locale-name'
pairs. On other platforms, such as *BSD, the representation is positional likename1 / name2 / ...
. name1 is always for a particular category as defined by the platform, as are the other names. The sequence that separates the names (the/
above) also varies by platform. Previously, perl had problems with platforms that used the positional notation. This is now fixed.A bug has been fixed in the regexp engine with an optimisation that applies to the
+
quantifier where it was followed by a(*SKIP)
pattern.
Acknowledgements
Perl 5.39.4 represents approximately 5 weeks of development since Perl 5.39.3 and contains approximately 46,000 lines of changes across 460 files from 20 authors.
Excluding auto-generated files, documentation and release tools, there were approximately 44,000 lines of changes to 390 .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.39.4:
Abe Timmerman, Amory Meltzer, Craig A. Berry, Dagfinn Ilmari Mannsåker, Dan Jacobson, Elvin Aslanov, Gianni Ceccarelli, Graham Knop, Jake Hamby, James E Keenan, Joe McMahon, Karl Williamson, Leon Timmermans, Lukas Mai, Matthew Horsfall, Paul Evans, Peter John Acklam, Tony Cook, William Lyu, Yves Orton.
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 AUTHORS file in the Perl source distribution.
Reporting Bugs
If you find what you think is a bug, you might check the perl bug database at https://github.com/Perl/perl5/issues. There may also be information at http://www.perl.org/, the Perl Home Page.
If you believe you have an unreported bug, please open an issue at 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 "SECURITY VULNERABILITY CONTACT INFORMATION" in perlsec for details of how to report the issue.
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 perlthanks
program:
perlthanks
This will send an email to the Perl 5 Porters list with your show of thanks.
SEE ALSO
The Changes file for an explanation of how to view exhaustive details on what changed.
The INSTALL file for how to build Perl.
The README file for general stuff.
The Artistic and Copying files for copyright information.