summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMarc Green <marcgreen@cpan.org>2011-06-18 11:26:49 -0400
committerMarc Green <marcgreen@cpan.org>2011-10-31 13:26:40 -0400
commit8e1ba33ca237189994b1360b50c07cba3eb7b987 (patch)
treebe825e5d4f13a74cbdcde4c3445afa58d395fbe8
parenta4fca47160a93b0fd7f11a25ee3cf8f303946666 (diff)
downloadperl-8e1ba33ca237189994b1360b50c07cba3eb7b987.tar.gz
Add $Htmlfileurl to support relativizing crossrefs
-rw-r--r--ext/Pod-Html/lib/Pod/Html.pm39
1 files changed, 28 insertions, 11 deletions
diff --git a/ext/Pod-Html/lib/Pod/Html.pm b/ext/Pod-Html/lib/Pod/Html.pm
index 4bb2d1e2f7..619b3cb51e 100644
--- a/ext/Pod-Html/lib/Pod/Html.pm
+++ b/ext/Pod-Html/lib/Pod/Html.pm
@@ -193,7 +193,7 @@ This program is distributed under the Artistic License.
=cut
-my($Htmlroot, $Htmldir, $Htmlfile);
+my($Htmlroot, $Htmldir, $Htmlfile, $Htmlfileurl);
my($Podfile, @Podpath, $Podroot);
my $Css;
@@ -219,6 +219,10 @@ sub init_globals {
$Htmldir = ""; # The directory to which the html pages
# will (eventually) be written.
$Htmlfile = ""; # write to stdout by default
+ $Htmlfileurl = ""; # The url that other files would use to
+ # refer to this file. This is only used
+ # to make relative urls that point to
+ # other files.
$Podfile = ""; # read from stdin by default
@Podpath = (); # list of directories containing library pods.
@@ -241,16 +245,28 @@ sub pod2html {
init_globals();
parse_command_line();
- # Prevent '//' in urls
+ # prevent '//' in urls
$Htmlroot = "" if $Htmlroot eq "/";
$Htmldir =~ s#/\z##;
+
+ if ( $Htmlroot eq ''
+ && defined( $Htmldir )
+ && $Htmldir ne ''
+ && substr( $Htmlfile, 0, length( $Htmldir ) ) eq $Htmldir
+ )
+ {
+ # Set the 'base' url for this file, so that we can use it
+ # as the location from which to calculate relative links
+ # to other files. If this is '', then absolute links will
+ # be used throughout.
+ $Htmlfileurl = "$Htmldir/" . substr( $Htmlfile, length( $Htmldir ) + 1);
+ }
- # Get the full path
+ # get the full path
@Podpath = map { File::Spec->catdir($Podroot, $_) } @Podpath;
- # finds all pod modules/pages in podpath, stores in %Pages
- # --recurse is implemented in _save_page for now (its inefficient right now)
- # (maybe subclass ::Search to implement instead (then remove callback())
+ # find all pod modules/pages in podpath, store in %Pages
+ # - callback used to remove $Podroot from each file
Pod::Simple::Search->new->inc(0)->verbose($Verbose)
->callback(\&_save_page)->survey(@Podpath);
@@ -259,13 +275,14 @@ sub pod2html {
$parser->pages(\%Pages);
$parser->backlink($Backlink);
$parser->htmldir($Htmldir);
+ $parser->htmlfileurl($Htmlfileurl);
$parser->htmlroot($Htmlroot);
$parser->index($Doindex);
$parser->output_string(\my $output); # written to file later
$parser->quiet($Quiet);
$parser->verbose($Verbose);
- # TODO: implement default title generator in pod::simple::xhtml
+ # TODO: implement default title generator in pod::simple::xhtml
$Title = html_escape($Title);
my $csslink = '';
@@ -465,13 +482,12 @@ sub anchorify {
return $anchor;
}
+#
+# store POD files in %Pages
+#
sub _save_page {
my ($modspec, $modname) = @_;
- unless ($Recurse) {
-# discard any pages that are below top level dir
- }
-
# Remove $Podroot from path for cross referencing
my $rel_path = substr($modspec, length($Podroot) + 1);
@@ -480,3 +496,4 @@ sub _save_page {
}
1;
+