summaryrefslogtreecommitdiff
path: root/bin/pod2html.pl
blob: 935ff11989172f7907c209e84f1fa9128af34b16 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
#!/usr/bin/env perl

=head1 NAME

pod2html.pl

=head1 DESCRIPTION

Generate HTML from POD documentation

Search directories /usr/local/share/perl and /usr/local/bin

Output HTML to /var/www/html/freeside-doc

=cut

use strict;
use warnings;
use v5.10;

use Pod::Simple::Search;
use Pod::Simple::HTML;
use Pod::Simple::HTMLBatch;

# Disable this to only build docs for Freeside modules
# This will cause links to non-freeside packages to be broken,
# but save 30-60secs during build process
my $include_system_perl_modules = 1;


my $html_dir = shift @ARGV
  or HELP_MESSAGE('Please specify an OUTPUT_DIRECTORY');

HELP_MESSAGE("Directory $html_dir: No write access!")
  unless -w $html_dir;


my $parser = Pod::Simple::HTMLBatch->new;

# Uncomment to suppress status output to STDIN
# $parser->verbose(0);

$parser->search_class('Inline::Pod::Simple::Search');
$parser->html_render_class('Inline::Pod::Simple::HTML');

# Customized HTML output
our $html_before_title = q{
  <% include( '/elements/header.html', 'Developer Documentation' ) %>
  <& /elements/menubar.html,
    'Freeside Perl Modules' => $fsurl.'docs/library/FS.html',
    'Complete Index' => $fsurl.'docs/library/index.html',
  &>

  <div style="width: 90%; margin: 1em auto; font-size: .9em; border: solid 1px #666; background-color: #eee; padding: 1em;">
  <h1 style="margin: .5em; border-bottom: solid 1px #999;">
};
our $html_after_title = q{</h1>};
our $html_footer = q{</div><% include ('/elements/footer.html' ) %>};

$parser->contents_page_start(
  "$html_before_title Freeside Documentation Index $html_after_title"
);
$parser->contents_page_end( $html_footer );

my @search_dirs = (
  '/usr/local/share/perl/5.24.1',
  '/usr/local/bin',
  $include_system_perl_modules ? (
    '/usr/share/perl5',
    '/usr/share/perl/5.24',
    '/usr/share/perl/5.24.1',
  ) : (),
);

$parser->batch_convert( \@search_dirs, $html_dir );

sub HELP_MESSAGE {
  my $error = shift;
  print " ERROR: $error \n"
    if $error;
  print "
    Tool to generate HTML from Freeside POD documentation

    Usage: pod2html.pl OUTPUT_DIRECTORY

  ";
  exit;
}



# Subclass Pod::Simple::Search to render POD from files without
# normal perl extensions like PL and PM
package Inline::Pod::Simple::Search;
use base 'Pod::Simple::Search';

sub new {
  my $class = shift;
  my $self = Pod::Simple::Search->new( @_ );
  $self->laborious(1);
  $self;
}
1;


# Subclass Pod::Simple::HTML to control HTML output
package Inline::Pod::Simple::HTML;
use base 'Pod::Simple::HTML';

sub html_header_before_title { $html_before_title }
sub html_header_after_title { $html_after_title }
sub html_footer { $html_footer }

1;