147 lines
5.0 KiB
Plaintext
147 lines
5.0 KiB
Plaintext
|
If you read this file _as_is_, just ignore the funny characters you see.
|
||
|
It is written in the POD format (see pod/perlpod.pod) which is specially
|
||
|
designed to be readable as is.
|
||
|
|
||
|
=head1 NAME
|
||
|
|
||
|
perlplan9 - Plan 9-specific documentation for Perl
|
||
|
|
||
|
=head1 DESCRIPTION
|
||
|
|
||
|
These are a few notes describing features peculiar to
|
||
|
Plan 9 Perl. As such, it is not intended to be a replacement
|
||
|
for the rest of the Perl 5 documentation (which is both
|
||
|
copious and excellent). If you have any questions to
|
||
|
which you can't find answers in these man pages, contact
|
||
|
Luther Huffman at lutherh@stratcom.com and we'll try to
|
||
|
answer them.
|
||
|
|
||
|
=head2 Invoking Perl
|
||
|
|
||
|
Perl is invoked from the command line as described in
|
||
|
L<perl>. Most perl scripts, however, do have a first line
|
||
|
such as "#!/usr/local/bin/perl". This is known as a shebang
|
||
|
(shell-bang) statement and tells the OS shell where to find
|
||
|
the perl interpreter. In Plan 9 Perl this statement should be
|
||
|
"#!/bin/perl" if you wish to be able to directly invoke the
|
||
|
script by its name.
|
||
|
Alternatively, you may invoke perl with the command "Perl"
|
||
|
instead of "perl". This will produce Acme-friendly error
|
||
|
messages of the form "filename:18".
|
||
|
|
||
|
Some scripts, usually identified with a *.PL extension, are
|
||
|
self-configuring and are able to correctly create their own
|
||
|
shebang path from config information located in Plan 9
|
||
|
Perl. These you won't need to be worried about.
|
||
|
|
||
|
=head2 What's in Plan 9 Perl
|
||
|
|
||
|
Although Plan 9 Perl currently only provides static
|
||
|
loading, it is built with a number of useful extensions.
|
||
|
These include Opcode, FileHandle, Fcntl, and POSIX. Expect
|
||
|
to see others (and DynaLoading!) in the future.
|
||
|
|
||
|
=head2 What's not in Plan 9 Perl
|
||
|
|
||
|
As mentioned previously, dynamic loading isn't currently
|
||
|
available nor is MakeMaker. Both are high-priority items.
|
||
|
|
||
|
=head2 Perl5 Functions not currently supported in Plan 9 Perl
|
||
|
|
||
|
Some, such as C<chown> and C<umask> aren't provided
|
||
|
because the concept does not exist within Plan 9. Others,
|
||
|
such as some of the socket-related functions, simply
|
||
|
haven't been written yet. Many in the latter category
|
||
|
may be supported in the future.
|
||
|
|
||
|
The functions not currently implemented include:
|
||
|
|
||
|
chown, chroot, dbmclose, dbmopen, getsockopt,
|
||
|
setsockopt, recvmsg, sendmsg, getnetbyname,
|
||
|
getnetbyaddr, getnetent, getprotoent, getservent,
|
||
|
sethostent, setnetent, setprotoent, setservent,
|
||
|
endservent, endnetent, endprotoent, umask
|
||
|
|
||
|
There may be several other functions that have undefined
|
||
|
behavior so this list shouldn't be considered complete.
|
||
|
|
||
|
=head2 Signals in Plan 9 Perl
|
||
|
|
||
|
For compatibility with perl scripts written for the Unix
|
||
|
environment, Plan 9 Perl uses the POSIX signal emulation
|
||
|
provided in Plan 9's ANSI POSIX Environment (APE). Signal stacking
|
||
|
isn't supported. The signals provided are:
|
||
|
|
||
|
SIGHUP, SIGINT, SIGQUIT, SIGILL, SIGABRT,
|
||
|
SIGFPE, SIGKILL, SIGSEGV, SIGPIPE, SIGPIPE, SIGALRM,
|
||
|
SIGTERM, SIGUSR1, SIGUSR2, SIGCHLD, SIGCONT,
|
||
|
SIGSTOP, SIGTSTP, SIGTTIN, SIGTTOU
|
||
|
|
||
|
=head1 COMPILING AND INSTALLING PERL ON PLAN 9
|
||
|
|
||
|
WELCOME to Plan 9 Perl, brave soul!
|
||
|
|
||
|
This is a preliminary alpha version of Plan 9 Perl. Still to be
|
||
|
implemented are MakeMaker and DynaLoader. Many perl commands are
|
||
|
missing or currently behave in an inscrutable manner. These gaps will,
|
||
|
with perseverance and a modicum of luck, be remedied in the near
|
||
|
future.To install this software:
|
||
|
|
||
|
1. Create the source directories and libraries for perl by running the
|
||
|
plan9/setup.rc command (i.e., located in the plan9 subdirectory).
|
||
|
Note: the setup routine assumes that you haven't dearchived these
|
||
|
files into /sys/src/cmd/perl. After running setup.rc you may delete
|
||
|
the copy of the source you originally detarred, as source code has now
|
||
|
been installed in /sys/src/cmd/perl. If you plan on installing perl
|
||
|
binaries for all architectures, run "setup.rc -a".
|
||
|
|
||
|
2. After making sure that you have adequate privileges to build system
|
||
|
software, from /sys/src/cmd/perl/5.00301 (adjust version
|
||
|
appropriately) run:
|
||
|
|
||
|
mk install
|
||
|
|
||
|
If you wish to install perl versions for all architectures (68020,
|
||
|
mips, sparc and 386) run:
|
||
|
|
||
|
mk installall
|
||
|
|
||
|
3. Wait. The build process will take a *long* time because perl
|
||
|
bootstraps itself. A 75MHz Pentium, 16MB RAM machine takes roughly 30
|
||
|
minutes to build the distribution from scratch.
|
||
|
|
||
|
=head2 Installing Perl Documentation on Plan 9
|
||
|
|
||
|
This perl distribution comes with a tremendous amount of
|
||
|
documentation. To add these to the built-in manuals that come with
|
||
|
Plan 9, from /sys/src/cmd/perl/5.00301 (adjust version appropriately)
|
||
|
run:
|
||
|
|
||
|
mk man
|
||
|
|
||
|
To begin your reading, start with:
|
||
|
|
||
|
man perl
|
||
|
|
||
|
This is a good introduction and will direct you towards other man
|
||
|
pages that may interest you.
|
||
|
|
||
|
(Note: "mk man" may produce some extraneous noise. Fear not.)
|
||
|
|
||
|
=head1 BUGS
|
||
|
|
||
|
"As many as there are grains of sand on all the beaches of the
|
||
|
world . . ." - Carl Sagan
|
||
|
|
||
|
=head1 Revision date
|
||
|
|
||
|
This document was revised 09-October-1996 for Perl 5.003_7.
|
||
|
|
||
|
=head1 AUTHOR
|
||
|
|
||
|
Direct questions, comments, and the unlikely bug report (ahem) direct
|
||
|
comments toward:
|
||
|
|
||
|
Luther Huffman, lutherh@stratcom.com,
|
||
|
Strategic Computer Solutions, Inc.
|