The Perl 6 Summary for the week ending 2004-07-18
Following last week's bizarrely dated summary (I misplaced a day) we're
back with the correct week ending date, but I'm ashamed to admit that
I've slipped to writing on a Tuesday again. My head hangs in shame and I
am filled with the direst remorse.
It will probably happen again though; life's like that.
Pie-thon!
Anyone would think that the possibility of not even being able to run
the Piethon benchmark (let alone getting a pie in the face for running
it too slowly) weighs heavily on Dan.
The bulk of the week's traffic related to getting to the point where we
can at least run all the tests.
Python::Bytecode, the module that parses, well, python bytecode, shot up
in version numbers; I think it reached 2.7 by the end of the week.
Dan released a Piethon translator, a tool that uses Python::Bytecode
translate python to parrot. So has Leo. Dan's is on his website (see the
link below, you'll find Leo's in languages/python/pie-thon.pl).
http://xrl.us/chh9 -- Parrot runs a python lambda
http://xrl.us/chia -- Notes on pie-thon.pl
http://xrl.us/chib -- Namespaces for builtins
http://xrl.us/chic -- Dan's translator
Semi-stack code
In a quest for speed when emulating python's stack manipulation ops, Dan
outlined a plan for manipulating a pseudo stack using some of Parrot's
PMC register (18-29, with P31 used for overflow). Leo wasn't convinced
it was needed.
http://xrl.us/chid
"string_to_num" precision
Leo's got some problems with the precision of the "string_to_num"
function found in string.c. He doctored things to use "atof", but Dan's
not so keen on that idea because "atof" doesn't have standard behaviour
across platforms. He recommended grabbing Perl 5's string to num code
(which he thought we'd already done). Nicholas Clark wasn't convinced
that this was a good idea; he reckoned that Perl 5's code wasn't good
enough. I think Nicholas convinced Dan that "atof" is actually the right
thing to use (with a little preprocessing to deal with C99's "atof"
being incompatible with C89's -- Parrot expects C89 behaviour).
http://xrl.us/chie
GMP Licensing
Armin Obersteiner reported his investigations into the licensing
requirements of the GMP maths library. It appears that the FSF's 'GPL
Compliance Engineer' reckons we won't need to include the GMP's source
code with binary distributions. We just have to make it available from
the same source as the distribution. Which is handy.
http://xrl.us/chif
Parrot configuration -- a small perl task
Leo asked for volunteers to fix up Configure.pl in order to make it less
dependent on the host Perl's configuration. Brent Royal-Gordon provided
a teeny-tiny patch that's actually shorter than Leo's description of the
problem.
http://xrl.us/chig
Meanwhile, in perl6-language
Scalar subscripting
Remember Guatam Gopalakrishnan's question about subscripting scalars?
Discussion continued. One Piers Cawley (who he?) suggested that it
should be possible to specify a "postcircumfix:[] is rw" method in the
String class to make string subscripting behave in a helpful fashion. He
also suggested pulling this (and other similar behaviours) out into a
Sequence trait. Juerd thought the proposed method name was a little
verbose compared to Ruby's syntax for doing the same thing and showed
off some rather pretty Ruby metaphors.
Another subthread discussed interpolation in strings. Larry's changed
his mind so that "$file.ext" is now interpreted as "$object.method". You
need to do "${file}.ext" or ""$( $file ).ext"". Or maybe "$�file�.ext"
by analogy with "%foo�bar�". James Mastros pointed out that "." is
rather ambiguous in a literal string; sometimes a full stop is just a
full stop.
http://xrl.us/chih
Pushing lazy lists
This thread continues to resemble the lists it is nominally discussing:
Infinitely long and possibly endless.
http://xrl.us/chii
Perl 6 and Parrot Essentials, 2nd Edition
Leo pointed us at an O'Reilly press release announcing that the second
edition of *Perl 6 and Parrot Essentials* is available. Huzzah! Let joy
be unconfined.
http://xrl.us/chij
Rules to match abbreviations
Hans Ginzel wondered wondered about adding something to the rules system
to easily match specified abbreviations of a string. Luke Palmer came up
with a (pretty ugly) solution which he then wrapped very neatly in a
rule.
http://xrl.us/chik
Enhancing "open"
There's a good deal of mileage to be had talking about how to improve
the "open" function it seems.
Larry continues to come up with new and interesting ways of designing
the language in such a way that almost every decision about how to do
something can be deferred. Speaking as someone who wishes he could just
write "Application.new.run" and then debug his way to working code, I'm
all for this kind of late binding.
It's also amazing how much use Larry's getting out of his colon. (The
character, obviously).
http://xrl.us/chim
Cartesian products and iterations
Michele Dondi wondered whether Perl 6 will support Cartesian products
between lists. Short answer: "Yes". It's probably called "outer".
http://xrl.us/chin
Do we really need filehandles?
Dave Whipp thought the unthinkable (but in a good way) and wondered if
we actually *need* user visible filehandles give the tools we have for
slicing and dicing strings, manipulating lazy data structures, etc. He
proposed being able to write:
my $text is TextFile("/tmp/foo.txt");
for $text.lines -> {
...
}
Which is rather neat isn't it? Personally I'm not sure we can get rid of
filehandles, but I do like the idea of a library that implements
something like this. Alex Shitov pointed out that there would still be a
need for methods like "$text.flush()" or "$text.close()".
http://xrl.us/chio
Announcements, Apologies, Acknowledgements
Okay, so the interview was on Tuesday 13th of July. It went well; I'm
going to be a maths teacher.
If you find these summaries useful or enjoyable, please consider
contributing to the Perl Foundation to help support the development of
Perl. You might also like to send me feedback at
mailto:[EMAIL PROTECTED]
http://donate.perl-foundation.org/ -- The Perl Foundation
http://dev.perl.org/perl6/ -- Perl 6 Development site