This Week on perl5-porters - 27 February-5 March 2006
"Module::Build" achieves core status, VMS improvements, and the usual bunch of bug fixes and enhancements. Topics of Interest Function prototyping and op/utftaint.t failures in "blead" in "Win32" Yves Orton first starting looking at smoke failures on Win32, and wondered why he was seeing redefined subroutines in "Getopt::Long", but Nicholas Clark stepped up and said that Yves had been caught out by a glitch that had since been fixed in the source code. Steve Hay and Nicholas worked through the failure, which was a problem of taintedness when "." (dot) appears in the "PATH" environment variable. A fine example of how hard it is to get cross-platform platform-dependent code correct. http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-02/msg00939.html "Term::ReadLine", "CON:" and "Term::ReadKey" on "Win32" (cpan #17773) Johnathon Stowe mentioned the issues he had uncovered with CPAN bug reports filed against "Term::ReadKey". He had traced the problem to "Term::ReadLine" using the special device "CON:" (as in *console*) on "Win32". One may open such a file directly, and things will work correctly, but open the file and pass it as a handle to "Term::ReadLine" and things start to fall apart, which is in fact what happens at the moment. Johnathon thought that the best approach would be to fix "Term::ReadLine". Somebody else's bug http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-02/msg01018.html DBD::Oracle 1.17 and 64-bit perl on AIX 5.1 John L. Allen was failing miserably at getting Oracle and 64-bit perl on AIX to talk to each other, and asked for help. H.Merijn Brand thought that the combination was "like voluntarily having someone tie you down on a bed of nails, and then being whipped with a bunch of rusty barbed wire." Dave Mitchell considered it highly doubtful that one would be able to connect a 32-bit Oracle library to a 64-bit perl. After trying out different long integer and long double Perl compilations, John succeeded in building a perl with 32-bit integers, long doubles (128 bits) and Oracle all playing nicely. Alan Olsen, speaking from experience, recommended that John go either full 32-bit, or full 64-bit. Choosing the middle ground just leads to pain and unhappiness. It can be done http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00008.html "pow" failures on AIX with "uselongdouble" After having done battle with Oracle on AIX, John L. Allen turned his attention to failures in the test suite, and noticed some misbehaviour with the "pow" function. Dominic Dunlop confirmed that something strange was indeed occurring. After a bit of detective work, John realised that the problem was not with perl, but AIX's underlying math libraries. He wrote a small C program to demonstrate the error, which should allow someone with the necessary "Configure"-fu to write the probe to work around the breakage. The library and the damage done http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00105.html Detecting @ISA cache invalidation Caching in which package a method is found ensures decent run-time performance. That is, if an object calls a method unknown to the current package, it consults @ISA to look for other packages that may have a suitable method. Once it succeeds in finding it the first time, it caches the information so that subsequent method calls can avoid paying the cost of the search. That works fine until @ISA is modified, in which case the cache has to be invalidated, which in turn means that objects need to take a fresh look through the @ISA chain to locate their methods again. Usually you don't have to care about this at all, it just works. But some modules extremely tricky things, and can get thrown by changes to @ISA, and worse, up until now there was no easy way of determining when it happens. So Joshua ben Jore wrote "B::sub_generation", which provides a handy technique for letting user code know when cache invalidation occurs. When asked to explain what this all meant, Joshua provided a short snippet of code, showing how things can get derailed if code doesn't realise that @ISA changed. Rafael thought that Joshua's exposé should be saved somewhere in "perlguts". Talkin' about my B::sub_generation http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00021.html Small bug fixed in "Module::Build" passthrough Makefile.PL Ken Williams made a change to "Module::Build::Compat" to deal with the fact that the method call "CPAN::Shell->install()" doesn't appear to return anything useful. Yitzchak Scott-Thoennes wanted to know how one could reliably test to see whether the install did in fact succeed. Andreas Koenig recommended using the "$module->uptodate" method as a suitable work-around. Ken planned to use that approach soon. Look for a new version of Module::Build soon http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00031.html Tracking down leaks in "XS" "SV"s Tracking down leaking scalars in "XS" code is hard. Andy Armstrong has started to work on "Devel::LeakTrace", which uses a custom run loop, and was having trouble determining the relationship between where "SV"s are created, and where perl reports that they were created. Dave Mitchell pointed out that since 5.8.1 it has been possible to compile a perl executable with "-DDEBUG_LEAKING_SCALARS", which adds extra information to "SV"s, which in turn can be picked up by something like "Devel::Peek". On the other hand, Andy's approach has the benefit of not requiring a specially prepared perl. http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00066.html http://search.cpan.org/dist/Devel-LeakTrace/ Understanding "ext" and testing Adam Kennedy is working on the Vanilla Perl 5.8.8 distribution, and was having trouble with some of the tests in the "IO::" packages. He didn't understand how the tests could succeed at all, and wondered how long they had been failing. Steve Hay had a look, and saw that the behaviour is dependent on whether the "fork" emulation code is used or not. And that some of the tests to see whether "fork" is defined or not are quite bizarre. Nick Ing-Simmons came to the rescue, giving an explanation for why some of the things are the way they are. All in all, it's an area that Needs Work. http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00078.html Making "File::Find" Iterative The venerable "File::Find" module uses a callback scheme, something beginners to Perl may find a bit unusual. Shlomi Fish looked at extending it to provide an iterative interface similar to Shlomi's own "File::FTS" module. Randal Schwartz pointed to an article he had written that dealt with the same issue. Steve Peters noted that the main criterion for judging patches to "File::Find" is that they should incur no speed penalty, thus, for a patch to be accepted, it would need solid benchmarking. Nick Ing-Simmons explained that the question of speed was one of system calls. Make one unnecessary call, and the difference would show up for people scanning deep and wide directory trees. In the end, Shlomi decided to concentrate on "File::Find::Object", as it appeared to be closer to suiting his needs. David Nicol wondered whether "File::Find" was thread-safe, and Tels made a plug for his own "File::Walker" http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00047.html File::FTS http://search.cpan.org/dist/File-FTS/ File::Walker http://search.cpan.org/dist/File-Walker/ Will someone please fix "Devel::DProf"? Jarkko Hietaniemi made a plea for someone with too much spare time on their hands to please take a look at "Devel::DProf" and fix some its worst bugs. Andy Lester wanted some test cases. Jarkko countered with: $ perl -d:DProf -e 'sub foo { next } for (1) { foo }' $ perl -d:DProf -e 'use autouse qw(Pod::Usage pod2usage); pod2usage' Tels searched the RT queue: http://rt.perl.org/rt3/Ticket/Display.html?id=24058 The bug stops here http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00152.html "Module::Build" 0.27_08 added to the standard distribution A first attempt was made to add "Module::Build" to the core. This was perhaps the largest thread of the week. It appears the graft has succeeded, but more work is required. http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00167.html The continuing saga of "*a=$a=*b;${"a"}=*a;" Nicholas returned to the "*a=$a=*b;${"a"}=*a;"-perl-go-boom bug and couldn't see a easy way out, short of cheating and getting the optimiser to spot the sequence and thereby emit a different op-tree to make the problem go away. David Nicol wondered whether it was a case of worrying too much about a construct that doesn't come up in practice. chromatic thought that a tool simply should not crash on invalid input. http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00169.html Some more VMS goodness Peter Prymmer sent in a patch for some VMS-specific issues, which Craig Berry applied partially. Peter was lacking a bit of context to understand the reason why Craig did not apply the rest of it, and John E. Malmberg summarised the issue nicely for the vmsperl readership who don't follow p5p, and thus also saved the p5p summariser from having to do so: Peter's patch http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00170.html John's summary http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00186.html Matching dynamic Unicode properties Dan "Mr. Encode" Kogai related something he'd heard about non-existent Unicode properties (like "\p{IsBogus}") in pattern matches. Sometimes perl spits out an error... but not always. Yitzchak was quick to that the results depended on whether the match had failed or not before the scanner reached the location of "\p" property in the target string. Hugo van der Sanden wasn't even sure one could call it a bug (which Dan did not say either), but thought that perhaps the "utf8" module could offer something to check for this situation, since, as Sadahiro-san pointed out, it could be hard to check for user-defined properties sufficiently early in the general case. http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00189.html What Andy Lester did this week Removed a redundant o->op_type http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-02/msg01001.html http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00000.html Non-null optimizations for SvREFCNT_inc http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00032.html Initialising all of mgvtbl http://www.xray.mpe.mpg.de/maIling-lists/perl5-porters/2006-03/msg00033.html Patches of Interest "PERL_TRACK_MEMPOOL" cripples environment after "exit()" Marcus Holland-Moritz uses "blead" for his daily work, which leads to some interesting discoveries. He had wanted to run "gcov" coverage analysis of one of his XS modules, and became distracted by strange failures, probably best attributed to the environment variable code clean out that took place a few months ago. Evidently there are still demons lurking in that code. Marcus supplied a patch to nail one of them, applied by Rafael Garcia-Suarez. http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-02/msg00940.html Silence useless errors in "B::Lint" for "grep" Joshua ben Jore offered a patch to silent what he perceived to be a useless warning emitted by "B::Lint", concerning implicit matches with "grep". Since "grep{ /pattern/ }" is such a frequent idiom (and insofar as $_ is topicalised (the New way of referring to what used to be known as "local"ised) within the "grep" code block), it's a rather stupid warning. Rafael agreed with Joshua and applied the patch, saying that he'd be happy to accept similar patches for postfix "for" and "map". http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00002.html Long pathnames on VMS and sundry fixes John E. Malmberg sent in a patch for VMS builds and long pathname handling. Abe Timmerman reported that results looked good. The patch http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00122.html The smoke results http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00127.html Watching the smoke signals Smoke [5.9.4] 27358 FAIL(F) hp-ux 11.11/64 (PA-2.0/64/2 cpu) H.Merijn Brand poked around in "test.pl" to try and cope with change #27345 and problems with tainting. He made the appropriate changes to get things to work on HP-UX but wondered whether the patch would work on other systems like "VMS" or "Win32". Steve Hay found problems with the latter, and proposed an alternative. http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00041.html New and old bugs from RT Lexical variables in regexp "?{}" assertions (#38639) Richard Clayton identified a problem with lexicals defined within a "for" and being set within a "?{}" assertion of a pattern match. It gets set the first time through the loop, but not on subsequent iterations. The work-around is to declare the lexical in a scope further out from the "for" block. No takers. http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-02/msg00941.html "Configure -des" stops waiting for "<CR>" (#38642) Anton Koinov ran into problems configuring perl on Gentoo. Andy Dougherty was intrigued, and tried to guess what was going wrong, and suggested Anton run the following command sh -x ./Configure -S 2>&1 | tee Configure.out ... in order to capture all of the text generated during the run (as "-des" discards certain output deemed to be mostly harmless). No news back from Anton as of yet. http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-02/msg00944.html MULTICALL causes segfaults with very large return stacks (#38644) Tassilo von Parseval has been working with the new "MULTICALL" interface and noticed problems when the return stack is very large. This shows up as segfaults in XS code, such as "List::Util". http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-02/msg00958.html Long file names on Stratus VOS (#38645 and #38646) Paul Green uses Perl on Stratus VOS, whose file system limits file names to no more than 32 characters. This poses a problem when he tries to run the test suite of a module like "Pod::Simple", which contains a test name search_25_glob_squaa_coloncolon_kleene.t. At 40 characters long, that's more than Stratus can bear. Similarly, there's another file, _white_with_navy_blue_on_black.css that is also a bit too long. Nicholas Clark wondered whether 32 was some sort of POSIX minimum, and recalled that some tests had already been renamed to deal with characters in file names that VMS had trouble processing. Joshua Juran noted that traditional Mac-based platforms ("MacOS" and "Lamp") are limited to 31 characters. (MacOS X does not have this limitation). (The Summariser wishes to point out the existence of Sébastien Aperghis-Tramoni's "Test::Portablility::Files" to module authors). One file http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-02/msg01003.html And then another http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-02/msg01004.html No more excuses http://search.cpan.org/dist/Test-Portability-Files/ 64-bit (non-)builds on Solaris 8 (#38664) James Overly had problems building a 64-bit perl on Solaris 8. http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00058.html Debugger Loses Names for Anonymous Subroutines (#38673) chromatic showed how the trick of assigning to the "__ANON__" typeglob to name an anonymous subroutine doesn't work in the debugger. http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00147.html "O::Deparse" not working as expected (#38684) "harleypig" was having trouble with "split". I tried to pay attention, but Stephen McCamant supplied a patch to fix the behaviour (which was apparently broken), which was applied by Rafael. The end. http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00202.html Perl5 Bug Summary 1548 open items http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00193.html in all their glory http://rt.perl.org/rt3/NoAuth/perl5/Overview.html New Core Modules * "CPAN" version 1.87 uploaded by Andreas Koenig. http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-02/msg00949.html * "Archive::Tar" version 1.29 uploaded by Jos I. Boumans. http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00074.html In Brief Seung-Ho Han wanted to know how make sense of what "B::Xref::compile" produces. Joshua ben Jore explained what was going on, and that more clues can be found by studying O.pm. http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-02/msg00952.html Jerry Hedden started to extract threads.pm from the core in order to make it available on CPAN. This would permit enhancements to be made to the threads implementation faster than the current "blead" to "maint" to "release" cycle. http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-02/msg01013.html Jim Cromie continued to refine his self-described hare-brained "op-next"/"op-sibling"optimisation scheme, defending it against the critics, but ran into trouble somewhere deep down in the guts. In doing so, he came up with a new presentation scheme for "B::Concise". http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00001.html Anton Berezin caught and eliminated an extraneous "#endif" in fakesdio.h. http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00010.html Jarkko Hietaniemi discovered that "-d:Foo=bar" no longer works in the current Perl release (bug report #38657). Rafael traced the problem down to the fact that "\0" (NUL) was no longer allowed in environment variables, and fixed things up as change #27359. Jarkko also supplied another patch for the same thing, which Rafael also applied. http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00025.html http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00052.html Getting back to last week's thread on unwanted auto-vivification with "foreach", David Nicol showed a snippet of code that offers a way of working around the problem, and wondered whether the documentation should record it somewhere. Graham Barr noted that using "reverse" also suppresses the auto-vivification behaviour. And that if you didn't want a slice reversed, you needed to "reverse reverse". There's at least one way to do it http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00044.html Jarkko added a test to "Data::Dumper"'s test suite to ensure that the bug #38612 that was fixed in 5.8.7 never returns. http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00049.html H.Merijn added "Configure" support for the GCC compiler options "__builtin_expect" and "__builtin_choose_expr". http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00063.html Paul Marquess delivered a patch for "Compress::Zlib", following on from his recent work to add compression plugins. http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00064.html Joshua start to have a look at the new smart match operator "~~" and found a discrepancy between its behaviour and that of Pugs/Perl6. http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00081.html Abe Timmerman patched Porting/checkcfgvar.pl to pick up configure.com and plunged unwittingly into the wonderful and frightening world of VMS symbols. John E. Malmberg and Craig A. Berry were sent in to rescue him. http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00090.html Abe then thought it would be a good idea to see what happens when one builds a threaded perl on VMS. In the process he uncovered a couple of problems that John and Craig sorted out. http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00139.html Dave Rolsky wanted to know if nested closures still leak memory. Dave Mitchell thought that no closure leakage bugs remained in "blead", but pointed out that not all of the new code had made it back into "maint". Until proven otherwise http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00103.html Randy W. Sims want to install an older perl on his Ubuntu linux distribution, but the install began to create an infinitely deep directory tree. On and on and on http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00148.html Linda W gave a report on the effects of configuration options on the resulting perl binary. http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00161.html Perl can no longer be compiled with a K&R compiler. http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00160.html David Nicol posted his thought on what he would like to see in the way of plug-in optimisers. A optimistic optimiser could optimise a section of code, and then, if some assumption failed to hold true, it could de-optimise the code back to the initial state. I think some proof-of-concept code will be required. http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-03/msg00174.html About this summary This summary was written by David Landgren. Information concerning bugs referenced in this summary (as #nnnnn) may be viewed at http://rt.perl.org/rt3/Ticket/Display.html?id=nnnnn Information concerning patches to "maint" or "blead" referenced in this summary (as #nnnnn) may be viewed at http://public.activestate.com/cgi-bin/perlbrowse?patch=nnnnn If you want a bookmarklet approach to viewing bugs and change reports, there are a couple of bookmarklets that you might find useful on my page of Perl stuff: http://www.landgren.net/perl/ Weekly summaries are published on http://use.perl.org/ and posted on a mailing list, (subscription: [EMAIL PROTECTED]). The archive is at http://dev.perl.org/perl5/list-summaries/. Corrections and comments are welcome. If you found this summary useful or enjoyable, please consider contributing to the Perl Foundation to help support the development of Perl. -- "It's overkill of course, but you can never have too much overkill."