NAME
perl588delta - what is new for perl v5.8.8
DESCRIPTION
This document describes differences between the 5.8.7 release and the 5.8.8 release.
Incompatible Changes
There are no changes intentionally incompatible with 5.8.7. If any exist, they are bugs and reports are welcome.
Core Enhancements
chdir,chmodandchowncan now work on filehandles as well as filenames, if the system supports respectivelyfchdir,fchmodandfchown, thanks to a patch provided by Gisle Aas.
Modules and Pragmata
Attribute::Handlersupgraded to version 0.78_02Documentation typo fix
attrsupgraded to version 1.02Internal cleanup only
autouseupgraded to version 1.05Simplified implementation
Bupgraded to version 1.09_01The inheritance hierarchy of the
B::modules has been corrected;B::NVnow inherits fromB::SV(instead ofB::IV).
blibupgraded to version 1.03Documentation typo fix
ByteLoaderupgraded to version 0.06Internal cleanup
CGIupgraded to version 3.15Extraneous "?" from
self_url()removedscrolling_list()select attribute fixedvirtual_portnow works properly with the https protocolupload_hook()andappend()now works in function-oriented modePOST_MAXdoesn't cause the client to hang any moreAutomatic tab indexes are now disabled and new
-tabindexpragma has been added to turn automatic indexes back onend_form()doesn't emit empty (and non-validating)<div>CGI::Carpworks better in certain mod_perl configurationsSetting
$CGI::TMPDIRECTORYis now effectiveEnhanced documentation
charnamesupgraded to version 1.05viacode()now accept hex strings and has been optimized.
CPANupgraded to version 1.76_021 minor bug fix for Win32
Cwdupgraded to version 3.12canonpath()on Win32 now collapses foo\.. sections correctly.Improved behaviour on Symbian OS.
Enhanced documentation and typo fixes
Internal cleanup
Data::Dumperupgraded to version 2.121_08A problem where
Data::Dumperwould sometimes update the iterator state of hashes has been fixedNumeric labels now work
Internal cleanup
DBupgraded to version 1.01A problem where the state of the regexp engine would sometimes get clobbered when running under the debugger has been fixed.
DB_Fileupgraded to version 1.814Adds support for Berkeley DB 4.4.
Devel::DProfupgraded to version 20050603.00Internal cleanup
Devel::Peekupgraded to version 1.03Internal cleanup
Devel::PPPortupgraded to version 3.06_01--compat-versionargument checking has been improvedFiles passed on the command line are filtered by default
--nofilteroption to override the filtering has been addedEnhanced documentation
diagnosticsupgraded to version 1.15Documentation typo fix
Digestupgraded to version 1.14The constructor now knows which module implements SHA-224
Documentation tweaks and typo fixes
Digest::MD5upgraded to version 2.36XSLoaderis now used for faster loadingEnhanced documentation including MD5 weaknesses discovered lately
Dumpvalueupgraded to version 1.12Documentation fix
DynaLoaderupgraded but unfortunately we're not able to increment its version number :-(Implements
dl_unload_fileon Win32Internal cleanup
XSLoader0.06 incorporated; small optimisation for callingbootstrap_inherit()and documentation enhancements.
Encodeupgraded to version 2.12A coderef is now acceptable for
CHECK!3 new characters added to the ISO-8859-7 encoding
New encoding
MIME-Header-ISO_2022_JPaddedProblem with partial characters and
encoding(utf-8-strict)fixed.Documentation enhancements and typo fixes
Englishupgraded to version 1.02the
$COMPILINGvariable has been added
ExtUtils::Constantupgraded to version 0.17Improved compatibility with older versions of perl
ExtUtils::MakeMakerupgraded to version 6.30 (was 6.17)Too much to list here; see http://search.cpan.org/dist/ExtUtils-MakeMaker/Changes
File::Basenameupgraded to version 2.74, with changes contributed by Michael Schwern.Documentation clarified and errors corrected.
basenamenow strips trailing path separators before processing the name.basenamenow returns/for parameter/, to makebasenameconsistent with the shell utility of the same name.The suffix is no longer stripped if it is identical to the remaining characters in the name, again for consistency with the shell utility.
Some internal code cleanup.
File::Copyupgraded to version 2.09Copying a file onto itself used to fail.
Moving a file between file systems now preserves the access and modification time stamps
File::Findupgraded to version 1.10Win32 portability fixes
Enhanced documentation
File::Globupgraded to version 1.05Internal cleanup
File::Pathupgraded to version 1.08mkpathnow preserveserrnowhenmkdirfails
File::Specupgraded to version 3.12File::Spec-rootdir()> now returns\on Win32, instead of/$^Ocould sometimes become tainted. This has been fixed.canonpathon Win32 now collapsesfoo/..(orfoo\..) sections correctly, rather than doing the "misguided" work it was previously doing. Note thatcanonpathon Unix still does not collapse these sections, as doing so would be incorrect.Some documentation improvements
Some internal code cleanup
FileCacheupgraded to version 1.06POD formatting errors in the documentation fixed
Filter::Simpleupgraded to version 0.82FindBinupgraded to version 1.47Now works better with directories where access rights are more restrictive than usual.
GDBM_Fileupgraded to version 1.08Internal cleanup
Getopt::Longupgraded to version 2.35prefix_patternhas now been complemented by a new configuration optionlong_prefix_patternthat allows the user to specify what prefix patterns should have long option style semantics applied.Options can now take multiple values at once (experimental)
Various bug fixes
ifupgraded to version 0.05Give more meaningful error messages from
ifwhen invoked with a condition in list context.Restore backwards compatibility with earlier versions of perl
IOupgraded to version 1.22Enhanced documentation
Internal cleanup
IPC::Open2upgraded to version 1.02Enhanced documentation
IPC::Open3upgraded to version 1.02Enhanced documentation
List::Utilupgraded to version 1.18 (was 1.14)Fix pure-perl version of
refaddrto avoid blessing an un-blessed referenceUse
XSLoaderfor faster loadingFixed various memory leaks
Internal cleanup and portability fixes
Math::Complexupgraded to version 1.35atan2(0, i)now works, as do all the (computable) complex argument casesFixes for certain bugs in
makeandemakeSupport returning the kth root directly
Support
[2,-3pi/8]inemakeSupport
infformake/emakeDocument
make/emakemore visibly
Math::Trigupgraded to version 1.03Add more great circle routines:
great_circle_waypointandgreat_circle_destination
MIME::Base64upgraded to version 3.07Use
XSLoaderfor faster loadingEnhanced documentation
Internal cleanup
NDBM_Fileupgraded to version 1.06Enhanced documentation
ODBM_Fileupgraded to version 1.06Documentation typo fixed
Internal cleanup
Opcodeupgraded to version 1.06Enhanced documentation
Internal cleanup
openupgraded to version 1.05Enhanced documentation
overloadupgraded to version 1.04Enhanced documentation
PerlIOupgraded to version 1.04PerlIO::viaiterate over layers properly nowPerlIO::scalarunderstands$/ = ""nowencoding(utf-8-strict)with partial characters now worksEnhanced documentation
Internal cleanup
Pod::Functionsupgraded to version 1.03Documentation typos fixed
Pod::Htmlupgraded to version 1.0504HTML output will now correctly link to
=items on the same page, and should be valid XHTML.Variable names are recognized as intended
Documentation typos fixed
Pod::Parserupgraded to version 1.32Allow files that start with
=headon the first lineWin32 portability fix
Exit status of
pod2usagefixedNew
-noperldocswitch forpod2usageArbitrary URL schemes now allowed
Documentation typos fixed
POSIXupgraded to version 1.09Documentation typos fixed
Internal cleanup
reupgraded to version 0.05Documentation typo fixed
Safeupgraded to version 2.12Minor documentation enhancement
SDBM_Fileupgraded to version 1.05Documentation typo fixed
Internal cleanup
Socketupgraded to version 1.78Internal cleanup
Storableupgraded to version 2.15This includes the
STORABLE_attachhook functionality added by Adam Kennedy, and more frugal memory requirements when storing underithreads, by using theithreadscloning tracking code.
Switchupgraded to version 2.10_01Documentation typos fixed
Sys::Syslogupgraded to version 0.13Now provides numeric macros and meaningful
Exportertags.No longer uses
Sys::Hostnameas it may provide useless values in unconfigured network environments, so instead usesINADDR_LOOPBACKdirectly.syslog()now uses local timestamp.setlogmask()now behaves like its C counterpart.setlogsock()will nowcroak()as documented.Improved error and warnings messages.
Improved documentation.
Term::ANSIColorupgraded to version 1.10Fixes a bug in
coloredwhen$EACHLINEis set that caused it to not color lines consisting solely of 0 (literal zero).Improved tests.
Term::ReadLineupgraded to version 1.02Documentation tweaks
Test::Harnessupgraded to version 2.56 (was 2.48)The
Test::Harnesstimer is now off by default.Now shows elapsed time in milliseconds.
Various bug fixes
Test::Simpleupgraded to version 0.62 (was 0.54)is_deeply()no longer fails to work for many casesVarious minor bug fixes
Documentation enhancements
Text::Tabsupgraded to version 2005.0824Provides a faster implementation of
expand
Text::Wrapupgraded to version 2005.082401Adds
$Text::Wrap::separator2, which allows you to preserve existing newlines but add line-breaks with some other string.
threadsupgraded to version 1.07threadswill now honourno warnings 'threads'A thread's interpreter is now freed after
$t->join()rather than afterundef $t, which should fix someithreadsmemory leaks. (Fixed by Dave Mitchell)Some documentation typo fixes.
threads::sharedupgraded to version 0.94Documentation changes only
Note: An improved implementation of
threads::sharedis available on CPAN - this will be merged into 5.8.9 if it proves stable.
Tie::Hashupgraded to version 1.02Documentation typo fixed
Time::HiResupgraded to version 1.86 (was 1.66)clock_nanosleep()andclock()functions addedSupport for the POSIX
clock_gettime()andclock_getres()has been addedReturn
undefor an empty list if the Cgettimeofday()function failsImproved
nanosleepdetectionInternal cleanup
Enhanced documentation
Unicode::Collateupgraded to version 0.52Now implements UCA Revision 14 (based on Unicode 4.1.0).
Unicode::Collate-new> method no longer overwrites user's$_Enhanced documentation
Unicode::UCDupgraded to version 0.24Documentation typos fixed
User::grentupgraded to version 1.01Documentation typo fixed
utf8upgraded to version 1.06Documentation typos fixed
vmsishupgraded to version 1.02Documentation typos fixed
warningsupgraded to version 1.05Gentler messing with
Carp::internalsInternal cleanup
Documentation update
Win32upgraded to version 0.2601Provides Windows Vista support to
Win32::GetOSNameDocumentation enhancements
XS::Typemapupgraded to version 0.02Internal cleanup
Utility Changes
h2xs enhancements
h2xs implements new option --use-xsloader to force use of XSLoader even in backwards compatible modules.
The handling of authors' names that had apostrophes has been fixed.
Any enums with negative values are now skipped.
perlivp enhancements
perlivp implements new option -a and will not check for *.ph files by default any more. Use the -a option to run all tests.
New Documentation
The perlglossary manpage is a glossary of terms used in the Perl documentation, technical and otherwise, kindly provided by O'Reilly Media, inc.
Performance Enhancements
Weak reference creation is now O(1) rather than O(n), courtesy of Nicholas Clark. Weak reference deletion remains O(n), but if deletion only happens at program exit, it may be skipped completely.
Salvador Fandiño provided improvements to reduce the memory usage of
sortand to speed up some cases.Jarkko Hietaniemi and Andy Lester worked to mark as much data as possible in the C source files as
static, to increase the proportion of the executable file that the operating system can share between process, and thus reduce real memory usage on multi-user systems.
Installation and Configuration Improvements
Parallel makes should work properly now, although there may still be problems if make test is instructed to run in parallel.
Building with Borland's compilers on Win32 should work more smoothly. In particular Steve Hay has worked to side step many warnings emitted by their compilers and at least one C compiler internal error.
Configure will now detect clearenv and unsetenv, thanks to a patch from Alan Burlison. It will also probe for futimes and whether sprintf correctly returns the length of the formatted string, which will both be used in perl 5.8.9.
There are improved hints for next-3.0, vmesa, IX, Darwin, Solaris, Linux, DEC/OSF, HP-UX and MPE/iX
Perl extensions on Windows now can be statically built into the Perl DLL, thanks to a work by Vadim Konovalov. (This improvement was actually in 5.8.7, but was accidentally omitted from perl587delta).
Selected Bug Fixes
no warnings 'category' works correctly with -w
Previously when running with warnings enabled globally via -w, selective disabling of specific warning categories would actually turn off all warnings. This is now fixed; now no warnings 'io'; will only turn off warnings in the io class. Previously it would erroneously turn off all warnings.
This bug fix may cause some programs to start correctly issuing warnings.
Remove over-optimisation
Perl 5.8.4 introduced a change so that assignments of undef to a scalar, or of an empty list to an array or a hash, were optimised away. As this could cause problems when goto jumps were involved, this change has been backed out.
sprintf() fixes
Using the sprintf() function with some formats could lead to a buffer overflow in some specific cases. This has been fixed, along with several other bugs, notably in bounds checking.
In related fixes, it was possible for badly written code that did not follow the documentation of Sys::Syslog to have formatting vulnerabilities. Sys::Syslog has been changed to protect people from poor quality third party code.
Debugger and Unicode slowdown
It had been reported that running under perl's debugger when processing Unicode data could cause unexpectedly large slowdowns. The most likely cause of this was identified and fixed by Nicholas Clark.
Smaller fixes
FindBinnow works better with directories where access rights are more restrictive than usual.Several memory leaks in ithreads were closed. An improved implementation of
threads::sharedis available on CPAN - this will be merged into 5.8.9 if it proves stable.Trailing spaces are now trimmed from
$!and$^E.Operations that require perl to read a process's list of groups, such as reads of
$(and$), now dynamically allocate memory rather than using a fixed sized array. The fixed size array could cause C stack exhaustion on systems configured to use large numbers of groups.PerlIO::scalarnow works better with non-default$/settings.You can now use the
xoperator to repeat aqw//list. This used to raise a syntax error.The debugger now traces correctly execution in eval("")uated code that contains #line directives.
The value of the
openpragma is no longer ignored for three-argument opens.The optimisation of
for (reverse @a)introduced in perl 5.8.6 could misbehave when the array had undefined elements and was used in LVALUE context. Dave Mitchell provided a fix.Some case insensitive matches between UTF-8 encoded data and 8 bit regexps, and vice versa, could give malformed character warnings. These have been fixed by Dave Mitchell and Yves Orton.
lcfirstanducfirstcould corrupt the string for certain cases where the length UTF-8 encoding of the string in lower case, upper case or title case differed. This was fixed by Nicholas Clark.Perl will now use the C library calls
unsetenvandclearenvif present to delete keys from%ENVand delete%ENVentirely, thanks to a patch from Alan Burlison.
New or Changed Diagnostics
Attempt to set length of freed array
This is a new warning, produced in situations such as this:
$r = do {my @a; \$#a};
$$r = 503;
Non-string passed as bitmask
This is a new warning, produced when number has been passed as a argument to select(), instead of a bitmask.
# Wrong, will now warn
$rin = fileno(STDIN);
($nfound,$timeleft) = select($rout=$rin, undef, undef, $timeout);
# Should be
$rin = '';
vec($rin,fileno(STDIN),1) = 1;
($nfound,$timeleft) = select($rout=$rin, undef, undef, $timeout);
Search pattern not terminated or ternary operator parsed as search pattern
This syntax error indicates that the lexer couldn't find the final delimiter of a ?PATTERN? construct. Mentioning the ternary operator in this error message makes it easier to diagnose syntax errors.
Changed Internals
There has been a fair amount of refactoring of the C source code, partly to make it tidier and more maintainable. The resulting object code and the perl binary may well be smaller than 5.8.7, in particular due to a change contributed by Dave Mitchell which reworked the warnings code to be significantly smaller. Apart from being smaller and possibly faster, there should be no user-detectable changes.
Andy Lester supplied many improvements to determine which function parameters and local variables could actually be declared const to the C compiler. Steve Peters provided new *_set macros and reworked the core to use these rather than assigning to macros in LVALUE context.
Dave Mitchell improved the lexer debugging output under -DT
Nicholas Clark changed the string buffer allocation so that it is now rounded up to the next multiple of 4 (or 8 on platforms with 64 bit pointers). This should reduce the number of calls to realloc without actually using any extra memory.
The HV's array of HE*s is now allocated at the correct (minimal) size, thanks to another change by Nicholas Clark. Compile with -DPERL_USE_LARGE_HV_ALLOC to use the old, sloppier, default.
For XS or embedding debugging purposes, if perl is compiled with -DDEBUG_LEAKING_SCALARS_FORK_DUMP in addition to -DDEBUG_LEAKING_SCALARS then a child process is forked just before global destruction, which is used to display the values of any scalars found to have leaked at the end of global destruction. Without this, the scalars have already been freed sufficiently at the point of detection that it is impossible to produce any meaningful dump of their contents. This feature was implemented by the indefatigable Nicholas Clark, based on an idea by Mike Giroux.
Platform Specific Problems
The optimiser on HP-UX 11.23 (Itanium 2) is currently partly disabled (scaled down to +O1) when using HP C-ANSI-C; the cause of problems at higher optimisation levels is still unclear.
There are a handful of remaining test failures on VMS, mostly due to test fixes and minor module tweaks with too many dependencies to integrate into this release from the development stream, where they have all been corrected. The following is a list of expected failures with the patch number of the fix where that is known:
ext/Devel/PPPort/t/ppphtest.t #26913
ext/List/Util/t/p_tainted.t #26912
lib/ExtUtils/t/PL_FILES.t #26813
lib/ExtUtils/t/basic.t #26813
t/io/fs.t
t/op/cmp.t
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 http://bugs.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 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 perl -V, will be sent off to perlbug@perl.org to be analysed by the Perl porting team. You can browse and search the Perl 5 bugs at http://bugs.perl.org/
SEE ALSO
The Changes file for 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.