Perl 6 Summary for the week ending 20030703 "Ooh look, it's another Perl 6 summary. Doesn't that man ever take a holiday?" "I think he took one last month." "Is it in Esperanto this week?" "I don't think so." "Does Leon Brocard get a mention?" "It certainly looks that way." "Does it start with the internals list again?" "I think it does, in fact, here it comes now."
Approaching Python Discussions (and coding) of the Parrot implementation of Python continued this week. Michal Wallace is working on taking a preexisting (but incomplete, it's a proof of concept only) python parse tree -> parrot code generator and rejigging it to generate code for IMCC. Assuming the initial rejig is doable, Michal surmises that getting a complete python compiler will be 'just' a matter of fleshing out the rest of the visitor methods, 'and then dealing with the C-stuff.' Actually, the main strand of this discussion dealt with ways of extending IMCC to help optimize the translation of stack based code to code that uses registers more efficiently (register unspilling as Benjamin Goldberg called it), which should help with any bytecode translator based efforts. http://xrl.us/crudf http://xrl.us/crukq Semantics of clone for PIO-objects Jürgen Bömmels' work on the Parrot IO system continues to find edge cases in Parrot's memory management subsystem. As initially written, a clone call adds a reference to a ParrotIO object, but that object is neither garbage collected nor refcounted, and it gets destroyed when its first reference is destroyed. The problem can be solved by allocating a new ParrotIO in the clone call, but Jürgen had some questions about how to handle various things like what to do with buffering or position pointers. Jos Visser offered a suggestion involving indirection and reference counting which met with (at least) Melvin Smith's approval. http://xrl.us/crusx Making 'make' less verbose Leo Tötsch checked in a patch to make make's output rather less verbose. After the patch, the make process only echos the name of the file being compiled, and doesn't spam your terminal with the entire compiler commandline (the compiler warnings do that). Some people liked this. Others didn't. http://xrl.us/cruz5 Don't trace system areas in sweep ops One of the things we discussed at the Parrot BOF was how to solve the 'bogus objects' problem when doing timely destruction sweeps (The 'bogus objects' problem is when the stack walk code detects chimerical objects through holes in the C stack (hmm... if anyone has a good drawing of this?)). After much discussion we came to the conclusion that the trick was to only walk the system stack during DOD (Dead Object Detection) runs that got triggered via resource starvation. This works because "There is nothing unanchored and alive beyond the runloop's stack". Brent Dax was impressed, but then, he wasn't at the BOF so he doesn't know how long it took us to get to the answer. http://xrl.us/cru73 User defined events Klaas-Jan Stol wondered if there would be some way of generating and posting user defined events. Uri Guttman thought that there probably would be. http://xrl.us/crviz PHP/Parrot The language implementation insanity continues! Stephen Thorne announced that he's working on implementing a PHP parser and is seriously considering targetting Parrot. He asked for pointers to good docs on how to go about doing so. He worried a little about bootstrapping as well. Luke Palmer and Simon Glover were forthcoming with lots of useful answers and pointers. http://xrl.us/crvsa Why Parrot uses Continuation Passing Style In a delayed response to a question from Klaas-Jan Stol, Dan has posted a long message on the reasons for choosing Continuation Passing Style as Parrot's calling convention. It's definitely worth the read if you're at all interested in the reasoning behind Parrot (and the reason that my copy of *Perl 6 Essentials* has a signed correction from Dan). http://xrl.us/crv24 IMCC supports the Parrot Calling Conventions Leo announced that IMCC's brand of assembler, PIR (I can't remember what it stands for, Parrot Intermediate Representation perhaps). Of course, there are things it doesn't quite do yet (tail call detection, only preserving 'necessary' registers...) and it's somewhat lacking on the test front, but it's a start. Yay Leo! http://xrl.us/crv75 Another task for the interested: Coverage Dan threw out another 'task for the interested' this week. At present we don't have a complete set of coverage tests for the parrot opcodes, nor do we even know why opcodes do have coverage. Volunteers to fix this state of affairs (start with a coverage report being generated as part of the "make test" run) would be very welcome. It turns out that Leo already has an "unportable, ugly, slightly tested" script generating a coverage report of sorts which he posted. Josh Wilmes also has a coverage testing tool generating reports on the web, but he'd turned it off following some problems under testing. http://xrl.us/crwdy http://xrl.us/crwob -- Josh's reports Pirate (py...rrot) Will the terrible jokes never stop? Michal Wallace reported to the list on his attempts to retool amk's parrot-gen.py to generate code for IMCC. It sounds like he's making good progress, but his choice of codename -- Pirate, from py...rrot -- had at least one summarizer groaning. Later Michal asked the list about the best way of generating subroutines and asked for some pointers about how best to arrange the generated code. He also let slip that Pirate could handle Lists, strings, and ints; assignments; control structures; maths; boolean logic; and comparisons... Leo came up with a suggestion about code layout for Michal and spoke for everyone (I think) when he added: "Wow." Luke Palmer offered a few performance tuning tips (the parrot of Python translation is currently running 3 times slower than python on euclid, but I'm sure we'll get that fixed soon enough. http://xrl.us/crwwo http://xrl.us/crw4n JVM->PIR translator Just as we were all giving Michal some good Wow, Joseph Ryan announced that he had a partially complete JVM->PIR translator done, though it still had a few issues. http://xrl.us/crxbc http://xrl.us/crxhi Dynamic PMC Classes Leo announced that he's started working on dynamic PMC classes. The idea is that PMCs could be loaded on demand, in a similar fashion (though hopefully with a nicer interface) to Perl 5's DynaLoader tricks. He already has something working, and asked for comments. Dan responded by outlining his thoughts on the interfaces and requirements for dynamic PMC loading, which weren't quite the same as what Leo had implemented, but they don't call it software for nothing. Christian Renz wondered if there were any plans to allow PMCs to be implemented in Parrot assembly. Dan confirmed that there were. http://xrl.us/crxmk Question about "interpreter == NULL" Jürgen Bömmels wondered which functions allowed the caller to pass in a NULL pointer in place of the interpreter. Some functions allow this, others fall in big segfaulty heaps. He and Leo thrashed out the details of what is and isn't allowed, hopefully this will make it into documentation at some point. http://xrl.us/crxrp Adding "yield" semantics to IMCC Kenneth A Graves has been experimenting with the ".pcc_*" directives for implementing function calls, and wants to add coroutine support by implementing ".pcc_begin_yield" and ".pcc_end_yield" which would be analogous to the current ".pcc_*_return" directives. He supplied a patch implementing what he was after. Leo liked the patch and applied it. http://xrl.us/crxxi IMCC objects speed, ".include", file-scoped vars et cetera Now that Parrot nearly has objects, Jerome Quelin has started work on a new version of Befunge in IMCC. This meant he had a pile of questions about speed, file scoping of variables, problems with line numbering within included files, and fragility in the absence of newline termination. Melvin Smith opined that the time had come to start putting together a nice web based set of docs for IMCC, and volunteered to start work on it himself as soon as he'd caught up with the current state of the IMCC art. Leo Tötsch meanwhile answered most of Jerome's questions. http://xrl.us/crx5m IMCC's "call" vs first class functions If you were still not sure of the virtues of Continuation Passing Style in Parrot, then Michal Wallace's problems with making first class function objects in Pirate might help convince you of their virtue. As far as I can see, just switching to a CPS style should mean that anonymous functions in Pirate become almost automatic. (I could be wrong of course) http://xrl.us/crycc David Adler Scares Himself For reasons best known only to himself Dave Adler has implemented an hq9+ interpreter in pasm. Quite what an hq9+ interpreter is was left as an exercise for the interested reader. Having just now done the Google search for the language, I think it's best if I leave it to you to do the search yourself, but quite frankly, I wouldn't bother. http://xrl.us/cryj5 Upcoming backwards incompatible changes to IMCC Leo Tötsch announced some changes to IMCC which will mean it is no longer backwards compatible. What's changing is that from now, all code outside of compilation units will be ignored, which means that nested subroutines will no longer be supported. He will also be adding a new ".globalconst" directive for declaring file scoped constants. http://xrl.us/cry3r Embedding Parrot Jeff Horwitz is interested in embedding parrot in other programs, and wanted to know if there was any prior art, or even a road map. So far there's been no response. http://xrl.us/crzbf Meanwhile, in perl6-language Things are starting to warm up a little in perl6-language following the publication of Exegesis 6 (take a look, you'll find it at http://xrl.us/crznl, there's much good stuff in there; Perl 6 is starting to look like a real language I tell you). The volume's not got up to post-Apocalypse 6 levels yet, but it's early days yet. Perl 6's "for()" signature John Siracusa referred back to an earlier summary where I had wondered if either of two "for" implementations had got the signature quite right. Luke Palmer (perpetrator of one of the for implementations) thought that it wasn't quite possible to come up with an accurate signature for "for" (or at least, not one that could tell the compiler enough to detect errors at compile time.) because you essentially needed a slurpy list followed by a block, but slurpy lists have to be the last parameter in the signature. John countered by quoting from Exegesis 6 "An important goal of Perl 6 is to make the language powerful enough to implement all its own built-ins", which doesn't exactly contradict what Luke said, as there's always the possibility of implementing something "for"-like using a macro, but that doesn't feel too comfortable. Rod Adams proposed "non-greedy slurpy arrays" which would be analogous to non-greedy regex matches and proposed "*?@" as the sigil combination for such a parameter. (Perl? Line noise? Never!) Damian Conway tweaked Simon Cozens' "Soylen^WPerl 6 is Ruby!" detector when he mentioned that Larry was considering adding a special case for allowing a single &block parameter after a slurpy parameter, but that both Larry and Damian weren't entirely happy with the idea. Larry offered words of wisdom. As usual. http://xrl.us/crzyb http://xrl.us/crz9j -- the earlier summary http://xrl.us/cr2hc -- Larry dispenses wisdom Exegesis 6: Assume nothing Referring to Exegesis 6, Trey Harris wondered how one could curry a subroutine to always use the default value for the 'assumed' parameter. He wanted to be able to created a curried function in such a way that, if the original function's default value changed, the curried function would reflect that. I don't think this thread has been resolved to anyone's satisfaction yet, and I can't quite tell where it's headed. My gut feeling is that this is a sufficiently rare requirement that Damian's solution of not using ".assuming" at all and just writing a simple wrapper function by hand may be the way forward. http://xrl.us/cr2pv Mandating name-only parameters Mark J. Reed wondered if the new parameter declaration syntax meant it was possible to declare a mandatory name-only parameter. Damian thinks it will probably be doable, but only by using traits rather than the single character prefixes. http://xrl.us/cr2yl Small Junctions Exegesis 6 describes a junction as "a single scalar value that can act like two or more values at once". Dave Whipp wondered how junctions with 0 or 1 members would behave. As Dave said, the case of a single member junction is relatively easily to understand, but he's unsure as to the semantics for a 0 member junction. Luke Palmer gave a good answer, and pointed at Damian's message about "Perl 6 and Set Theory" for more detail. http://xrl.us/cr28j http://xrl.us/cr3ep Macros and "is parsed" Abhijit A Mahabal asked for some clarification about the workings of macros, in particular how/when macro arguments were parsed. The answer from Larry appears to be that macros get a default "parsed" trait, which can be overridden by "is parsed" when the macro is declared, so macro arguments are parsed by the macro's "parsed" trait. http://xrl.us/cr3lx Macro arguments themselves Luke Palmer wondered what macros do about being passed variables, with a supplementary question about recursive macros. Larry answered that macros dealt with their arguments in the way that Luke hoped (it'd be a disaster if the didn't, frankly), but that to get a recursive macro you would probably have to write a helper function. http://xrl.us/cr3q2 Another macro question Abhijit A. Mahabal wondered what macro foo() { return { my $x = 7 } } foo; print $x; would be equivalent to. According to Larry, the answer is probably: do { my $x = 7 } print $x; Which would throw an error under use strict. It seems to me that the way to get expanded code that looks like: my $x = 7; print $x; would be to declare "foo" as: macro foo() { return 'my $x = 7' } http://xrl.us/cr3xe "grep EXPR, LIST" John Williams wondered if the Perl 5ish "grep EXPR, LIST" would still work in Perl 6. Larry thinks not. I think it should be possible to declare an appropriate macro version of grep, but the margins of this summary are too narrow to contain my solution. http://xrl.us/cr35m Acknowledgements, Announcements and Apologies Thanks to Damian for Exegesis 6, Perl 6 may be slow in coming, but I like it more with each revelation. Ooh look, another plug for http://xrl.us/mt4. As ever, if you've appreciated this summary, please consider one or more of the following options: * Send money to the Perl Foundation at http://donate.perl-foundation.org/ and help support the ongoing development of Perl. * Get involved in the Perl 6 process. The mailing lists are open to all. http://dev.perl.org/perl6/ and http://www.parrotcode.org/ are good starting points with links to the appropriate mailing lists. * Send feedback, flames, money, requests for consultancy, photographic and writing commissions, or suggestions for something else to ask for in this bit to [EMAIL PROTECTED]