diff options
-rw-r--r-- | perl6-pod.html.markdown | 81 |
1 files changed, 40 insertions, 41 deletions
diff --git a/perl6-pod.html.markdown b/perl6-pod.html.markdown index c47f6156..6c769acb 100644 --- a/perl6-pod.html.markdown +++ b/perl6-pod.html.markdown @@ -1,6 +1,5 @@ --- language: Pod -name: Perl 6 Pod contributors: - ["Luis F. Uceta", "https://uzluisf.gitlab.io/"] filename: learnpod.pod6 @@ -50,7 +49,7 @@ Every Pod document has to begin with `=begin pod` and end with `=end pod`. Everything between these two delimiters will be processed and used to generate documentation. -```md +``` =begin pod A very simple Perl 6 Pod document. All the other directives go here! @@ -69,7 +68,7 @@ constructs are between the `=begin pod ... =end pod` directives. Text can be easily styled as bold, italic, underlined or verbatim (for code formatting) using the formatting code: `B<>`, `I<>`, `U<>` and `C<>`. -```md +``` B<This text is in Bold.> I<This text is in Italics.> @@ -89,7 +88,7 @@ angle brackets. The Unicode variant («») can also be used. Headings are created by using the `=headN` directive where `N` is the heading level. -```md +``` =head1 This is level 1 =head2 This is level 2 =head3 This is level 3 @@ -104,7 +103,7 @@ Ordinary paragraphs consist of one or more adjacent lines of text, each of which starts with a non-whitespace character. Any paragraph is terminated by the first blank line or block directive. -```md +``` =head1 First level heading block =head2 Paragraph 1 @@ -120,7 +119,7 @@ This is another ordinary paragraph albeit shorter. Alternatively, the `=para` directive can be used to explicitly mark adjacent lines of text as a paragraph. -```md +``` =head1 First level heading block =head2 Paragraph 1 @@ -139,7 +138,7 @@ This is another ordinary paragraph albeit shorter. Unordered lists can be made using the `=item` directive. -```md +``` =item Item =item Item =item Another item @@ -148,7 +147,7 @@ Unordered lists can be made using the `=item` directive. Sublists are achieved with items at each level specified using the `=item1`, `=item2`, `=item3`, etc. directives. -```md +``` =item1 Item one =item1 Item two =item1 Item three @@ -160,7 +159,7 @@ Sublists are achieved with items at each level specified using the `=item1`, Definition lists that define terms or commands use the `=defn`. This is equivalent to the `<dl>` element in HTML. -```md +``` =defn Beast of Bodmin A large feline inhabiting Bodmin Moor. @@ -176,7 +175,7 @@ A giant owl-like creature. A code block is created (which uses the `<code>` element) by starting each line with one or more whitespace characters. -```md +``` #`( this is comment ) my $sum = -> $x, $y { $x + $y } say $sum(12, 5); @@ -185,7 +184,7 @@ line with one or more whitespace characters. As shown in the [Basic Text Formatting](#basic-text-formatting) section, inline code can be created using the `C<>` code. -```md +``` In Perl 6, there are several functions/methods to output text. Some of them are C<print>, C<put> and C<say>. ``` @@ -197,7 +196,7 @@ as a Pod block will be read and interpreted by Pod renderers. In order to prevent Pod blocks from being rendered by any renderer, use the `=comment` directive. -```md +``` =comment Add more here about the algorithm. =comment Pod comments are great for documenting the documentation. @@ -205,7 +204,7 @@ directive. To create inline comments, use the `Z<>` code. -```md +``` Pod is awesome Z<Of course it is!>. And Perl 6 too! ``` @@ -219,20 +218,20 @@ Creating links in Pod is quite easy and is done by enclosing them in a `L<>` code. The general format is `L<Label|Url>` with `Label` being optional. -```md +``` Perl 6 homepage is L<https://perl6.org>. L<Click me!|http://link.org/>. ``` Relative paths work too. -```md +``` L<Go to music|/music/>. ``` Linking to a section in the same document works as well. -```md +``` L<Link to Headings|#Headings> ``` @@ -244,7 +243,7 @@ constructing tables is shown. To learn about good practices and see examples of both good and bad tables, please visit https://docs.perl6.org/language/tables. -```md +``` =begin table Option | Description ============|================ @@ -276,12 +275,12 @@ The rest of the line is treated as block data, rather than as configuration. The content terminates at the next Pod directive or the first blank line (which is not part of the block data). The general syntax is -```md +``` =BLOCK_TYPE BLOCK_DATA ``` For example: -```md +``` =head1 Top level heading ``` @@ -291,7 +290,7 @@ Delimited blocks are bounded by `=begin` and `=end` markers, both of which are followed by a valid Perl 6 identifier, which is the `typename` of the block. The general syntax is -```md +``` =begin BLOCK_TYPE BLOCK_DATA =end BLOCK_TYPE @@ -299,7 +298,7 @@ BLOCK_DATA For example: -```md +``` =begin head1 Top level heading =end head1 @@ -310,7 +309,7 @@ etc. with multiple paragraphs. For example, * a multiline item of a list -```md +``` =begin item This is a paragraph in list item. @@ -320,7 +319,7 @@ This is another paragraph in the same list item. * a code block -```md +``` =begin code #`(A recursive implementation of a power function using multi subs. @@ -349,14 +348,14 @@ the next Pod directive or the first blank line (which is not considered to be part of the block's contents). The `=for` marker is followed by the `typename` of the block. The general syntax is -```md +``` =for BLOCK_TYPE BLOCK DATA ``` For example: -```md +``` =for head1 Top level heading ``` @@ -370,7 +369,7 @@ are more general syntaxes for these blocks: * Delimited blocks -```md +``` =begin BLOCK_TYPE OPTIONAL_CONFIG_INFO = ADDITIONAL_CONFIG_INFO BLOCK_DATA @@ -379,7 +378,7 @@ BLOCK_DATA * Paragraph blocks -```md +``` =for BLOCK_TYPE OPTIONAL_CONFIG_INFO = ADDITIONAL_CONFIG_INFO BLOCK DATA @@ -415,7 +414,7 @@ can be applied to any block. For example: -```md +``` =for head1 :numbered The Problem =for head1 :numbered @@ -436,7 +435,7 @@ block that contains verbatim text. Given the following snippet: -```md +``` =begin code :allow('B', 'I') B<sub> greet( $name ) { B<say> "Hello, $nameI<!>"; @@ -460,7 +459,7 @@ The `=config` directive allows you to prespecify standard configuration information that is applied to every block of a particular type. The general syntax for configuration directives is: -```md +``` =config BLOCK_TYPE CONFIG OPTIONS = ADDITIONAL_CONFIG_INFO ``` @@ -468,7 +467,7 @@ The general syntax for configuration directives is: For example, to specify that every heading level 1 be numbered, bold and underlined, you preconfigure the `=head1` as follows: -```md +``` =config head1 :formatted('B', 'U') :numbered ``` @@ -478,7 +477,7 @@ All uppercase block typenames are reserved for specifying standard documentation, publishing, source components, or meta-information. Some of them are: -```md +``` =NAME =AUTHOR =VERSION @@ -491,7 +490,7 @@ Some of them are: Most of these blocks would typically be used in their full delimited forms. For example, -```md +``` =NAME B<Doc::Magic> =begin DESCRIPTION @@ -518,7 +517,7 @@ Not source code needed! Most of it is outsourced from a black hole. Notes are rendered as footnotes and created by enclosing a note in a `N<>` code. -```md +``` In addition, the language is also multi-paradigmatic N<According to Wikipedia, this means that it supports procedural, object-oriented, and functional programming.> @@ -528,7 +527,7 @@ programming.> To flag text as keyboard input enclose it in a `K<>` code. -```md +``` Enter your name K<John Doe> ``` @@ -536,7 +535,7 @@ Enter your name K<John Doe> To flag text as terminal output enclose it in `T<>` code. -```md +``` Hello, T<John Doe> ``` @@ -545,7 +544,7 @@ Hello, T<John Doe> To include Unicode code points or HTML5 character references in a Pod document, enclose them in a `E<>` code. -```md +``` Perl 6 makes considerable use of the E<171> and E<187> characters. Perl 6 makes considerable use of the E<laquo> and E<raquo> characters. ``` @@ -567,14 +566,14 @@ For instructions about installing Perl 6, Run the following command to generate a certain output -```md +``` perl6 --doc=TARGET input.pod6 > output.html ``` with `TARGET` being `Markdown`, `HTML`, `Text`, etc. Thus to generate Markdown from Pod, run this: -```md +``` perl6 --doc=Markdown input.pod6 > output.html ``` @@ -590,7 +589,7 @@ the whole structure of the Pod document. If we place the following piece of Perl 6 code and the Pod documentation in the section [Semantic blocks](#semantic-blocks) in the same file: -```md +``` my %used-directives; for $=pod -> $pod-item { for $pod-item.contents -> $pod-block { @@ -604,7 +603,7 @@ say %used-directives.keys.join("\n"); we get the following output: -```md +``` SYNOPSIS NAME VERSION |