perl

Standard Library source code

Evaluate Perl code from ZuzuScript.

Module

Name
perl
Area
Standard Library
Source
modules/perl.zzm
=encoding utf8

=head1 NAME

perl - Evaluate Perl code from ZuzuScript.

=head1 SYNOPSIS

  from perl import Perl, PerlResult;

  let r := Perl.eval("[ 7, 8, 9 ]");
  assert( r instanceof PerlResult );

  let j := r.toJSON();

  let r2 := r.eval(" $_->[1] ");
  assert( r2 instanceof PerlResult );

  let n;
  n := r2.value() if r2.isSafe();

=head1 IMPLEMENTATION SUPPORT

This module is supported by zuzu.pl. It is not supported by zuzu-rust or
zuzu-js.

=head1 DESCRIPTION

This builtin module bridges to the host Perl interpreter.

C<Perl.version()> returns the current Perl version string.

C<Perl.eval(String code)> evaluates Perl in scalar context and
returns C<PerlResult>.

C<PerlResult> wraps the underlying Perl value. Use C<isSafe()> to
check whether C<value()> can convert it into a native Zuzu value.

C<toJSON()> attempts to encode the wrapped value as JSON text.

C<eval(String code)> evaluates more Perl with the wrapped value in
C<$_>, again returning C<PerlResult>.

=head1 EXPORTS

=head2 Classes

=over

=item C<Perl>

Runtime-supported Perl bridge class.

=over

=item C<< Perl.version() >>

Parameters: none. Returns: C<String>. Returns the host Perl interpreter
version.

=item C<< Perl.eval(String code) >>

Parameters: C<code> is Perl source text. Returns: C<PerlResult>.
Evaluates C<code> in scalar context in the host Perl interpreter.

=back

=item C<PerlResult>

Wrapper for a Perl value returned by C<Perl.eval()> or
C<PerlResult.eval()>.

=over

=item C<< result.eval(String code) >>

Parameters: C<code> is Perl source text. Returns: C<PerlResult>.
Evaluates C<code> with the wrapped Perl value available in C<$_>.

=item C<< result.isSafe() >>

Parameters: none. Returns: C<Boolean>. Returns true when C<value()> can
convert the wrapped Perl value into a native ZuzuScript value.

=item C<< result.value() >>

Parameters: none. Returns: value. Converts and returns the wrapped Perl
value when C<isSafe()> is true.

=item C<< result.toJSON() >>

Parameters: none. Returns: C<String>. Serializes the wrapped Perl value
as JSON text.

=back

=back

=head1 COPYRIGHT AND LICENCE

B<< perl >> is copyright Toby Inkster.

It is free software; you may redistribute it and/or modify it under
the terms of either the Artistic License 1.0 or the GNU General Public
License version 2.