summaryrefslogtreecommitdiffstats
path: root/upstream/mageia-cauldron/man3pm/Pod::Simple::HTML.3pm
diff options
context:
space:
mode:
Diffstat (limited to 'upstream/mageia-cauldron/man3pm/Pod::Simple::HTML.3pm')
-rw-r--r--upstream/mageia-cauldron/man3pm/Pod::Simple::HTML.3pm343
1 files changed, 343 insertions, 0 deletions
diff --git a/upstream/mageia-cauldron/man3pm/Pod::Simple::HTML.3pm b/upstream/mageia-cauldron/man3pm/Pod::Simple::HTML.3pm
new file mode 100644
index 00000000..2edd45c7
--- /dev/null
+++ b/upstream/mageia-cauldron/man3pm/Pod::Simple::HTML.3pm
@@ -0,0 +1,343 @@
+.\" -*- mode: troff; coding: utf-8 -*-
+.\" Automatically generated by Pod::Man 5.01 (Pod::Simple 3.43)
+.\"
+.\" Standard preamble:
+.\" ========================================================================
+.de Sp \" Vertical space (when we can't use .PP)
+.if t .sp .5v
+.if n .sp
+..
+.de Vb \" Begin verbatim text
+.ft CW
+.nf
+.ne \\$1
+..
+.de Ve \" End verbatim text
+.ft R
+.fi
+..
+.\" \*(C` and \*(C' are quotes in nroff, nothing in troff, for use with C<>.
+.ie n \{\
+. ds C` ""
+. ds C' ""
+'br\}
+.el\{\
+. ds C`
+. ds C'
+'br\}
+.\"
+.\" Escape single quotes in literal strings from groff's Unicode transform.
+.ie \n(.g .ds Aq \(aq
+.el .ds Aq '
+.\"
+.\" If the F register is >0, we'll generate index entries on stderr for
+.\" titles (.TH), headers (.SH), subsections (.SS), items (.Ip), and index
+.\" entries marked with X<> in POD. Of course, you'll have to process the
+.\" output yourself in some meaningful fashion.
+.\"
+.\" Avoid warning from groff about undefined register 'F'.
+.de IX
+..
+.nr rF 0
+.if \n(.g .if rF .nr rF 1
+.if (\n(rF:(\n(.g==0)) \{\
+. if \nF \{\
+. de IX
+. tm Index:\\$1\t\\n%\t"\\$2"
+..
+. if !\nF==2 \{\
+. nr % 0
+. nr F 2
+. \}
+. \}
+.\}
+.rr rF
+.\" ========================================================================
+.\"
+.IX Title "Pod::Simple::HTML 3pm"
+.TH Pod::Simple::HTML 3pm 2023-11-28 "perl v5.38.2" "Perl Programmers Reference Guide"
+.\" For nroff, turn off justification. Always turn off hyphenation; it makes
+.\" way too many mistakes in technical documents.
+.if n .ad l
+.nh
+.SH NAME
+Pod::Simple::HTML \- convert Pod to HTML
+.SH SYNOPSIS
+.IX Header "SYNOPSIS"
+.Vb 1
+\& perl \-MPod::Simple::HTML \-e Pod::Simple::HTML::go thingy.pod
+.Ve
+.SH DESCRIPTION
+.IX Header "DESCRIPTION"
+This class is for making an HTML rendering of a Pod document.
+.PP
+This is a subclass of Pod::Simple::PullParser and inherits all its
+methods (and options).
+.PP
+Note that if you want to do a batch conversion of a lot of Pod
+documents to HTML, you should see the module Pod::Simple::HTMLBatch.
+.SH "CALLING FROM THE COMMAND LINE"
+.IX Header "CALLING FROM THE COMMAND LINE"
+TODO
+.PP
+.Vb 1
+\& perl \-MPod::Simple::HTML \-e Pod::Simple::HTML::go Thing.pod Thing.html
+.Ve
+.SH "CALLING FROM PERL"
+.IX Header "CALLING FROM PERL"
+.SS "Minimal code"
+.IX Subsection "Minimal code"
+.Vb 6
+\& use Pod::Simple::HTML;
+\& my $p = Pod::Simple::HTML\->new;
+\& $p\->output_string(\emy $html);
+\& $p\->parse_file(\*(Aqpath/to/Module/Name.pm\*(Aq);
+\& open my $out, \*(Aq>\*(Aq, \*(Aqout.html\*(Aq or die "Cannot open \*(Aqout.html\*(Aq: $!\en";
+\& print $out $html;
+.Ve
+.SS "More detailed example"
+.IX Subsection "More detailed example"
+.Vb 1
+\& use Pod::Simple::HTML;
+.Ve
+.PP
+Set the content type:
+.PP
+.Vb 1
+\& $Pod::Simple::HTML::Content_decl = q{<meta http\-equiv="Content\-Type" content="text/html; charset=UTF\-8" >};
+\&
+\& my $p = Pod::Simple::HTML\->new;
+.Ve
+.PP
+Include a single javascript source:
+.PP
+.Vb 1
+\& $p\->html_javascript(\*(Aqhttp://abc.com/a.js\*(Aq);
+.Ve
+.PP
+Or insert multiple javascript source in the header
+(or for that matter include anything, thought this is not recommended)
+.PP
+.Vb 3
+\& $p\->html_javascript(\*(Aq
+\& <script type="text/javascript" src="http://abc.com/b.js"></script>
+\& <script type="text/javascript" src="http://abc.com/c.js"></script>\*(Aq);
+.Ve
+.PP
+Include a single css source in the header:
+.PP
+.Vb 1
+\& $p\->html_css(\*(Aq/style.css\*(Aq);
+.Ve
+.PP
+or insert multiple css sources:
+.PP
+.Vb 3
+\& $p\->html_css(\*(Aq
+\& <link rel="stylesheet" type="text/css" title="pod_stylesheet" href="http://remote.server.com/jquery.css">
+\& <link rel="stylesheet" type="text/css" title="pod_stylesheet" href="/style.css">\*(Aq);
+.Ve
+.PP
+Tell the parser where should the output go. In this case it will be placed in the \f(CW$html\fR variable:
+.PP
+.Vb 2
+\& my $html;
+\& $p\->output_string(\e$html);
+.Ve
+.PP
+Parse and process a file with pod in it:
+.PP
+.Vb 1
+\& $p\->parse_file(\*(Aqpath/to/Module/Name.pm\*(Aq);
+.Ve
+.SH METHODS
+.IX Header "METHODS"
+TODO
+all (most?) accessorized methods
+.PP
+The following variables need to be set \fBbefore\fR the call to the \->new constructor.
+.PP
+Set the string that is included before the opening <html> tag:
+.PP
+.Vb 2
+\& $Pod::Simple::HTML::Doctype_decl = qq{<!DOCTYPE HTML PUBLIC "\-//W3C//DTD HTML 4.01 Transitional//EN"
+\& "http://www.w3.org/TR/html4/loose.dtd">\en};
+.Ve
+.PP
+Set the content-type in the HTML head: (defaults to ISO\-8859\-1)
+.PP
+.Vb 1
+\& $Pod::Simple::HTML::Content_decl = q{<meta http\-equiv="Content\-Type" content="text/html; charset=UTF\-8" >};
+.Ve
+.PP
+Set the value that will be embedded in the opening tags of F, C tags and verbatim text.
+F maps to <em>, C maps to <code>, Verbatim text maps to <pre> (Computerese defaults to "")
+.PP
+.Vb 1
+\& $Pod::Simple::HTML::Computerese = \*(Aq class="some_class_name\*(Aq;
+.Ve
+.SS html_css
+.IX Subsection "html_css"
+.SS html_javascript
+.IX Subsection "html_javascript"
+.SS title_prefix
+.IX Subsection "title_prefix"
+.SS title_postfix
+.IX Subsection "title_postfix"
+.SS html_header_before_title
+.IX Subsection "html_header_before_title"
+This includes everything before the <title> opening tag including the Document type
+and including the opening <title> tag. The following call will set it to be a simple HTML
+file:
+.PP
+.Vb 1
+\& $p\->html_header_before_title(\*(Aq<html><head><title>\*(Aq);
+.Ve
+.SS top_anchor
+.IX Subsection "top_anchor"
+By default Pod::Simple::HTML adds a dummy anchor at the top of the HTML.
+You can change it by calling
+.PP
+.Vb 1
+\& $p\->top_anchor(\*(Aq<a name="zz" >\*(Aq);
+.Ve
+.SS html_h_level
+.IX Subsection "html_h_level"
+Normally =head1 will become <h1>, =head2 will become <h2> etc.
+Using the html_h_level method will change these levels setting the h level
+of =head1 tags:
+.PP
+.Vb 1
+\& $p\->html_h_level(3);
+.Ve
+.PP
+Will make sure that =head1 will become <h3> and =head2 will become <h4> etc...
+.SS index
+.IX Subsection "index"
+Set it to some true value if you want to have an index (in reality a table of contents)
+to be added at the top of the generated HTML.
+.PP
+.Vb 1
+\& $p\->index(1);
+.Ve
+.SS html_header_after_title
+.IX Subsection "html_header_after_title"
+Includes the closing tag of </title> and through the rest of the head
+till the opening of the body
+.PP
+.Vb 1
+\& $p\->html_header_after_title(\*(Aq</title>...</head><body id="my_id">\*(Aq);
+.Ve
+.SS html_footer
+.IX Subsection "html_footer"
+The very end of the document:
+.PP
+.Vb 1
+\& $p\->html_footer( qq[\en<!\-\- end doc \-\->\en\en</body></html>\en] );
+.Ve
+.SH SUBCLASSING
+.IX Header "SUBCLASSING"
+Can use any of the methods described above but for further customization
+one needs to override some of the methods:
+.PP
+.Vb 3
+\& package My::Pod;
+\& use strict;
+\& use warnings;
+\&
+\& use base \*(AqPod::Simple::HTML\*(Aq;
+\&
+\& # needs to return a URL string such
+\& # http://some.other.com/page.html
+\& # #anchor_in_the_same_file
+\& # /internal/ref.html
+\& sub do_pod_link {
+\& # My::Pod object and Pod::Simple::PullParserStartToken object
+\& my ($self, $link) = @_;
+\&
+\& say $link\->tagname; # will be L for links
+\& say $link\->attr(\*(Aqto\*(Aq); #
+\& say $link\->attr(\*(Aqtype\*(Aq); # will be \*(Aqpod\*(Aq always
+\& say $link\->attr(\*(Aqsection\*(Aq);
+\&
+\& # Links local to our web site
+\& if ($link\->tagname eq \*(AqL\*(Aq and $link\->attr(\*(Aqtype\*(Aq) eq \*(Aqpod\*(Aq) {
+\& my $to = $link\->attr(\*(Aqto\*(Aq);
+\& if ($to =~ /^Padre::/) {
+\& $to =~ s{::}{/}g;
+\& return "/docs/Padre/$to.html";
+\& }
+\& }
+\&
+\& # all other links are generated by the parent class
+\& my $ret = $self\->SUPER::do_pod_link($link);
+\& return $ret;
+\& }
+\&
+\& 1;
+.Ve
+.PP
+Meanwhile in script.pl:
+.PP
+.Vb 1
+\& use My::Pod;
+\&
+\& my $p = My::Pod\->new;
+\&
+\& my $html;
+\& $p\->output_string(\e$html);
+\& $p\->parse_file(\*(Aqpath/to/Module/Name.pm\*(Aq);
+\& open my $out, \*(Aq>\*(Aq, \*(Aqout.html\*(Aq or die;
+\& print $out $html;
+.Ve
+.PP
+TODO
+.PP
+maybe override do_beginning do_end
+.SH "SEE ALSO"
+.IX Header "SEE ALSO"
+Pod::Simple, Pod::Simple::HTMLBatch
+.PP
+TODO: a corpus of sample Pod input and HTML output? Or common
+idioms?
+.SH SUPPORT
+.IX Header "SUPPORT"
+Questions or discussion about POD and Pod::Simple should be sent to the
+pod\-people@perl.org mail list. Send an empty email to
+pod\-people\-subscribe@perl.org to subscribe.
+.PP
+This module is managed in an open GitHub repository,
+<https://github.com/perl\-pod/pod\-simple/>. Feel free to fork and contribute, or
+to clone <git://github.com/perl\-pod/pod\-simple.git> and send patches!
+.PP
+Patches against Pod::Simple are welcome. Please send bug reports to
+<bug\-pod\-simple@rt.cpan.org>.
+.SH "COPYRIGHT AND DISCLAIMERS"
+.IX Header "COPYRIGHT AND DISCLAIMERS"
+Copyright (c) 2002\-2004 Sean M. Burke.
+.PP
+This library is free software; you can redistribute it and/or modify it
+under the same terms as Perl itself.
+.PP
+This program is distributed in the hope that it will be useful, but
+without any warranty; without even the implied warranty of
+merchantability or fitness for a particular purpose.
+.SH ACKNOWLEDGEMENTS
+.IX Header "ACKNOWLEDGEMENTS"
+Thanks to Hurricane Electric <http://he.net/> for permission to use its
+Linux man pages online <http://man.he.net/> site for man page links.
+.PP
+Thanks to search.cpan.org <http://search.cpan.org/> for permission to use the
+site for Perl module links.
+.SH AUTHOR
+.IX Header "AUTHOR"
+Pod::Simple was created by Sean M. Burke <sburke@cpan.org>.
+But don't bother him, he's retired.
+.PP
+Pod::Simple is maintained by:
+.IP \(bu 4
+Allison Randal \f(CW\*(C`allison@perl.org\*(C'\fR
+.IP \(bu 4
+Hans Dieter Pearcey \f(CW\*(C`hdp@cpan.org\*(C'\fR
+.IP \(bu 4
+David E. Wheeler \f(CW\*(C`dwheeler@cpan.org\*(C'\fR