| 1 | #!/usr/local/bin/perl
|
|---|
| 2 |
|
|---|
| 3 | use Config;
|
|---|
| 4 | use File::Basename qw(&basename &dirname);
|
|---|
| 5 | use Cwd;
|
|---|
| 6 |
|
|---|
| 7 | # List explicitly here the variables you want Configure to
|
|---|
| 8 | # generate. Metaconfig only looks for shell variables, so you
|
|---|
| 9 | # have to mention them as if they were shell variables, not
|
|---|
| 10 | # %Config entries. Thus you write
|
|---|
| 11 | # $startperl
|
|---|
| 12 | # to ensure Configure will look for $Config{startperl}.
|
|---|
| 13 |
|
|---|
| 14 | # This forces PL files to create target in same directory as PL file.
|
|---|
| 15 | # This is so that make depend always knows where to find PL derivatives.
|
|---|
| 16 | $origdir = cwd;
|
|---|
| 17 | chdir(dirname($0));
|
|---|
| 18 | ($file = basename($0)) =~ s/\.PL$//;
|
|---|
| 19 | $file =~ s/\.pl$//
|
|---|
| 20 | if ($^O eq 'VMS' or $^O eq 'os2' or $^O eq 'dos'); # "case-forgiving"
|
|---|
| 21 | $file .= '.com' if $^O eq 'VMS';
|
|---|
| 22 |
|
|---|
| 23 | open OUT,">$file" or die "Can't create $file: $!";
|
|---|
| 24 |
|
|---|
| 25 | print "Extracting $file (with variable substitutions)\n";
|
|---|
| 26 |
|
|---|
| 27 | # In this section, perl variables will be expanded during extraction.
|
|---|
| 28 | # You can use $Config{...} to use Configure variables.
|
|---|
| 29 |
|
|---|
| 30 | print OUT <<"!GROK!THIS!";
|
|---|
| 31 | $Config{'startperl'}
|
|---|
| 32 | eval 'exec perl -S \$0 "\$@"'
|
|---|
| 33 | if 0;
|
|---|
| 34 | !GROK!THIS!
|
|---|
| 35 |
|
|---|
| 36 | # In the following, perl variables are not expanded during extraction.
|
|---|
| 37 |
|
|---|
| 38 | print OUT <<'!NO!SUBS!';
|
|---|
| 39 | #############################################################################
|
|---|
| 40 | # podchecker -- command to invoke the podchecker function in Pod::Checker
|
|---|
| 41 | #
|
|---|
| 42 | # Copyright (c) 1998-2000 by Bradford Appleton. All rights reserved.
|
|---|
| 43 | # This file is part of "PodParser". PodParser is free software;
|
|---|
| 44 | # you can redistribute it and/or modify it under the same terms
|
|---|
| 45 | # as Perl itself.
|
|---|
| 46 | #############################################################################
|
|---|
| 47 |
|
|---|
| 48 | use strict;
|
|---|
| 49 | #use diagnostics;
|
|---|
| 50 |
|
|---|
| 51 | =head1 NAME
|
|---|
| 52 |
|
|---|
| 53 | podchecker - check the syntax of POD format documentation files
|
|---|
| 54 |
|
|---|
| 55 | =head1 SYNOPSIS
|
|---|
| 56 |
|
|---|
| 57 | B<podchecker> [B<-help>] [B<-man>] [B<-(no)warnings>] [I<file>S< >...]
|
|---|
| 58 |
|
|---|
| 59 | =head1 OPTIONS AND ARGUMENTS
|
|---|
| 60 |
|
|---|
| 61 | =over 8
|
|---|
| 62 |
|
|---|
| 63 | =item B<-help>
|
|---|
| 64 |
|
|---|
| 65 | Print a brief help message and exit.
|
|---|
| 66 |
|
|---|
| 67 | =item B<-man>
|
|---|
| 68 |
|
|---|
| 69 | Print the manual page and exit.
|
|---|
| 70 |
|
|---|
| 71 | =item B<-warnings> B<-nowarnings>
|
|---|
| 72 |
|
|---|
| 73 | Turn on/off printing of warnings. Repeating B<-warnings> increases the
|
|---|
| 74 | warning level, i.e. more warnings are printed. Currently increasing to
|
|---|
| 75 | level two causes flagging of unescaped "E<lt>,E<gt>" characters.
|
|---|
| 76 |
|
|---|
| 77 | =item I<file>
|
|---|
| 78 |
|
|---|
| 79 | The pathname of a POD file to syntax-check (defaults to standard input).
|
|---|
| 80 |
|
|---|
| 81 | =back
|
|---|
| 82 |
|
|---|
| 83 | =head1 DESCRIPTION
|
|---|
| 84 |
|
|---|
| 85 | B<podchecker> will read the given input files looking for POD
|
|---|
| 86 | syntax errors in the POD documentation and will print any errors
|
|---|
| 87 | it find to STDERR. At the end, it will print a status message
|
|---|
| 88 | indicating the number of errors found.
|
|---|
| 89 |
|
|---|
| 90 | Directories are ignored, an appropriate warning message is printed.
|
|---|
| 91 |
|
|---|
| 92 | B<podchecker> invokes the B<podchecker()> function exported by B<Pod::Checker>
|
|---|
| 93 | Please see L<Pod::Checker/podchecker()> for more details.
|
|---|
| 94 |
|
|---|
| 95 | =head1 RETURN VALUE
|
|---|
| 96 |
|
|---|
| 97 | B<podchecker> returns a 0 (zero) exit status if all specified
|
|---|
| 98 | POD files are ok.
|
|---|
| 99 |
|
|---|
| 100 | =head1 ERRORS
|
|---|
| 101 |
|
|---|
| 102 | B<podchecker> returns the exit status 1 if at least one of
|
|---|
| 103 | the given POD files has syntax errors.
|
|---|
| 104 |
|
|---|
| 105 | The status 2 indicates that at least one of the specified
|
|---|
| 106 | files does not contain I<any> POD commands.
|
|---|
| 107 |
|
|---|
| 108 | Status 1 overrides status 2. If you want unambigouus
|
|---|
| 109 | results, call B<podchecker> with one single argument only.
|
|---|
| 110 |
|
|---|
|
|---|