Perl 6
Perl 6: Revision 62
^^ Welcome to the Perl 6 Workspace Wiki

^^^ Copyright and License

* (c) 2006 under the same (always latest) license(s) used by the Perl 6 /src branch of the Pugs trunk.
* See for the latest details.
* See the "GPL-2", "Artistic-2.0b5", and "MIT" files in for the full license texts.

^^^ This is the home page for Perl 6

* Please post any questions about this Wiki to perl.perl6.users. (See section on Perl 6 mailing lists for more information.)
* There is a {link: parrot [Parrot]} workspace as well.
* "About that $1,000 Perl 6 Wiki prize"[Conrad Schneiker].
* Please feel free to add or modify pages — even this one — as you see fit. That's the idea of a Workspace. So please contribute links and information! (See *Wiki 101* at bottom of page to get started.)


^^ What is Perl 6?

* "Perl 6"<> is an extensively refactored, super-modernized, and ultra-supercharged derivative of Perl 5. Simple things will still be simple to do, but you'll have enormously more "syntactic compound leverage" and "semantic overdrive" available for tackling challenging tasks.
* Chromatic has written a good introductory article on "why Perl 6 is needed, and what it is"<>.
* Also see Juerd's "Refuting Perl 6 Myths"<>. (A slight correction to Juerd's slides: it is Perl 5.10 that will have many Perl 6 features you can start using. These will be in ""<>, which is currently part of the "Perl 5.9 developer branch"<>.)
* See the documentation section below for much more information.

^^^ The Long Perl 6 Super-Feature List

* [The Long Perl 6 Super-Feature List] This list was moved to its own page so that there would be plenty of room for people at add additional explanations of what these features are, and to explain why they are Very Good Things (tm).

^^^ Other Answers

* Larry Wall (2006): Perhaps the Perl 6 slogan should be "All Your Paradigms Are Belong To Us". We'll get to that.
* Damian Conway (2003): The Perl 6 design process is about keeping what works in Perl 5, fixing what doesn't, and adding what's missing. That means there will be a few fundamental changes to the language, a large number of extensions to existing features, and a handful of completely new ideas. These modifications, enhancements, and innovations will work together to make the future Perl even more insanely great — without, we hope, making it even more greatly insane.
* Perl 6 is still under construction. So don't make critical plans that depend on it just yet. However, please see other sections below about intermediate Perl 6-related solutions you can use now (or soon, as in Perl 5.10, which will feature several Perl 6 features).
* Crazy (in a good way).
* Perl 5 : Swiss Army Chain Saw == Perl 6 : Swiss Army T-X Terminator (on the side of humans in this case).
* ....

^^ Where to get Perl 6

* Win32 binary builds of Pugs and Parrot (easiest way to get started):
** (<>).
** ( appears to have stopped routinely updating their Win32 builds.)
* Pugs: (<>)
* Parrot home page: (<>)
* FYI: Perl development server: (<>).
* Code repository:
** Live repository (<>)
** Mirror (<>)
* Perl 6 code examples. (Once you've had a chance to play with these examples, you may want to contribute your own examples and tests.):
** Perl 6 examples (<>)
** Perl 6 tests (<>)

^^ The Very Latest Perl 6 Information

(See the next major section for general information, including documentation, tutorials, and so on.)

^^^ Perl 6 News

* "Planet Perl 6 blog aggregrator"<> (The best general news source for Perl 6. It would be very helpful if others selectively copied the most useful information from this great resource into appropriate sections of this wiki.)
* "Planet Parrot blog aggregator"<>

^^^ Perl 6 Mailing Lists

The currently active Perl 6 mailing lists are at (<>) and Google Groups (<>) under these names:

* "perl.perl6.users"<> # For users of (versus developers of) Perl 6.
* "perl.perl6.internals"<>
* "perl.perl6.language"<>
* "perl.perl6.compiler"<>
* "perl.perl6.announce"<>

You can also get these by email; see (<> for details (and make appropriate substitutions on "-users" for other groups).

You can access the mailing lists in several ways (we use perl.perl6.users as an example below, make appropriate substitutions for the other cases):

* Subscribe by emailing
* Access the news feed by pointing your news reader to: (news:// Need a decent Windows newsreader? "Mozilla's Thunderbird"<> works for me.
* We're also (-: at last! :-) available at Google Groups perl.perl6.users (<>).
* Subject lines of mailing list posts with link to each post can be found in the perl.perl6.users mail list archives (<>).
* There is also a "RSS feed"<>.

^^^ Perl 6 IRC

IRC channels (and their archives) are a major source of useful information. NOTE: Please don't unthinkingly interrupt and pester the developers of Perl 6 with questions that you can just as well ask on perl.perl6.users, which they and others can then later answer at their convenience. (As always, it's good manners to search Google Groups and to check archival logs before posting questions.)

* The "#perl6" IRC channel is on (<>).
* "Daily logs"<> are available.
* "TimToady" is Larry Wall's nickname on #perl6.
* Need an IRC client on Windows? Try "Chatzilla"<>, a "Firefox"<> extension.
* Some handy #perl6 "bot-isms":
** ?eval <Perl 6 expression> # Replays with evaluated expression.
** perlbot nopaste # Use to paste blocks of text offline; it replies to IRC with URL to it.

^^ Perl 6 Docs

^^^ General docs

* [Glossary of Perl 6 Terms and Jargon].
* "Official Perl 6 Documentation Page"<> (Which means, documentation that is officially bundled with Perl 6 builds and releases.) (on feather, a Perl 6 development server)
* "Perl6 Community Development Server"<> (on feather, a Perl 6 development server)
* "Perl's Official Home Page"<> (at
* "Perl 6 Synopses"<> (This is the official Perl 6 specification, which supersedes the apocalypses and exegeses, and which is bundled with Perl 6 builds. The rapidly growing Perl 6 test base is another {very important, complementary, and emerging} part of the Perl 6 specification as well.)
* "Perl 6 Development Info"<> (at
* "Another Perl 6 Wiki"<> (For a long time, the Perl 6 Wiki at was the best general introduction to Perl 6, and a great point of departure to other Perl 6 resources around the web.)
* "Perl 6 Users FAQ"<> (The initial large batch of text and links on this Wiki originally came from this FAQ on the Perl 6 Wiki. The folks there deserve much thanks for "Wikifying" my original ugly ASCII Perl 6 Users FAQ, which was developed at the inaguration of perl.perl6.users.)
* "Perl 6 Tutorial"<> (at
* Most of the information on getting started can be found on this "getting started"<> page. You may also find the following links useful:
** Debian Linux (guide in "English"<>, "German"<>).
** "Ubuntu Linux"<>.
* Russian language "Perl 6 website"<>.

^^^ Articles on Perl 6

* "Who's Who in Perl 6, Parrot, & Pugs"<>
* "What is Perl 6?"<>
* "Refuting Perl 6 Myths"<>
* "Present Continuous, Future Perfect"<,_Future_Perfect> Larry Wall's 2006 Perl talk.
* The O'Reilly "Perl website"<> sometimes has interesting articles about Perl 6. (Need to search for them.)

^^^ Some design influences on Perl 6

* "Perl Best Practices" by Damian Conway. Even though this currently applies to Perl 5, most of the principles also apply to Perl 6. This book is a semi-officially recommended guideline for people doing develop core Perl 6 modules and tests.
* ""Confessions of a Used Programming Language Salesman; Getting the Masses Hooked on Haskell"<>" (Warning: PDF link) by Erik Meijer.
* "Traits"<> are one of the "Big Ideas" that have had some influence on #perl6 design discussions.
* ""The 100 Year Language"<>" Useful information on how we should view Perl 6 (although it's not about Perl 6).

^^^ Helping hack the Perl 6 production docs

* "Read this first"<>.
* "The evil plan"<>. This mentions many things you can do to help out with docs, although it is a bit dated.
* This plan is still current AFAIK: "Perl 6 developers are refactoring relevant introductions, tutorials, specifications into the Perl6::Doc namespace; expect to see this module subsumed by it in the near future.":
** (<>),
** (<>).

^^^ Helping hack on (versus hack with) Perl 6

* "Pugs Apocryphon 1"<> Overview of the Pugs project.
* "Doing Pugs-related development"<>.
* "A Peek Into Pugs Internals"<>
* "German language notes about compiling Pugs"<>
* "Pugs SVN repository"<>.
* "Parrot"<>.
* "Parrot FAQ"<>

^^^ Perl 5 modules implementing Perl 6 features

* In Perl 5.9 (development branch) and Perl 5.10 (production release), ""<> provides some Perl 6 features that you will be able to selectively turn on.
* There are many modules that currently implement parts of Perl 6 in Perl 5. Go to "CPAN"<> and do a "module search on perl6"<>.
* (Note: (<>) is missing many entries. Use the search above for the time being.)
* Some of these are listed on the "Perl 6"<> page.
* ....

^^ What are people doing with Perl 6?

^^^ Organizations

* The Perl Foundation Grants (to be completed).
* Google Summer of Code (to be completed).

^^^ Projects, Modules, and Such

* PITA — The Perl Image Testing Architecture (<>).
* Darren Duncan's work on a Perl 6 Relation type (as in relational algebra and data structures).
* ....

^^ Wiki 101

* If you'd like an *introductory tour* of the Socialtext Workspace, [start here].
* Visit *Recent Changes* every once in a while to see what's new, and see {link: help [Socialtext Documentation]} for tips to use this Workspace.
* Make links by putting words or phrases in square brackets. Click on *Edit This Page* to see some examples. Note from wiki novice: If you (or someone else) later changes the title of a page you create this way, you'll need to update the original link too. The Wiki's Recent Changes link will show you the new name, if you forget what it was, or otherwise lose track of your renamed page.


What license will content on this wiki be covered under?

_contributed by {user:} on {date: 2006-09-02 11:35:12 GMT}_

Upload Files

Click "Browse" to find the file you want to upload. When you click "Upload file" your file will be uploaded and added to the list of attachments for this page.

Maximum file size: 50MB

File Name Author Date Uploaded Size

Save Page As

Enter a meaningful and distinctive title for your page.

Page Title:

Tip: You'll be able to find this page later by using the title you choose.

Page Already Exists

There is already a page named XXX. Would you like to:

Save with a different name:

Save the page with the name "XXX"

Append your text to the bottom of the existing page named: "XXX"

Upload Files

Click "Browse" to find the file you want to upload. When you click "Add file" this file will be added to the list of attachments for this page, and uploaded when you save the page.

Add Tags

Enter a tag and click "Add tag". The tag will be saved when you save the page.