This is a live mirror of the Perl 5 development currently hosted at https://github.com/perl/perl5
expand code comment in perly.y
[perl5.git] / README.plan9
1 If you read this file _as_is_, just ignore the funny characters you see.
2 It is written in the POD format (see pod/perlpod.pod) which is specially
3 designed to be readable as is.
4
5 =head1 NAME
6
7 perlplan9 - Plan 9-specific documentation for Perl
8
9 =head1 DESCRIPTION
10
11 These are a few notes describing features peculiar to
12 Plan 9 Perl. As such, it is not intended to be a replacement
13 for the rest of the Perl 5 documentation (which is both 
14 copious and excellent). If you have any questions to 
15 which you can't find answers in these man pages, contact 
16 Luther Huffman at lutherh@stratcom.com and we'll try to 
17 answer them.
18
19 =head2 Invoking Perl
20
21 Perl is invoked from the command line as described in 
22 L<perl>. Most perl scripts, however, do have a first line 
23 such as "#!/usr/local/bin/perl". This is known as a shebang 
24 (shell-bang) statement and tells the OS shell where to find 
25 the perl interpreter. In Plan 9 Perl this statement should be 
26 "#!/bin/perl" if you wish to be able to directly invoke the 
27 script by its name.
28      Alternatively, you may invoke perl with the command "Perl"
29 instead of "perl". This will produce Acme-friendly error
30 messages of the form "filename:18".
31
32 Some scripts, usually identified with a *.PL extension, are 
33 self-configuring and are able to correctly create their own 
34 shebang path from config information located in Plan 9 
35 Perl. These you won't need to be worried about.
36
37 =head2 What's in Plan 9 Perl
38
39 Although Plan 9 Perl currently only  provides static 
40 loading, it is built with a number of useful extensions. 
41 These include Opcode, FileHandle, Fcntl, and POSIX. Expect 
42 to see others (and DynaLoading!) in the future.
43
44 =head2 What's not in Plan 9 Perl
45
46 As mentioned previously, dynamic loading isn't currently 
47 available nor is MakeMaker. Both are high-priority items.
48
49 =head2 Perl5 Functions not currently supported in Plan 9 Perl
50
51 Some, such as C<chown> and C<umask> aren't provided 
52 because the concept does not exist within Plan 9. Others,
53 such as some of the socket-related functions, simply
54 haven't been written yet. Many in the latter category 
55 may be supported in the future.
56
57 The functions not currently implemented include:
58
59     chown, chroot, dbmclose, dbmopen, getsockopt, 
60     setsockopt, recvmsg, sendmsg, getnetbyname, 
61     getnetbyaddr, getnetent, getprotoent, getservent, 
62     sethostent, setnetent, setprotoent, setservent, 
63     endservent, endnetent, endprotoent, umask
64
65 There may be several other functions that have undefined 
66 behavior so this list shouldn't be considered complete.
67
68 =head2 Signals in Plan 9 Perl
69
70 For compatibility with perl scripts written for the Unix 
71 environment, Plan 9 Perl uses the POSIX signal emulation
72 provided in Plan 9's ANSI POSIX Environment (APE). Signal stacking
73 isn't supported. The signals provided are:
74
75     SIGHUP, SIGINT, SIGQUIT, SIGILL, SIGABRT,
76     SIGFPE, SIGKILL, SIGSEGV, SIGPIPE, SIGPIPE, SIGALRM, 
77     SIGTERM, SIGUSR1, SIGUSR2, SIGCHLD, SIGCONT,
78     SIGSTOP, SIGTSTP, SIGTTIN, SIGTTOU
79
80 =head1 COMPILING AND INSTALLING PERL ON PLAN 9
81
82 WELCOME to Plan 9 Perl, brave soul!
83
84    This is a preliminary alpha version of Plan 9 Perl. Still to be
85 implemented are MakeMaker and DynaLoader. Many perl commands are
86 missing or currently behave in an inscrutable manner. These gaps will,
87 with perseverance and a modicum of luck, be remedied in the near
88 future.To install this software:
89
90 1. Create the source directories and libraries for perl by running the
91 plan9/setup.rc command (i.e., located in the plan9 subdirectory).
92 Note: the setup routine assumes that you haven't dearchived these
93 files into /sys/src/cmd/perl. After running setup.rc you may delete
94 the copy of the source you originally detarred, as source code has now
95 been installed in /sys/src/cmd/perl. If you plan on installing perl
96 binaries for all architectures, run "setup.rc -a".
97
98 2. After making sure that you have adequate privileges to build system
99 software, from /sys/src/cmd/perl/5.00301 (adjust version
100 appropriately) run:
101
102         mk install
103
104 If you wish to install perl versions for all architectures (68020,
105 mips, sparc and 386) run:
106
107         mk installall
108
109 3. Wait. The build process will take a *long* time because perl
110 bootstraps itself. A 75MHz Pentium, 16MB RAM machine takes roughly 30
111 minutes to build the distribution from scratch.
112
113 =head2 Installing Perl Documentation on Plan 9
114
115 This perl distribution comes with a tremendous amount of
116 documentation. To add these to the built-in manuals that come with
117 Plan 9, from /sys/src/cmd/perl/5.00301 (adjust version appropriately)
118 run:
119
120         mk man
121
122 To begin your reading, start with:
123
124         man perl
125
126 This is a good introduction and will direct you towards other man
127 pages that may interest you.
128
129 (Note: "mk man" may produce some extraneous noise. Fear not.)
130
131 =head1 BUGS
132
133 "As many as there are grains of sand on all the beaches of the 
134 world . . ." - Carl Sagan
135
136 =head1 Revision date
137
138 This document was revised 09-October-1996 for Perl 5.003_7.
139
140 =head1 AUTHOR
141
142 Direct questions, comments, and the unlikely bug report (ahem) direct
143 comments toward:
144
145 Luther Huffman, lutherh@stratcom.com, 
146 Strategic Computer Solutions, Inc.