diff options
51 files changed, 2416 insertions, 445 deletions
diff --git a/Porting/p4desc b/Porting/p4desc index b6b412d517..0bf79da2e0 100755 --- a/Porting/p4desc +++ b/Porting/p4desc @@ -65,7 +65,7 @@ my $cur = m|^Affected files| ... m|^Differences|; # while we are within range if ($cur) { - if (m|^\.\.\. (//depot/.+?#\d+) add$|) { + if (m{^\.\.\. (//depot/.+?#\d+) (add|branch)$}) { my $newfile = $1; push @addfiles, $newfile; warn "$newfile add, revision != 1!\n" unless $newfile =~ /#1$/; @@ -90,9 +90,9 @@ sub newfiles { my $addfile; my $ret = ""; for $addfile (@addfiles) { - my $type = `p4 -p $p4port files $addfile`; + my $type = `p4 -p $p4port files '$addfile'`; if ($?) { - warn "$0: `p4 -p $p4port print $addfile` failed, status[$?]\n"; + warn "$0: `p4 -p $p4port print '$addfile'` failed, status[$?]\n"; next; } $type =~ m|^//.*\((.+)\)$| or next; @@ -101,9 +101,9 @@ sub newfiles { $ret .= "\n==== $addfile ($type) ====\n\n"; next; } - my @new = `p4 -p $p4port print $addfile`; + my @new = `p4 -p $p4port print '$addfile'`; if ($?) { - die "$0: `p4 -p $p4port print $addfile` failed, status[$?]\n"; + die "$0: `p4 -p $p4port print '$addfile'` failed, status[$?]\n"; } my $desc = shift @new; # discard initial description $ret .= "\n==== $addfile ($type) ====\n\n"; @@ -111,6 +111,7 @@ sub newfiles { $lines = "" if @new < 2; $ret .= "\@\@ -0,0 +1$lines \@\@\n"; $ret .= join("+","",@new); + $ret .= "\n\\ No newline at end of file\n" if $ret !~ /\n$/; } @addfiles = (); return $ret; diff --git a/README.win32 b/README.win32 index d5adfd7dc2..c7e61264d6 100644 --- a/README.win32 +++ b/README.win32 @@ -177,7 +177,7 @@ If you have either the source or a library that contains des_fcrypt(), enable the appropriate option in the makefile. des_fcrypt() is not bundled with the distribution due to US Government restrictions on the export of cryptographic software. Nevertheless, this routine -is part of the "libdes" library (written by Ed Young) which is widely +is part of the "libdes" library (written by Eric Young) which is widely available worldwide, usually along with SSLeay (for example: "ftp://fractal.mta.ca/pub/crypto/SSLeay/DES/"). Set CRYPT_SRC to the name of the file that implements des_fcrypt(). Alternatively, if diff --git a/embedvar.h b/embedvar.h index 837c0308cf..342f5433b2 100644 --- a/embedvar.h +++ b/embedvar.h @@ -199,6 +199,7 @@ #define PL_bitcount (PERL_GET_INTERP->Ibitcount) #define PL_bufend (PERL_GET_INTERP->Ibufend) #define PL_bufptr (PERL_GET_INTERP->Ibufptr) +#define PL_checkav (PERL_GET_INTERP->Icheckav) #define PL_collation_ix (PERL_GET_INTERP->Icollation_ix) #define PL_collation_name (PERL_GET_INTERP->Icollation_name) #define PL_collation_standard (PERL_GET_INTERP->Icollation_standard) @@ -367,7 +368,6 @@ #define PL_statusvalue_vms (PERL_GET_INTERP->Istatusvalue_vms) #define PL_stderrgv (PERL_GET_INTERP->Istderrgv) #define PL_stdingv (PERL_GET_INTERP->Istdingv) -#define PL_stopav (PERL_GET_INTERP->Istopav) #define PL_strtab (PERL_GET_INTERP->Istrtab) #define PL_strtab_mutex (PERL_GET_INTERP->Istrtab_mutex) #define PL_sub_generation (PERL_GET_INTERP->Isub_generation) @@ -463,6 +463,7 @@ #define PL_bitcount (vTHX->Ibitcount) #define PL_bufend (vTHX->Ibufend) #define PL_bufptr (vTHX->Ibufptr) +#define PL_checkav (vTHX->Icheckav) #define PL_collation_ix (vTHX->Icollation_ix) #define PL_collation_name (vTHX->Icollation_name) #define PL_collation_standard (vTHX->Icollation_standard) @@ -631,7 +632,6 @@ #define PL_statusvalue_vms (vTHX->Istatusvalue_vms) #define PL_stderrgv (vTHX->Istderrgv) #define PL_stdingv (vTHX->Istdingv) -#define PL_stopav (vTHX->Istopav) #define PL_strtab (vTHX->Istrtab) #define PL_strtab_mutex (vTHX->Istrtab_mutex) #define PL_sub_generation (vTHX->Isub_generation) @@ -864,6 +864,7 @@ #define PL_bitcount (aTHXo->interp.Ibitcount) #define PL_bufend (aTHXo->interp.Ibufend) #define PL_bufptr (aTHXo->interp.Ibufptr) +#define PL_checkav (aTHXo->interp.Icheckav) #define PL_collation_ix (aTHXo->interp.Icollation_ix) #define PL_collation_name (aTHXo->interp.Icollation_name) #define PL_collation_standard (aTHXo->interp.Icollation_standard) @@ -1032,7 +1033,6 @@ #define PL_statusvalue_vms (aTHXo->interp.Istatusvalue_vms) #define PL_stderrgv (aTHXo->interp.Istderrgv) #define PL_stdingv (aTHXo->interp.Istdingv) -#define PL_stopav (aTHXo->interp.Istopav) #define PL_strtab (aTHXo->interp.Istrtab) #define PL_strtab_mutex (aTHXo->interp.Istrtab_mutex) #define PL_sub_generation (aTHXo->interp.Isub_generation) @@ -1129,6 +1129,7 @@ #define PL_Ibitcount PL_bitcount #define PL_Ibufend PL_bufend #define PL_Ibufptr PL_bufptr +#define PL_Icheckav PL_checkav #define PL_Icollation_ix PL_collation_ix #define PL_Icollation_name PL_collation_name #define PL_Icollation_standard PL_collation_standard @@ -1297,7 +1298,6 @@ #define PL_Istatusvalue_vms PL_statusvalue_vms #define PL_Istderrgv PL_stderrgv #define PL_Istdingv PL_stdingv -#define PL_Istopav PL_stopav #define PL_Istrtab PL_strtab #define PL_Istrtab_mutex PL_strtab_mutex #define PL_Isub_generation PL_sub_generation diff --git a/ext/B/B/C.pm b/ext/B/B/C.pm index 6e3af0d5bc..fa1053f1e1 100644 --- a/ext/B/B/C.pm +++ b/ext/B/B/C.pm @@ -1576,6 +1576,8 @@ No copy-on-grow. Optimisation level (n = 0, 1, 2, ...). B<-O> means B<-O1>. Currently, B<-O1> and higher set B<-fcog>. +=back + =head1 EXAMPLES perl -MO=C,-ofoo.c foo.pl diff --git a/ext/B/B/Deparse.pm b/ext/B/B/Deparse.pm index be7088e768..f8bcc7c8df 100644 --- a/ext/B/B/Deparse.pm +++ b/ext/B/B/Deparse.pm @@ -1194,7 +1194,7 @@ BEGIN { sub deparse_binop_left { my $self = shift; my($op, $left, $prec) = @_; - if ($left{assoc_class($op)} + if ($left{assoc_class($op)} && $left{assoc_class($left)} and $left{assoc_class($op)} == $left{assoc_class($left)}) { return $self->deparse($left, $prec - .00001); @@ -1227,7 +1227,7 @@ BEGIN { sub deparse_binop_right { my $self = shift; my($op, $right, $prec) = @_; - if ($right{assoc_class($op)} + if ($right{assoc_class($op)} && $right{assoc_class($right)} and $right{assoc_class($op)} == $right{assoc_class($right)}) { return $self->deparse($right, $prec - .00001); diff --git a/ext/B/B/Stash.pm b/ext/B/B/Stash.pm index d992a89af8..fca3443c13 100644 --- a/ext/B/B/Stash.pm +++ b/ext/B/B/Stash.pm @@ -4,7 +4,7 @@ package B::Stash; BEGIN { %Seen = %INC } -STOP { +CHECK { my @arr=scan($main::{"main::"}); @arr=map{s/\:\:$//;$_;} @arr; print "-umain,-u", join (",-u",@arr) ,"\n"; diff --git a/ext/B/NOTES b/ext/B/NOTES index 8309892d80..89d03ba9a2 100644 --- a/ext/B/NOTES +++ b/ext/B/NOTES @@ -161,8 +161,8 @@ O module it should return a sub ref (usually a closure) to perform the actual compilation. When O regains control, it ensures that the "-c" option is forced (so that the program being compiled doesn't - end up running) and registers a STOP block to call back the sub ref + end up running) and registers a CHECK block to call back the sub ref returned from the backend's compile(). Perl then continues by parsing prog.pl (just as it would with "perl -c prog.pl") and after - doing so, assuming there are no parse-time errors, the STOP block + doing so, assuming there are no parse-time errors, the CHECK block of O gets called and the actual backend compilation happens. Phew. diff --git a/ext/B/O.pm b/ext/B/O.pm index d07c4a5b0f..352f8d4206 100644 --- a/ext/B/O.pm +++ b/ext/B/O.pm @@ -11,7 +11,7 @@ sub import { my $compilesub = &{"B::${backend}::compile"}(@options); if (ref($compilesub) eq "CODE") { minus_c; - eval 'STOP { &$compilesub() }'; + eval 'CHECK { &$compilesub() }'; } else { die $compilesub; } @@ -59,7 +59,7 @@ C<B::Backend> module and calls the C<compile> function in that package, passing it OPTIONS. That function is expected to return a sub reference which we'll call CALLBACK. Next, the "compile-only" flag is switched on (equivalent to the command-line option C<-c>) -and a STOP block is registered which calls CALLBACK. Thus the main +and a CHECK block is registered which calls CALLBACK. Thus the main Perl program mentioned on the command-line is read in, parsed and compiled into internal syntax tree form. Since the C<-c> flag is set, the program does not start running (excepting BEGIN blocks of diff --git a/ext/Devel/Peek/Peek.pm b/ext/Devel/Peek/Peek.pm index 17b1519c3b..38251c6ee8 100644 --- a/ext/Devel/Peek/Peek.pm +++ b/ext/Devel/Peek/Peek.pm @@ -373,32 +373,32 @@ This shows that =over -=item +=item * the subroutine is not an XSUB (since C<START> and C<ROOT> are non-zero, and C<XSUB> is zero); -=item +=item * that it was compiled in the package C<main>; -=item +=item * under the name C<MY::top_targets>; -=item +=item * inside a 5th eval in the program; -=item +=item * it is not currently executed (see C<DEPTH>); -=item +=item * it has no prototype (C<PROTOTYPE> field is missing). -=over +=back =head1 EXPORTS diff --git a/ext/File/Glob/Glob.pm b/ext/File/Glob/Glob.pm index ea56b445b7..6026499a80 100644 --- a/ext/File/Glob/Glob.pm +++ b/ext/File/Glob/Glob.pm @@ -238,7 +238,7 @@ The FreeBSD extensions to the POSIX standard are the following flags: =item C<GLOB_BRACE> -Pre-process the string to expand C<{pat,pat,...} strings like csh(1). +Pre-process the string to expand C<{pat,pat,...}> strings like csh(1). The pattern '{}' is left unexpanded for historical reasons (and csh(1) does the same thing to ease typing of find(1) patterns). @@ -331,6 +331,8 @@ Win32 users should use the real slash. If you really want to use backslashes, consider using Sarathy's File::DosGlob, which comes with the standard Perl distribution. +=back + =head1 AUTHOR The Perl interface was written by Nathan Torkington E<lt>gnat@frii.comE<gt>, diff --git a/ext/IO/lib/IO/Socket/INET.pm b/ext/IO/lib/IO/Socket/INET.pm index 7818508fe2..30a923034a 100644 --- a/ext/IO/lib/IO/Socket/INET.pm +++ b/ext/IO/lib/IO/Socket/INET.pm @@ -332,6 +332,8 @@ by default. This was not the case with earlier releases. NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE +=back + =head2 METHODS =over 4 diff --git a/ext/IPC/SysV/SysV.pm b/ext/IPC/SysV/SysV.pm index eb245937aa..bebb8fd81b 100644 --- a/ext/IPC/SysV/SysV.pm +++ b/ext/IPC/SysV/SysV.pm @@ -74,11 +74,15 @@ C<IPC::SysV> defines and conditionally exports all the constants defined in your system include files which are needed by the SysV IPC calls. +=over + =item ftok( PATH, ID ) Return a key based on PATH and ID, which can be used as a key for C<msgget>, C<semget> and C<shmget>. See L<ftok> +=back + =head1 SEE ALSO L<IPC::Msg>, L<IPC::Semaphore>, L<ftok> diff --git a/ext/Thread/Thread.pm b/ext/Thread/Thread.pm index 32e4c82bf7..5e47d413e9 100644 --- a/ext/Thread/Thread.pm +++ b/ext/Thread/Thread.pm @@ -176,6 +176,8 @@ increasing integer assigned when a thread is created. The main thread of a program will have a tid of zero, while subsequent threads will have tids assigned starting with one. +=back + =head1 LIMITATIONS The sequence number used to assign tids is a simple integer, and no diff --git a/intrpvar.h b/intrpvar.h index 606a892374..f110b32748 100644 --- a/intrpvar.h +++ b/intrpvar.h @@ -93,7 +93,7 @@ PERLVAR(Iglobalstash, HV *) /* global keyword overrides imported here */ PERLVAR(Icurstname, SV *) /* name of current package */ PERLVAR(Ibeginav, AV *) /* names of BEGIN subroutines */ PERLVAR(Iendav, AV *) /* names of END subroutines */ -PERLVAR(Istopav, AV *) /* names of STOP subroutines */ +PERLVAR(Icheckav, AV *) /* names of CHECK subroutines */ PERLVAR(Iinitav, AV *) /* names of INIT subroutines */ PERLVAR(Istrtab, HV *) /* shared string table */ PERLVARI(Isub_generation,U32,1) /* incr to invalidate method cache */ diff --git a/keywords.h b/keywords.h index 972240f4f8..334304149f 100644 --- a/keywords.h +++ b/keywords.h @@ -16,7 +16,7 @@ #define KEY_LE 15 #define KEY_LT 16 #define KEY_NE 17 -#define KEY_STOP 18 +#define KEY_CHECK 18 #define KEY_abs 19 #define KEY_accept 20 #define KEY_alarm 21 diff --git a/keywords.pl b/keywords.pl index acdf807d43..46dd53d70e 100755 --- a/keywords.pl +++ b/keywords.pl @@ -42,7 +42,7 @@ INIT LE LT NE -STOP +CHECK abs accept alarm diff --git a/lib/AutoSplit.pm b/lib/AutoSplit.pm index 936edc4758..41d5489531 100644 --- a/lib/AutoSplit.pm +++ b/lib/AutoSplit.pm @@ -10,7 +10,7 @@ use strict; our($VERSION, @ISA, @EXPORT, @EXPORT_OK, $Verbose, $Keep, $Maxlen, $CheckForAutoloader, $CheckModTime); -$VERSION = "1.0304"; +$VERSION = "1.0305"; @ISA = qw(Exporter); @EXPORT = qw(&autosplit &autosplit_lib_modules); @EXPORT_OK = qw($Verbose $Keep $Maxlen $CheckForAutoloader $CheckModTime); @@ -149,7 +149,7 @@ my $Is_VMS = ($^O eq 'VMS'); # allow checking for valid ': attrlist' attachments my $nested; $nested = qr{ \( (?: (?> [^()]+ ) | (?p{ $nested }) )* \) }x; -my $one_attr = qr{ (?> (?! \d) \w+ (?:$nested)? ) [\s,]* }x; +my $one_attr = qr{ (?> (?! \d) \w+ (?:$nested)? ) (?:\s*\:\s*|\s+(?!\:)) }x; my $attr_list = qr{ \s* : \s* (?: $one_attr )* }x; @@ -468,5 +468,5 @@ package Yet::Another::AutoSplit; sub testtesttesttest4_1 ($) { "another test 4\n"; } sub testtesttesttest4_2 ($$) { "another duplicate test 4\n"; } package Yet::More::Attributes; -sub test_a1 ($) : locked { 1; } +sub test_a1 ($) : locked :locked { 1; } sub test_a2 : locked { 1; } diff --git a/lib/Class/Struct.pm b/lib/Class/Struct.pm index 554865a8e2..b4f2117557 100644 --- a/lib/Class/Struct.pm +++ b/lib/Class/Struct.pm @@ -355,7 +355,7 @@ The element is an array, initialized by default to C<()>. With no argument, the accessor returns a reference to the element's whole array (whether or not the element was -specified as C<'@'> or C<'*@'). +specified as C<'@'> or C<'*@'>). With one or two arguments, the first argument is an index specifying one element of the array; the second argument, if @@ -370,7 +370,7 @@ The element is a hash, initialized by default to C<()>. With no argument, the accessor returns a reference to the element's whole hash (whether or not the element was -specified as C<'%'> or C<'*%'). +specified as C<'%'> or C<'*%'>). With one or two arguments, the first argument is a key specifying one element of the hash; the second argument, if present, is @@ -520,6 +520,7 @@ struct's constructor. print "(which was a ", $cat->breed->name, ")\n"; print "had two kittens: ", join(' and ', @{$cat->kittens}), "\n"; +=back =head1 Author and Modification History diff --git a/lib/File/Find.pm b/lib/File/Find.pm index 0485bce8ed..9963d8198b 100644 --- a/lib/File/Find.pm +++ b/lib/File/Find.pm @@ -53,12 +53,12 @@ If either I<follow> or I<follow_fast> is in effect: =over 6 -=item +=item * It is guarantueed that an I<lstat> has been called before the user's I<wanted()> function is called. This enables fast file checks involving S< _>. -=item +=item * There is a variable C<$File::Find::fullname> which holds the absolute pathname of the file with all symbolic links resolved diff --git a/lib/File/Spec/VMS.pm b/lib/File/Spec/VMS.pm index 00c068accb..79491463cd 100644 --- a/lib/File/Spec/VMS.pm +++ b/lib/File/Spec/VMS.pm @@ -22,6 +22,8 @@ See File::Spec::Unix for a documentation of the methods provided there. This package overrides the implementation of these methods, not the semantics. +=over + =item eliminate_macros Expands MM[KS]/Make macros in a text string, using the contents of @@ -111,6 +113,7 @@ sub fixpath { $fixedpath; } +=back =head2 Methods always loaded diff --git a/lib/Pod/Html.pm b/lib/Pod/Html.pm index c2f8865c59..4d77bc0a11 100644 --- a/lib/Pod/Html.pm +++ b/lib/Pod/Html.pm @@ -466,7 +466,7 @@ END_OF_HEAD process_over(); } elsif (/^=back/) { # =back process_back(); - } elsif (/^=for\s+(\S+)\s+(.*)/si) {# =for + } elsif (/^=for\s+(\S+)\s*(.*)/si) {# =for process_for($1,$2); } else { /^=(\S*)\s*/; diff --git a/lib/SelfLoader.pm b/lib/SelfLoader.pm index 4672ac49da..2aa29303fd 100644 --- a/lib/SelfLoader.pm +++ b/lib/SelfLoader.pm @@ -3,7 +3,7 @@ package SelfLoader; require Exporter; @ISA = qw(Exporter); @EXPORT = qw(AUTOLOAD); -$VERSION = "1.09"; +$VERSION = "1.0901"; sub Version {$VERSION} $DEBUG = 0; @@ -12,7 +12,7 @@ my %Cache; # private cache for all SelfLoader's client packages # allow checking for valid ': attrlist' attachments my $nested; $nested = qr{ \( (?: (?> [^()]+ ) | (?p{ $nested }) )* \) }x; -my $one_attr = qr{ (?> (?! \d) \w+ (?:$nested)? ) [\s,]* }x; +my $one_attr = qr{ (?> (?! \d) \w+ (?:$nested)? ) (?:\s*\:\s*|\s+(?!\:)) }x; my $attr_list = qr{ \s* : \s* (?: $one_attr )* }x; sub croak { require Carp; goto &Carp::croak } diff --git a/lib/UNIVERSAL.pm b/lib/UNIVERSAL.pm index dc02423029..13cce5853b 100644 --- a/lib/UNIVERSAL.pm +++ b/lib/UNIVERSAL.pm @@ -67,12 +67,12 @@ of the following statements is true. =over 8 -=item +=item * C<VAL> is a blessed reference and is blessed into package C<TYPE> or inherits from package C<TYPE> -=item +=item * C<VAL> is a reference to a C<TYPE> of perl variable (er 'HASH') diff --git a/lib/attributes.pm b/lib/attributes.pm index 09f355139f..bbbb8b78ee 100644 --- a/lib/attributes.pm +++ b/lib/attributes.pm @@ -1,6 +1,6 @@ package attributes; -$VERSION = 0.02; +$VERSION = 0.03; @EXPORT_OK = qw(get reftype); @EXPORT = (); @@ -54,7 +54,7 @@ sub import { my $s = ((@pkgattrs == 1) ? '' : 's'); carp "$svtype package attribute$s " . "may clash with future reserved word$s: " . - join(' , ' , @pkgattrs); + join(' : ' , @pkgattrs); } } } @@ -65,7 +65,7 @@ sub import { croak "Invalid $svtype attribute" . (( @badattrs == 1 ) ? '' : 's') . ": " . - join(' , ', @badattrs); + join(' : ', @badattrs); } } @@ -267,7 +267,8 @@ will use that package name. =head2 Syntax of Attribute Lists An attribute list is a sequence of attribute specifications, separated by -whitespace, commas, or both. Each attribute specification is a simple +whitespace or a colon (with optional whitespace). +Each attribute specification is a simple name, optionally followed by a parenthesised parameter list. If such a parameter list is present, it is scanned past as for the rules for the C<q()> operator. (See L<perlop/"Quote and Quote-like Operators">.) @@ -275,8 +276,8 @@ The parameter list is passed as it was found, however, and not as per C<q()>. Some examples of syntactically valid attribute lists: - switch(10,foo(7,3)) , , expensive - Ugly('\(") , Bad + switch(10,foo(7,3)) : expensive + Ugly('\(") :Bad _5x5 locked method @@ -286,7 +287,7 @@ Some examples of syntactically invalid attribute lists (with annotation): Ugly('(') # ()-string not balanced 5x5 # "5x5" not a valid identifier Y2::north # "Y2::north" not a simple identifier - foo + bar # "+" neither a comma nor whitespace + foo + bar # "+" neither a colon nor whitespace =head1 EXPORTS diff --git a/lib/constant.pm b/lib/constant.pm index 01570ca49f..bbfdb78ec4 100644 --- a/lib/constant.pm +++ b/lib/constant.pm @@ -9,7 +9,7 @@ $VERSION = '1.01'; #======================================================================= # Some names are evil choices. -my %keywords = map +($_, 1), qw{ BEGIN INIT STOP END DESTROY AUTOLOAD }; +my %keywords = map +($_, 1), qw{ BEGIN INIT CHECK END DESTROY AUTOLOAD }; my %forced_into_main = map +($_, 1), qw{ STDIN STDOUT STDERR ARGV ARGVOUT ENV INC SIG }; diff --git a/makedef.pl b/makedef.pl index eb927198e5..9c2e96ac48 100644 --- a/makedef.pl +++ b/makedef.pl @@ -95,24 +95,20 @@ while (<CFG>) { $define{$1} = 1 if /^\s*#\s*define\s+(USE_ITHREADS)\b/; $define{$1} = 1 if /^\s*#\s*define\s+(USE_PERLIO)\b/; $define{$1} = 1 if /^\s*#\s*define\s+(MULTIPLICITY)\b/; + $define{$1} = 1 if /^\s*#\s*define\s+(PERL_IMPLICIT_SYS)\b/; $define{$1} = 1 if /^\s*#\s*define\s+(PERL_BINCOMPAT_5005)\b/; } close(CFG); if ($PLATFORM eq 'win32') { warn join(' ',keys %define)."\n"; - if ($define{PERL_OBJECT} || $define{MULTIPLICITY}) { - print "LIBRARY Perl56\n"; - print "DESCRIPTION 'Perl interpreter'\n"; - print "EXPORTS\n"; + print "LIBRARY Perl56\n"; + print "DESCRIPTION 'Perl interpreter'\n"; + print "EXPORTS\n"; + if ($define{PERL_IMPLICIT_SYS}) { output_symbol("perl_get_host_info"); output_symbol("perl_alloc_override"); } - else { - print "LIBRARY Perl56\n"; - print "DESCRIPTION 'Perl interpreter, export autogenerated'\n"; - print "EXPORTS\n"; - } } elsif ($PLATFORM eq 'os2') { ($v = $]) =~ s/(\d\.\d\d\d)(\d\d)$/$1_$2/; @@ -4547,7 +4547,7 @@ Perl_newATTRSUB(pTHX_ I32 floor, OP *o, OP *proto, OP *attrs, OP *block) else s = name; - if (*s != 'B' && *s != 'E' && *s != 'S' && *s != 'I') + if (*s != 'B' && *s != 'E' && *s != 'C' && *s != 'I') goto done; if (strEQ(s, "BEGIN")) { @@ -4577,12 +4577,12 @@ Perl_newATTRSUB(pTHX_ I32 floor, OP *o, OP *proto, OP *attrs, OP *block) av_store(PL_endav, 0, SvREFCNT_inc(cv)); GvCV(gv) = 0; } - else if (strEQ(s, "STOP") && !PL_error_count) { - if (!PL_stopav) - PL_stopav = newAV(); + else if (strEQ(s, "CHECK") && !PL_error_count) { + if (!PL_checkav) + PL_checkav = newAV(); DEBUG_x( dump_sub(gv) ); - av_unshift(PL_stopav, 1); - av_store(PL_stopav, 0, SvREFCNT_inc(cv)); + av_unshift(PL_checkav, 1); + av_store(PL_checkav, 0, SvREFCNT_inc(cv)); GvCV(gv) = 0; } else if (strEQ(s, "INIT") && !PL_error_count) { @@ -4693,7 +4693,7 @@ Perl_newXS(pTHX_ char *name, XSUBADDR_t subaddr, char *filename) else s = name; - if (*s != 'B' && *s != 'E' && *s != 'S' && *s != 'I') + if (*s != 'B' && *s != 'E' && *s != 'C' && *s != 'I') goto done; if (strEQ(s, "BEGIN")) { @@ -4709,11 +4709,11 @@ Perl_newXS(pTHX_ char *name, XSUBADDR_t subaddr, char *filename) av_store(PL_endav, 0, SvREFCNT_inc(cv)); GvCV(gv) = 0; } - else if (strEQ(s, "STOP")) { - if (!PL_stopav) - PL_stopav = newAV(); - av_unshift(PL_stopav, 1); - av_store(PL_stopav, 0, SvREFCNT_inc(cv)); + else if (strEQ(s, "CHECK")) { + if (!PL_checkav) + PL_checkav = newAV(); + av_unshift(PL_checkav, 1); + av_store(PL_checkav, 0, SvREFCNT_inc(cv)); GvCV(gv) = 0; } else if (strEQ(s, "INIT")) { @@ -453,11 +453,11 @@ perl_destruct(pTHXx) /* startup and shutdown function lists */ SvREFCNT_dec(PL_beginav); SvREFCNT_dec(PL_endav); - SvREFCNT_dec(PL_stopav); + SvREFCNT_dec(PL_checkav); SvREFCNT_dec(PL_initav); PL_beginav = Nullav; PL_endav = Nullav; - PL_stopav = Nullav; + PL_checkav = Nullav; PL_initav = Nullav; /* shortcuts just get cleared */ @@ -742,8 +742,8 @@ setuid perl scripts securely.\n"); env, xsinit); switch (ret) { case 0: - if (PL_stopav) - call_list(oldscope, PL_stopav); + if (PL_checkav) + call_list(oldscope, PL_checkav); return 0; case 1: STATUS_ALL_FAILURE; @@ -754,8 +754,8 @@ setuid perl scripts securely.\n"); LEAVE; FREETMPS; PL_curstash = PL_defstash; - if (PL_stopav) - call_list(oldscope, PL_stopav); + if (PL_checkav) + call_list(oldscope, PL_checkav); return STATUS_NATIVE_EXPORT; case 3: PerlIO_printf(Perl_error_log, "panic: top_env\n"); @@ -3180,7 +3180,7 @@ Perl_call_list(pTHX_ I32 oldscope, AV *paramList) else Perl_sv_catpvf(aTHX_ atsv, "%s failed--call queue aborted", - paramList == PL_stopav ? "STOP" + paramList == PL_checkav ? "CHECK" : paramList == PL_initav ? "INIT" : "END"); while (PL_scopestack_ix > oldscope) @@ -3204,7 +3204,7 @@ Perl_call_list(pTHX_ I32 oldscope, AV *paramList) Perl_croak(aTHX_ "BEGIN failed--compilation aborted"); else Perl_croak(aTHX_ "%s failed--call queue aborted", - paramList == PL_stopav ? "STOP" + paramList == PL_checkav ? "CHECK" : paramList == PL_initav ? "INIT" : "END"); } @@ -136,6 +136,8 @@ START_EXTERN_C #define PL_bufend (*Perl_Ibufend_ptr(aTHXo)) #undef PL_bufptr #define PL_bufptr (*Perl_Ibufptr_ptr(aTHXo)) +#undef PL_checkav +#define PL_checkav (*Perl_Icheckav_ptr(aTHXo)) #undef PL_collation_ix #define PL_collation_ix (*Perl_Icollation_ix_ptr(aTHXo)) #undef PL_collation_name @@ -472,8 +474,6 @@ START_EXTERN_C #define PL_stderrgv (*Perl_Istderrgv_ptr(aTHXo)) #undef PL_stdingv #define PL_stdingv (*Perl_Istdingv_ptr(aTHXo)) -#undef PL_stopav -#define PL_stopav (*Perl_Istopav_ptr(aTHXo)) #undef PL_strtab #define PL_strtab (*Perl_Istrtab_ptr(aTHXo)) #undef PL_strtab_mutex @@ -1826,7 +1826,7 @@ case 59: #line 338 "perly.y" { STRLEN n_a; char *name = SvPV(((SVOP*)yyvsp[0].opval)->op_sv,n_a); if (strEQ(name, "BEGIN") || strEQ(name, "END") - || strEQ(name, "STOP") || strEQ(name, "INIT")) + || strEQ(name, "INIT") || strEQ(name, "CHECK")) CvSPECIAL_on(PL_compcv); yyval.opval = yyvsp[0].opval; } break; @@ -337,7 +337,7 @@ startformsub: /* NULL */ /* start a format subroutine scope */ subname : WORD { STRLEN n_a; char *name = SvPV(((SVOP*)$1)->op_sv,n_a); if (strEQ(name, "BEGIN") || strEQ(name, "END") - || strEQ(name, "STOP") || strEQ(name, "INIT")) + || strEQ(name, "INIT") || strEQ(name, "CHECK")) CvSPECIAL_on(PL_compcv); $$ = $1; } ; diff --git a/pod/buildtoc b/pod/buildtoc index 41cb76dcb5..8192b5bd3d 100644 --- a/pod/buildtoc +++ b/pod/buildtoc @@ -114,6 +114,8 @@ podset( @modules[ sort { $modname[$a] cmp $modname[$b] } 0 .. $#modules ] ); Here should be listed all the extra programs' documentation, but they don't all have manual pages yet: + =over + =item a2p =item s2p @@ -132,6 +134,7 @@ podset( @modules[ sort { $modname[$a] cmp $modname[$b] } 0 .. $#modules ] ); =item wrapsuid + =back =head1 AUTHOR @@ -150,8 +153,7 @@ sub podset { while(<>) { if (s/^=head1 (NAME)\s*/=head2 /) { $pod = path2modname($ARGV); - unitem(); - unhead2(); + unhead1(); output "\n \n\n=head2 "; $_ = <>; if ( /^\s*$pod\b/ ) { @@ -164,7 +166,9 @@ sub podset { next; } if (s/^=head1 (.*)/=item $1/) { - unitem(); unhead2(); + unhead2(); + output "=over\n\n" unless $inhead1; + $inhead1 = 1; output $_; nl(); next; } if (s/^=head2 (.*)/=item $1/) { @@ -172,7 +176,6 @@ sub podset { output "=over\n\n" unless $inhead2; $inhead2 = 1; output $_; nl(); next; - } if (s/^=item ([^=].*)\n/$1/) { next if $pod eq 'perldiag'; @@ -188,6 +191,10 @@ sub podset { s/^-X\b/-I<X>/; output $_; next; } + if (s/^=cut\s*\n//) { + unhead1(); + next; + } } } @@ -200,12 +207,20 @@ sub path2modname { return $_; } +sub unhead1 { + unhead2(); + if ($inhead1) { + output "\n\n=back\n\n"; + } + $inhead1 = 0; +} + sub unhead2 { + unitem(); if ($inhead2) { output "\n\n=back\n\n"; } $inhead2 = 0; - $initem = 0; } sub unitem { diff --git a/pod/perlcompile.pod b/pod/perlcompile.pod index 0ba94187db..04dc019b36 100644 --- a/pod/perlcompile.pod +++ b/pod/perlcompile.pod @@ -409,7 +409,7 @@ formats are defined and used within a program and the modules it loads. See L</"The Cross Referencing Back End"> for details about usage. -=cut +=back =head1 KNOWN PROBLEMS diff --git a/pod/perldelta.pod b/pod/perldelta.pod index a48aa044d2..f61ee697c1 100644 --- a/pod/perldelta.pod +++ b/pod/perldelta.pod @@ -24,10 +24,10 @@ responsibility to ensure that warnings are enabled judiciously. =over 4 -=item STOP is a new keyword +=item CHECK is a new keyword In addition to C<BEGIN>, C<INIT>, C<END>, C<DESTROY> and C<AUTOLOAD>, -subroutines named C<STOP> are now special. These are queued up during +subroutines named C<CHECK> are now special. These are queued up during compilation and behave similar to END blocks, except they are called at the end of compilation rather than at the end of execution. They cannot be called directly. @@ -679,9 +679,9 @@ as requiring an automatic lock() when it is entered, you had to declare that with a C<use attrs> pragma in the body of the subroutine. That can now be accomplished with a declaration syntax, like this: - sub mymethod : locked, method ; + sub mymethod : locked method ; ... - sub mymethod : locked, method { + sub mymethod : locked :method { ... } @@ -925,7 +925,7 @@ run in compile-only mode. Since this is typically not the expected behavior, END blocks are not executed anymore when the C<-c> switch is used. -See L<STOP blocks> for how to run things when the compile phase ends. +See L<CHECK blocks> for how to run things when the compile phase ends. =head2 Potential to leak DATA filehandles @@ -1914,14 +1914,14 @@ The offending range is now explicitly displayed. =item Invalid separator character %s in attribute list -(F) Something other than a comma or whitespace was seen between the +(F) Something other than a colon or whitespace was seen between the elements of an attribute list. If the previous attribute had a parenthesised parameter list, perhaps that list was terminated too soon. See L<attributes>. =item Invalid separator character %s in subroutine attribute list -(F) Something other than a comma or whitespace was seen between the +(F) Something other than a colon or whitespace was seen between the elements of a subroutine attribute list. If the previous attribute had a parenthesised parameter list, perhaps that list was terminated too soon. diff --git a/pod/perldiag.pod b/pod/perldiag.pod index 9c5b33ee7c..b7e115fb71 100644 --- a/pod/perldiag.pod +++ b/pod/perldiag.pod @@ -1342,7 +1342,7 @@ unlikely to be what you want. =item %s failed--call queue aborted -(F) An untrapped exception was raised while executing a STOP, INIT, or +(F) An untrapped exception was raised while executing a CHECK, INIT, or END subroutine. Processing of the remainder of the queue of such routines has been prematurely ended. @@ -1745,7 +1745,7 @@ See L<perlfunc/sprintf>. =item Invalid separator character %s in attribute list -(F) Something other than a comma or whitespace was seen between the +(F) Something other than a colon or whitespace was seen between the elements of an attribute list. If the previous attribute had a parenthesised parameter list, perhaps that list was terminated too soon. See L<attributes>. diff --git a/pod/perlfork.pod b/pod/perlfork.pod index 533dcfab31..6c11b5e662 100644 --- a/pod/perlfork.pod +++ b/pod/perlfork.pod @@ -217,6 +217,8 @@ representation for pseudo-process IDs will be implemented in future. This document may be incomplete in some respects. +=back + =head1 AUTHOR Support for concurrent interpreters and the fork() emulation was implemented diff --git a/pod/perlfunc.pod b/pod/perlfunc.pod index dbefd85ee4..905c444e5e 100644 --- a/pod/perlfunc.pod +++ b/pod/perlfunc.pod @@ -3902,7 +3902,7 @@ array by 1 and moving everything down. If there are no elements in the array, returns the undefined value. If ARRAY is omitted, shifts the C<@_> array within the lexical scope of subroutines and formats, and the C<@ARGV> array at file scopes or within the lexical scopes established by -the C<eval ''>, C<BEGIN {}>, C<INIT {}>, C<STOP {}>, and C<END {}> +the C<eval ''>, C<BEGIN {}>, C<INIT {}>, C<CHECK {}>, and C<END {}> constructs. See also C<unshift>, C<push>, and C<pop>. C<Shift()> and C<unshift> do the diff --git a/pod/perlmod.pod b/pod/perlmod.pod index 351ba73c5a..994c3eb5dc 100644 --- a/pod/perlmod.pod +++ b/pod/perlmod.pod @@ -213,7 +213,7 @@ This also has implications for the use of the SUPER:: qualifier =head2 Package Constructors and Destructors Four special subroutines act as package constructors and destructors. -These are the C<BEGIN>, C<STOP>, C<INIT>, and C<END> routines. The +These are the C<BEGIN>, C<CHECK>, C<INIT>, and C<END> routines. The C<sub> is optional for these routines. A C<BEGIN> subroutine is executed as soon as possible, that is, the moment @@ -245,9 +245,9 @@ Perl runtime begins execution, in "first in, first out" (FIFO) order. For example, the code generators documented in L<perlcc> make use of C<INIT> blocks to initialize and resolve pointers to XSUBs. -Similar to C<END> blocks, C<STOP> blocks are run just after the +Similar to C<END> blocks, C<CHECK> blocks are run just after the Perl compile phase ends and before the run time begins, in -LIFO order. C<STOP> blocks are again useful in the Perl compiler +LIFO order. C<CHECK> blocks are again useful in the Perl compiler suite to save the compiled state of the program. When you use the B<-n> and B<-p> switches to Perl, C<BEGIN> and diff --git a/pod/perlre.pod b/pod/perlre.pod index 70ec00c6cb..d2f64d2eb6 100644 --- a/pod/perlre.pod +++ b/pod/perlre.pod @@ -269,8 +269,6 @@ Any punctuation character. Any hexadecimal digit. Though this may feel silly (/0-9a-f/i would work just fine) it is included for completeness. -=item - =back You can negate the [::] character classes by prefixing the class name diff --git a/pod/perlrun.pod b/pod/perlrun.pod index 5eb3b829f0..f668d53178 100644 --- a/pod/perlrun.pod +++ b/pod/perlrun.pod @@ -268,7 +268,7 @@ An alternate delimiter may be specified using B<-F>. =item B<-c> causes Perl to check the syntax of the program and then exit without -executing it. Actually, it I<will> execute C<BEGIN>, C<STOP>, and +executing it. Actually, it I<will> execute C<BEGIN>, C<CHECK>, and C<use> blocks, because these are considered as occurring outside the execution of your program. C<INIT> and C<END> blocks, however, will be skipped. diff --git a/pod/perlsub.pod b/pod/perlsub.pod index 4ec11f99d4..927e944c93 100644 --- a/pod/perlsub.pod +++ b/pod/perlsub.pod @@ -207,7 +207,7 @@ core, as are modules whose names are in all lower case. A function in all capitals is a loosely-held convention meaning it will be called indirectly by the run-time system itself, usually due to a triggered event. Functions that do special, pre-defined -things include C<BEGIN>, C<STOP>, C<INIT>, C<END>, C<AUTOLOAD>, and +things include C<BEGIN>, C<CHECK>, C<INIT>, C<END>, C<AUTOLOAD>, and C<DESTROY>--plus all functions mentioned in L<perltie>. =head2 Private Variables via my() @@ -454,7 +454,7 @@ starts to run: } See L<perlmod/"Package Constructors and Destructors"> about the -special triggered functions, C<BEGIN>, C<STOP>, C<INIT> and C<END>. +special triggered functions, C<BEGIN>, C<CHECK>, C<INIT> and C<END>. If declared at the outermost scope (the file scope), then lexicals work somewhat like C's file statics. They are available to all @@ -1230,7 +1230,7 @@ functions to Perl code in L<perlxs>. A subroutine declaration or definition may have a list of attributes associated with it. If such an attribute list is present, it is -broken up at space or comma boundaries and treated as though a +broken up at space or colon boundaries and treated as though a C<use attributes> had been seen. See L<attributes> for details about what attributes are currently supported. Unlike the limitation with the obsolescent C<use attrs>, the @@ -1244,8 +1244,8 @@ nest properly. Examples of valid syntax (even though the attributes are unknown): - sub fnord (&\%) : switch(10,foo(7,3)) , , expensive ; - sub plugh () : Ugly('\(") , Bad ; + sub fnord (&\%) : switch(10,foo(7,3)) : expensive ; + sub plugh () : Ugly('\(") :Bad ; sub xyzzy : _5x5 { ... } Examples of invalid syntax: @@ -1254,7 +1254,7 @@ Examples of invalid syntax: sub snoid : Ugly('(') ; # ()-string not balanced sub xyzzy : 5x5 ; # "5x5" not a valid identifier sub plugh : Y2::north ; # "Y2::north" not a simple identifier - sub snurt : foo + bar ; # "+" not a comma or space + sub snurt : foo + bar ; # "+" not a colon or space The attribute list is passed as a list of constant strings to the code which associates them with the subroutine. In particular, the second example diff --git a/pod/perltoc.pod b/pod/perltoc.pod index dee5951db5..8f56d7a9eb 100644 --- a/pod/perltoc.pod +++ b/pod/perltoc.pod @@ -13,6 +13,8 @@ through to locate the proper section you're looking for. =head2 perl - Practical Extraction and Report Language +=over + =item SYNOPSIS =item DESCRIPTION @@ -43,9 +45,13 @@ environment, with integrated editor support, POSIX 1003.1 compliant library =item NOTES +=back + =head2 perlfaq - frequently asked questions about Perl ($Date: 1999/05/23 20:38:02 $) +=over + =item DESCRIPTION perlfaq: Structural overview of the FAQ, L<perlfaq1>: General Questions @@ -293,9 +299,13 @@ authors 23/May/99, 13/April/99, 7/January/99, 22/June/98, 24/April/97, 23/April/97, 25/March/97, 18/March/97, 17/March/97 Version, Initial Release: 11/March/97 +=back + =head2 perlfaq1 - General Questions About Perl ($Revision: 1.23 $, $Date: 1999/05/23 16:08:30 $) +=over + =item DESCRIPTION =over @@ -336,8 +346,12 @@ Scheme, or Tcl? =item AUTHOR AND COPYRIGHT -=head2 perlfaq2 - Obtaining and Learning about Perl ($Revision: 1.31 $, -$Date: 1999/04/14 03:46:19 $) +=back + +=head2 perlfaq2 - Obtaining and Learning about Perl ($Revision: 1.32 $, +$Date: 1999/10/14 18:46:09 $) + +=over =item DESCRIPTION @@ -385,15 +399,19 @@ References, Tutorials =item Where do I send bug reports? -=item What is perl.com? +=item What is perl.com? Perl Mongers? pm.org? perl.org? =back =item AUTHOR AND COPYRIGHT +=back + =head2 perlfaq3 - Programming Tools ($Revision: 1.38 $, $Date: 1999/05/23 16:08:30 $) +=over + =item DESCRIPTION =over @@ -468,9 +486,13 @@ mean? =item AUTHOR AND COPYRIGHT +=back + =head2 perlfaq4 - Data Manipulation ($Revision: 1.49 $, $Date: 1999/05/23 20:37:49 $) +=over + =item DESCRIPTION =item Data: Numbers @@ -677,9 +699,13 @@ array of hashes or arrays? =item AUTHOR AND COPYRIGHT +=back + =head2 perlfaq5 - Files and Formats ($Revision: 1.38 $, $Date: 1999/05/23 16:08:30 $) +=over + =item DESCRIPTION =over @@ -764,8 +790,12 @@ protected files? Isn't this a bug in Perl? =item AUTHOR AND COPYRIGHT +=back + =head2 perlfaq6 - Regexes ($Revision: 1.27 $, $Date: 1999/05/23 16:08:30 $) +=over + =item DESCRIPTION =over @@ -826,9 +856,13 @@ file? =item AUTHOR AND COPYRIGHT +=back + =head2 perlfaq7 - Perl Language Issues ($Revision: 1.28 $, $Date: 1999/05/23 20:36:18 $) +=over + =item DESCRIPTION =over @@ -901,9 +935,13 @@ is in scope? =item AUTHOR AND COPYRIGHT +=back + =head2 perlfaq8 - System Interaction ($Revision: 1.39 $, $Date: 1999/05/23 18:37:57 $) +=over + =item DESCRIPTION =over @@ -1027,9 +1065,13 @@ search path? =item AUTHOR AND COPYRIGHT +=back + =head2 perlfaq9 - Networking ($Revision: 1.26 $, $Date: 1999/05/23 16:08:30 $) +=over + =item DESCRIPTION =over @@ -1089,7 +1131,11 @@ CGI script to do bad things? =item AUTHOR AND COPYRIGHT -=head2 perldelta - what's new for perl v5.6 (as of v5.005_62) +=back + +=head2 perldelta - what's new for perl v5.6 (as of v5.005_64) + +=over =item DESCRIPTION @@ -1099,18 +1145,19 @@ CGI script to do bad things? =item Perl Source Incompatibilities -Treatment of list slices of undef has changed, Possibly changed -pseudo-random number generator, Hashing function for hash keys has changed, -C<undef> fails on read only values, Close-on-exec bit may be set on pipe() -handles, Writing C<"$$1"> to mean C<"${$}1"> is unsupported, values(%h) and -C<\(%h)> operate on aliases to values, not copies, vec(EXPR,OFFSET,BITS) -enforces powers-of-two BITS, Text of some diagnostic output has changed, -C<%@> has been removed +CHECK is a new keyword, Treatment of list slices of undef has changed, +Possibly changed pseudo-random number generator, Hashing function for hash +keys has changed, C<undef> fails on read only values, Close-on-exec bit may +be set on pipe() handles, Writing C<"$$1"> to mean C<"${$}1"> is +unsupported, delete(), values() and C<\(%h)> operate on aliases to values, +not copies, vec(EXPR,OFFSET,BITS) enforces powers-of-two BITS, Text of some +diagnostic output has changed, C<%@> has been removed, Parenthesized not() +behaves like a list operator, Semantics of bareword prototype C<(*)> have +changed =item C Source Incompatibilities -C<PERL_POLLUTE>, C<PERL_IMPLICIT_CONTEXT>, C<PERL_POLLUTE_MALLOC>, C<PL_na> -and C<dTHR> Issues +C<PERL_POLLUTE>, C<PERL_IMPLICIT_CONTEXT>, C<PERL_POLLUTE_MALLOC> =item Compatible C Source API Changes @@ -1140,7 +1187,7 @@ C<PATCHLEVEL> is now C<PERL_VERSION>, Support for C++ exceptions =item C<-A> flag -=item New Installation Scheme +=item Enhanced Installation Directories =back @@ -1150,6 +1197,8 @@ C<PATCHLEVEL> is now C<PERL_VERSION>, Support for C++ exceptions =item Unicode and UTF-8 support +=item Interpreter threads + =item Lexically scoped warning categories =item Lvalue subroutines @@ -1158,20 +1207,30 @@ C<PATCHLEVEL> is now C<PERL_VERSION>, Support for C++ exceptions =item Weak references +=item File globbing implemented internally + =item Binary numbers supported =item Some arrows may be omitted in calls through references +=item exists() is supported on subroutine names + +=item exists() and delete() are supported on array elements + =item syswrite() ease-of-use -=item Filehandles can be autovivified +=item File and directory handles can be autovivified =item 64-bit support =item Large file support +=item Long doubles + =item "more bits" +=item Enhanced support for sort() subroutines + =item Better syntax checks on parenthesized unary operators =item POSIX character class syntax [: :] supported @@ -1224,6 +1283,8 @@ C<PATCHLEVEL> is now C<PERL_VERSION>, Support for C++ exceptions =item Where possible, buffered data discarded from duped input filehandle +=item eof() has the same old magic as <> + =item system(), backticks and pipe open now reflect exec() failure =item Implicitly closed filehandles are safer @@ -1304,12 +1365,12 @@ C<PATCHLEVEL> is now C<PERL_VERSION>, Support for C++ exceptions =item Modules -attributes, B, ByteLoader, B, constant, charnames, Data::Dumper, DB, -DB_File, Devel::DProf, Dumpvalue, Benchmark, Devel::Peek, -ExtUtils::MakeMaker, Fcntl, File::Compare, File::Find, File::Spec, -File::Spec::Functions, Getopt::Long, IO, JPL, Math::BigInt, Math::Complex, -Math::Trig, Pod::Parser, Pod::Text and Pod::Man, SDBM_File, Time::Local, -Win32, DBM Filters +attributes, B, ByteLoader, constant, charnames, Data::Dumper, DB, DB_File, +Devel::DProf, Dumpvalue, Benchmark, Devel::Peek, ExtUtils::MakeMaker, +Fcntl, File::Compare, File::Find, File::Glob, File::Spec, +File::Spec::Functions, Getopt::Long, IO, JPL, lib, Math::BigInt, +Math::Complex, Math::Trig, Pod::Parser, Pod::Text and Pod::Man, SDBM_File, +Time::Local, Win32, DBM Filters =item Pragmata @@ -1329,44 +1390,55 @@ Win32, DBM Filters =item Documentation Changes -perlopentut.pod, perlreftut.pod, perltootc.pod, perlcompile.pod - -=item New Diagnostics - -"my sub" not yet implemented, '!' allowed only after types %s, / cannot -take a count, / must be followed by a, A or Z, / must be followed by a*, A* -or Z*, / must follow a numeric type, Repeat count in pack overflows, Repeat -count in unpack overflows, /%s/: Unrecognized escape \\%c passed through, -/%s/ should probably be written as "%s", %s() called too early to check -prototype, %s package attribute may clash with future reserved word: %s, - (in cleanup) %s, <> should be quotes, Attempt to join self, Bad +perlcompile.pod, perlfilter.pod, perlhack.pod, perlopentut.pod, +perlreftut.pod, perltootc.pod + +=item New or Changed Diagnostics + +"%s" variable %s masks earlier declaration in same %s, "my sub" not yet +implemented, "our" variable %s redeclared, '!' allowed only after types %s, +/ cannot take a count, / must be followed by a, A or Z, / must be followed +by a*, A* or Z*, / must follow a numeric type, /%s/: Unrecognized escape +\\%c passed through, /%s/: Unrecognized escape \\%c in character class +passed through, /%s/ should probably be written as "%s", %s() called too +early to check prototype, %s argument is not a HASH or ARRAY element, %s +argument is not a HASH or ARRAY element or slice, %s argument is not a +subroutine name, %s package attribute may clash with future reserved word: +%s, (in cleanup) %s, <> should be quotes, Attempt to join self, Bad evalled substitution pattern, Bad realloc() ignored, Binary number > 0b11111111111111111111111111111111 non-portable, Bit vector size > 32 non-portable, Buffer overflow in prime_env_iter: %s, Can't check filesystem -of script "%s", Can't modify non-lvalue subroutine call, Can't read CRTL -environ, Can't remove %s: %s, skipping file, Can't return %s from lvalue -subroutine, Can't weaken a nonreference, Character class [:%s:] unknown, -Character class syntax [%s] belongs inside character classes, Constant is -not %s reference, constant(%s): %%^H is not localized, constant(%s): %s, -defined(@array) is deprecated, defined(%hash) is deprecated, Did not -produce a valid header, Document contains no data, entering effective %s -failed, Filehandle %s opened only for output, Hexadecimal number > -0xffffffff non-portable, Ill-formed CRTL environ value "%s", Ill-formed -message in prime_env_iter: |%s|, Illegal binary digit %s, Illegal binary -digit %s ignored, Illegal number of bits in vec, Integer overflow in %s -number, Invalid %s attribute: %s, Invalid %s attributes: %s, Invalid -separator character %s in attribute list, Invalid separator character %s in -subroutine attribute list, leaving effective %s failed, Lvalue subs -returning %s not implemented yet, Method %s not permitted, Missing -%sbrace%s on \N{}, Missing command in piped open, Missing name in "my sub", -no UTC offset information; assuming local time is UTC, Octal number > -037777777777 non-portable, panic: del_backref, panic: kid popen errno read, -panic: magic_killbackrefs, Possible Y2K bug: %s, Premature end of script -headers, realloc() of freed memory ignored, Reference is already weak, -setpgrp can't take arguments, Strange *+?{} on zero-length expression, -switching effective %s is not implemented, This Perl can't reset CRTL -eviron elements (%s), This Perl can't set CRTL environ elements (%s=%s), -Unknown open() mode '%s', Unknown process %x sent message to +of script "%s", Can't declare class for non-scalar %s in "%s", Can't +declare %s in "%s", Can't ignore signal CHLD, forcing to default, Can't +modify non-lvalue subroutine call, Can't read CRTL environ, Can't remove +%s: %s, skipping file, Can't return %s from lvalue subroutine, Can't weaken +a nonreference, Character class [:%s:] unknown, Character class syntax [%s] +belongs inside character classes, Constant is not %s reference, +constant(%s): %%^H is not localized, constant(%s): %s, defined(@array) is +deprecated, defined(%hash) is deprecated, Did not produce a valid header, +Did you mean "local" instead of "our"?, Document contains no data, entering +effective %s failed, false [] range "%s" in regexp, Filehandle %s opened +only for output, flock() on closed filehandle %s, Global symbol "%s" +requires explicit package name, Hexadecimal number > 0xffffffff +non-portable, Ill-formed CRTL environ value "%s", Ill-formed message in +prime_env_iter: |%s|, Illegal binary digit %s, Illegal binary digit %s +ignored, Illegal number of bits in vec, Integer overflow in %s number, +Invalid %s attribute: %s, Invalid %s attributes: %s, invalid [] range "%s" +in regexp, Invalid separator character %s in attribute list, Invalid +separator character %s in subroutine attribute list, leaving effective %s +failed, Lvalue subs returning %s not implemented yet, Method %s not +permitted, Missing %sbrace%s on \N{}, Missing command in piped open, +Missing name in "my sub", No %s specified for -%c, No package name allowed +for variable %s in "our", No space allowed after -%c, no UTC offset +information; assuming local time is UTC, Octal number > 037777777777 +non-portable, panic: del_backref, panic: kid popen errno read, panic: +magic_killbackrefs, Parentheses missing around "%s" list, Possible Y2K bug: +%s, Premature end of script headers, Repeat count in pack overflows, Repeat +count in unpack overflows, realloc() of freed memory ignored, Reference is +already weak, setpgrp can't take arguments, Strange *+?{} on zero-length +expression, switching effective %s is not implemented, This Perl can't +reset CRTL environ elements (%s), This Perl can't set CRTL environ elements +(%s=%s), Unknown open() mode '%s', Unknown process %x sent message to prime_env_iter: %s, Unrecognized escape \\%c passed through, Unterminated attribute parameter in attribute list, Unterminated attribute list, Unterminated attribute parameter in subroutine attribute list, Unterminated @@ -1385,8 +1457,12 @@ mean "${$}<digit>" is deprecated =item HISTORY +=back + =head2 perldata - Perl data types +=over + =item DESCRIPTION =over @@ -1409,8 +1485,12 @@ mean "${$}<digit>" is deprecated =item SEE ALSO +=back + =head2 perlsyn - Perl syntax +=over + =item DESCRIPTION =over @@ -1437,8 +1517,12 @@ mean "${$}<digit>" is deprecated =back +=back + =head2 perlop - Perl operators and precedence +=over + =item SYNOPSIS =item DESCRIPTION @@ -1528,8 +1612,12 @@ regular expressions =back +=back + =head2 perlre - Perl regular expressions +=over + =item DESCRIPTION i, m, s, x @@ -1538,7 +1626,7 @@ i, m, s, x =item Regular Expressions -cntrl, graph, print, punct, xdigit, +cntrl, graph, print, punct, xdigit =item Extended Patterns @@ -1555,6 +1643,13 @@ C<(?(condition)yes-pattern|no-pattern)>, C<(?(condition)yes-pattern)> =item Repeated patterns matching zero-length substring +=item Combining pieces together + +C<ST>, C<S|T>, C<S{REPEAT_COUNT}>, C<S{min,max}>, C<S{min,max}?>, C<S?>, +C<S*>, C<S+>, C<S??>, C<S*?>, C<S+?>, C<(?E<gt>S)>, C<(?=S)>, C<(?<=S)>, +C<(?!S)>, C<(?<!S)>, C<(?p{ EXPR })>, +C<(?(condition)yes-pattern|no-pattern)> + =item Creating custom RE engines =back @@ -1563,8 +1658,12 @@ C<(?(condition)yes-pattern|no-pattern)>, C<(?(condition)yes-pattern)> =item SEE ALSO +=back + =head2 perlrun - how to execute the Perl interpreter +=over + =item SYNOPSIS =item DESCRIPTION @@ -1594,8 +1693,12 @@ B<-x> I<directory> HOME, LOGDIR, PATH, PERL5LIB, PERL5OPT, PERLLIB, PERL5DB, PERL5SHELL (specific to the Win32 port), PERL_DEBUG_MSTATS, PERL_DESTRUCT_LEVEL +=back + =head2 perlfunc - Perl builtin functions +=over + =item DESCRIPTION =over @@ -1642,13 +1745,13 @@ endnetent, endprotoent, endservent, getsockname SOCKET, getsockopt SOCKET,LEVEL,OPTNAME, glob EXPR, glob, gmtime EXPR, goto LABEL, goto EXPR, goto &NAME, grep BLOCK LIST, grep EXPR,LIST, hex EXPR, hex, import, index STR,SUBSTR,POSITION, index STR,SUBSTR, int EXPR, int, ioctl -FILEHANDLE,FUNCTION,SCALAR, join EXPR,LIST, keys HASH, kill LIST, last -LABEL, last, lc EXPR, lc, lcfirst EXPR, lcfirst, length EXPR, length, link -OLDFILE,NEWFILE, listen SOCKET,QUEUESIZE, local EXPR, localtime EXPR, lock, -log EXPR, log, lstat FILEHANDLE, lstat EXPR, lstat, m//, map BLOCK LIST, -map EXPR,LIST, mkdir FILENAME,MASK, msgctl ID,CMD,ARG, msgget KEY,FLAGS, -msgsnd ID,MSG,FLAGS, msgrcv ID,VAR,SIZE,TYPE,FLAGS, my EXPR, my EXPR : -ATTRIBUTES, next LABEL, next, no Module LIST, oct EXPR, oct, open +FILEHANDLE,FUNCTION,SCALAR, join EXPR,LIST, keys HASH, kill SIGNAL, LIST, +last LABEL, last, lc EXPR, lc, lcfirst EXPR, lcfirst, length EXPR, length, +link OLDFILE,NEWFILE, listen SOCKET,QUEUESIZE, local EXPR, localtime EXPR, +lock, log EXPR, log, lstat FILEHANDLE, lstat EXPR, lstat, m//, map BLOCK +LIST, map EXPR,LIST, mkdir FILENAME,MASK, msgctl ID,CMD,ARG, msgget +KEY,FLAGS, msgsnd ID,MSG,FLAGS, msgrcv ID,VAR,SIZE,TYPE,FLAGS, my EXPR, my +EXPR : ATTRIBUTES, next LABEL, next, no Module LIST, oct EXPR, oct, open FILEHANDLE,MODE,EXPR, open FILEHANDLE,EXPR, open FILEHANDLE, opendir DIRHANDLE,EXPR, ord EXPR, ord, our EXPR, pack TEMPLATE,LIST, package, package NAMESPACE, pipe READHANDLE,WRITEHANDLE, pop ARRAY, pop, pos SCALAR, @@ -1691,8 +1794,12 @@ PID,FLAGS, wantarray, warn LIST, write FILEHANDLE, write EXPR, write, y/// =back +=back + =head2 perlvar - Perl predefined variables +=over + =item DESCRIPTION =over @@ -1717,10 +1824,11 @@ $CHILD_ERROR, $?, $OS_ERROR, $ERRNO, $!, $EXTENDED_OS_ERROR, $^E, $EVAL_ERROR, $@, $PROCESS_ID, $PID, $$, $REAL_USER_ID, $UID, $<, $EFFECTIVE_USER_ID, $EUID, $>, $REAL_GROUP_ID, $GID, $(, $EFFECTIVE_GROUP_ID, $EGID, $), $PROGRAM_NAME, $0, $[, $PERL_VERSION, $], -$COMPILING, $^C, $DEBUGGING, $^D, $SYSTEM_FD_MAX, $^F, $^H, $INPLACE_EDIT, -$^I, $^M, $OSNAME, $^O, $PERLDB, $^P, 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, -$^R, $^S, $BASETIME, $^T, $WARNING, $^W, ${^Warnings}, $EXECUTABLE_NAME, -$^X, $ARGV, @ARGV, @INC, @_, %INC, %ENV, $ENV{expr}, %SIG, $SIG{expr} +$COMPILING, $^C, $DEBUGGING, $^D, $SYSTEM_FD_MAX, $^F, $^H, %^H, +$INPLACE_EDIT, $^I, $^M, $OSNAME, $^O, $PERLDB, $^P, 0x01, 0x02, 0x04, +0x08, 0x10, 0x20, $^R, $^S, $BASETIME, $^T, $WARNING, $^W, ${^Warnings}, +$EXECUTABLE_NAME, $^X, $ARGV, @ARGV, @INC, @_, %INC, %ENV, $ENV{expr}, +%SIG, $SIG{expr} =item Error Indicators @@ -1730,8 +1838,12 @@ $^X, $ARGV, @ARGV, @INC, @_, %INC, %ENV, $ENV{expr}, %SIG, $SIG{expr} =item BUGS +=back + =head2 perlsub - Perl subroutines +=over + =item SYNOPSIS =item DESCRIPTION @@ -1770,8 +1882,12 @@ You want to temporarily change just one element of an array or hash =item SEE ALSO +=back + =head2 perlmod - Perl modules (packages and symbol tables) +=over + =item DESCRIPTION =over @@ -1790,8 +1906,12 @@ You want to temporarily change just one element of an array or hash =item SEE ALSO +=back + =head2 perlmodlib - constructing new Perl modules and finding existing ones +=over + =item DESCRIPTION =item THE PERL MODULE LIBRARY @@ -1800,42 +1920,42 @@ You want to temporarily change just one element of an array or hash =item Pragmatic Modules -attributes, attrs, autouse, base, blib, constant, diagnostics, fields, -filetest, integer, less, lib, locale, ops, overload, re, sigtrap, strict, -subs, utf8, vars, warnings, vmsish +attributes, attrs, autouse, base, blib, caller, charnames, constant, +diagnostics, fields, filetest, integer, less, lib, locale, ops, overload, +re, sigtrap, strict, subs, utf8, vars, warnings =item Standard Modules AnyDBM_File, AutoLoader, AutoSplit, B, B::Asmdata, B::Assembler, B::Bblock, B::Bytecode, B::C, B::CC, B::Debug, B::Deparse, B::Disassembler, B::Lint, -B::Showlex, B::Stackobj, B::Terse, B::Xref, Benchmark, CGI, CGI::Apache, -CGI::Carp, CGI::Cookie, CGI::Fast, CGI::Push, CGI::Switch, CPAN, -CPAN::FirstTime, CPAN::Nox, Carp, Class::Struct, Config, Cwd, DB, DB_File, -Data::Dumper, Devel::Peek, Devel::SelfStubber, DirHandle, Dumpvalue, -DynaLoader, English, Env, Errno, Exporter, ExtUtils::Command, -ExtUtils::Embed, ExtUtils::Install, ExtUtils::Installed, ExtUtils::Liblist, -ExtUtils::MM_OS2, ExtUtils::MM_Unix, ExtUtils::MM_VMS, ExtUtils::MM_Win32, -ExtUtils::MakeMaker, ExtUtils::Manifest, ExtUtils::Miniperl, +B::Showlex, B::Stackobj, B::Terse, B::Xref, Benchmark, ByteLoader, CGI, +CGI::Apache, CGI::Carp, CGI::Cookie, CGI::Fast, CGI::Pretty, CGI::Push, +CGI::Switch, CPAN, CPAN::FirstTime, CPAN::Nox, Carp, Carp::Heavy, +Class::Struct, Config, Cwd, DB, DB_File, Data::Dumper, Devel::DProf, +Devel::Peek, Devel::SelfStubber, DirHandle, Dumpvalue, DynaLoader, English, +Env, Errno, Exporter, Exporter::Heavy, ExtUtils::Command, ExtUtils::Embed, +ExtUtils::Install, ExtUtils::Installed, ExtUtils::Liblist, +ExtUtils::MM_Cygwin, ExtUtils::MM_OS2, ExtUtils::MM_Unix, ExtUtils::MM_VMS, +ExtUtils::MM_Win32, ExtUtils::MakeMaker, ExtUtils::Manifest, ExtUtils::Mkbootstrap, ExtUtils::Mksymlists, ExtUtils::Packlist, -ExtUtils::testlib, Fatal, Fcntl, File::Basename, File::Compare, File::Copy, -File::DosGlob, File::Find, File::Path, File::Spec, File::Spec::Functions, -File::Spec::Mac, File::Spec::OS2, File::Spec::Unix, File::Spec::VMS, -File::Spec::Win32, File::stat, FileCache, FileHandle, FindBin, GDBM_File, -Getopt::Long, Getopt::Std, I18N::Collate, IO, IO::Dir, IO::File, -IO::Handle, IO::Pipe, IO::Poll, IO::Seekable, IO::Select, IO::Socket, -IO::Socket::INET, IO::Socket::UNIX, IPC::Msg, IPC::Open2, IPC::Open3, -IPC::Semaphore, IPC::SysV, Math::BigFloat, Math::BigInt, Math::Complex, -Math::Trig, NDBM_File, Net::Ping, Net::hostent, Net::netent, Net::protoent, -Net::servent, O, Opcode, POSIX, Pod::Html, Pod::Text, SDBM_File, Safe, -Search::Dict, SelectSaver, SelfLoader, Shell, Socket, Symbol, -Sys::Hostname, Sys::Syslog, Term::Cap, Term::Complete, Term::ReadLine, -Test, Test::Harness, Text::Abbrev, Text::ParseWords, Text::Soundex, -Text::Tabs -- expand and unexpand tabs per the unix expand(1) and -unexpand(1), Text::Wrap, Thread, Thread::Queue, Thread::Semaphore, -Thread::Signal, Thread::Specific, Tie::Array, Tie::Handle, Tie::Hash, -Tie::StdHash, Tie::RefHash, Tie::Scalar, Tie::StdScalar, Tie::SubstrHash, -Time::Local, Time::gmtime, Time::localtime, Time::tm, UNIVERSAL, -User::grent, User::pwent +ExtUtils::testlib, Fatal, Fcntl, File::Basename, File::CheckTree, +File::Compare, File::Copy, File::DosGlob, File::Find, File::Glob, +File::Path, File::Spec, File::Spec::Functions, File::Spec::Mac, +File::Spec::OS2, File::Spec::Unix, File::Spec::VMS, File::Spec::Win32, +File::stat, FileCache, FileHandle, FindBin, GDBM_File, Getopt::Long, +Getopt::Std, I18N::Collate, IO, IO::Dir, IO::File, IO::Handle, IO::Pipe, +IO::Poll, IO::Seekable, IO::Select, IO::Socket, IO::Socket::INET, +IO::Socket::UNIX, IPC::Msg, IPC::Open2, IPC::Open3, IPC::Semaphore, +IPC::SysV, Math::BigFloat, Math::BigInt, Math::Complex, Math::Trig, +Net::Ping, Net::hostent, Net::netent, Net::protoent, Net::servent, O, +Opcode, POSIX, Pod::Checker, Pod::Html, Pod::InputObjects, Pod::Man, +Pod::Parser, Pod::Select, Pod::Text, Pod::Text::Color, Pod::Usage, +SDBM_File, Safe, Search::Dict, SelectSaver, SelfLoader, Shell, Socket, +Symbol, Sys::Hostname, Sys::Syslog, Term::Cap, Term::Complete, +Term::ReadLine, Test, Test::Harness, Text::Abbrev, Text::ParseWords, +Text::Soundex, Text::Wrap, Tie::Array, Tie::Handle, Tie::Hash, +Tie::RefHash, Tie::Scalar, Tie::SubstrHash, Time::Local, Time::gmtime, +Time::localtime, Time::tm, UNIVERSAL, User::grent, User::pwent =item Extension Modules @@ -1855,8 +1975,8 @@ World Wide Web, HTML, HTTP, CGI, MIME, Server and Daemon Utilities, Archiving and Compression, Images, Pixmap and Bitmap Manipulation, Drawing, and Graphing, Mail and Usenet News, Control Flow Utilities (callbacks and exceptions etc), File Handle and Input/Output Stream Utilities, -Miscellaneous Modules, Africa, Asia, Australasia, Europe, North America, -South America +Miscellaneous Modules, Africa, Asia, Australasia, Central America, Europe, +North America, South America =item Modules: Creation, Use, and Abuse @@ -1895,8 +2015,12 @@ can then be reduced to a small =item NOTE +=back + =head2 perlmodinstall - Installing CPAN Modules +=over + =item DESCRIPTION =over @@ -1914,8 +2038,49 @@ module (sometimes unnecessary), B<INSTALL> the module =item COPYRIGHT +=back + +=head2 perlfork - Perl's fork() emulation + +=over + +=item SYNOPSIS + +=item DESCRIPTION + +=over + +=item Behavior of other Perl features in forked pseudo-processes + +$$ or $PROCESS_ID, %ENV, chdir() and all other builtins that accept +filenames, wait() and waitpid(), kill(), exec(), exit(), Open handles to +files, directories and network sockets + +=item Resource limits + +=item Killing the parent process + +=item Lifetime of the parent process and pseudo-processes + +=item CAVEATS AND LIMITATIONS + +BEGIN blocks, Open filehandles, Global state maintained by XSUBs, +Interpreter embedded in larger application, Thread-safety of extensions + +=back + +=item BUGS + +=item AUTHOR + +=item SEE ALSO + +=back + =head2 perlform - Perl formats +=over + =item DESCRIPTION =over @@ -1936,9 +2101,13 @@ module (sometimes unnecessary), B<INSTALL> the module =item WARNINGS +=back + =head2 perllocale - Perl locale handling (internationalization and localization) +=over + =item DESCRIPTION =item PREPARING TO USE LOCALES @@ -1990,12 +2159,11 @@ localization) B<Comparison operators> (C<lt>, C<le>, C<ge>, C<gt> and C<cmp>):, B<Case-mapping interpolation> (with C<\l>, C<\L>, C<\u> or C<\U>), B<Matching operator> (C<m//>):, B<Substitution operator> (C<s///>):, -B<In-memory formatting function> (sprintf()):, B<Output formatting -functions> (printf() and write()):, B<Case-mapping functions> (lc(), -lcfirst(), uc(), ucfirst()):, B<POSIX locale-dependent functions> -(localeconv(), strcoll(),strftime(), strxfrm()):, B<POSIX character class -tests> (isalnum(), isalpha(), isdigit(),isgraph(), islower(), isprint(), -ispunct(), isspace(), isupper(), +B<Output formatting functions> (printf() and write()):, B<Case-mapping +functions> (lc(), lcfirst(), uc(), ucfirst()):, B<POSIX locale-dependent +functions> (localeconv(), strcoll(),strftime(), strxfrm()):, B<POSIX +character class tests> (isalnum(), isalpha(), isdigit(),isgraph(), +islower(), isprint(), ispunct(), isspace(), isupper(), isxdigit()): =item ENVIRONMENT @@ -2035,8 +2203,12 @@ LC_NUMERIC, LC_TIME, LANG =item HISTORY +=back + =head2 perlref - Perl references and nested data structures +=over + =item NOTE =item DESCRIPTION @@ -2061,8 +2233,12 @@ LC_NUMERIC, LC_TIME, LANG =item SEE ALSO +=back + =head2 perlreftut - Mark's very short tutorial about references +=over + =item DESCRIPTION =item Who Needs Complicated Data Structures? @@ -2097,8 +2273,12 @@ LC_NUMERIC, LC_TIME, LANG =back +=back + =head2 perldsc - Perl Data Structures Cookbook +=over + =item DESCRIPTION arrays of arrays, hashes of arrays, arrays of hashes, hashes of hashes, @@ -2182,8 +2362,12 @@ more elaborate constructs =item AUTHOR +=back + =head2 perllol - Manipulating Arrays of Arrays in Perl +=over + =item DESCRIPTION =item Declaration and Access of Arrays of Arrays @@ -2198,8 +2382,12 @@ more elaborate constructs =item AUTHOR +=back + =head2 perltoot - Tom's object-oriented tutorial for perl +=over + =item DESCRIPTION =item Creating a Class @@ -2294,8 +2482,12 @@ more elaborate constructs =back +=back + =head2 perltootc - Tom's OO Tutorial for Class Data in Perl +=over + =item DESCRIPTION =item Class Data as Package Variables @@ -2342,8 +2534,12 @@ more elaborate constructs =item HISTORY +=back + =head2 perlobj - Perl objects +=over + =item DESCRIPTION =over @@ -2372,8 +2568,12 @@ isa(CLASS), can(METHOD), VERSION( [NEED] ) =item SEE ALSO +=back + =head2 perltie - how to hide an object class in a simple variable +=over + =item SYNOPSIS =item DESCRIPTION @@ -2410,8 +2610,12 @@ LIST, READ this, LIST, READLINE this, GETC this, CLOSE this, DESTROY this =item AUTHOR +=back + =head2 perlbot - Bag'o Object Tricks (the BOT) +=over + =item DESCRIPTION =item OO SCALING TIPS @@ -2436,9 +2640,13 @@ LIST, READ this, LIST, READLINE this, GETC this, CLOSE this, DESTROY this =item DELEGATION +=back + =head2 perlipc - Perl interprocess communication (signals, fifos, pipes, safe subprocesses, sockets, and semaphores) +=over + =item DESCRIPTION =item Signals @@ -2511,8 +2719,12 @@ Proto, LocalPort, Listen, Reuse =item SEE ALSO +=back + =head2 perldbmfilter - Perl DBM Filters +=over + =item SYNOPSIS =item DESCRIPTION @@ -2534,8 +2746,12 @@ B<filter_fetch_value> =item AUTHOR +=back + =head2 perldebug - Perl debugging +=over + =item DESCRIPTION =item The Perl Debugger @@ -2623,12 +2839,20 @@ C<anchored(TYPE)> =back +=back + =head2 perldiag - various Perl diagnostics +=over + =item DESCRIPTION +=back + =head2 perlsec - Perl security +=over + =item DESCRIPTION =over @@ -2647,8 +2871,12 @@ C<anchored(TYPE)> =item SEE ALSO +=back + =head2 perltrap - Perl traps for the unwary +=over + =item DESCRIPTION =over @@ -2674,7 +2902,7 @@ Subroutine, Signal, Sorting Traps, OS Traps, DBM Traps, Unclassified Traps Discontinuance, Deprecation, BugFix, Discontinuance, Discontinuance, Discontinuance, BugFix, Discontinuance, Discontinuance, BugFix, -Discontinuance, Discontinuance, Deprecation, Discontinuance +Discontinuance, Deprecation, Discontinuance =item Parsing Traps @@ -2682,7 +2910,7 @@ Parsing, Parsing, Parsing, Parsing =item Numerical Traps -Numerical, Numerical, Numerical +Numerical, Numerical, Numerical, Bitwise string ops =item General data type traps @@ -2728,8 +2956,12 @@ LIMIT specified =back +=back + =head2 perlport - Writing portable Perl +=over + =item DESCRIPTION Not all Perl programs have to be portable, Nearly all of Perl already I<is> @@ -2841,7 +3073,7 @@ getnetent, getprotoent, getservent, setpwent, setgrent, sethostent STAYOPEN, setnetent STAYOPEN, setprotoent STAYOPEN, setservent STAYOPEN, endpwent, endgrent, endhostent, endnetent, endprotoent, endservent, getsockopt SOCKET,LEVEL,OPTNAME, glob EXPR, glob, ioctl -FILEHANDLE,FUNCTION,SCALAR, kill LIST, link OLDFILE,NEWFILE, lstat +FILEHANDLE,FUNCTION,SCALAR, kill SIGNAL, LIST, link OLDFILE,NEWFILE, lstat FILEHANDLE, lstat EXPR, lstat, msgctl ID,CMD,ARG, msgget KEY,FLAGS, msgsnd ID,MSG,FLAGS, msgrcv ID,VAR,SIZE,TYPE,FLAGS, open FILEHANDLE,EXPR, open FILEHANDLE, pipe READHANDLE,WRITEHANDLE, readlink EXPR, readlink, select @@ -2859,22 +3091,30 @@ wait, waitpid PID,FLAGS =item CHANGES -v1.44, 19 July 1999, v1.43, 24 May 1999, v1.42, 22 May 1999, v1.41, 19 May -1999, v1.40, 11 April 1999, v1.39, 11 February 1999, v1.38, 31 December -1998, v1.37, 19 December 1998, v1.36, 9 September 1998, v1.35, 13 August -1998, v1.33, 06 August 1998, v1.32, 05 August 1998, v1.30, 03 August 1998, -v1.23, 10 July 1998 +v1.45, 20 December 1999, v1.44, 19 July 1999, v1.43, 24 May 1999, v1.42, 22 +May 1999, v1.41, 19 May 1999, v1.40, 11 April 1999, v1.39, 11 February +1999, v1.38, 31 December 1998, v1.37, 19 December 1998, v1.36, 9 September +1998, v1.35, 13 August 1998, v1.33, 06 August 1998, v1.32, 05 August 1998, +v1.30, 03 August 1998, v1.23, 10 July 1998 =item AUTHORS / CONTRIBUTORS =item VERSION +=back + =head2 perlstyle - Perl style guide +=over + =item DESCRIPTION +=back + =head2 perlpod - plain old documentation +=over + =item DESCRIPTION =over @@ -2897,12 +3137,20 @@ v1.23, 10 July 1998 =item AUTHOR +=back + =head2 perlbook - Perl book information +=over + =item DESCRIPTION +=back + =head2 perlembed - how to embed perl in your C program +=over + =item DESCRIPTION =over @@ -2943,8 +3191,12 @@ program =item COPYRIGHT +=back + =head2 perlapio - perl's IO abstraction interface. +=over + =item SYNOPSIS =item DESCRIPTION @@ -2973,8 +3225,12 @@ B<PerlIO_get_base(f)>, B<PerlIO_get_bufsiz(f)> =back +=back + =head2 perlxs - XS language reference manual +=over + =item DESCRIPTION =over @@ -3063,8 +3319,12 @@ B<PerlIO_get_base(f)>, B<PerlIO_get_bufsiz(f)> =item AUTHOR +=back + =head2 perlxstut, perlXStut - Tutorial for writing XSUBs +=over + =item DESCRIPTION =item SPECIAL NOTES @@ -3107,7 +3367,11 @@ B<PerlIO_get_base(f)>, B<PerlIO_get_bufsiz(f)> =item What has happened here? -=item More about XSUBPP +=item Anatomy of .xs file + +=item Getting the fat out of XSUBs + +=item More about XSUB arguments =item The Argument Stack @@ -3143,8 +3407,12 @@ B<PerlIO_get_base(f)>, B<PerlIO_get_bufsiz(f)> =back +=back + =head2 perlguts - Perl's Internal Functions +=over + =item DESCRIPTION =item Variables @@ -3300,8 +3568,12 @@ XS_VERSION, XS_VERSION_BOOTCHECK, Zero =item AUTHORS +=back + =head2 perlcall - Perl calling conventions from C +=over + =item DESCRIPTION An Error Handler, An Event Driven Program @@ -3382,8 +3654,12 @@ callback =item DATE +=back + =head2 perlcompile - Introduction to the Perl Compiler-Translator +=over + =item DESCRIPTION =over @@ -3418,12 +3694,20 @@ B::Stash, B::Terse, B::Xref =back +=back + +=over + =item KNOWN PROBLEMS =item AUTHOR +=back + =head2 perlhist - the Perl history records +=over + =item DESCRIPTION =item INTRODUCTION @@ -3448,24 +3732,36 @@ B::Stash, B::Terse, B::Xref =item THE KEEPERS OF THE RECORDS +=back + =head1 PRAGMA DOCUMENTATION =head2 attrs - set/get attributes of a subroutine (deprecated) +=over + =item SYNOPSIS =item DESCRIPTION method, locked +=back + =head2 re - Perl pragma to alter regular expression behaviour +=over + =item SYNOPSIS =item DESCRIPTION +=back + =head2 attributes - get/set subroutine or variable attributes +=over + =item SYNOPSIS =item DESCRIPTION @@ -3488,20 +3784,40 @@ FETCH_I<type>_ATTRIBUTES, MODIFY_I<type>_ATTRIBUTES =back +=item EXPORTS + +=over + +=item Default exports + +=item Available exports + +=item Export tags defined + +=back + =item EXAMPLES =item SEE ALSO +=back + =head2 attrs - set/get attributes of a subroutine (deprecated) +=over + =item SYNOPSIS =item DESCRIPTION method, locked +=back + =head2 autouse - postpone load of modules until a function is used +=over + =item SYNOPSIS =item DESCRIPTION @@ -3512,8 +3828,12 @@ method, locked =item SEE ALSO +=back + =head2 base - Establish IS-A relationship with base class at compile time +=over + =item SYNOPSIS =item DESCRIPTION @@ -3522,8 +3842,12 @@ method, locked =item SEE ALSO +=back + =head2 blib - Use MakeMaker's uninstalled version of a package +=over + =item SYNOPSIS =item DESCRIPTION @@ -3532,17 +3856,36 @@ method, locked =item AUTHOR +=back + +=head2 byte - Perl pragma to turn force treating strings as bytes not +UNICODE + +=over + +=item SYNOPSIS + +=item DESCRIPTION + +=back + =head2 caller - inherit pragmatic attributes from the context of the caller +=over + =item SYNOPSIS =item DESCRIPTION encoding +=back + =head2 charnames - define character names for C<\N{named}> string literal escape. +=over + =item SYNOPSIS =item DESCRIPTION @@ -3551,8 +3894,12 @@ escape. =item BUGS +=back + =head2 constant - Perl pragma to declare constants +=over + =item SYNOPSIS =item DESCRIPTION @@ -3567,9 +3914,13 @@ escape. =item COPYRIGHT +=back + =head2 diagnostics - Perl compiler pragma to force verbose warning diagnostics +=over + =item SYNOPSIS =item DESCRIPTION @@ -3590,16 +3941,24 @@ diagnostics =item AUTHOR +=back + =head2 fields - compile-time class fields +=over + =item SYNOPSIS =item DESCRIPTION =item SEE ALSO +=back + =head2 filetest - Perl pragma to control the filetest permission operators +=over + =item SYNOPSIS $can_perhaps_read = -r "file"; # use the mode bits @@ -3617,21 +3976,33 @@ diagnostics =back +=back + =head2 integer - Perl pragma to compute arithmetic in integer instead of double +=over + =item SYNOPSIS =item DESCRIPTION +=back + =head2 less - perl pragma to request less of something from the compiler +=over + =item SYNOPSIS =item DESCRIPTION +=back + =head2 lib - manipulate @INC at compile time +=over + =item SYNOPSIS =item DESCRIPTION @@ -3650,23 +4021,35 @@ double =item AUTHOR +=back + =head2 locale - Perl pragma to use and avoid POSIX locales for built-in operations +=over + =item SYNOPSIS =item DESCRIPTION +=back + =head2 ops - Perl pragma to restrict unsafe operations when compiling +=over + =item SYNOPSIS =item DESCRIPTION =item SEE ALSO +=back + =head2 overload - Package for overloading perl operations +=over + =item SYNOPSIS =item DESCRIPTION @@ -3757,14 +4140,22 @@ integer, float, binary, q, qr =item BUGS +=back + =head2 re - Perl pragma to alter regular expression behaviour +=over + =item SYNOPSIS =item DESCRIPTION +=back + =head2 sigtrap - Perl pragma to enable simple signal handling +=over + =item SYNOPSIS =item DESCRIPTION @@ -3789,44 +4180,68 @@ B<untrapped>, B<any>, I<signal>, I<number> =item EXAMPLES +=back + =head2 strict - Perl pragma to restrict unsafe constructs +=over + =item SYNOPSIS =item DESCRIPTION C<strict refs>, C<strict vars>, C<strict subs> +=back + =head2 subs - Perl pragma to predeclare sub names +=over + =item SYNOPSIS =item DESCRIPTION +=back + =head2 utf8 - Perl pragma to turn on UTF-8 and Unicode support +=over + =item SYNOPSIS =item DESCRIPTION =item CAVEATS -=head2 vars - Perl pragma to predeclare global variable names +=back + +=head2 vars - Perl pragma to predeclare global variable names (obsolete) + +=over =item SYNOPSIS =item DESCRIPTION +=back + =head2 warnings - Perl pragma to control optional warnings +=over + =item SYNOPSIS =item DESCRIPTION +=back + =head1 MODULE DOCUMENTATION =head2 AnyDBM_File - provide framework for multiple DBMs +=over + =item SYNOPSIS =item DESCRIPTION @@ -3841,8 +4256,12 @@ C<strict refs>, C<strict vars>, C<strict subs> =item SEE ALSO +=back + =head2 AutoLoader - load subroutines only on demand +=over + =item SYNOPSIS =item DESCRIPTION @@ -3865,8 +4284,12 @@ C<strict refs>, C<strict vars>, C<strict subs> =item SEE ALSO +=back + =head2 AutoSplit - split a package for autoloading +=over + =item SYNOPSIS =item DESCRIPTION @@ -3881,8 +4304,12 @@ $keep, $check, $modtime =item DIAGNOSTICS +=back + =head2 B - The Perl Compiler +=over + =item SYNOPSIS =item DESCRIPTION @@ -3931,8 +4358,8 @@ USEFUL, PREVIOUS, RARE, TABLE =item B::GV METHODS -NAME, STASH, SV, IO, FORM, AV, HV, EGV, CV, CVGEN, LINE, FILEGV, GvREFCNT, -FLAGS +NAME, STASH, SV, IO, FORM, AV, HV, EGV, CV, CVGEN, LINE, FILE, FILEGV, +GvREFCNT, FLAGS =item B::IO METHODS @@ -3945,7 +4372,7 @@ FILL, MAX, OFF, ARRAY, AvFLAGS =item B::CV METHODS -STASH, START, ROOT, GV, FILEGV, DEPTH, PADLIST, OUTSIDE, XSUB, XSUBANY, +STASH, START, ROOT, GV, FILE, DEPTH, PADLIST, OUTSIDE, XSUB, XSUBANY, CvFLAGS =item B::HV METHODS @@ -3980,11 +4407,11 @@ pmreplroot, pmreplstart, pmnext, pmregexp, pmflags, pmpermflags, precomp =item B::SVOP METHOD -sv +sv, gv -=item B::GVOP METHOD +=item B::PADOP METHOD -gv +padix =item B::PVOP METHOD @@ -3996,7 +4423,7 @@ redoop, nextop, lastop =item B::COP METHODS -label, stash, filegv, cop_seq, arybase, line +label, stash, file, cop_seq, arybase, line =back @@ -4009,40 +4436,56 @@ hash(STR), cast_I32(I), minus_c, cstring(STR), class(OBJ), threadsv_names =item AUTHOR +=back + =head2 B::Asmdata - Autogenerated data about Perl ops, used to generate bytecode +=over + =item SYNOPSIS =item DESCRIPTION =item AUTHOR +=back + =head2 B::Assembler - Assemble Perl bytecode +=over + =item SYNOPSIS =item DESCRIPTION =item AUTHOR +=back + =head2 B::Bblock - Walk basic blocks +=over + =item SYNOPSIS =item DESCRIPTION =item AUTHOR +=back + =head2 B::Bytecode - Perl compiler's bytecode backend +=over + =item SYNOPSIS =item DESCRIPTION =item OPTIONS -B<-ofilename>, B<-->, B<-f>, B<-fcompress-nullops>, +B<-ofilename>, B<-afilename>, B<-->, B<-f>, B<-fcompress-nullops>, B<-fomit-sequence-numbers>, B<-fbypass-nullops>, B<-fstrip-syntax-tree>, B<-On>, B<-D>, B<-Do>, B<-Db>, B<-Da>, B<-DC>, B<-S>, B<-m> @@ -4052,8 +4495,12 @@ B<-On>, B<-D>, B<-Do>, B<-Db>, B<-Da>, B<-DC>, B<-S>, B<-m> =item AUTHOR +=back + =head2 B::C - Perl compiler's C backend +=over + =item SYNOPSIS =item DESCRIPTION @@ -4069,8 +4516,12 @@ B<-DC>, B<-DM>, B<-f>, B<-fcog>, B<-fno-cog>, B<-On> =item AUTHOR +=back + =head2 B::CC - Perl compiler's optimized C translation backend +=over + =item SYNOPSIS =item DESCRIPTION @@ -4101,16 +4552,24 @@ B<-ffreetmps-each-bblock>, B<-ffreetmps-each-loop>, B<-fomit-taint>, B<-On> =item AUTHOR +=back + =head2 B::Debug - Walk Perl syntax tree, printing debug info about ops +=over + =item SYNOPSIS =item DESCRIPTION =item AUTHOR +=back + =head2 B::Deparse - Perl compiler backend to produce perl code +=over + =item SYNOPSIS =item DESCRIPTION @@ -4138,16 +4597,24 @@ B<T>, B<v>I<STRING>B<.> =item AUTHOR +=back + =head2 B::Disassembler - Disassemble Perl bytecode +=over + =item SYNOPSIS =item DESCRIPTION =item AUTHOR +=back + =head2 B::Lint - Perl lint +=over + =item SYNOPSIS =item DESCRIPTION @@ -4165,8 +4632,12 @@ B<-u Package> =item AUTHOR +=back + =head2 B::O, O - Generic interface to Perl Compiler backends +=over + =item SYNOPSIS =item DESCRIPTION @@ -4177,32 +4648,48 @@ B<-u Package> =item AUTHOR +=back + =head2 B::Showlex - Show lexical variables used in functions or files +=over + =item SYNOPSIS =item DESCRIPTION =item AUTHOR +=back + =head2 B::Stackobj - Helper module for CC backend +=over + =item SYNOPSIS =item DESCRIPTION =item AUTHOR +=back + =head2 B::Terse - Walk Perl syntax tree, printing terse info about ops +=over + =item SYNOPSIS =item DESCRIPTION =item AUTHOR +=back + =head2 B::Xref - Generates cross reference reports for Perl programs +=over + =item SYNOPSIS =item DESCRIPTION @@ -4215,15 +4702,23 @@ C<-oFILENAME>, C<-r>, C<-D[tO]> =item AUTHOR +=back + =head2 Bblock, B::Bblock - Walk basic blocks +=over + =item SYNOPSIS =item DESCRIPTION =item AUTHOR -=head2 Benchmark - benchmark running times of code +=back + +=head2 Benchmark - benchmark running times of Perl code + +=over =item SYNOPSIS @@ -4251,16 +4746,24 @@ STYLE ] ), cmpthese ( RESULTSHASHREF ), countit(TIME, CODE), disablecache ( =item NOTES +=item EXAMPLES + =item INHERITANCE =item CAVEATS +=item SEE ALSO + =item AUTHORS =item MODIFICATION HISTORY +=back + =head2 ByteLoader - load byte compiled perl code +=over + =item SYNOPSIS =item DESCRIPTION @@ -4269,15 +4772,19 @@ STYLE ] ), cmpthese ( RESULTSHASHREF ), countit(TIME, CODE), disablecache ( =item SEE ALSO +=back + =head2 Bytecode, B::Bytecode - Perl compiler's bytecode backend +=over + =item SYNOPSIS =item DESCRIPTION =item OPTIONS -B<-ofilename>, B<-->, B<-f>, B<-fcompress-nullops>, +B<-ofilename>, B<-afilename>, B<-->, B<-f>, B<-fcompress-nullops>, B<-fomit-sequence-numbers>, B<-fbypass-nullops>, B<-fstrip-syntax-tree>, B<-On>, B<-D>, B<-Do>, B<-Db>, B<-Da>, B<-DC>, B<-S>, B<-m> @@ -4287,8 +4794,12 @@ B<-On>, B<-D>, B<-Do>, B<-Db>, B<-Da>, B<-DC>, B<-S>, B<-m> =item AUTHOR +=back + =head2 CGI - Simple Common Gateway Interface Class +=over + =item SYNOPSIS =item ABSTRACT @@ -4524,23 +5035,31 @@ MacEachern (dougm@opengroup.org), Robin Houston (robin@oneworld.org), =item SEE ALSO -=head2 CGI::Apache - Make things work with CGI.pm against Perl-Apache API +=back + +=head2 CGI::Apache - Backward compatibility module for CGI.pm + +=over =item SYNOPSIS +=item ABSTRACT + =item DESCRIPTION -=item NOTE 1 +=item AUTHOR INFORMATION -=item NOTE 2 +=item BUGS =item SEE ALSO -=item AUTHOR +=back =head2 CGI::Carp, B<CGI::Carp> - CGI routines for writing to the HTTPD (or other) error log +=over + =item SYNOPSIS =item DESCRIPTION @@ -4561,8 +5080,12 @@ other) error log =item SEE ALSO +=back + =head2 CGI::Cookie - Interface to Netscape Cookies +=over + =item SYNOPSIS =item DESCRIPTION @@ -4591,8 +5114,12 @@ B<name()>, B<value()>, B<domain()>, B<path()>, B<expires()> =item SEE ALSO +=back + =head2 CGI::Fast - CGI Interface for Fast CGI +=over + =item SYNOPSIS =item DESCRIPTION @@ -4613,8 +5140,12 @@ B<name()>, B<value()>, B<domain()>, B<path()>, B<expires()> =item SEE ALSO +=back + =head2 CGI::Pretty - module to produce nicely formatted HTML code +=over + =item SYNOPSIS =item DESCRIPTION @@ -4623,6 +5154,8 @@ B<name()>, B<value()>, B<domain()>, B<path()>, B<expires()> =item Tags that won't be formatted +=item Customizing the Indenting + =back =item BUGS @@ -4631,8 +5164,12 @@ B<name()>, B<value()>, B<domain()>, B<path()>, B<expires()> =item SEE ALSO +=back + =head2 CGI::Push - Simple Interface to Server Push +=over + =item SYNOPSIS =item DESCRIPTION @@ -4657,19 +5194,30 @@ B<name()>, B<value()>, B<domain()>, B<path()>, B<expires()> =item SEE ALSO -=head2 CGI::Switch - Try more than one constructors and return the first -object available +=back + +=head2 CGI::Switch - Backward compatibility module for defunct CGI::Switch + +=over =item SYNOPSIS +=item ABSTRACT + =item DESCRIPTION +=item AUTHOR INFORMATION + +=item BUGS + =item SEE ALSO -=item AUTHOR +=back =head2 CPAN - query, download and build perl modules from CPAN sites +=over + =item SYNOPSIS =item DESCRIPTION @@ -4741,23 +5289,35 @@ http firewall, ftp firewall, One way visibility, SOCKS, IP Masquerade =item SEE ALSO +=back + =head2 CPAN::FirstTime - Utility for CPAN::Config file Initialization +=over + =item SYNOPSIS =item DESCRIPTION +=back + =head2 CPANox, CPAN::Nox - Wrapper around CPAN.pm without using any XS module +=over + =item SYNOPSIS =item DESCRIPTION =item SEE ALSO +=back + =head2 Carp, carp - warn of errors (from perspective of caller) +=over + =item SYNOPSIS =item DESCRIPTION @@ -4770,14 +5330,22 @@ module =item BUGS +=back + =head2 Carp::Heavy - Carp guts +=over + =item SYNOPIS =item DESCRIPTION +=back + =head2 Class::Struct - declare struct-like datatypes as Perl classes +=over + =item SYNOPSIS =item DESCRIPTION @@ -4801,8 +5369,12 @@ Example 1, Example 2, Example 3 =item Author and Modification History +=back + =head2 Config - access Perl configuration information +=over + =item SYNOPSIS =item DESCRIPTION @@ -4823,8 +5395,9 @@ C<_a>, C<_exe>, C<_o> =item a -C<afs>, C<alignbytes>, C<ansi2knr>, C<aphostname>, C<apiversion>, C<ar>, -C<archlib>, C<archlibexp>, C<archname64>, C<archname>, C<archobjs>, C<awk> +C<afs>, C<alignbytes>, C<ansi2knr>, C<aphostname>, C<api_revision>, +C<api_subversion>, C<api_version>, C<api_versionstring>, C<ar>, C<archlib>, +C<archlibexp>, C<archname64>, C<archname>, C<archobjs>, C<awk> =item b @@ -4834,11 +5407,14 @@ C<byacc>, C<byteorder> =item c C<c>, C<castflags>, C<cat>, C<cc>, C<cccdlflags>, C<ccdlflags>, C<ccflags>, -C<ccsymbols>, C<cf_by>, C<cf_email>, C<cf_time>, C<chgrp>, C<chmod>, -C<chown>, C<clocktype>, C<comm>, C<compress>, C<contains>, C<cp>, C<cpio>, -C<cpp>, C<cpp_stuff>, C<cppccsymbols>, C<cppflags>, C<cpplast>, -C<cppminus>, C<cpprun>, C<cppstdin>, C<cppsymbols>, C<crosscompile>, -C<cryptlib>, C<csh> +C<ccsymbols>, C<cf_by>, C<cf_email>, C<cf_time>, C<charsize>, C<chgrp>, +C<chmod>, C<chown>, C<clocktype>, C<comm>, C<compress> + +=item C + +C<CONFIGDOTSH>, C<contains>, C<cp>, C<cpio>, C<cpp>, C<cpp_stuff>, +C<cppccsymbols>, C<cppflags>, C<cpplast>, C<cppminus>, C<cpprun>, +C<cppstdin>, C<cppsymbols>, C<crosscompile>, C<cryptlib>, C<csh> =item d @@ -4846,62 +5422,61 @@ C<d_access>, C<d_accessx>, C<d_alarm>, C<d_archlib>, C<d_atolf>, C<d_atoll>, C<d_attribut>, C<d_bcmp>, C<d_bcopy>, C<d_bincompat5005>, C<d_bsd>, C<d_bsdgetpgrp>, C<d_bsdsetpgrp>, C<d_bzero>, C<d_casti32>, C<d_castneg>, C<d_charvspr>, C<d_chown>, C<d_chroot>, C<d_chsize>, -C<d_closedir>, C<d_cmsghdr_s>, C<d_const>, C<d_crypt>, C<d_csh>, -C<d_cuserid>, C<d_dbl_dig>, C<d_difftime>, C<d_dirnamlen>, C<d_dlerror>, -C<d_dlopen>, C<d_dlsymun>, C<d_dosuid>, C<d_drand48proto>, C<d_dup2>, -C<d_eaccess>, C<d_endgrent>, C<d_endhent>, C<d_endnent>, C<d_endpent>, -C<d_endpwent>, C<d_endsent>, C<d_endspent>, C<d_eofnblk>, C<d_eunice>, -C<d_fchmod>, C<d_fchown>, C<d_fcntl>, C<d_fd_macros>, C<d_fd_set>, -C<d_fds_bits>, C<d_fgetpos>, C<d_flexfnam>, C<d_flock>, C<d_fork>, -C<d_fpathconf>, C<d_fpos64_t>, C<d_fseeko>, C<d_fsetpos>, C<d_fstatfs>, +C<d_closedir>, C<d_const>, C<d_crypt>, C<d_csh>, C<d_cuserid>, +C<d_dbl_dig>, C<d_difftime>, C<d_dirnamlen>, C<d_dlerror>, C<d_dlopen>, +C<d_dlsymun>, C<d_dosuid>, C<d_drand48proto>, C<d_dup2>, C<d_eaccess>, +C<d_endgrent>, C<d_endhent>, C<d_endnent>, C<d_endpent>, C<d_endpwent>, +C<d_endsent>, C<d_endspent>, C<d_eofnblk>, C<d_eunice>, C<d_fchmod>, +C<d_fchown>, C<d_fcntl>, C<d_fd_macros>, C<d_fd_set>, C<d_fds_bits>, +C<d_fgetpos>, C<d_flexfnam>, C<d_flock>, C<d_fork>, C<d_fpathconf>, +C<d_fpos64_t>, C<d_fs_data_s>, C<d_fseeko>, C<d_fsetpos>, C<d_fstatfs>, C<d_fstatvfs>, C<d_ftello>, C<d_ftime>, C<d_Gconvert>, C<d_getgrent>, C<d_getgrps>, C<d_gethbyaddr>, C<d_gethbyname>, C<d_gethent>, -C<d_gethname>, C<d_gethostprotos>, C<d_getlogin>, C<d_getmntent>, -C<d_getnbyaddr>, C<d_getnbyname>, C<d_getnent>, C<d_getnetprotos>, -C<d_getpbyname>, C<d_getpbynumber>, C<d_getpent>, C<d_getpgid>, -C<d_getpgrp2>, C<d_getpgrp>, C<d_getppid>, C<d_getprior>, +C<d_gethname>, C<d_gethostprotos>, C<d_getlogin>, C<d_getmnt>, +C<d_getmntent>, C<d_getnbyaddr>, C<d_getnbyname>, C<d_getnent>, +C<d_getnetprotos>, C<d_getpbyname>, C<d_getpbynumber>, C<d_getpent>, +C<d_getpgid>, C<d_getpgrp2>, C<d_getpgrp>, C<d_getppid>, C<d_getprior>, C<d_getprotoprotos>, C<d_getpwent>, C<d_getsbyname>, C<d_getsbyport>, C<d_getsent>, C<d_getservprotos>, C<d_getspent>, C<d_getspnam>, C<d_gettimeod>, C<d_gnulibc>, C<d_grpasswd>, C<d_hasmntopt>, C<d_htonl>, -C<d_index>, C<d_inetaton>, C<d_int64t>, C<d_iovec_s>, C<d_isascii>, -C<d_killpg>, C<d_lchown>, C<d_ldbl_dig>, C<d_link>, C<d_llseek>, -C<d_locconv>, C<d_lockf>, C<d_longdbl>, C<d_longlong>, C<d_lstat>, -C<d_madvise>, C<d_mblen>, C<d_mbstowcs>, C<d_mbtowc>, C<d_memchr>, -C<d_memcmp>, C<d_memcpy>, C<d_memmove>, C<d_memset>, C<d_mkdir>, -C<d_mkfifo>, C<d_mktime>, C<d_mmap>, C<d_mprotect>, C<d_msg>, +C<d_index>, C<d_inetaton>, C<d_int64t>, C<d_isascii>, C<d_killpg>, +C<d_lchown>, C<d_ldbl_dig>, C<d_link>, C<d_locconv>, C<d_lockf>, +C<d_longdbl>, C<d_longlong>, C<d_lstat>, C<d_mblen>, C<d_mbstowcs>, +C<d_mbtowc>, C<d_memchr>, C<d_memcmp>, C<d_memcpy>, C<d_memmove>, +C<d_memset>, C<d_mkdir>, C<d_mkfifo>, C<d_mktime>, C<d_msg>, C<d_msg_ctrunc>, C<d_msg_dontroute>, C<d_msg_oob>, C<d_msg_peek>, -C<d_msg_proxy>, C<d_msgctl>, C<d_msgget>, C<d_msghdr_s>, C<d_msgrcv>, -C<d_msgsnd>, C<d_msync>, C<d_munmap>, C<d_mymalloc>, C<d_nice>, -C<d_off64_t>, C<d_old_pthread_create_joinable>, C<d_oldpthreads>, -C<d_oldsock>, C<d_open3>, C<d_pathconf>, C<d_pause>, C<d_phostname>, -C<d_pipe>, C<d_poll>, C<d_portable>, C<d_PRId64>, C<d_PRIeldbl>, -C<d_PRIEldbl>, C<d_PRIfldbl>, C<d_PRIFldbl>, C<d_PRIgldbl>, C<d_PRIGldbl>, -C<d_PRIi64>, C<d_PRIo64>, C<d_PRIu64>, C<d_PRIx64>, C<d_PRIX64>, -C<d_pthread_yield>, C<d_pwage>, C<d_pwchange>, C<d_pwclass>, -C<d_pwcomment>, C<d_pwexpire>, C<d_pwgecos>, C<d_pwpasswd>, C<d_pwquota>, -C<d_readdir>, C<d_readlink>, C<d_readv>, C<d_recvmsg>, C<d_rename>, -C<d_rewinddir>, C<d_rmdir>, C<d_safebcpy>, C<d_safemcpy>, C<d_sanemcmp>, -C<d_sched_yield>, C<d_scm_rights>, C<d_seekdir>, C<d_select>, C<d_sem>, -C<d_semctl>, C<d_semctl_semid_ds>, C<d_semctl_semun>, C<d_semget>, -C<d_semop>, C<d_sendmsg>, C<d_setegid>, C<d_seteuid>, C<d_setgrent>, -C<d_setgrps>, C<d_sethent>, C<d_setlinebuf>, C<d_setlocale>, C<d_setnent>, -C<d_setpent>, C<d_setpgid>, C<d_setpgrp2>, C<d_setpgrp>, C<d_setprior>, -C<d_setpwent>, C<d_setregid>, C<d_setresgid>, C<d_setresuid>, -C<d_setreuid>, C<d_setrgid>, C<d_setruid>, C<d_setsent>, C<d_setsid>, -C<d_setspent>, C<d_setvbuf>, C<d_sfio>, C<d_shm>, C<d_shmat>, +C<d_msg_proxy>, C<d_msgctl>, C<d_msgget>, C<d_msgrcv>, C<d_msgsnd>, +C<d_mymalloc>, C<d_nice>, C<d_nvpresuv>, C<d_off64_t>, +C<d_old_pthread_create_joinable>, C<d_oldpthreads>, C<d_oldsock>, +C<d_open3>, C<d_pathconf>, C<d_pause>, C<d_phostname>, C<d_pipe>, +C<d_poll>, C<d_portable>, C<d_PRId64>, C<d_PRIeldbl>, C<d_PRIEldbl>, +C<d_PRIfldbl>, C<d_PRIFldbl>, C<d_PRIgldbl>, C<d_PRIGldbl>, C<d_PRIi64>, +C<d_PRIo64>, C<d_PRIu64>, C<d_PRIx64>, C<d_PRIX64>, C<d_pthread_yield>, +C<d_pwage>, C<d_pwchange>, C<d_pwclass>, C<d_pwcomment>, C<d_pwexpire>, +C<d_pwgecos>, C<d_pwpasswd>, C<d_pwquota>, C<d_quad>, C<d_readdir>, +C<d_readlink>, C<d_rename>, C<d_rewinddir>, C<d_rmdir>, C<d_safebcpy>, +C<d_safemcpy>, C<d_sanemcmp>, C<d_sched_yield>, C<d_scm_rights>, +C<d_seekdir>, C<d_select>, C<d_sem>, C<d_semctl>, C<d_semctl_semid_ds>, +C<d_semctl_semun>, C<d_semget>, C<d_semop>, C<d_setegid>, C<d_seteuid>, +C<d_setgrent>, C<d_setgrps>, C<d_sethent>, C<d_setlinebuf>, C<d_setlocale>, +C<d_setnent>, C<d_setpent>, C<d_setpgid>, C<d_setpgrp2>, C<d_setpgrp>, +C<d_setprior>, C<d_setpwent>, C<d_setregid>, C<d_setresgid>, +C<d_setresuid>, C<d_setreuid>, C<d_setrgid>, C<d_setruid>, C<d_setsent>, +C<d_setsid>, C<d_setspent>, C<d_setvbuf>, C<d_sfio>, C<d_shm>, C<d_shmat>, C<d_shmatprototype>, C<d_shmctl>, C<d_shmdt>, C<d_shmget>, C<d_sigaction>, -C<d_sigsetjmp>, C<d_socket>, C<d_sockpair>, C<d_statblks>, C<d_statfs>, -C<d_statfsflags>, C<d_statvfs>, C<d_stdio_cnt_lval>, C<d_stdio_ptr_lval>, -C<d_stdio_stream_array>, C<d_stdiobase>, C<d_stdstdio>, C<d_strchr>, -C<d_strcoll>, C<d_strctcpy>, C<d_strerrm>, C<d_strerror>, C<d_strtod>, -C<d_strtol>, C<d_strtoul>, C<d_strtoull>, C<d_strxfrm>, C<d_suidsafe>, +C<d_sigsetjmp>, C<d_socket>, C<d_sockpair>, C<d_sqrtl>, C<d_statblks>, +C<d_statfs_f_flags>, C<d_statfs_s>, C<d_statvfs>, C<d_stdio_cnt_lval>, +C<d_stdio_ptr_lval>, C<d_stdio_stream_array>, C<d_stdiobase>, +C<d_stdstdio>, C<d_strchr>, C<d_strcoll>, C<d_strctcpy>, C<d_strerrm>, +C<d_strerror>, C<d_strtod>, C<d_strtol>, C<d_strtold>, C<d_strtoll>, +C<d_strtoul>, C<d_strtoull>, C<d_strtouq>, C<d_strxfrm>, C<d_suidsafe>, C<d_symlink>, C<d_syscall>, C<d_sysconf>, C<d_sysernlst>, C<d_syserrlst>, C<d_system>, C<d_tcgetpgrp>, C<d_tcsetpgrp>, C<d_telldir>, C<d_telldirproto>, C<d_time>, C<d_times>, C<d_truncate>, C<d_tzname>, -C<d_umask>, C<d_uname>, C<d_union_semun>, C<d_vendorlib>, C<d_vfork>, -C<d_void_closedir>, C<d_voidsig>, C<d_voidtty>, C<d_volatile>, -C<d_vprintf>, C<d_wait4>, C<d_waitpid>, C<d_wcstombs>, C<d_wctomb>, -C<d_writev>, C<d_xenix>, C<date>, C<db_hashtype>, C<db_prefixtype>, +C<d_umask>, C<d_uname>, C<d_union_semun>, C<d_ustat>, C<d_vendorbin>, +C<d_vendorlib>, C<d_vfork>, C<d_void_closedir>, C<d_voidsig>, C<d_voidtty>, +C<d_volatile>, C<d_vprintf>, C<d_wait4>, C<d_waitpid>, C<d_wcstombs>, +C<d_wctomb>, C<d_xenix>, C<date>, C<db_hashtype>, C<db_prefixtype>, C<defvoidused>, C<direntrytype>, C<dlext>, C<dlsrc>, C<doublesize>, C<drand01>, C<dynamic_ext> @@ -4913,12 +5488,12 @@ C<exe_ext>, C<expr>, C<extensions> =item f C<fflushall>, C<fflushNULL>, C<find>, C<firstmakefile>, C<flex>, -C<fpostype>, C<freetype>, C<full_ar>, C<full_csh>, C<full_sed> +C<fpossize>, C<fpostype>, C<freetype>, C<full_ar>, C<full_csh>, C<full_sed> =item g -C<gccversion>, C<gidtype>, C<glibpth>, C<grep>, C<groupcat>, C<groupstype>, -C<gzip> +C<gccversion>, C<gidformat>, C<gidsign>, C<gidsize>, C<gidtype>, +C<glibpth>, C<grep>, C<groupcat>, C<groupstype>, C<gzip> =item h @@ -4926,24 +5501,27 @@ C<h_fcntl>, C<h_sysfile>, C<hint>, C<hostcat>, C<huge> =item i -C<i_arpainet>, C<i_bsdioctl>, C<i_db>, C<i_dbm>, C<i_dirent>, C<i_dld>, -C<i_dlfcn>, C<i_fcntl>, C<i_float>, C<i_gdbm>, C<i_grp>, C<i_inttypes>, -C<i_limits>, C<i_locale>, C<i_machcthr>, C<i_malloc>, C<i_math>, -C<i_memory>, C<i_mntent>, C<i_ndbm>, C<i_netdb>, C<i_neterrno>, -C<i_netinettcp>, C<i_niin>, C<i_poll>, C<i_pthread>, C<i_pwd>, -C<i_rpcsvcdbm>, C<i_sfio>, C<i_sgtty>, C<i_shadow>, C<i_socks>, +C<i16size>, C<i16type>, C<i32size>, C<i32type>, C<i64size>, C<i64type>, +C<i8size>, C<i8type>, C<i_arpainet>, C<i_bsdioctl>, C<i_db>, C<i_dbm>, +C<i_dirent>, C<i_dld>, C<i_dlfcn>, C<i_fcntl>, C<i_float>, C<i_gdbm>, +C<i_grp>, C<i_inttypes>, C<i_limits>, C<i_locale>, C<i_machcthr>, +C<i_malloc>, C<i_math>, C<i_memory>, C<i_mntent>, C<i_ndbm>, C<i_netdb>, +C<i_neterrno>, C<i_netinettcp>, C<i_niin>, C<i_poll>, C<i_pthread>, +C<i_pwd>, C<i_rpcsvcdbm>, C<i_sfio>, C<i_sgtty>, C<i_shadow>, C<i_socks>, C<i_stdarg>, C<i_stddef>, C<i_stdlib>, C<i_string>, C<i_sysaccess>, C<i_sysdir>, C<i_sysfile>, C<i_sysfilio>, C<i_sysin>, C<i_sysioctl>, -C<i_sysmman>, C<i_sysmount>, C<i_sysndir>, C<i_sysparam>, C<i_sysresrc>, -C<i_syssecrt>, C<i_sysselct>, C<i_syssockio>, C<i_sysstat>, +C<i_sysmount>, C<i_sysndir>, C<i_sysparam>, C<i_sysresrc>, C<i_syssecrt>, +C<i_sysselct>, C<i_syssockio>, C<i_sysstat>, C<i_sysstatfs>, C<i_sysstatvfs>, C<i_systime>, C<i_systimek>, C<i_systimes>, C<i_systypes>, -C<i_sysuio>, C<i_sysun>, C<i_syswait>, C<i_termio>, C<i_termios>, -C<i_time>, C<i_unistd>, C<i_utime>, C<i_values>, C<i_varargs>, C<i_varhdr>, -C<i_vfork>, C<ignore_versioned_solibs>, C<incpath>, C<inews>, +C<i_sysuio>, C<i_sysun>, C<i_sysvfs>, C<i_syswait>, C<i_termio>, +C<i_termios>, C<i_time>, C<i_unistd>, C<i_ustat>, C<i_utime>, C<i_values>, +C<i_varargs>, C<i_varhdr>, C<i_vfork>, C<ignore_versioned_solibs>, +C<inc_version_list>, C<inc_version_list_init>, C<incpath>, C<inews>, C<installarchlib>, C<installbin>, C<installman1dir>, C<installman3dir>, C<installprefix>, C<installprefixexp>, C<installprivlib>, C<installscript>, -C<installsitearch>, C<installsitelib>, C<installstyle>, -C<installusrbinperl>, C<installvendorlib>, C<intsize> +C<installsitearch>, C<installsitebin>, C<installsitelib>, C<installstyle>, +C<installusrbinperl>, C<installvendorbin>, C<installvendorlib>, C<intsize>, +C<ivdformat>, C<ivsize>, C<ivtype> =item k @@ -4965,14 +5543,14 @@ C<man3direxp>, C<man3ext> =item M -C<Mcc>, C<medium>, C<mips_type>, C<mkdir>, C<mmaptype>, C<models>, -C<modetype>, C<more>, C<multiarch>, C<mv>, C<myarchname>, C<mydomain>, -C<myhostname>, C<myuname> +C<Mcc>, C<medium>, C<mips_type>, C<mkdir>, C<models>, C<modetype>, C<more>, +C<multiarch>, C<mv>, C<myarchname>, C<mydomain>, C<myhostname>, C<myuname> =item n C<n>, C<netdb_hlen_type>, C<netdb_host_type>, C<netdb_name_type>, -C<netdb_net_type>, C<nm>, C<nm_opt>, C<nm_so_opt>, C<nonxs_ext>, C<nroff> +C<netdb_net_type>, C<nm>, C<nm_opt>, C<nm_so_opt>, C<nonxs_ext>, C<nroff>, +C<nvsize>, C<nvtype> =item o @@ -4981,10 +5559,18 @@ C<orderlib>, C<osname>, C<osvers> =item p -C<package>, C<pager>, C<passcat>, C<patchlevel>, C<path_sep>, C<perl>, -C<perladmin>, C<perlpath>, C<pg>, C<phostname>, C<pidtype>, C<plibpth>, -C<pm_apiversion>, C<pmake>, C<pr>, C<prefix>, C<prefixexp>, C<privlib>, -C<privlibexp>, C<prototype>, C<ptrsize> +C<package>, C<pager>, C<passcat>, C<patchlevel>, C<path_sep>, C<perl> + +=item P + +C<PERL_REVISION>, C<PERL_SUBVERSION>, C<PERL_VERSION>, C<perladmin>, +C<perlpath>, C<pg>, C<phostname>, C<pidtype>, C<plibpth>, C<pmake>, C<pr>, +C<prefix>, C<prefixexp>, C<privlib>, C<privlibexp>, C<prototype>, +C<ptrsize> + +=item q + +C<quadkind>, C<quadtype> =item r @@ -4997,13 +5583,14 @@ C<sched_yield>, C<scriptdir>, C<scriptdirexp>, C<sed>, C<seedfunc>, C<selectminbits>, C<selecttype>, C<sendmail>, C<sh>, C<shar>, C<sharpbang>, C<shmattype>, C<shortsize>, C<shrpenv>, C<shsharp>, C<sig_count>, C<sig_name>, C<sig_name_init>, C<sig_num>, C<sig_num_init>, C<signal_t>, -C<sitearch>, C<sitearchexp>, C<sitelib>, C<sitelibexp>, C<siteprefix>, -C<siteprefixexp>, C<sizetype>, C<sleep>, C<smail>, C<small>, C<so>, -C<sockethdr>, C<socketlib>, C<sort>, C<spackage>, C<spitshell>, C<split>, -C<sPRId64>, C<sPRIeldbl>, C<sPRIEldbl>, C<sPRIfldbl>, C<sPRIFldbl>, -C<sPRIgldbl>, C<sPRIGldbl>, C<sPRIi64>, C<sPRIo64>, C<sPRIu64>, C<sPRIx64>, -C<sPRIX64>, C<src>, C<ssizetype>, C<startperl>, C<startsh>, C<static_ext>, -C<stdchar>, C<stdio_base>, C<stdio_bufsiz>, C<stdio_cnt>, C<stdio_filbuf>, +C<sitearch>, C<sitearchexp>, C<sitebin>, C<sitebinexp>, C<sitelib>, +C<sitelibexp>, C<siteprefix>, C<siteprefixexp>, C<sizetype>, C<sleep>, +C<smail>, C<small>, C<so>, C<sockethdr>, C<socketlib>, C<sort>, +C<spackage>, C<spitshell>, C<split>, C<sPRId64>, C<sPRIeldbl>, +C<sPRIEldbl>, C<sPRIfldbl>, C<sPRIFldbl>, C<sPRIgldbl>, C<sPRIGldbl>, +C<sPRIi64>, C<sPRIo64>, C<sPRIu64>, C<sPRIx64>, C<sPRIX64>, C<src>, +C<ssizetype>, C<startperl>, C<startsh>, C<static_ext>, C<stdchar>, +C<stdio_base>, C<stdio_bufsiz>, C<stdio_cnt>, C<stdio_filbuf>, C<stdio_ptr>, C<stdio_stream_array>, C<strings>, C<submit>, C<subversion>, C<sysman> @@ -5014,20 +5601,23 @@ C<touch>, C<tr>, C<trnl>, C<troff> =item u -C<uidsign>, C<uidtype>, C<uname>, C<uniq>, C<use64bits>, C<usedl>, -C<uselargefiles>, C<uselongdouble>, C<usemorebits>, C<usemultiplicity>, -C<usemymalloc>, C<usenm>, C<useopcode>, C<useperlio>, C<useposix>, -C<usesfio>, C<useshrplib>, C<usesocks>, C<usethreads>, C<usevendorprefix>, -C<usevfork>, C<usrinc>, C<uuname> +C<u16size>, C<u16type>, C<u32size>, C<u32type>, C<u64size>, C<u64type>, +C<u8size>, C<u8type>, C<uidformat>, C<uidsign>, C<uidsize>, C<uidtype>, +C<uname>, C<uniq>, C<uquadtype>, C<use5005threads>, C<use64bits>, C<usedl>, +C<useithreads>, C<uselargefiles>, C<uselongdouble>, C<uselonglong>, +C<usemorebits>, C<usemultiplicity>, C<usemymalloc>, C<usenm>, C<useopcode>, +C<useperlio>, C<useposix>, C<usesfio>, C<useshrplib>, C<usesocks>, +C<usethreads>, C<usevendorprefix>, C<usevfork>, C<usrinc>, C<uuname>, +C<uvoformat>, C<uvsize>, C<uvtype>, C<uvuformat>, C<uvxformat> =item v -C<vendorlib>, C<vendorlibexp>, C<vendorprefix>, C<vendorprefixexp>, -C<version>, C<vi>, C<voidflags> +C<vendorbin>, C<vendorbinexp>, C<vendorlib>, C<vendorlibexp>, +C<vendorprefix>, C<vendorprefixexp>, C<version>, C<vi>, C<voidflags> =item x -C<xlibpth>, C<xs_apiversion> +C<xlibpth> =item z @@ -5037,16 +5627,24 @@ C<zcat>, C<zip> =item NOTE +=back + =head2 Cwd, getcwd - get pathname of current working directory +=over + =item SYNOPSIS =item DESCRIPTION +=back + =head2 DB - programmatic interface to the Perl debugging API (draft, subject to change) +=over + =item SYNOPSIS =item DESCRIPTION @@ -5076,8 +5674,12 @@ CLIENT->output(LIST) =item AUTHOR +=back + =head2 DB_File - Perl5 access to Berkeley DB version 1.x +=over + =item SYNOPSIS =item DESCRIPTION @@ -5167,7 +5769,11 @@ B<filter_fetch_value> =over -=item Locking Databases +=item Locking: The Trouble with fd + +=item Safe ways to lock a database + +B<Tie::DB_Lock>, B<Tie::DB_LockFile>, B<DB_File::Lock> =item Sharing Databases With C Applications @@ -5203,9 +5809,13 @@ B<filter_fetch_value> =item AUTHOR +=back + =head2 Data::Dumper - stringified perl data structures, suitable for both printing and C<eval> +=over + =item SYNOPSIS =item DESCRIPTION @@ -5255,8 +5865,12 @@ Dumper =item SEE ALSO +=back + =head2 Devel::DProf - a Perl code profiler +=over + =item SYNOPSIS =item DESCRIPTION @@ -5271,8 +5885,12 @@ Dumper =item SEE ALSO +=back + =head2 Devel::Peek - A data debugging tool for the XS programmer +=over + =item SYNOPSIS =item DESCRIPTION @@ -5309,20 +5927,32 @@ Dumper =item SEE ALSO +=back + =head2 Devel::SelfStubber - generate stubs for a SelfLoading module +=over + =item SYNOPSIS =item DESCRIPTION +=back + =head2 DirHandle - supply object methods for directory handles +=over + =item SYNOPSIS =item DESCRIPTION +=back + =head2 Dumpvalue - provides screen dump of Perl data. +=over + =item SYNOPSIS =item DESCRIPTION @@ -5343,8 +5973,12 @@ veryCompact, set, get =back +=back + =head2 DynaLoader - Dynamically load C libraries into Perl code +=over + =item SYNOPSIS =item DESCRIPTION @@ -5357,23 +5991,48 @@ bootstrap() =item AUTHOR +=back + +=head2 DynaLoader::XSLoader, XSLoader - Dynamically load C libraries into +Perl code + +=over + +=item SYNOPSIS + +=item DESCRIPTION + +=item AUTHOR + +=back + =head2 English - use nice English (or awk) names for ugly punctuation variables +=over + =item SYNOPSIS =item DESCRIPTION +=back + =head2 Env - perl module that imports environment variables +=over + =item SYNOPSIS =item DESCRIPTION =item AUTHOR +=back + =head2 Errno - System errno constants +=over + =item SYNOPSIS =item DESCRIPTION @@ -5382,8 +6041,12 @@ variables =item COPYRIGHT +=back + =head2 Exporter - Implements default import method for modules +=over + =item SYNOPSIS =item DESCRIPTION @@ -5406,22 +6069,50 @@ variables =back +=back + =head2 Exporter::Heavy - Exporter guts +=over + =item SYNOPIS =item DESCRIPTION +=back + =head2 ExtUtils::Command - utilities to replace common UNIX commands in Makefiles etc. +=over + =item SYNOPSIS =item DESCRIPTION -cat, eqtime src dst, rm_f files..., rm_f files..., touch files .., mv -source... destination, cp source... destination, chmod mode files.., mkpath -directory.., test_f file +=back + +cat + +eqtime src dst + +rm_f files... + +rm_f files... + +touch files .. + +mv source... destination + +cp source... destination + +chmod mode files.. + +mkpath directory.. + +test_f file + +=over =item BUGS @@ -5429,8 +6120,12 @@ directory.., test_f file =item AUTHOR +=back + =head2 ExtUtils::Embed - Utilities for embedding Perl in C/C++ applications +=over + =item SYNOPSIS =item DESCRIPTION @@ -5448,14 +6143,22 @@ ccopts(), xsi_header(), xsi_protos(@modules), xsi_body(@modules) =item AUTHOR +=back + =head2 ExtUtils::Install - install files from here to there +=over + =item SYNOPSIS =item DESCRIPTION +=back + =head2 ExtUtils::Installed - Inventory management of installed modules +=over + =item SYNOPSIS =item DESCRIPTION @@ -5471,8 +6174,12 @@ packlist(), version() =item AUTHOR +=back + =head2 ExtUtils::Liblist - determine libraries to use and how to use them +=over + =item SYNOPSIS =item DESCRIPTION @@ -5501,24 +6208,36 @@ For static extensions, For dynamic extensions, For dynamic extensions =item SEE ALSO +=back + =head2 ExtUtils::MM_Cygwin - methods to override UN*X behaviour in ExtUtils::MakeMaker +=over + =item SYNOPSIS =item DESCRIPTION canonpath, cflags, manifypods, perl_archive +=back + =head2 ExtUtils::MM_OS2 - methods to override UN*X behaviour in ExtUtils::MakeMaker +=over + =item SYNOPSIS =item DESCRIPTION +=back + =head2 ExtUtils::MM_Unix - methods used by ExtUtils::MakeMaker +=over + =item SYNOPSIS =item DESCRIPTION @@ -5529,37 +6248,203 @@ ExtUtils::MakeMaker =item Preloaded methods -canonpath, catdir, catfile, curdir, rootdir, updir +canonpath + +=back + +=back + +catdir + +catfile + +curdir + +rootdir + +updir + +=over =item SelfLoaded methods -c_o (o), cflags (o), clean (o), const_cccmd (o), const_config (o), -const_loadlibs (o), constants (o), depend (o), dir_target (o), dist (o), -dist_basics (o), dist_ci (o), dist_core (o), dist_dir (o), dist_test (o), -dlsyms (o), dynamic (o), dynamic_bs (o), dynamic_lib (o), exescan, -extliblist, file_name_is_absolute, find_perl +c_o (o) + +=back + +cflags (o) + +clean (o) + +const_cccmd (o) + +const_config (o) + +const_loadlibs (o) + +constants (o) + +depend (o) + +dir_target (o) + +dist (o) + +dist_basics (o) + +dist_ci (o) + +dist_core (o) + +dist_dir (o) + +dist_test (o) + +dlsyms (o) + +dynamic (o) + +dynamic_bs (o) + +dynamic_lib (o) + +exescan + +extliblist + +file_name_is_absolute + +find_perl + +=over =item Methods to actually produce chunks of text for the Makefile -fixin, force (o), guess_name, has_link_code, htmlifypods (o), init_dirscan, -init_main, init_others, install (o), installbin (o), libscan (o), linkext -(o), lsdir, macro (o), makeaperl (o), makefile (o), manifypods (o), -maybe_command, maybe_command_in_dirs, needs_linking (o), nicetext, -parse_version, parse_abstract, pasthru (o), path, perl_script, perldepend -(o), ppd, perm_rw (o), perm_rwx (o), pm_to_blib, post_constants (o), -post_initialize (o), postamble (o), prefixify, processPL (o), realclean -(o), replace_manpage_separator, static (o), static_lib (o), staticmake (o), -subdir_x (o), subdirs (o), test (o), test_via_harness (o), test_via_script -(o), tool_autosplit (o), tools_other (o), tool_xsubpp (o), top_targets (o), -writedoc, xs_c (o), xs_cpp (o), xs_o (o), perl_archive, export_list +fixin =back +force (o) + +guess_name + +has_link_code + +htmlifypods (o) + +init_dirscan + +init_main + +init_others + +install (o) + +installbin (o) + +libscan (o) + +linkext (o) + +lsdir + +macro (o) + +makeaperl (o) + +makefile (o) + +manifypods (o) + +maybe_command + +maybe_command_in_dirs + +needs_linking (o) + +nicetext + +parse_version + +parse_abstract + +pasthru (o) + +path + +perl_script + +perldepend (o) + +ppd + +perm_rw (o) + +perm_rwx (o) + +pm_to_blib + +post_constants (o) + +post_initialize (o) + +postamble (o) + +prefixify + +processPL (o) + +realclean (o) + +replace_manpage_separator + +static (o) + +static_lib (o) + +staticmake (o) + +subdir_x (o) + +subdirs (o) + +test (o) + +test_via_harness (o) + +test_via_script (o) + +tool_autosplit (o) + +tools_other (o) + +tool_xsubpp (o) + +top_targets (o) + +writedoc + +xs_c (o) + +xs_cpp (o) + +xs_o (o) + +perl_archive + +export_list + +=over + =item SEE ALSO +=back + =head2 ExtUtils::MM_VMS - methods to override UN*X behaviour in ExtUtils::MakeMaker +=over + =item SYNOPSIS =item DESCRIPTION @@ -5568,42 +6453,159 @@ ExtUtils::MakeMaker =item Methods always loaded -wraplist, rootdir (override) +wraplist + +=back + +=back + +rootdir (override) + +=over =item SelfLoaded methods -guess_name (override), find_perl (override), path (override), maybe_command -(override), maybe_command_in_dirs (override), perl_script (override), -file_name_is_absolute (override), replace_manpage_separator, init_others -(override), constants (override), cflags (override), const_cccmd -(override), pm_to_blib (override), tool_autosplit (override), tool_sxubpp -(override), xsubpp_version (override), tools_other (override), dist -(override), c_o (override), xs_c (override), xs_o (override), top_targets -(override), dlsyms (override), dynamic_lib (override), dynamic_bs -(override), static_lib (override), manifypods (override), processPL -(override), installbin (override), subdir_x (override), clean (override), -realclean (override), dist_basics (override), dist_core (override), -dist_dir (override), dist_test (override), install (override), perldepend -(override), makefile (override), test (override), test_via_harness -(override), test_via_script (override), makeaperl (override), nicetext -(override) +guess_name (override) =back +find_perl (override) + +path (override) + +maybe_command (override) + +maybe_command_in_dirs (override) + +perl_script (override) + +file_name_is_absolute (override) + +replace_manpage_separator + +init_others (override) + +constants (override) + +cflags (override) + +const_cccmd (override) + +pm_to_blib (override) + +tool_autosplit (override) + +tool_sxubpp (override) + +xsubpp_version (override) + +tools_other (override) + +dist (override) + +c_o (override) + +xs_c (override) + +xs_o (override) + +top_targets (override) + +dlsyms (override) + +dynamic_lib (override) + +dynamic_bs (override) + +static_lib (override) + +manifypods (override) + +processPL (override) + +installbin (override) + +subdir_x (override) + +clean (override) + +realclean (override) + +dist_basics (override) + +dist_core (override) + +dist_dir (override) + +dist_test (override) + +install (override) + +perldepend (override) + +makefile (override) + +test (override) + +test_via_harness (override) + +test_via_script (override) + +makeaperl (override) + +nicetext (override) + =head2 ExtUtils::MM_Win32 - methods to override UN*X behaviour in ExtUtils::MakeMaker +=over + =item SYNOPSIS =item DESCRIPTION -catfile, constants (o), static_lib (o), dynamic_bs (o), dynamic_lib (o), -canonpath, perl_script, pm_to_blib, test_via_harness (o), tool_autosplit -(override), tools_other (o), xs_o (o), top_targets (o), htmlifypods (o), -manifypods (o), dist_ci (o), dist_core (o), pasthru (o) +=back + +catfile + +constants (o) + +static_lib (o) + +dynamic_bs (o) + +dynamic_lib (o) + +canonpath + +perl_script + +pm_to_blib + +test_via_harness (o) + +tool_autosplit (override) + +tools_other (o) + +xs_o (o) + +top_targets (o) + +htmlifypods (o) + +manifypods (o) + +dist_ci (o) + +dist_core (o) + +pasthru (o) =head2 ExtUtils::MakeMaker - create an extension Makefile +=over + =item SYNOPSIS =item DESCRIPTION @@ -5675,8 +6677,12 @@ PERL_MM_OPT =item AUTHORS +=back + =head2 ExtUtils::Manifest - utilities to write and check a MANIFEST file +=over + =item SYNOPSIS =item DESCRIPTION @@ -5696,23 +6702,35 @@ C<Added to MANIFEST:> I<file> =item AUTHOR +=back + =head2 ExtUtils::Miniperl, writemain - write the C code for perlmain.c +=over + =item SYNOPSIS =item DESCRIPTION =item SEE ALSO +=back + =head2 ExtUtils::Mkbootstrap - make a bootstrap file for use by DynaLoader +=over + =item SYNOPSIS =item DESCRIPTION +=back + =head2 ExtUtils::Mksymlists - write linker options files for dynamic extension +=over + =item SYNOPSIS =item DESCRIPTION @@ -5723,8 +6741,12 @@ DLBASE, DL_FUNCS, DL_VARS, FILE, FUNCLIST, IMPORTS, NAME =item REVISION +=back + =head2 ExtUtils::Packlist - manage .packlist files +=over + =item SYNOPSIS =item DESCRIPTION @@ -5739,22 +6761,34 @@ new(), read(), write(), validate(), packlist_file() =item AUTHOR +=back + =head2 ExtUtils::testlib - add blib/* directories to @INC +=over + =item SYNOPSIS =item DESCRIPTION +=back + =head2 Fatal - replace functions with equivalents which succeed or die +=over + =item SYNOPSIS =item DESCRIPTION =item AUTHOR +=back + =head2 Fcntl - load the C Fcntl.h defines +=over + =item SYNOPSIS =item DESCRIPTION @@ -5763,8 +6797,12 @@ new(), read(), write(), validate(), packlist_file() =item EXPORTED SYMBOLS +=back + =head2 File::Basename, fileparse - split a pathname into pieces +=over + =item SYNOPSIS =item DESCRIPTION @@ -5775,14 +6813,22 @@ fileparse_set_fstype, fileparse C<basename>, C<dirname> +=back + =head2 File::CheckTree, validate - run many filetest checks on a tree +=over + =item SYNOPSIS =item DESCRIPTION +=back + =head2 File::Compare - Compare files or filehandles +=over + =item SYNOPSIS =item DESCRIPTION @@ -5791,8 +6837,12 @@ C<basename>, C<dirname> =item AUTHOR +=back + =head2 File::Copy - Copy files or filehandles +=over + =item SYNOPSIS =item DESCRIPTION @@ -5809,8 +6859,12 @@ rmscopy($from,$to[,$date_flag]) =item AUTHOR +=back + =head2 File::DosGlob - DOS like globbing and then some +=over + =item SYNOPSIS =item DESCRIPTION @@ -5825,15 +6879,47 @@ rmscopy($from,$to[,$date_flag]) =item SEE ALSO +=back + =head2 File::Find, find - traverse a file tree +=over + =item SYNOPSIS =item DESCRIPTION -=item BUGS +C<wanted>, C<bydepth>, C<follow>, C<follow_fast>, C<follow_skip>, +C<no_chdir>, C<untaint>, C<untaint_pattern>, C<untaint_skip> + +=item CAVEAT + +=back -=head2 File::Path - create or remove a series of directories +=head2 File::Glob - Perl extension for BSD glob routine + +=over + +=item SYNOPSIS + +=item DESCRIPTION + +C<GLOB_ERR>, C<GLOB_MARK>, C<GLOB_NOCASE>, C<GLOB_NOCHECK>, C<GLOB_NOSORT>, +C<GLOB_BRACE>, C<GLOB_NOMAGIC>, C<GLOB_QUOTE>, C<GLOB_TILDE>, C<GLOB_CSH> + +=item DIAGNOSTICS + +C<GLOB_NOSPACE>, C<GLOB_ABEND> + +=item NOTES + +=item AUTHOR + +=back + +=head2 File::Path - create or remove directory trees + +=over =item SYNOPSIS @@ -5841,8 +6927,12 @@ rmscopy($from,$to[,$date_flag]) =item AUTHORS +=back + =head2 File::Spec - portably perform operations on file names +=over + =item SYNOPSIS =item DESCRIPTION @@ -5851,8 +6941,12 @@ rmscopy($from,$to[,$date_flag]) =item AUTHORS +=back + =head2 File::Spec::Functions - portably perform operations on file names +=over + =item SYNOPSIS =item DESCRIPTION @@ -5865,72 +6959,190 @@ rmscopy($from,$to[,$date_flag]) =item SEE ALSO +=back + =head2 File::Spec::Mac - File::Spec for MacOS +=over + =item SYNOPSIS =item DESCRIPTION =item METHODS -canonpath, catdir, catfile, curdir, devnull, rootdir, tmpdir, updir, -file_name_is_absolute, path +canonpath + +=back + +catdir + +catfile + +curdir + +devnull + +rootdir + +tmpdir + +updir + +file_name_is_absolute + +path + +=over =item SEE ALSO +=back + =head2 File::Spec::OS2 - methods for OS/2 file specs +=over + =item SYNOPSIS =item DESCRIPTION +=back + =head2 File::Spec::Unix - methods used by File::Spec +=over + =item SYNOPSIS =item DESCRIPTION =item METHODS -canonpath, catdir, catfile, curdir, devnull, rootdir, tmpdir, updir, -no_upwards, file_name_is_absolute, path, join, splitpath, splitdir, -catpath, abs2rel, rel2abs +canonpath + +=back + +catdir + +catfile + +curdir + +devnull + +rootdir + +tmpdir + +updir + +no_upwards + +file_name_is_absolute + +path + +join + +splitpath + +splitdir + +catpath + +abs2rel + +rel2abs + +=over =item SEE ALSO +=back + =head2 File::Spec::VMS - methods for VMS file specs +=over + =item SYNOPSIS =item DESCRIPTION -eliminate_macros, fixpath +eliminate_macros + +=back + +fixpath =over =item Methods always loaded -catdir, catfile, curdir (override), devnull (override), rootdir (override), -tmpdir (override), updir (override), path (override), file_name_is_absolute -(override) +catdir =back +catfile + +curdir (override) + +devnull (override) + +rootdir (override) + +tmpdir (override) + +updir (override) + +path (override) + +file_name_is_absolute (override) + +=over + =item SEE ALSO +=back + =head2 File::Spec::Win32 - methods for Win32 file specs +=over + =item SYNOPSIS =item DESCRIPTION -devnull, tmpdir, catfile, canonpath, splitpath, splitdir, catpath, abs2rel, +devnull + +=back + +tmpdir + +catfile + +canonpath + +splitpath + +splitdir + +catpath + +abs2rel + rel2abs +=over + =item SEE ALSO +=back + =head2 File::stat - by-name interface to Perl's built-in stat() functions +=over + =item SYNOPSIS =item DESCRIPTION @@ -5939,16 +7151,24 @@ rel2abs =item AUTHOR +=back + =head2 FileCache - keep more files open than the system permits +=over + =item SYNOPSIS =item DESCRIPTION =item BUGS +=back + =head2 FileHandle - supply object methods for filehandles +=over + =item SYNOPSIS =item DESCRIPTION @@ -5957,8 +7177,12 @@ $fh->print, $fh->printf, $fh->getline, $fh->getlines =item SEE ALSO +=back + =head2 FindBin - Locate directory of original perl script +=over + =item SYNOPSIS =item DESCRIPTION @@ -5971,8 +7195,12 @@ $fh->print, $fh->printf, $fh->getline, $fh->getlines =item COPYRIGHT +=back + =head2 GDBM_File - Perl5 access to the gdbm library. +=over + =item SYNOPSIS =item DESCRIPTION @@ -5983,9 +7211,13 @@ $fh->print, $fh->printf, $fh->getline, $fh->getlines =item SEE ALSO +=back + =head2 Getopt::Long, GetOptions - extended processing of command line options +=over + =item SYNOPSIS =item DESCRIPTION @@ -6025,28 +7257,44 @@ $Getopt::Long::VERSION, $Getopt::Long::error =item COPYRIGHT AND DISCLAIMER +=back + =head2 Getopt::Std, getopt - Process single-character switches with switch clustering +=over + =item SYNOPSIS =item DESCRIPTION +=back + =head2 I18N::Collate - compare 8-bit scalar data according to the current locale +=over + =item SYNOPSIS =item DESCRIPTION +=back + =head2 IO - load various IO modules +=over + =item SYNOPSIS =item DESCRIPTION +=back + =head2 IO::Dir - supply object methods for directory handles +=over + =item SYNOPSIS =item DESCRIPTION @@ -6060,8 +7308,12 @@ rewind (), close (), tie %hash, IO::Dir, DIRNAME [, OPTIONS ] =item COPYRIGHT +=back + =head2 IO::File - supply object methods for filehandles +=over + =item SYNOPSIS =item DESCRIPTION @@ -6078,8 +7330,12 @@ open( FILENAME [,MODE [,PERMS]] ) =item HISTORY +=back + =head2 IO::Handle - supply object methods for I/O handles +=over + =item SYNOPSIS =item DESCRIPTION @@ -6103,8 +7359,12 @@ $io->blocking ( [ BOOL ] ), $io->untaint =item HISTORY +=back + =head2 IO::Pipe - supply object methods for pipes +=over + =item SYNOPSIS =item DESCRIPTION @@ -6123,8 +7383,12 @@ reader ([ARGS]), writer ([ARGS]), handles () =item COPYRIGHT +=back + =head2 IO::Poll - Object interface to system poll call +=over + =item SYNOPSIS =item DESCRIPTION @@ -6140,8 +7404,12 @@ IO ), handles( [ EVENT_MASK ] ) =item COPYRIGHT +=back + =head2 IO::Seekable - supply seek based methods for I/O objects +=over + =item SYNOPSIS =item DESCRIPTION @@ -6150,8 +7418,12 @@ IO ), handles( [ EVENT_MASK ] ) =item HISTORY +=back + =head2 IO::Select - OO interface to the select system call +=over + =item SYNOPSIS =item DESCRIPTION @@ -6172,8 +7444,12 @@ count (), bits(), select ( READ, WRITE, ERROR [, TIMEOUT ] ) =item COPYRIGHT +=back + =head2 IO::Socket - Object interface to socket communications +=over + =item SYNOPSIS =item DESCRIPTION @@ -6193,8 +7469,12 @@ sockopt(OPT [, VAL]), sockdomain, socktype, protocol, connected =item COPYRIGHT +=back + =head2 IO::Socket::INET - Object interface for AF_INET domain sockets +=over + =item SYNOPSIS =item DESCRIPTION @@ -6218,8 +7498,12 @@ sockaddr (), sockport (), sockhost (), peeraddr (), peerport (), peerhost =item COPYRIGHT +=back + =head2 IO::Socket::UNIX - Object interface for AF_UNIX domain sockets +=over + =item SYNOPSIS =item DESCRIPTION @@ -6238,9 +7522,13 @@ hostpath(), peerpath() =item COPYRIGHT +=back + =head2 IO::lib::IO::Dir, IO::Dir - supply object methods for directory handles +=over + =item SYNOPSIS =item DESCRIPTION @@ -6254,8 +7542,12 @@ rewind (), close (), tie %hash, IO::Dir, DIRNAME [, OPTIONS ] =item COPYRIGHT +=back + =head2 IO::lib::IO::File, IO::File - supply object methods for filehandles +=over + =item SYNOPSIS =item DESCRIPTION @@ -6272,9 +7564,13 @@ open( FILENAME [,MODE [,PERMS]] ) =item HISTORY +=back + =head2 IO::lib::IO::Handle, IO::Handle - supply object methods for I/O handles +=over + =item SYNOPSIS =item DESCRIPTION @@ -6298,8 +7594,12 @@ $io->blocking ( [ BOOL ] ), $io->untaint =item HISTORY +=back + =head2 IO::lib::IO::Pipe, IO::Pipe - supply object methods for pipes +=over + =item SYNOPSIS =item DESCRIPTION @@ -6318,8 +7618,12 @@ reader ([ARGS]), writer ([ARGS]), handles () =item COPYRIGHT +=back + =head2 IO::lib::IO::Poll, IO::Poll - Object interface to system poll call +=over + =item SYNOPSIS =item DESCRIPTION @@ -6335,9 +7639,13 @@ IO ), handles( [ EVENT_MASK ] ) =item COPYRIGHT +=back + =head2 IO::lib::IO::Seekable, IO::Seekable - supply seek based methods for I/O objects +=over + =item SYNOPSIS =item DESCRIPTION @@ -6346,9 +7654,13 @@ I/O objects =item HISTORY +=back + =head2 IO::lib::IO::Select, IO::Select - OO interface to the select system call +=over + =item SYNOPSIS =item DESCRIPTION @@ -6369,9 +7681,13 @@ count (), bits(), select ( READ, WRITE, ERROR [, TIMEOUT ] ) =item COPYRIGHT +=back + =head2 IO::lib::IO::Socket, IO::Socket - Object interface to socket communications +=over + =item SYNOPSIS =item DESCRIPTION @@ -6391,9 +7707,13 @@ sockopt(OPT [, VAL]), sockdomain, socktype, protocol, connected =item COPYRIGHT +=back + =head2 IO::lib::IO::Socket::INET, IO::Socket::INET - Object interface for AF_INET domain sockets +=over + =item SYNOPSIS =item DESCRIPTION @@ -6417,9 +7737,13 @@ sockaddr (), sockport (), sockhost (), peeraddr (), peerport (), peerhost =item COPYRIGHT +=back + =head2 IO::lib::IO::Socket::UNIX, IO::Socket::UNIX - Object interface for AF_UNIX domain sockets +=over + =item SYNOPSIS =item DESCRIPTION @@ -6438,26 +7762,12 @@ hostpath(), peerpath() =item COPYRIGHT -=head2 IPC::Msg - SysV Msg IPC object class - -=item SYNOPSIS - -=item DESCRIPTION - -=item METHODS - -new ( KEY , FLAGS ), id, rcv ( BUF, LEN [, TYPE [, FLAGS ]] ), remove, set -( STAT ), set ( NAME => VALUE [, NAME => VALUE ...] ), snd ( TYPE, MSG [, -FLAGS ] ), stat - -=item SEE ALSO - -=item AUTHOR - -=item COPYRIGHT +=back =head2 IPC::Open2, open2 - open a process for both reading and writing +=over + =item SYNOPSIS =item DESCRIPTION @@ -6466,36 +7776,25 @@ FLAGS ] ), stat =item SEE ALSO +=back + =head2 IPC::Open3, open3 - open a process for reading, writing, and error handling -=item SYNOPSIS - -=item DESCRIPTION - -=item WARNING - -=head2 IPC::Semaphore - SysV Semaphore IPC object class +=over =item SYNOPSIS =item DESCRIPTION -=item METHODS - -new ( KEY , NSEMS , FLAGS ), getall, getncnt ( SEM ), getpid ( SEM ), -getval ( SEM ), getzcnt ( SEM ), id, op ( OPLIST ), remove, set ( STAT ), -set ( NAME => VALUE [, NAME => VALUE ...] ), setall ( VALUES ), setval ( N -, VALUE ), stat - -=item SEE ALSO - -=item AUTHOR +=item WARNING -=item COPYRIGHT +=back =head2 IPC::SysV - SysV IPC constants +=over + =item SYNOPSIS =item DESCRIPTION @@ -6508,8 +7807,12 @@ ftok( PATH, ID ) =item COPYRIGHT +=back + =head2 IPC::SysV::Msg, IPC::Msg - SysV Msg IPC object class +=over + =item SYNOPSIS =item DESCRIPTION @@ -6526,9 +7829,13 @@ FLAGS ] ), stat =item COPYRIGHT +=back + =head2 IPC::SysV::Semaphore, IPC::Semaphore - SysV Semaphore IPC object class +=over + =item SYNOPSIS =item DESCRIPTION @@ -6546,8 +7853,12 @@ set ( NAME => VALUE [, NAME => VALUE ...] ), setall ( VALUES ), setval ( N =item COPYRIGHT +=back + =head2 Math::BigFloat - Arbitrary length float math package +=over + =item SYNOPSIS =item DESCRIPTION @@ -6559,8 +7870,12 @@ performed =item AUTHOR +=back + =head2 Math::BigInt - Arbitrary size integer math package +=over + =item SYNOPSIS =item DESCRIPTION @@ -6575,9 +7890,13 @@ Canonical notation, Input, Output =item AUTHOR +=back + =head2 Math::Complex - complex numbers and associated mathematical functions +=over + =item SYNOPSIS =item DESCRIPTION @@ -6598,8 +7917,12 @@ functions =item AUTHORS +=back + =head2 Math::Trig - trigonometric functions +=over + =item SYNOPSIS =item DESCRIPTION @@ -6639,14 +7962,22 @@ cylindrical_to_spherical, spherical_to_cartesian, spherical_to_cylindrical =item AUTHORS +=back + =head2 NDBM_File - Tied access to ndbm files +=over + =item SYNOPSIS =item DESCRIPTION +=back + =head2 Net::Ping - check a remote host for reachability +=over + =item SYNOPSIS =item DESCRIPTION @@ -6664,9 +7995,13 @@ $timeout]);, $p->close();, pingecho($host [, $timeout]); =item NOTES +=back + =head2 Net::hostent - by-name interface to Perl's built-in gethost*() functions +=over + =item SYNOPSIS =item DESCRIPTION @@ -6677,9 +8012,13 @@ functions =item AUTHOR +=back + =head2 Net::netent - by-name interface to Perl's built-in getnet*() functions +=over + =item SYNOPSIS =item DESCRIPTION @@ -6690,9 +8029,13 @@ functions =item AUTHOR +=back + =head2 Net::protoent - by-name interface to Perl's built-in getproto*() functions +=over + =item SYNOPSIS =item DESCRIPTION @@ -6701,9 +8044,13 @@ functions =item AUTHOR +=back + =head2 Net::servent - by-name interface to Perl's built-in getserv*() functions +=over + =item SYNOPSIS =item DESCRIPTION @@ -6714,8 +8061,12 @@ functions =item AUTHOR +=back + =head2 O - Generic interface to Perl Compiler backends +=over + =item SYNOPSIS =item DESCRIPTION @@ -6726,14 +8077,22 @@ functions =item AUTHOR +=back + =head2 ODBM_File - Tied access to odbm files +=over + =item SYNOPSIS =item DESCRIPTION +=back + =head2 Opcode - Disable named opcodes when compiling perl code +=over + =item SYNOPSIS =item DESCRIPTION @@ -6758,6 +8117,10 @@ opdump (PAT) =item TO DO (maybe) +=back + +=over + =item Predefined Opcode Tags :base_core, :base_mem, :base_loop, :base_io, :base_orig, :base_math, @@ -6769,9 +8132,13 @@ opdump (PAT) =item AUTHORS +=back + =head2 Opcode::Safe, Safe - Compile and execute code in restricted compartments +=over + =item SYNOPSIS =item DESCRIPTION @@ -6799,17 +8166,25 @@ Memory, CPU, Snooping, Signals, State Changes =back +=back + =head2 Opcode::ops, ops - Perl pragma to restrict unsafe operations when compiling +=over + =item SYNOPSIS =item DESCRIPTION =item SEE ALSO +=back + =head2 POSIX - Perl interface to IEEE Std 1003.1 +=over + =item SYNOPSIS =item DESCRIPTION @@ -6935,20 +8310,64 @@ Constants, Macros =item CREATION +=back + =head2 Pod::Checker, podchecker() - check pod documents for syntax errors +=over + =item SYNOPSIS =item OPTIONS/ARGUMENTS +=over + +=item Options + +B<-warnings> =E<gt> I<val> + +=back + =item DESCRIPTION +=over + +=item Warnings + +=back + +=item DIAGNOSTICS + +=item RETURN VALUE + =item EXAMPLES =item AUTHOR +=back + +=head2 Pod::Checker, Pod::Hyperlink - class for manipulation of POD +hyperlinks + +=over + +=item SYNOPSIS + +=item DESCRIPTION + +=item METHODS + +new(), parse(), markup($on,$off,$pageon,$pageoff), text(), warning(), +page(), node(), type(), alttext(), line(), file() + +=item AUTHOR + +=back + =head2 Pod::Html - module to convert pod files to HTML +=over + =item SYNOPSIS =item DESCRIPTION @@ -6965,15 +8384,17 @@ verbose, quiet =item AUTHOR -=item BUGS - =item SEE ALSO =item COPYRIGHT +=back + =head2 Pod::InputObjects - objects representing POD input paragraphs, commands, etc. +=over + =item SYNOPSIS =item REQUIRES @@ -6985,96 +8406,224 @@ commands, etc. B<Pod::InputSource>, B<Pod::Paragraph>, B<Pod::InteriorSequence>, B<Pod::ParseTree> +=back + +=over + =item B<Pod::InputSource> +=back + =over =item B<new()> +=back + +=over + =item B<name()> +=back + +=over + =item B<handle()> +=back + +=over + =item B<was_cutting()> =back +=over + =item B<Pod::Paragraph> +=back + =over =item B<new()> +=back + +=over + =item B<cmd_name()> +=back + +=over + =item B<text()> +=back + +=over + =item B<raw_text()> +=back + +=over + =item B<cmd_prefix()> +=back + +=over + =item B<cmd_separator()> +=back + +=over + =item B<parse_tree()> +=back + +=over + =item B<file_line()> =back +=over + =item B<Pod::InteriorSequence> +=back + =over =item B<new()> +=back + +=over + =item B<cmd_name()> +=back + +=over + =item B<prepend()> +=back + +=over + =item B<append()> +=back + +=over + =item B<nested()> +=back + +=over + =item B<raw_text()> +=back + +=over + =item B<left_delimiter()> +=back + +=over + =item B<right_delimiter()> +=back + +=over + =item B<parse_tree()> +=back + +=over + =item B<file_line()> +=back + +=over + =item B<DESTROY()> =back +=over + =item B<Pod::ParseTree> +=back + =over =item B<new()> +=back + +=over + =item B<top()> +=back + +=over + =item B<children()> +=back + +=over + =item B<prepend()> +=back + +=over + =item B<append()> +=back + +=over + =item B<raw_text()> +=back + +=over + =item B<DESTROY()> =back +=over + =item SEE ALSO =item AUTHOR +=back + =head2 Pod::Man - Convert POD data to formatted *roff input +=over + =item SYNOPSIS =item DESCRIPTION @@ -7095,8 +8644,12 @@ EE<lt>%sE<gt>, Unknown sequence %s, Unmatched =back =item AUTHOR +=back + =head2 Pod::Parser - base class for creating POD filters and translators +=over + =item SYNOPSIS =item REQUIRES @@ -7111,91 +8664,231 @@ EE<lt>%sE<gt>, Unknown sequence %s, Unmatched =back B<-want_nonPODs> (default: unset), B<-process_cut_cmd> (default: unset) +=back + +=over + =item RECOMMENDED SUBROUTINE/METHOD OVERRIDES +=back + +=over + =item B<command()> C<$cmd>, C<$text>, C<$line_num>, C<$pod_para> +=back + +=over + =item B<verbatim()> C<$text>, C<$line_num>, C<$pod_para> +=back + +=over + =item B<textblock()> C<$text>, C<$line_num>, C<$pod_para> +=back + +=over + =item B<interior_sequence()> +=back + +=over + =item OPTIONAL SUBROUTINE/METHOD OVERRIDES +=back + +=over + =item B<new()> +=back + +=over + =item B<initialize()> +=back + +=over + =item B<begin_pod()> +=back + +=over + =item B<begin_input()> +=back + +=over + =item B<end_input()> +=back + +=over + =item B<end_pod()> +=back + +=over + =item B<preprocess_line()> +=back + +=over + =item B<preprocess_paragraph()> +=back + +=over + =item METHODS FOR PARSING AND PROCESSING +=back + +=over + =item B<parse_text()> B<-expand_seq> =E<gt> I<code-ref>|I<method-name>, B<-expand_text> =E<gt> I<code-ref>|I<method-name>, B<-expand_ptree> =E<gt> I<code-ref>|I<method-name> +=back + +=over + =item B<interpolate()> +=back + +=over + =item B<parse_paragraph()> +=back + +=over + =item B<parse_from_filehandle()> +=back + +=over + =item B<parse_from_file()> +=back + +=over + =item ACCESSOR METHODS +=back + +=over + =item B<errorsub()> +=back + +=over + =item B<cutting()> +=back + +=over + =item B<parseopts()> +=back + +=over + =item B<output_file()> +=back + +=over + =item B<output_handle()> +=back + +=over + =item B<input_file()> +=back + +=over + =item B<input_handle()> +=back + +=over + =item B<input_streams()> +=back + +=over + =item B<top_stream()> +=back + +=over + =item PRIVATE METHODS AND DATA +=back + +=over + =item B<_push_input_stream()> +=back + +=over + =item B<_pop_input_stream()> +=back + +=over + =item TREE-BASED PARSING =item SEE ALSO =item AUTHOR +=back + =head2 Pod::Select, podselect() - extract selected sections of POD from input +=over + =item SYNOPSIS =item REQUIRES @@ -7208,44 +8901,100 @@ input =item RANGE SPECIFICATIONS +=back + +=over + =item OBJECT METHODS +=back + +=over + =item B<curr_headings()> +=back + +=over + =item B<select()> +=back + +=over + =item B<add_selection()> +=back + +=over + =item B<clear_selections()> +=back + +=over + =item B<match_section()> +=back + +=over + =item B<is_selected()> +=back + +=over + =item EXPORTED FUNCTIONS +=back + +=over + =item B<podselect()> B<-output>, B<-sections>, B<-ranges> +=back + +=over + =item PRIVATE METHODS AND DATA +=back + +=over + =item B<_compile_section_spec()> +=back + =over =item $self->{_SECTION_HEADINGS} +=back + +=over + =item $self->{_SELECTED_SECTIONS} =back +=over + =item SEE ALSO =item AUTHOR +=back + =head2 Pod::Text - Convert POD data to formatted ASCII text +=over + =item SYNOPSIS =item DESCRIPTION @@ -7265,8 +9014,12 @@ Unknown sequence: %s, Unmatched =back =item AUTHOR +=back + =head2 Pod::Text::Color - Convert POD data to formatted color ASCII text +=over + =item SYNOPSIS =item DESCRIPTION @@ -7277,9 +9030,13 @@ Unknown sequence: %s, Unmatched =back =item AUTHOR +=back + =head2 Pod::Text::Termcap, Pod::Text::Color - Convert POD data to ASCII text with format escapes +=over + =item SYNOPSIS =item DESCRIPTION @@ -7288,9 +9045,13 @@ text with format escapes =item AUTHOR +=back + =head2 Pod::Usage, pod2usage() - print a usage message from embedded pod documentation +=over + =item SYNOPSIS =item ARGUMENTS @@ -7314,14 +9075,22 @@ C<-pathlist> =item ACKNOWLEDGEMENTS +=back + =head2 SDBM_File - Tied access to sdbm files +=over + =item SYNOPSIS =item DESCRIPTION +=back + =head2 Safe - Compile and execute code in restricted compartments +=over + =item SYNOPSIS =item DESCRIPTION @@ -7349,20 +9118,32 @@ Memory, CPU, Snooping, Signals, State Changes =back +=back + =head2 Search::Dict, look - search for key in dictionary file +=over + =item SYNOPSIS =item DESCRIPTION +=back + =head2 SelectSaver - save and restore selected file handle +=over + =item SYNOPSIS =item DESCRIPTION +=back + =head2 SelfLoader - load functions only on demand +=over + =item SYNOPSIS =item DESCRIPTION @@ -7385,17 +9166,25 @@ Memory, CPU, Snooping, Signals, State Changes =item Multiple packages and fully qualified subroutine names +=back + =head2 Shell - run shell commands transparently within perl +=over + =item SYNOPSIS =item DESCRIPTION =item AUTHOR +=back + =head2 Socket, sockaddr_in, sockaddr_un, inet_aton, inet_ntoa - load the C socket.h defines and structure manipulators +=over + =item SYNOPSIS =item DESCRIPTION @@ -7406,23 +9195,35 @@ SOCKADDR_IN, pack_sockaddr_in PORT, IP_ADDRESS, unpack_sockaddr_in SOCKADDR_IN, sockaddr_un PATHNAME, sockaddr_un SOCKADDR_UN, pack_sockaddr_un PATH, unpack_sockaddr_un SOCKADDR_UN +=back + =head2 Symbol - manipulate Perl symbols and their names +=over + =item SYNOPSIS =item DESCRIPTION +=back + =head2 Sys::Hostname - Try every conceivable way to get hostname +=over + =item SYNOPSIS =item DESCRIPTION =item AUTHOR +=back + =head2 Syslog, Sys::Syslog, openlog, closelog, setlogmask, syslog - Perl interface to the UNIX syslog(3) calls +=over + =item SYNOPSIS =item DESCRIPTION @@ -7439,16 +9240,24 @@ closelog =item AUTHOR +=back + =head2 Term::Cap - Perl termcap interface +=over + =item SYNOPSIS =item DESCRIPTION =item EXAMPLES +=back + =head2 Term::Complete - Perl word completion module +=over + =item SYNOPSIS =item DESCRIPTION @@ -7461,9 +9270,13 @@ E<lt>tabE<gt>, ^D, ^U, E<lt>delE<gt>, E<lt>bsE<gt> =item AUTHOR +=back + =head2 Term::ReadLine - Perl interface to various C<readline> packages. If no real package is found, substitutes stubs instead of basic functions. +=over + =item SYNOPSIS =item DESCRIPTION @@ -7481,8 +9294,12 @@ C<tkRunning>, C<ornaments>, C<newTTY> =item ENVIRONMENT +=back + =head2 Test - provides a simple framework for writing test scripts +=over + =item SYNOPSIS =item DESCRIPTION @@ -7499,8 +9316,12 @@ NORMAL TESTS, SKIPPED TESTS, TODO TESTS =item AUTHOR +=back + =head2 Test::Harness - run perl standard test scripts with statistics +=over + =item SYNOPSIS =item DESCRIPTION @@ -7528,17 +9349,25 @@ C<All tests successful.\nFiles=%d, Tests=%d, %s>, C<FAILED tests =item BUGS +=back + =head2 Text::Abbrev, abbrev - create an abbreviation table from a list +=over + =item SYNOPSIS =item DESCRIPTION =item EXAMPLE +=back + =head2 Text::ParseWords - parse text into an array of tokens or array of arrays +=over + =item SYNOPSIS =item DESCRIPTION @@ -7553,9 +9382,13 @@ backslashed double-quote) =item AUTHORS +=back + =head2 Text::Soundex - Implementation of the Soundex Algorithm as Described by Knuth +=over + =item SYNOPSIS =item DESCRIPTION @@ -7566,9 +9399,13 @@ by Knuth =item AUTHOR +=back + =head2 Text::Tabs -- expand and unexpand tabs per the unix expand(1) and unexpand(1) +=over + =item SYNOPSIS =item DESCRIPTION @@ -7577,8 +9414,12 @@ unexpand(1) =item AUTHOR +=back + =head2 Text::Wrap - line wrapping to form simple paragraphs +=over + =item SYNOPSIS =item DESCRIPTION @@ -7587,8 +9428,12 @@ unexpand(1) =item AUTHOR +=back + =head2 Thread - multithreading +=over + =item SYNOPSIS =item DESCRIPTION @@ -7607,8 +9452,12 @@ join, eval, detach, equal, tid =item SEE ALSO +=back + =head2 Thread::Queue - thread-safe queues +=over + =item SYNOPSIS =item DESCRIPTION @@ -7619,8 +9468,12 @@ new, enqueue LIST, dequeue, dequeue_nb, pending =item SEE ALSO +=back + =head2 Thread::Semaphore - thread-safe semaphores +=over + =item SYNOPSIS =item DESCRIPTION @@ -7629,38 +9482,54 @@ new, enqueue LIST, dequeue, dequeue_nb, pending new, new NUMBER, down, down NUMBER, up, up NUMBER +=back + =head2 Thread::Signal - Start a thread which runs signal handlers reliably +=over + =item SYNOPSIS =item DESCRIPTION =item BUGS +=back + =head2 Thread::Specific - thread-specific keys +=over + =item SYNOPSIS =item DESCRIPTION +=back + =head2 Tie::Array - base class for tied arrays +=over + =item SYNOPSIS =item DESCRIPTION TIEARRAY classname, LIST, STORE this, index, value, FETCH this, index, -FETCHSIZE this, STORESIZE this, count, EXTEND this, count, CLEAR this, -DESTROY this, PUSH this, LIST, POP this, SHIFT this, UNSHIFT this, LIST, -SPLICE this, offset, length, LIST +FETCHSIZE this, STORESIZE this, count, EXTEND this, count, EXISTS this, +key, DELETE this, key, CLEAR this, DESTROY this, PUSH this, LIST, POP this, +SHIFT this, UNSHIFT this, LIST, SPLICE this, offset, length, LIST =item CAVEATS =item AUTHOR +=back + =head2 Tie::Handle, Tie::StdHandle - base class definitions for tied handles +=over + =item SYNOPSIS =item DESCRIPTION @@ -7672,8 +9541,12 @@ EOF this, TELL this, SEEK this, offset, whence, DESTROY this =item MORE INFORMATION +=back + =head2 Tie::Hash, Tie::StdHash - base class definitions for tied hashes +=over + =item SYNOPSIS =item DESCRIPTION @@ -7685,8 +9558,12 @@ this, NEXTKEY this, lastkey, EXISTS this, key, DELETE this, key, CLEAR this =item MORE INFORMATION +=back + =head2 Tie::RefHash - use references as hash keys +=over + =item SYNOPSIS =item DESCRIPTION @@ -7699,9 +9576,13 @@ this, NEXTKEY this, lastkey, EXISTS this, key, DELETE this, key, CLEAR this =item SEE ALSO +=back + =head2 Tie::Scalar, Tie::StdScalar - base class definitions for tied scalars +=over + =item SYNOPSIS =item DESCRIPTION @@ -7710,16 +9591,24 @@ TIESCALAR classname, LIST, FETCH this, STORE this, value, DESTROY this =item MORE INFORMATION +=back + =head2 Tie::SubstrHash - Fixed-table-size, fixed-key-length hashing +=over + =item SYNOPSIS =item DESCRIPTION =item CAVEATS +=back + =head2 Time::Local - efficiently compute time from local and GMT time +=over + =item SYNOPSIS =item DESCRIPTION @@ -7728,9 +9617,13 @@ TIESCALAR classname, LIST, FETCH this, STORE this, value, DESTROY this =item BUGS +=back + =head2 Time::gmtime - by-name interface to Perl's built-in gmtime() function +=over + =item SYNOPSIS =item DESCRIPTION @@ -7739,9 +9632,13 @@ function =item AUTHOR +=back + =head2 Time::localtime - by-name interface to Perl's built-in localtime() function +=over + =item SYNOPSIS =item DESCRIPTION @@ -7750,16 +9647,24 @@ function =item AUTHOR +=back + =head2 Time::tm - internal object used by Time::gmtime and Time::localtime +=over + =item SYNOPSIS =item DESCRIPTION =item AUTHOR +=back + =head2 UNIVERSAL - base class for ALL classes (blessed references) +=over + =item SYNOPSIS =item DESCRIPTION @@ -7767,9 +9672,13 @@ function isa ( TYPE ), can ( METHOD ), VERSION ( [ REQUIRE ] ), UNIVERSAL::isa ( VAL, TYPE ), UNIVERSAL::can ( VAL, METHOD ) +=back + =head2 User::grent - by-name interface to Perl's built-in getgr*() functions +=over + =item SYNOPSIS =item DESCRIPTION @@ -7778,9 +9687,13 @@ functions =item AUTHOR +=back + =head2 User::pwent - by-name interface to Perl's built-in getpw*() functions +=over + =item SYNOPSIS =item DESCRIPTION @@ -7789,11 +9702,27 @@ functions =item AUTHOR +=back + +=head2 XSLoader - Dynamically load C libraries into Perl code + +=over + +=item SYNOPSIS + +=item DESCRIPTION + +=item AUTHOR + +=back + =head1 AUXILIARY DOCUMENTATION Here should be listed all the extra programs' documentation, but they don't all have manual pages yet: +=over + =item a2p =item s2p @@ -7812,6 +9741,8 @@ don't all have manual pages yet: =item wrapsuid +=back + =head1 AUTHOR Larry Wall <F<larry@wall.org>>, with the help of oodles diff --git a/pod/perltodo.pod b/pod/perltodo.pod index 7836acf677..55a29bd3be 100644 --- a/pod/perltodo.pod +++ b/pod/perltodo.pod @@ -297,6 +297,8 @@ subject on perl5-porters. Ronald Kimball (rjk@linguist.dartmouth.edu) has volunteered. +=back + =head2 Include a search tool perldoc should be able to 'grep' fulltext indices of installed POD @@ -824,7 +826,7 @@ Workarounds to help Win32 dynamic loading. =head2 END blocks -END blocks need saving in compiled output, now that STOP blocks +END blocks need saving in compiled output, now that CHECK blocks are available. =head2 _AUTOLOAD @@ -6832,7 +6832,7 @@ perl_clone_using(PerlInterpreter *proto_perl, UV flags, PL_beginav = av_dup_inc(proto_perl->Ibeginav); PL_endav = av_dup_inc(proto_perl->Iendav); - PL_stopav = av_dup_inc(proto_perl->Istopav); + PL_checkav = av_dup_inc(proto_perl->Icheckav); PL_initav = av_dup_inc(proto_perl->Iinitav); PL_sub_generation = proto_perl->Isub_generation; diff --git a/t/op/attrs.t b/t/op/attrs.t index e89c2cb816..615e4d3343 100644 --- a/t/op/attrs.t +++ b/t/op/attrs.t @@ -63,12 +63,12 @@ mytest; BEGIN {++$ntests} my $anon1; -eval '$anon1 = sub ($) : locked,,method { $_[0]++ }'; +eval '$anon1 = sub ($) : locked:method { $_[0]++ }'; mytest; BEGIN {++$ntests} my $anon2; -eval '$anon2 = sub : locked , method { $_[0]++ }'; +eval '$anon2 = sub : locked : method { $_[0]++ }'; mytest; BEGIN {++$ntests} diff --git a/t/op/fork.t b/t/op/fork.t index b743a4589f..11efa79d17 100755 --- a/t/op/fork.t +++ b/t/op/fork.t @@ -6,7 +6,10 @@ BEGIN { chdir 't' if -d 't'; unshift @INC, '../lib'; require Config; import Config; - unless ($Config{'d_fork'} || ($^O eq 'MSWin32' && $Config{'useithreads'})) { + unless ($Config{'d_fork'} + or ($^O eq 'MSWin32' and $Config{useithreads} + and $Config{ccflags} =~ /-DPERL_IMPLICIT_SYS/)) + { print "1..0 # Skip: no fork\n"; exit 0; } diff --git a/t/op/misc.t b/t/op/misc.t index 9f8c7dedab..6ffc04cbcf 100755 --- a/t/op/misc.t +++ b/t/op/misc.t @@ -357,11 +357,11 @@ BEGIN { @ARGV = qw(a b c d e) } BEGIN { print "argv <@ARGV>\nbegin <",shift,">\n" } END { print "end <",shift,">\nargv <@ARGV>\n" } INIT { print "init <",shift,">\n" } -STOP { print "stop <",shift,">\n" } +CHECK { print "check <",shift,">\n" } EXPECT argv <a b c d e> begin <a> -stop <b> +check <b> init <c> end <d> argv <e> @@ -2797,8 +2797,10 @@ Perl_yylex(pTHX) newSVpvn(s, len))); } s = skipspace(d); - while (*s == ',') + if (*s == ':' && s[1] != ':') s = skipspace(s+1); + else if (s == d) + break; /* require real whitespace or :'s */ } tmp = (PL_expect == XOPERATOR ? '=' : '{'); /*'}(' for vi */ if (*s != ';' && *s != tmp && (tmp != '=' || *s != ')')) { @@ -3858,9 +3860,9 @@ Perl_yylex(pTHX) case KEY_AUTOLOAD: case KEY_DESTROY: case KEY_BEGIN: - case KEY_END: - case KEY_STOP: + case KEY_CHECK: case KEY_INIT: + case KEY_END: if (PL_expect == XSTATE) { s = PL_bufptr; goto really_sub; @@ -4921,6 +4923,7 @@ Perl_keyword(pTHX_ register char *d, I32 len) break; case 'C': if (strEQ(d,"CORE")) return -KEY_CORE; + if (strEQ(d,"CHECK")) return KEY_CHECK; break; case 'c': switch (len) { @@ -5304,9 +5307,6 @@ Perl_keyword(pTHX_ register char *d, I32 len) break; } break; - case 'S': - if (strEQ(d,"STOP")) return KEY_STOP; - break; case 's': switch (d[1]) { case 0: return KEY_s; diff --git a/vms/perly_c.vms b/vms/perly_c.vms index ebc7d57cc3..b17faeade1 100644 --- a/vms/perly_c.vms +++ b/vms/perly_c.vms @@ -1828,7 +1828,7 @@ case 59: #line 338 "perly.y" { STRLEN n_a; char *name = SvPV(((SVOP*)yyvsp[0].opval)->op_sv,n_a); if (strEQ(name, "BEGIN") || strEQ(name, "END") - || strEQ(name, "STOP") || strEQ(name, "INIT")) + || strEQ(name, "INIT") || strEQ(name, "CHECK")) CvSPECIAL_on(PL_compcv); yyval.opval = yyvsp[0].opval; } break; diff --git a/win32/win32.c b/win32/win32.c index c7621157cf..af5e454f27 100644 --- a/win32/win32.c +++ b/win32/win32.c @@ -1797,6 +1797,7 @@ EXTERN_C _CRTIMP ioinfo* __pioinfo[]; #ifdef USE_FIXED_OSFHANDLE #define FOPEN 0x01 /* file handle open */ +#define FNOINHERIT 0x10 /* file handle opened O_NOINHERIT */ #define FAPPEND 0x20 /* file handle opened O_APPEND */ #define FDEV 0x40 /* file handle refers to device */ #define FTEXT 0x80 /* file handle is in text mode */ @@ -1837,7 +1838,8 @@ EXTERN_C _CRTIMP ioinfo* __pioinfo[]; /* create an ioinfo entry, kill its handle, and steal the entry */ -static int _alloc_osfhnd() +static int +_alloc_osfhnd(void) { HANDLE hF = CreateFile("NUL", 0, 0, NULL, OPEN_ALWAYS, 0, NULL); int fh = _open_osfhandle((long)hF, 0); @@ -1863,6 +1865,9 @@ my_open_osfhandle(long osfhandle, int flags) if (flags & O_TEXT) fileflags |= FTEXT; + if (flags & O_NOINHERIT) + fileflags |= FNOINHERIT; + /* attempt to allocate a C Runtime file handle */ if ((fh = _alloc_osfhnd()) == -1) { errno = EMFILE; /* too many open files */ @@ -2671,7 +2676,8 @@ win32_dup2(int fd1,int fd2) #define FTEXT 0x80 /* file handle is in text mode */ #define MAX_DESCRIPTOR_COUNT (64*32) /* this is the maximun that MSVCRT can handle */ -int __cdecl _fixed_read(int fh, void *buf, unsigned cnt) +int __cdecl +_fixed_read(int fh, void *buf, unsigned cnt) { int bytes_read; /* number of bytes read */ char *buffer; /* buffer to read to */ diff --git a/win32/win32.h b/win32/win32.h index 066ed720d4..69a4caf063 100644 --- a/win32/win32.h +++ b/win32/win32.h @@ -232,7 +232,7 @@ typedef long gid_t; /* compatibility stuff for other compilers goes here */ -#if !defined(PERL_OBJECT) && defined(PERL_MEMBER_PTR_SIZE) +#if !defined(PERL_OBJECT) && defined(PERL_CAPI) && defined(PERL_MEMBER_PTR_SIZE) # define STRUCT_MGVTBL_DEFINITION \ struct mgvtbl { \ union { \ @@ -268,7 +268,7 @@ struct mgvtbl { \ U8 op_flags; \ U8 op_private; -#endif /* !PERL_OBJECT && PERL_MEMBER_PTR_SIZE */ +#endif /* !PERL_OBJECT && PERL_CAPI && PERL_MEMBER_PTR_SIZE */ START_EXTERN_C |