NAME
Parrot FAQ - Frequently Asked Questions
VERSION
- Revision 0.3 - 13 March 2002
-
Translated to POD and added "Why aren't we using external tool or library X?"
- Revision 0.2 - 03 December 2001
-
Added the "Parrot and Perl" section and "Why Re-implement Perl". Incorporated Dan's Q&A items.
- Revision 0.1 - 03 December 2001
-
Adopted from Simon Cozens's article, "Parrot: A Cross-Language Virtual Machine Architecture".
GENERAL QUESTIONS
What is Parrot?
Parrot is the new interpreter being designed from scratch to support the upcoming Perl6 language. It is being designed as a standalone virtual machine that can be used to execute bytecode compiled dynamic languages such as Perl6, but also Perl5. Ideally, Parrot can be used to support other dynamic, bytecode-compiled languages such as Python, Ruby and Tcl.
Why "Parrot"?
The name "Parrot" relates to Simon Cozens's April Fool's Joke where Larry Wall and Guido van Rossum announced the merger of the Perl and Python languages.
When not orchestrating elaborate pranks such as this, Simon spends a modicum of time as Parrot's lead developer.
Is Parrot the same as Perl 6?
No. Parrot is an implementation that is expected to be used to execute Perl6 programs. The Perl6 language definition is currently (December 2001) being crafted by Larry Wall. While the true nature of Perl6 is still unknown, it will be substantially similar to Perl as we know it today, and will need a runtime system. For more information on the nascent Perl6 language definition, check out Larry's apocolypses.
Can I use Parrot today?
Well, almost. :^)
Parrot is in the early phases of its implementation. The primary way to use Parrot is to write Parrot assembly code, described in PDD6.
You can also create dynamic content within Apache using Ask Bjorn Hansen's mod_parrot module. You are strongly advised that mod_parrot is a toy, and should not be used with any production code.
Why should I program in Parrot Assembly language?
Lots of reasons, actually. :^)
All the cool kids are doing it.
It's a neat hack.
You get all the pleasure of programming in assembly language without any of the requisite system crashes.
Seriously, though, programming in Parrot assembly language is an interesting challenge. It's also one of the best ways to write test cases for Parrot.
When can I expect to use Parrot with a real programming language?
It depends on what you mean by real. :^)
Leon Brocard has released a proof-of-concept Java bytecode to Parrot bytecode compiler.
Gregor Purdy is working on a little language called Jako that targets Parrot bytecode directly. (Available with the Parrot distribution.)
Dan Sugalski and Jeff Goff have started work on compiling Scheme down to Parrot bytecode. (Available with the Parrot distribution.)
What language is Parrot written in?
C.
For the love of God, man, why?!?!?!?
Because it's the best we've got.
That's sad.
So true. Regardless, C's available pretty much everywhere. Perl 5's in C, so we can potentially build any place Perl 5 builds.
Why not write it in insert favorite language here?
Because of one of:
Not available everywhere.
Limited talent pool for core programmers.
Not fast enough.
Why aren't you using external tool or library X?
The most common issues are:
License compatibility.
Parrot has an odd license. Most licenses--even open-source ones--aren't compatible with Parrot. Anything licensed under Perl 5's terms is okay, and some things licensed under BSD or X licenses may be. GPL licenses aren't okay.
Platform compatibility.
Parrot has to work on most of Perl 5's platforms, as well as a few of its own. Perl 5 runs on eighty platforms; Parrot must run on Unix, Windows, Mac OS (X and Classic), VMS, Crays, Windows CE, and Palm OS, just to name a few. Among its processor architectures will be x86, SPARC, Alpha, IA-64, ARM, and 68x00 (Palms and old Macs). If something doesn't work on all of these, we can't use it in Parrot.
Speed, size, and flexibility.
Not only does Parrot have to run on all those platforms, but it must also run efficiently. Parrot's core size is currently between 250K and 700K, depending on compiler. That's pushing it on the handheld platforms. Any library used by Parrot must be fast enough to have a fairly small performance impact, small enough to have little impact on core size, and flexible enough to handle the varying demands of Perl, Python, Tcl, Ruby, Scheme, and whatever else some clever or twisted hacker throws at Parrot.
These tests are very hard to pass; currently we're expecting we'll probably have to write everything but the Unicode stuff.
Why your own virtual machine? Why not compile to JVM/.NET?
Those VMs are designed for statically typed languages. That's fine, since Java, C#, and lots of other languages are statically typed. Perl isn't. For a variety of reasons, it means that perl would run more slowly there than on an interpreter geared towards dynamic languages.
So you won't run on JVM/.NET?
Sure we will. They're just not our first target. We build our own interpreter/VM, then when that's working we start in on the JVM and/or .NET back ends.
PARROT AND PERL
Why re-implement Perl?
Good question.
At The Perl Conference 4.0, in the summer of 2000, Larry Wall announced that it was time to recreate Perl from the ground up. This included the Perl language, the implementation of that language, the community of open source developers who volunteer to implement and maintain the language, and the larger community of programmers who use Perl.
A variety of reasons were given for embarking on this project:
Perl5 is a stable, reliable, robust platform for developing software; it's not going away for a long time, even after Perl6 is released. (Proof: Perl4 is still out there, no matter how much we all want it to go away.)
We have the ability to translate Perl5 into Perl6 if necessary. This preserves backward compatibility with a large body of existing Perl code, which is very important.
The language can stand some revision: formats don't really belong in the core language, and typeglobs have outlived their usefulness. By revising the language now, we can make Perl better.
Some warts really should be removed:
system
should return true instead of false on success, andlocaltime
should return the year, not the year - 1900.It would be nice to write the Perl to Bytecode compiler in Perl, instead of C. That would make it much easier for Perl hackers to hack on Perl.
You want to write the Perl compiler in Perl?
Sure. Why not? C, Java, Lisp, Scheme, and practically every other language is self-hoisting. Why not?
Isn't there a bootstrapping problem?
No, not really. Don't forget that we can use Perl 5 to run Perl 5 programs, such as a Perl 5 to Parrot compiler.
How will Parrot handle both Perl 5 and Perl 6?
We don't know yet, since it depends on the Perl 6 language definition. But we could use the more appropriate of two Perl compilers, depending of whether we're compiling Perl 5 or Perl 6. Larry has mumbled something about a package
statement declaring that the file is Perl 5, but we're still not quite sure on how that fits in.
Is this how Parrot will run Python, Ruby, and Tcl code?
Probably.
Latin and Klingon too?
No, Parrot won't be twisted enough for Damian. Perhaps when Parrot is ported to a pair of supercool calcium ions, though...
Huh?
You had to be there.
PARROT IMPLEMENTATION ISSUES
What's with the whole register thing machine?
Not much, why do you ask?
Don't you know that stack machines are the way to go in software?
No, in fact, I don't.
But look at all the successful stack-based VMs!
Like what? There's just the JVM.
What about all the others?
What others? That's it, unless you count Perl, Python, or Ruby.
Yeah them!
Yeah, right. You never thought of them as VMs, admit it. :^)
Seriously, we're already running with a faster opcode dispatch than any of them are, and having registers just decreases the amount of stack thrash we get.
Right, smarty. Then name a successful register-based VM!
The 68K emulator Apple ships with all its PPC-enabled versions of Mac OS.
Really?
LINKS
April Fool's Joke: http://www.perl.com/pub/a/2001/04/01/parrot.htm
apocolypses: http://www.panix.com/~ziggy/
cool kids: http://use.perl.org/~acme/journal
Java bytecode to Parrot bytecode: http://archive.develooper.com/perl6-internals@perl.org/msg03864.html
http://www.perl.com/pub/a/2000/10/23/soto2000.html
be there: http://www.csse.monash.edu.au/~damian/papers/#Superpositions
Really.: http://developer.apple.com/techpubs/mac/PPCSoftware/PPCSoftware-13.html