This Week on perl5-porters - 31 October-6 November 2005

  This week sees consolidation on several fronts: mathoms, ops, env
  handling, futimes, sort... plus the usual assortment of bug fixes and
  enhancements.

Feedback from last week's summary

  Steve Peters remembered the history of mathoms.c in p5p dated back to
  2001 and not only June/July this year, when it came to life again.
  Also, the Configure option which was anticipated were not ready yet at
  the summary time, but it is now.

    Steve Peters patches the summary
    http://xrl.us/ib67

  Concerning Cygwin, "unlink", Win32, Yitzchak Scott-Thoennes commented
  that he was referring to the Cygwin DLL source code and not perl when
  illustrating how "unlink" in Cygwin mapped to the Windows API.

    Yitzchak Scott-Thoennes makes things clear
    http://xrl.us/ib68

More mathoms.c fallout

  The recent introduction of mathoms.c produced fallout in various
  places this week

    Gisle implements the Configure option
    http://xrl.us/ib69

    and shrinks the perl binary by 0.75%
    http://xrl.us/ib7a

    Getting C<do_exec> on Win32 back in order
    http://xrl.us/ib7b

    Getting C<perl.h> on VMS back in order
    http://xrl.us/ib7c

More on "ExtUtils::Constant"

  chromatic raised an eyebrow at Sébastien Aperghis-Tramoni's use of
  indirect object notation (current best practices these days dictating
  that one should say "Object->method" rather than "method Object".
  Nicholas Clark discovered that the patch causes a bad failure in
  "blead" due to dependency orderings, because somehow in "blead",
  "FileHandle" now requires "IO::File" which is not yet available during
  the build. Nicholas fixed it up by with some conditional "require"ing
  in patch #25927.

    The patch
    http://xrl.us/ib7d

    The patch to the patch
    http://xrl.us/ib7e

Bring out yer dead (ops)

  After running perl under "gcov", Nicholas noticed that about twenty
  ops were never hit by the test suite. It could be expected that an op
  like "pp_dump" (which exists solely to make perl dump core) would not
  be covered by the test suite, but maybe some ops should (which Dave
  Mitchell said was the case for "pp_regcmaybe" and provided a snippet
  to prove it).

  Maybe some are obsolete and could thus be chainsawed away. Rafael
  Garcia-Suarez pointed out that a certain number of ops are required
  during compilation, but are optimised away afterwards, and thus it
  would be a non-trivial effort to truly get rid of them. Although he
  thought that "pp_threadsv" and "pp_setstate" could probably be let go.

  Rafael then noted that he had written some XS code in the past that
  called some "pp_*" routines directly, and mentioned that he had
  published a module on CPAN that lets you change the interpreter
  runloop on the fly.

  This led Nicholas to think about the possibility of making the runloop
  deal with the handling of signals differently. That is, getting rid of
  the current "PERL_ASYNC_CHECK()" ("safe signals") call in the runloop,
  and merely switching to a runloop that knows how to deal with a
  signal, when a signal is encountered.

    Reported in ticket #37573
    http://xrl.us/ib7f

    Change your runloop
    http://search.cpan.org/dist/Runops-Switch/lib/Runops/Switch.pm

    Nick's second idea
    http://xrl.us/ib7g

Andy's consting

  Andy Lester consted more stuff, spotted a couple of chances to
  simplify code, and dedicated the patch to Etta James:

    The patch
    http://xrl.us/ib7h

    Etta James
    http://www.etta-james.com/

  ... and dealt with perlio.c seperately because it's so hairy:

    http://xrl.us/ib7i

  Andy also posted the switches he's using for building perl under GCC
  4.1.0 snapshots (using as many switches as possible to seek out
  doubtful code constructs).

    Bondage and discipline
    http://xrl.us/ib7j

  and also found a lovely trailing semi-colon-on-on-if bug in
  "pp_ftrowned":

    http://xrl.us/ib7k

  and yet more consting

    http://xrl.us/ib7m

  and cleaning of the x2p directory

    http://xrl.us/ib7n

DB_File patched to deal with Berkeley DB 4.4

  Paul Marquess supplied a patch to get DB_File to run with the upcoming
  4.4 release of Berkeley DB. Steve Peters applied the patch and
  Yitzchak wondered whether it was important enough to make sure it made
  its way into 5.8.8.

    http://xrl.us/ib7o

Let the good futimes roll

  Gisle Aas continued on the thread last week about using "futimes" on
  platforms where it is available, noting that the MacOS X manpage says
  that "utime" is obsolete and "utimes" should be used, but the Posix
  manpage says that "utimes" is legacy, and "utime" should be used for
  maximum portability. Sigh. Steve Peters and Gisle discussed the
  problem of getting Configure to probe for this.

  Also, Solaris 10 has a function called "futimesat", which does
  everything, and more besides. (In case you were wondering, these
  functions deal with setting the access and modification times for
  files).

    utime? utimes?
    http://xrl.us/ib7p

    Abe Timmerman patches configure.com
    http://xrl.us/ib7q

sort/multicall patch in blead

  Robin Houston's sort/multicall patch went into blead. Rafael noticed a
  few puffs of smoke escape from the lab, and saw that one functionality
  that the patch broke was the ability to empty the array *while you
  sort it* and still retrieve the results afterwards. Since no-one was
  really sure why anyone would want to do a thing like that, the test
  was quietly dropped.

  So don't try the following at home, because it's not going to work any
  more:

    @a = (1..10);
    @b = sort { @a=(); ($a+1)<=>($b+1) } @a;

  Nicholas was worried that the test was a guard to check for core
  dumps, but perl wasn't dumping core, just sorting an array of
  undefined elements (which seems to be the right behaviour under the
  circumstances).

  Paul Marquess found that "DB_File" revealed a couple of problems in
  the patch, and these problems were fixed. Jim Cromie pitched in and
  fixed a couple of other test errors.

  Dave Mitchell had a couple of minor queries about the code but
  basically liked it. The conversation went on between Robin and Dave
  for a while. Robin summed it up best:

    It's the usual perl internals story really: everything
    depends on everything else in mysterious and undocumented
    ways, and it's hard to make apparently innocent changes
    without subtle breakage...

    Starting from last week
    http://xrl.us/ib7r

    The patch applied
    http://xrl.us/ib7s

    Dave weighs in
    http://xrl.us/ib7t

Compiling 5.8.7 with Visual Studio 2005

  Joel Reed wrote in to say that he was having some difficulty in
  compiling 5.8.7 with Microsoft's latest compiler, especially in the
  area of "perlio" and related some very wacky symptoms. He also tried
  5.9.2, and that didn't work, either. And unfortunately for Joel, he
  was Warnocked.

    http://xrl.us/ib7u

The prototype of "Perl_magic_clear_all_env"

  Alan Burlison, in his quest to make the environment code a little less
  icky, wanted to change the signature of the "Perl_magic_clear_all_env"
  function. This would prevent memory leaks when one lets perl manage
  the environment.

  The main problem is whether or not this would break binary
  compatibility. Steve Peters used the CPAN source code search and found
  that no-one outside of core is using it, and thought that it is
  unlikely that any other code does so, but the possibility cannot be
  ruled out.

  Alan was worried about platforms using different calling conventions
  and decided that the best way forward would be to put the new smarts
  in a new routine, and thereby not allow the possibility of breaking
  binary compatibility.

  Alan subsequently posted a patch to make use perl use "clearenv" on
  platforms where it makes sense, and called for feedback on other
  platforms such as MacOS, Symbian, VMS and Win32.

    The question
    http://xrl.us/ib7v

    All hail gonzui
    http://cpansearch.bulknews.net/

    using clearenv
    http://xrl.us/ib7w

A surprising segfault

  Robin Houston was rather bemused by:

    % perl -e 'map print(reverse), ("")x68'
    Segmentation fault

  and wondered why it was happening. Dave Mitchell promptly described
  the problem and fixed it. Sadahiro Tomoyuki found that many other
  "pp_*" functions exhibit similar behaviour and provided a patch to fix
  them too. Tels wanted tests.

    segfault
    http://xrl.us/ib7x

    How to kill perl
    http://www.perlmonks.org/index.pl?node_id=505817

See perl say()

  Steve Peters proposed a patch to bring Perl 6's "say()" to Perl 5.
  (Which is roughly "print" with a "\n" tacked on). Robin Houston
  pointed to a prior thread (and patch) on the issue, that was not well
  received at the time. The main problem is one of backwards
  compatibility: how do you deal with a program that has defined a
  subroutine named "say"?

  (The summariser recalls a thread on Perlmonks where someone suggested
  using "-l" on the command line to get equivalent "say" functionality
  with "print" and use "printf" (not necessarily with "%" args) to get
  non-newline print behaviour).

    This time
    http://xrl.us/ib7y

    Last time around
    http://xrl.us/ib7z

New Core Module Releases

  Andreas J. Koenig brought "CPAN.pm" up to version 1.76_60. (The _60
  implies a beta version). Some of the new features include: plays
  nicely with version.pm, support for "sudo", new commands, better error
  messages and better handling of configuration variables.

Perl 5 Bug Summary

  1520 open items, six items less that 2 weeks old have not been
  responded to.

In brief

  Jarkko added UIQ support to the Symbian port

    http://xrl.us/ib72

  Steven Schubiger cleared up the no-whitespace-before-semicolon
  problems for pod files that needed it.

    http://xrl.us/ib73

  Jutta posted a bug report dealing with "sysread" in UTF-8 mode. When
  Steve Peters opined that a little bit of code might help understand
  the problem more easily, Jutta replied with a TCP server written in C
  and a client written in Perl. What more could you wish for?

    http://xrl.us/ib74

  Alan Burlison was still wondering about the "malloc_wrap" compiler
  warnings being produced. After discussing the issue with Nicholas, he
  decided to add an explanation about the compiler warnings to the
  README.solaris file.

    http://xrl.us/ib75

  Dan Dascalescu posted a bug report concerning "File::Glob", escaped
  metacharacters and spaces in filenames. Steven Schubiger showed a
  couple of ways to get around the problem.

    http://xrl.us/ib76

  Andreas J. Koenig took a stab at fixing bug #19049 (Incorrect $` after
  replacement). Rafael applied it, and then backed it out after not
  being able to solve the remaining problems himself. If someone else
  wants to have a go...

    http://xrl.us/ib77

  Robin Houston noted that perlcall.pod documents problems that were
  fixed way back in version 5.002, and fired up the chainsaw.

    http://xrl.us/ib78

  Anno Siegel posted an interesting bug:

    my $str = 'aa';
    $str &= 'a';
    $str =~ /a+$/ or die;

  This dies, and Anno says it shouldn't. No response for the moment.

    http://xrl.us/ib79

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

  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.



Reply via email to