## A useful, usable, "early adopter" distribution of Perl 6

On behalf of the Rakudo and Perl 6 development teams, I'm happy to
announce the February 2015 release of "Rakudo Star", a useful and usable
distribution of Perl 6. The tarball for the February 2015 release is
available from <http://rakudo.org/downloads/star/>.

This Rakudo Star release comes with support for the MoarVM
backend (all module tests pass on supported platforms) along with
experimental support for the JVM backend (some module tests fail).
One shipped module is known to fail on Parrot (jsonrpc).

In the Perl 6 world, we make a distinction between the language
("Perl 6") and specific implementations of the language such as
"Rakudo Perl". This Star release includes [release 2015.02] of the
[Rakudo Perl 6 compiler], version 6.10.0 of the [Parrot Virtual
Machine], version 2015.02 of [MoarVM], plus various modules,
documentation, and other resources collected from the Perl 6
community.

[release 2015.02]:
    https://github.com/rakudo/rakudo/blob/nom/docs/announce/2015.02.md
[Rakudo Perl 6 compiler]: http://github.com/rakudo/rakudo
[Parrot Virtual Machine]: http://parrot.org
[MoarVM]: http://moarvm.org/

Some of the new compiler features added to this release include:

+ On MoarVM, symlinks are now followed.  This means that e.g. a given
  path can have both .l and .d be true, if the symlink points to a
  directory. This behaviour now matches the behaviour on the Parrot
  and JVM backend, therefore one could consider this a bug fix,
  rather than an incompatible change.
+ Overriding `invoke`/`postcircumfix:<( )>` for type coercions (ex.
  `MyType(...)`) now passes the function arguments as-is, rather than
  just passing a Capture containing them. To get the old behavior,
  simply declare a Capture parameter (|c).
+ `6;` at unit start is no longer a way to say `no strict;`.  It was
  deemed to be a bad meme and huffmannized inappropriately.
+ Coercion syntax now works in signatures: `sub foo(Str(Any) $a) { ... }`
  will take Any value as its first positional parameter, and coerce
  it to `Str` before making it available in `$a`.  Note that `Str(Any)`
  can be shortened to `Str()`.
+ `sub MAIN;` (as in, rest of file is the MAIN unit) has been
  implemented.
+ Metaop `=` now respects the precedence of the op it is meta-ing.
+ Many optimizations, improved error messages and bugs fixed (over
  200 commits to Rakudo since the 2015.01 release).

In future, the `nqp::` namespace willl only be available after a
declaration like `use nqp;`.

Changes to modules included in Rakudo Star:

- [JSON::Tiny](https://github.com/moritz/json) gives better error
messages on invalid input
- [panda](https://github.com/tadzik/panda) gives better error messages
when
  projects.json is not a valid JSON file (for example due to ISP-level
HTTP filtering)
- [doc](https://github.com/perl6/doc) ships with much more documentation
- [LWP::Simple](https://github.com/cosimo/perl6-lwp-simple) supports
PUT and HEAD requests,
  as well as TLS if
[IO::Socket::SSL](https://github.com/sergot/io-socket-ssl/) is installed.

The `Math::Model` and `Math::RungeKutta` modules no longer ship with
Rakudo
Star. They can still be installed with `panda`.

This is the last Rakudo Star release with support for the Parrot
backend, until volunteers are found that bring the Parrot backend in
shape and on par with the other backends, and implement necessary
features for upcoming changes. See
[this blog post](http://pmthium.com/2015/02/suspending-rakudo-parrot/)
for more information.

There are some key features of Perl 6 that Rakudo Star does not yet
handle appropriately, although they will appear in upcoming releases.
Some of the not-quite-there features include:

  * advanced macros
  * threads and concurrency (in progress for the JVM and MoarVM backend)
  * Unicode strings at levels other than codepoints
  * interactive readline that understands Unicode
  * non-blocking I/O (in progress for the JVM and MoarVM backend)
  * much of Synopsis 9 and 11

There is an online resource at <http://perl6.org/compilers/features>
that lists the known implemented and missing features of Rakudo's
backends and other Perl 6 implementations.

In many places we've tried to make Rakudo smart enough to inform the
programmer that a given feature isn't implemented, but there are many
that we've missed. Bug reports about missing and broken features are
welcomed at <rakudo...@perl.org>.

See <http://perl6.org/> for links to much more information about
Perl 6, including documentation, example code, tutorials, reference
materials, specification documents, and other supporting resources. A
draft of a Perl 6 book is available as docs/UsingPerl6-draft.pdf in
the release tarball.

The development team thanks all of the contributors and sponsors for
making Rakudo Star possible. If you would like to contribute, see
<http://rakudo.org/how-to-help>, ask on the <perl6-compi...@perl.org>
mailing list, or join us on IRC \#perl6 on freenode.

Reply via email to