perlpod.pod

来自「MSYS在windows下模拟了一个类unix的终端」· POD 代码 · 共 319 行

POD
319
字号
=head1 NAMEperlpod - plain old documentation=head1 DESCRIPTIONA pod-to-whatever translator reads a pod file paragraph by paragraph,and translates it to the appropriate output format.  There arethree kinds of paragraphs:L<verbatim|/"Verbatim Paragraph">,L<command|/"Command Paragraph">, andL<ordinary text|/"Ordinary Block of Text">.=head2 Verbatim ParagraphA verbatim paragraph, distinguished by being indented (that is,it starts with space or tab).  It should be reproduced exactly,with tabs assumed to be on 8-column boundaries.  There are nospecial formatting escapes, so you can't italicize or anythinglike that.  A \ means \, and nothing else.=head2 Command ParagraphAll command paragraphs start with "=", followed by anidentifier, followed by arbitrary text that the command canuse however it pleases.  Currently recognized commands are    =head1 heading    =head2 heading    =item text    =over N    =back    =cut    =pod    =for X    =begin X    =end X=over 4=item =pod=item =cutThe "=pod" directive does nothing beyond telling the compiler to layoff parsing code through the next "=cut".  It's useful for addinganother paragraph to the doc if you're mixing up code and pod a lot.=item =head1=item =head2Head1 and head2 produce first and second level headings, with the text inthe same paragraph as the "=headn" directive forming the heading description.=item =over=item =back=item =itemItem, over, and back require a little more explanation: "=over" starts asection specifically for the generation of a list using "=item" commands. Atthe end of your list, use "=back" to end it. You will probably want to give"4" as the number to "=over", as some formatters will use this for indentation.The unit of indentation is optional. If the unit is not given the naturalindentation of the formatting system applied will be used. Note also thatthere are some basic rules to using =item: don't use them outside of an =over/=back block, use at least one inside an =over/=back block, you don't_have_ to include the =back if the list just runs off the document, andperhaps most importantly, keep the items consistent: either use "=item *" forall of them, to produce bullets, or use "=item 1.", "=item 2.", etc., toproduce numbered lists, or use "=item foo", "=item bar", etc., i.e., thingsthat looks nothing like bullets or numbers. If you start with bullets ornumbers, stick with them, as many formatters use the first "=item" type todecide how to format the list.=item =for=item =begin=item =endFor, begin, and end let you include sections that are not interpretedas pod text, but passed directly to particular formatters. A formatterthat can utilize that format will use the section, otherwise it will becompletely ignored.  The directive "=for" specifies that the entire nextparagraph is in the format indicated by the first word after"=for", like this: =for html <br>  <p> This is a raw HTML paragraph </p>The paired commands "=begin" and "=end" work very similarly to "=for", butinstead of only accepting a single paragraph, all text from "=begin" to aparagraph with a matching "=end" are treated as a particular format.Here are some examples of how to use these: =begin html <br>Figure 1.<IMG SRC="figure1.png"><br> =end html =begin text   ---------------   |  foo        |   |        bar  |   --------------- ^^^^ Figure 1. ^^^^ =end textSome format names that formatters currently are known to accept include"roff", "man", "latex", "tex", "text", and "html". (Some formatters willtreat some of these as synonyms.)And don't forget, when using any command, that the command lasts up untilthe end of the B<paragraph>, not the line. Hence in the examples below, youcan see the empty lines after each command to end its paragraph.Some examples of lists include: =over 4 =item * First item =item * Second item =back =over 4 =item Foo() Description of Foo function =item Bar() Description of Bar function =back=back=head2 Ordinary Block of TextIt will be filled, and maybe evenjustified.  Certain interior sequences are recognized bothhere and in commands:    I<text>     Italicize text, used for emphasis or variables    B<text>     Embolden text, used for switches and programs    S<text>     Text contains non-breaking spaces    C<code>     Render code in a typewriter font, or give some other                indication that this represents program text    L<name>     A link (cross reference) to name		    L<name>		manual page		    L<name/ident>	item in manual page		    L<name/"sec">	section in other manual page		    L<"sec">		section in this manual page					(the quotes are optional)		    L</"sec">		ditto		same as above but only 'text' is used for output.		(Text can not contain the characters '/' and '|', 		and should contain matched '<' or '>')		    L<text|name>		    L<text|name/ident>		    L<text|name/"sec">		    L<text|"sec">		    L<text|/"sec">    F<file>	Used for filenames    X<index>	An index entry    Z<>		A zero-width character    E<escape>   A named character (very similar to HTML escapes)		    E<lt>		A literal <		    E<gt>		A literal >		    E<sol>		A literal /		    E<verbar>		A literal |		    (these are optional except in other interior		     sequences and when preceded by a capital letter)		    E<n>		Character number n (probably in ASCII)    	    	    E<html>		Some non-numeric HTML entity, such					as E<Agrave>Most of the time, you will only need a single set of angle brackets todelimit the beginning and end of interior sequences.  However, sometimesyou will want to put a right angle bracket (or greater-than sign '>')inside of a sequence.  This is particularly common when using a sequenceto provide a different font-type for a snippet of code.  As with allthings in Perl, there is more than one way to do it.  One way is tosimply escape the closing bracket using an C<E> sequence:    C<$a E<lt>=E<gt> $b>This will produce: "C<$a E<lt>=E<gt> $b>"A more readable, and perhaps more "plain" way is to use an alternate set ofdelimiters that doesn't require a ">" to be escaped.  As of perl5.5.660,doubled angle brackets ("<<" and ">>") may be used I<if and only if thereis whitespace immediately following the opening delimiter and immediatelypreceding the closing delimiter!> For example, the following will do thetrick:    C<< $a <=> $b >>In fact, you can use as many repeated angle-brackets as you like solong as you have the same number of them in the opening and closingdelimiters, and make sure that whitespace immediately follows the last'<' of the opening delimiter, and immediately precedes the first '>' ofthe closing delimiter.  So the following will also work:    C<<< $a <=> $b >>>    C<<<< $a <=> $b >>>>This is currently supported by pod2text (Pod::Text), pod2man (Pod::Man),and any other pod2xxx and Pod::Xxxx translator that uses Pod::Parser1.093 or later.=head2 The IntentThat's it.  The intent is simplicity, not power.  I wanted paragraphsto look like paragraphs (block format), so that they stand outvisually, and so that I could run them through fmt easily to reformatthem (that's F7 in my version of B<vi>).  I wanted the translator (and notme) to worry about whether " or ' is a left quote or a right quotewithin filled text, and I wanted it to leave the quotes alone, dammit, inverbatim mode, so I could slurp in a working program, shift it over 4spaces, and have it print out, er, verbatim.  And presumably in aconstant width font.In particular, you can leave things like this verbatim in your text:    Perl    FILEHANDLE    $variable    function()    manpage(3r)Doubtless a few other commands or sequences will need to be added alongthe way, but I've gotten along surprisingly well with just these.Note that I'm not at all claiming this to be sufficient for producing abook.  I'm just trying to make an idiot-proof common source for nroff,TeX, and other markup languages, as used for online documentation.Translators exist for B<pod2man>  (that's for nroff(1) and troff(1)),B<pod2text>, B<pod2html>, B<pod2latex>, and B<pod2fm>.=head2 Embedding Pods in Perl ModulesYou can embed pod documentation in your Perl scripts.  Start yourdocumentation with a "=head1" command at the beginning, and end itwith a "=cut" command.  Perl will ignore the pod text.  See any of thesupplied library modules for examples.  If you're going to put yourpods at the end of the file, and you're using an __END__ or __DATA__cut mark, make sure to put an empty line there before the first poddirective.    __END__    =head1 NAME    modern - I am a modern moduleIf you had not had that empty line there, then the translators wouldn'thave seen it.=head2 Common Pod Pitfalls=over 4=item *Pod translators usually will require paragraphs to be separated bycompletely empty lines.  If you have an apparently empty line withsome spaces on it, this can cause odd formatting.=item *Translators will mostly add wording around a LE<lt>E<gt> link, so thatC<LE<lt>foo(1)E<gt>> becomes "the I<foo>(1) manpage", for example (seeB<pod2man> for details).  Thus, you shouldn't write things like C<theLE<lt>fooE<gt> manpage>, if you want the translated document to readsensibly.If you need total control of the text used for a link in the outputuse the form LE<lt>show this text|fooE<gt> instead.=item *The B<podchecker> command is provided to check pod syntaxfor errors and warnings. For example, it checks for completelyblank lines in pod segments and for unknown escape sequences.It is still advised to pass it throughone or more translators and proofread the result, or print out theresult and proofread that.  Some of the problems found may be bugs inthe translators, which you may or may not wish to work around.=back=head1 SEE ALSOL<pod2man>, L<perlsyn/"PODs: Embedded Documentation">,L<podchecker>=head1 AUTHORLarry Wall

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?