View file File name : podlint Content :#!/usr/bin/perl -w eval 'exec /usr/bin/perl -w -S $0 ${1+"$@"}' if 0; # not running under some shell use Pod::POM; use Getopt::Std; use File::Basename; my $program = basename($0); my %opts; getopts('fh', \%opts); die usage() if $opts{ h }; my $file = shift || die usage(); my $parser = Pod::POM->new( warn => 1, code => 1 ) || die "$Pod::POM::ERROR\n"; my $pom = $parser->parse_file($file) || die $parser->error(), "\n"; print $pom if $opts{ f }; sub usage { return <<EOF; usage: $program [-f] file Checks Pod file for well-formedness, printing warnings to STDERR. The -f option can be set to fix problems (where possible), printing the modified output to STDOUT. EOF } =head1 NAME podlint - check POD for correctness using Pod::POM =head1 SYNOPSIS podlint MyFile.pm =head1 DESCRIPTION This script uses Pod::POM to parse a Pod document with full warnings enabled, effectively acting as a syntax and structure checker. The -f option can be specified to have the parsed Pod Object Model printed to STDOUT with any markup errors fixed. Note there are some critical parse errors that can't be handled and fixed by the parser and in this case the script will terminate reporting the error. =head1 AUTHOR Andy Wardley E<lt>abw@kfs.orgE<gt> =head1 VERSION This is version 0.2 of podlint. =head1 COPYRIGHT Copyright (C) 2000, 2001 Andy Wardley. All Rights Reserved. This module is free software; you can redistribute it and/or modify it under the same terms as Perl itself. =head1 SEE ALSO For further information please see L<Pod::POM>.