X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=tools%2FPM-Pod2html-snippet.pl;h=dd4f51cd8560b0feec2bbd7b8680f42866fbfc0c;hb=bd9f3e156952798c46df29d610af0a36ea065e89;hp=d45d28db8e4d35057991f766417d965e445c0061;hpb=55bbf7a209993f4172fd7e6555dda0947b844089;p=sdlgit%2FSDL-Site.git diff --git a/tools/PM-Pod2html-snippet.pl b/tools/PM-Pod2html-snippet.pl index d45d28d..dd4f51c 100644 --- a/tools/PM-Pod2html-snippet.pl +++ b/tools/PM-Pod2html-snippet.pl @@ -3,11 +3,12 @@ use strict; use warnings; use Carp; +use Data::Dumper; use Pod::Xhtml; use File::Copy; use File::Spec::Functions qw(rel2abs splitpath splitdir catpath catdir catfile canonpath); -my $input_path = 'C:/SDL_perl/lib/pods'; +my $input_path = 'D:/dev/SDL/lib/pods'; $input_path = $ARGV[0] if $ARGV[0]; my ($volume, $dirs) = splitpath(rel2abs(__FILE__)); @@ -94,6 +95,7 @@ sub read_file read_file($_) if(-d $_); if($_ =~ /\.pod$/i) { + print "Processing $_\n"; my $key = ''; my $file_name = $_; $file_name =~ s/^$input_path\/*//; @@ -174,20 +176,25 @@ sub new return $self; } +my $warn = 0; sub node { my $self = shift; + if($self->SUPER::type() eq 'page') { my $page = $self->SUPER::page(); my $suff = ''; - if($page =~ /^SDL\b/) + if($page =~ /^SDL(x)?\b/) { $page =~ s/::([A-Z]+)/-$1/g; - $page =~ s/(.*)::(.*)/\/$1.html#$2/; + printf "%03d WARNING: " . $self->SUPER::page() . " better written as L<$2|$1/\"$2\">\n", ++$warn if $self->SUPER::page() =~ /(.*)::([a-z_]+)$/; + + $page =~ s/(.*)\/"(.*)"/\/$1.html#$2/; $page .= '.html' unless $page =~ /\.html/; + #print $self->SUPER::page() . " -> " . $page . "\n" if $page =~ /Event/; return $page; } else @@ -195,6 +202,24 @@ sub node return "http://search.cpan.org/perldoc?$page"; } } + elsif($self->SUPER::type() eq 'item') + { + my $page = $self->SUPER::page(); + my $node = $self->SUPER::node(); + my $suff = ''; + + if($page =~ /^SDL(x)?\b/) + { + $page =~ s/::([A-Z]+)/-$1/g; + $node =~ s/"//g; + + return "/$page.html#$node"; + } + else + { + return "http://search.cpan.org/perldoc?$page"; + } + } $self->SUPER::node(@_); } @@ -208,7 +233,7 @@ sub text sub type { my $self = shift; - return "hyperlink" if($self->SUPER::type() eq 'page'); + return "hyperlink" if($self->SUPER::type() =~ /(page|item)/); $self->SUPER::type(@_); }