6041 lines
		
	
	
		
			218 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			6041 lines
		
	
	
		
			218 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| AsciiDoc User Guide
 | ||
| ===================
 | ||
| Stuart Rackham <srackham@gmail.com>
 | ||
| :Author Initials: SJR
 | ||
| :toc:
 | ||
| :icons:
 | ||
| :numbered:
 | ||
| :website: http://www.methods.co.nz/asciidoc/
 | ||
| 
 | ||
| AsciiDoc is a text document format for writing notes, documentation,
 | ||
| articles, books, ebooks, slideshows, web pages, blogs and UNIX man
 | ||
| pages.  AsciiDoc files can be translated to many formats including
 | ||
| HTML, PDF, EPUB, man page.  AsciiDoc is highly configurable: both the
 | ||
| AsciiDoc source file syntax and the backend output markups (which can
 | ||
| be almost any type of SGML/XML markup) can be customized and extended
 | ||
| by the user.
 | ||
| 
 | ||
| .This document
 | ||
| **********************************************************************
 | ||
| This is an overly large document, it probably needs to be refactored
 | ||
| into a Tutorial, Quick Reference and Formal Reference.
 | ||
| 
 | ||
| If you're new to AsciiDoc read this section and the <<X6,Getting
 | ||
| Started>> section and take a look at the example AsciiDoc (`*.txt`)
 | ||
| source files in the distribution `doc` directory.
 | ||
| **********************************************************************
 | ||
| 
 | ||
| 
 | ||
| Introduction
 | ||
| ------------
 | ||
| AsciiDoc is a plain text human readable/writable document format that
 | ||
| can be translated to DocBook or HTML using the asciidoc(1) command.
 | ||
| You can then either use asciidoc(1) generated HTML directly or run
 | ||
| asciidoc(1) DocBook output through your favorite DocBook toolchain or
 | ||
| use the AsciiDoc a2x(1) toolchain wrapper to produce PDF, EPUB, DVI,
 | ||
| LaTeX, PostScript, man page, HTML and text formats.
 | ||
| 
 | ||
| The AsciiDoc format is a useful presentation format in its own right:
 | ||
| AsciiDoc markup is simple, intuitive and as such is easily proofed and
 | ||
| edited.
 | ||
| 
 | ||
| AsciiDoc is light weight: it consists of a single Python script and a
 | ||
| bunch of configuration files. Apart from asciidoc(1) and a Python
 | ||
| interpreter, no other programs are required to convert AsciiDoc text
 | ||
| files to DocBook or HTML. See <<X11,Example AsciiDoc Documents>>
 | ||
| below.
 | ||
| 
 | ||
| Text markup conventions tend to be a matter of (often strong) personal
 | ||
| preference: if the default syntax is not to your liking you can define
 | ||
| your own by editing the text based asciidoc(1) configuration files.
 | ||
| You can also create configuration files to translate AsciiDoc
 | ||
| documents to almost any SGML/XML markup.
 | ||
| 
 | ||
| asciidoc(1) comes with a set of configuration files to translate
 | ||
| AsciiDoc articles, books and man pages to HTML or DocBook backend
 | ||
| formats.
 | ||
| 
 | ||
| .My AsciiDoc Itch
 | ||
| **********************************************************************
 | ||
| DocBook has emerged as the de facto standard Open Source documentation
 | ||
| format. But DocBook is a complex language, the markup is difficult to
 | ||
| read and even more difficult to write directly -- I found I was
 | ||
| spending more time typing markup tags, consulting reference manuals
 | ||
| and fixing syntax errors, than I was writing the documentation.
 | ||
| **********************************************************************
 | ||
| 
 | ||
| 
 | ||
| [[X6]]
 | ||
| Getting Started
 | ||
| ---------------
 | ||
| Installing AsciiDoc
 | ||
| ~~~~~~~~~~~~~~~~~~~
 | ||
| See the `README` and `INSTALL` files for install prerequisites and
 | ||
| procedures. Packagers take a look at <<X38,Packager Notes>>.
 | ||
| 
 | ||
| [[X11]]
 | ||
| Example AsciiDoc Documents
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| The best way to quickly get a feel for AsciiDoc is to view the
 | ||
| AsciiDoc web site and/or distributed examples:
 | ||
| 
 | ||
| - Take a look at the linked examples on the AsciiDoc web site home
 | ||
|   page {website}.  Press the 'Page Source' sidebar menu item to view
 | ||
|   corresponding AsciiDoc source.
 | ||
| - Read the `*.txt` source files in the distribution `./doc` directory
 | ||
|   along with the corresponding HTML and DocBook XML files.
 | ||
| 
 | ||
| 
 | ||
| AsciiDoc Document Types
 | ||
| -----------------------
 | ||
| There are three types of AsciiDoc documents: article, book and
 | ||
| manpage. All document types share the same AsciiDoc format with some
 | ||
| minor variations. If you are familiar with DocBook you will have
 | ||
| noticed that AsciiDoc document types correspond to the same-named
 | ||
| DocBook document types.
 | ||
| 
 | ||
| Use the asciidoc(1) `-d` (`--doctype`) option to specify the AsciiDoc
 | ||
| document type -- the default document type is 'article'.
 | ||
| 
 | ||
| By convention the `.txt` file extension is used for AsciiDoc document
 | ||
| source files.
 | ||
| 
 | ||
| article
 | ||
| ~~~~~~~
 | ||
| Used for short documents, articles and general documentation.  See the
 | ||
| AsciiDoc distribution `./doc/article.txt` example.
 | ||
| 
 | ||
| AsciiDoc defines standard DocBook article frontmatter and backmatter
 | ||
| <<X93,section markup templates>> (appendix, abstract, bibliography,
 | ||
| glossary, index).
 | ||
| 
 | ||
| book
 | ||
| ~~~~
 | ||
| Books share the same format as articles, with the following
 | ||
| differences:
 | ||
| 
 | ||
| - The part titles in multi-part books are <<X17,top level titles>>
 | ||
|   (same level as book title).
 | ||
| - Some sections are book specific e.g. preface and colophon.
 | ||
| 
 | ||
| Book documents will normally be used to produce DocBook output since
 | ||
| DocBook processors can automatically generate footnotes, table of
 | ||
| contents, list of tables, list of figures, list of examples and
 | ||
| indexes.
 | ||
| 
 | ||
| AsciiDoc defines standard DocBook book frontmatter and backmatter
 | ||
| <<X93,section markup templates>> (appendix, dedication, preface,
 | ||
| bibliography, glossary, index, colophon).
 | ||
| 
 | ||
| .Example book documents
 | ||
| Book::
 | ||
|   The `./doc/book.txt` file in the AsciiDoc distribution.
 | ||
| 
 | ||
| Multi-part book::
 | ||
|   The `./doc/book-multi.txt` file in the AsciiDoc distribution.
 | ||
| 
 | ||
| manpage
 | ||
| ~~~~~~~
 | ||
| Used to generate roff format UNIX manual pages.  AsciiDoc manpage
 | ||
| documents observe special header title and section naming conventions
 | ||
| -- see the <<X1,Manpage Documents>> section for details.
 | ||
| 
 | ||
| AsciiDoc defines the 'synopsis' <<X93,section markup template>> to
 | ||
| generate the DocBook `refsynopsisdiv` section.
 | ||
| 
 | ||
| See also the asciidoc(1) man page source (`./doc/asciidoc.1.txt`) from
 | ||
| the AsciiDoc distribution.
 | ||
| 
 | ||
| 
 | ||
| [[X5]]
 | ||
| AsciiDoc Backends
 | ||
| -----------------
 | ||
| The asciidoc(1) command translates an AsciiDoc formatted file to the
 | ||
| backend format specified by the `-b` (`--backend`) command-line
 | ||
| option. asciidoc(1) itself has little intrinsic knowledge of backend
 | ||
| formats, all translation rules are contained in customizable cascading
 | ||
| configuration files. Backend specific attributes are listed in the
 | ||
| <<X88,Backend Attributes>> section.
 | ||
| 
 | ||
| docbook45::
 | ||
|   Outputs DocBook XML 4.5 markup.
 | ||
| 
 | ||
| html4::
 | ||
|   This backend generates plain HTML 4.01 Transitional markup.
 | ||
| 
 | ||
| xhtml11::
 | ||
|   This backend generates XHTML 1.1 markup styled with CSS2. Output
 | ||
|   files have an `.html` extension.
 | ||
| 
 | ||
| html5::
 | ||
|   This backend generates HTML 5 markup, apart from the inclusion of
 | ||
|   <<X98,audio and video block macros>> it is functionally identical to
 | ||
|   the 'xhtml11' backend.
 | ||
| 
 | ||
| slidy::
 | ||
|   Use this backend to generate self-contained
 | ||
|   http://www.w3.org/Talks/Tools/Slidy2/[Slidy] HTML slideshows for
 | ||
|   your web browser from AsciiDoc documents. The Slidy backend is
 | ||
|   documented in the distribution `doc/slidy.txt` file and
 | ||
|   {website}slidy.html[online].
 | ||
| 
 | ||
| wordpress::
 | ||
|   A minor variant of the 'html4' backend to support
 | ||
|   http://srackham.wordpress.com/blogpost1/[blogpost].
 | ||
| 
 | ||
| latex::
 | ||
|   Experimental LaTeX backend.
 | ||
| 
 | ||
| Backend Aliases
 | ||
| ~~~~~~~~~~~~~~~
 | ||
| Backend aliases are alternative names for AsciiDoc backends.  AsciiDoc
 | ||
| comes with two backend aliases: 'html' (aliased to 'xhtml11') and
 | ||
| 'docbook' (aliased to 'docbook45').
 | ||
| 
 | ||
| You can assign (or reassign) backend aliases by setting an AsciiDoc
 | ||
| attribute named like `backend-alias-<alias>` to an AsciiDoc backend
 | ||
| name. For example, the following backend alias attribute definitions
 | ||
| appear in the `[attributes]` section of the global `asciidoc.conf`
 | ||
| configuration file:
 | ||
| 
 | ||
|   backend-alias-html=xhtml11
 | ||
|   backend-alias-docbook=docbook45
 | ||
| 
 | ||
| [[X100]]
 | ||
| Backend Plugins
 | ||
| ~~~~~~~~~~~~~~~
 | ||
| The asciidoc(1) `--backend` option is also used to install and manage
 | ||
| backend <<X101,plugins>>.
 | ||
| 
 | ||
| - A backend plugin is used just like the built-in backends.
 | ||
| - Backend plugins <<X27,take precedence>> over built-in backends with
 | ||
|   the same name.
 | ||
| - You can use the `{asciidoc-confdir}` <<X60, intrinsic attribute>> to
 | ||
|   refer to the built-in backend configuration file location from
 | ||
|   backend plugin configuration files.
 | ||
| - You can use the `{backend-confdir}` <<X60, intrinsic attribute>> to
 | ||
|   refer to the backend plugin configuration file location.
 | ||
| - By default backends plugins are installed in
 | ||
|   `$HOME/.asciidoc/backends/<backend>` where `<backend>` is the
 | ||
|   backend name.
 | ||
| 
 | ||
| 
 | ||
| DocBook
 | ||
| -------
 | ||
| AsciiDoc generates 'article', 'book' and 'refentry'
 | ||
| http://www.docbook.org/[DocBook] documents (corresponding to the
 | ||
| AsciiDoc 'article', 'book' and 'manpage' document types).
 | ||
| 
 | ||
| Most Linux distributions come with conversion tools (collectively
 | ||
| called a toolchain) for <<X12,converting DocBook files>> to
 | ||
| presentation formats such as Postscript, HTML, PDF, EPUB, DVI,
 | ||
| PostScript, LaTeX, roff (the native man page format), HTMLHelp,
 | ||
| JavaHelp and text.  There are also programs that allow you to view
 | ||
| DocBook files directly, for example http://live.gnome.org/Yelp[Yelp]
 | ||
| (the GNOME help viewer).
 | ||
| 
 | ||
| [[X12]]
 | ||
| Converting DocBook to other file formats
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| DocBook files are validated, parsed and translated various
 | ||
| presentation file formats using a combination of applications
 | ||
| collectively called a DocBook 'tool chain'. The function of a tool
 | ||
| chain is to read the DocBook markup (produced by AsciiDoc) and
 | ||
| transform it to a presentation format (for example HTML, PDF, HTML
 | ||
| Help, EPUB, DVI, PostScript, LaTeX).
 | ||
| 
 | ||
| A wide range of user output format requirements coupled with a choice
 | ||
| of available tools and stylesheets results in many valid tool chain
 | ||
| combinations.
 | ||
| 
 | ||
| [[X43]]
 | ||
| a2x Toolchain Wrapper
 | ||
| ~~~~~~~~~~~~~~~~~~~~~
 | ||
| One of the biggest hurdles for new users is installing, configuring
 | ||
| and using a DocBook XML toolchain. `a2x(1)` can help -- it's a
 | ||
| toolchain wrapper command that will generate XHTML (chunked and
 | ||
| unchunked), PDF, EPUB, DVI, PS, LaTeX, man page, HTML Help and text
 | ||
| file outputs from an AsciiDoc text file.  `a2x(1)` does all the grunt
 | ||
| work associated with generating and sequencing the toolchain commands
 | ||
| and managing intermediate and output files.  `a2x(1)` also optionally
 | ||
| deploys admonition and navigation icons and a CSS stylesheet. See the
 | ||
| `a2x(1)` man page for more details. In addition to `asciidoc(1)` you
 | ||
| also need <<X40,xsltproc(1)>>, <<X13,DocBook XSL Stylesheets>> and
 | ||
| optionally: <<X31,dblatex>> or <<X14,FOP>> (to generate PDF);
 | ||
| `w3m(1)` or `lynx(1)` (to generate text).
 | ||
| 
 | ||
| The following examples generate `doc/source-highlight-filter.pdf` from
 | ||
| the AsciiDoc `doc/source-highlight-filter.txt` source file. The first
 | ||
| example uses `dblatex(1)` (the default PDF generator) the second
 | ||
| example forces FOP to be used:
 | ||
| 
 | ||
|   $ a2x -f pdf doc/source-highlight-filter.txt
 | ||
|   $ a2x -f pdf --fop doc/source-highlight-filter.txt
 | ||
| 
 | ||
| See the `a2x(1)` man page for details.
 | ||
| 
 | ||
| TIP: Use the `--verbose` command-line option to view executed
 | ||
| toolchain commands.
 | ||
| 
 | ||
| HTML generation
 | ||
| ~~~~~~~~~~~~~~~
 | ||
| AsciiDoc produces nicely styled HTML directly without requiring a
 | ||
| DocBook toolchain but there are also advantages in going the DocBook
 | ||
| route:
 | ||
| 
 | ||
| - HTML from DocBook can optionally include automatically generated
 | ||
|   indexes, tables of contents, footnotes, lists of figures and tables.
 | ||
| - DocBook toolchains can also (optionally) generate separate (chunked)
 | ||
|   linked HTML pages for each document section.
 | ||
| - Toolchain processing performs link and document validity checks.
 | ||
| - If the DocBook 'lang' attribute is set then things like table of
 | ||
|   contents, figure and table captions and admonition captions will be
 | ||
|   output in the specified language (setting the AsciiDoc 'lang'
 | ||
|   attribute sets the DocBook 'lang' attribute).
 | ||
| 
 | ||
| On the other hand, HTML output directly from AsciiDoc is much faster,
 | ||
| is easily customized and can be used in situations where there is no
 | ||
| suitable DocBook toolchain (for example, see the {website}[AsciiDoc
 | ||
| website]).
 | ||
| 
 | ||
| PDF generation
 | ||
| ~~~~~~~~~~~~~~
 | ||
| There are two commonly used tools to generate PDFs from DocBook,
 | ||
| <<X31,dblatex>> and <<X14,FOP>>.
 | ||
| 
 | ||
| .dblatex or FOP?
 | ||
| - 'dblatex' is easier to install, there's zero configuration
 | ||
|   required and no Java VM to install -- it just works out of the box.
 | ||
| - 'dblatex' source code highlighting and numbering is superb.
 | ||
| - 'dblatex' is easier to use as it converts DocBook directly to PDF
 | ||
|   whereas before using 'FOP' you have to convert DocBook to XML-FO
 | ||
|   using <<X13,DocBook XSL Stylesheets>>.
 | ||
| - 'FOP' is more feature complete (for example, callouts are processed
 | ||
|   inside literal layouts) and arguably produces nicer looking output.
 | ||
| 
 | ||
| HTML Help generation
 | ||
| ~~~~~~~~~~~~~~~~~~~~
 | ||
| . Convert DocBook XML documents to HTML Help compiler source files
 | ||
|   using <<X13,DocBook XSL Stylesheets>> and <<X40,xsltproc(1)>>.
 | ||
| . Convert the HTML Help source (`.hhp` and `.html`) files to HTML Help
 | ||
|   (`.chm`) files using the <<X67,Microsoft HTML Help Compiler>>.
 | ||
| 
 | ||
| Toolchain components summary
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| AsciiDoc::
 | ||
|     Converts AsciiDoc (`.txt`) files to DocBook XML (`.xml`) files.
 | ||
| 
 | ||
| [[X13]]http://docbook.sourceforge.net/projects/xsl/[DocBook XSL Stylesheets]::
 | ||
|   These are a set of XSL stylesheets containing rules for converting
 | ||
|   DocBook XML documents to HTML, XSL-FO, manpage and HTML Help files.
 | ||
|   The stylesheets are used in conjunction with an XML parser such as
 | ||
|   <<X40,xsltproc(1)>>.
 | ||
| 
 | ||
| [[X40]]http://www.xmlsoft.org[xsltproc]::
 | ||
|   An XML parser for applying XSLT stylesheets (in our case the
 | ||
|   <<X13,DocBook XSL Stylesheets>>) to XML documents.
 | ||
| 
 | ||
| [[X31]]http://dblatex.sourceforge.net/[dblatex]::
 | ||
|   Generates PDF, DVI, PostScript and LaTeX formats directly from
 | ||
|   DocBook source via the intermediate LaTeX typesetting language --
 | ||
|   uses <<X13,DocBook XSL Stylesheets>>, <<X40,xsltproc(1)>> and
 | ||
|   `latex(1)`.
 | ||
| 
 | ||
| [[X14]]http://xml.apache.org/fop/[FOP]::
 | ||
|   The Apache Formatting Objects Processor converts XSL-FO (`.fo`)
 | ||
|   files to PDF files.  The XSL-FO files are generated from DocBook
 | ||
|   source files using <<X13,DocBook XSL Stylesheets>> and
 | ||
|   <<X40,xsltproc(1)>>.
 | ||
| 
 | ||
| [[X67]]Microsoft Help Compiler::
 | ||
|   The Microsoft HTML Help Compiler (`hhc.exe`) is a command-line tool
 | ||
|   that converts HTML Help source files to a single HTML Help (`.chm`)
 | ||
|   file. It runs on MS Windows platforms and can be downloaded from
 | ||
|   http://www.microsoft.com.
 | ||
| 
 | ||
| AsciiDoc dblatex configuration files
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| The AsciiDoc distribution `./dblatex` directory contains
 | ||
| `asciidoc-dblatex.xsl` (customized XSL parameter settings) and
 | ||
| `asciidoc-dblatex.sty` (customized LaTeX settings). These are examples
 | ||
| of optional <<X31,dblatex>> output customization and are used by
 | ||
| <<X43,a2x(1)>>.
 | ||
| 
 | ||
| AsciiDoc DocBook XSL Stylesheets drivers
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| You will have noticed that the distributed HTML and HTML Help
 | ||
| documentation files (for example `./doc/asciidoc.html`) are not the
 | ||
| plain outputs produced using the default 'DocBook XSL Stylesheets'
 | ||
| configuration.  This is because they have been processed using
 | ||
| customized DocBook XSL Stylesheets along with (in the case of HTML
 | ||
| outputs) the custom `./stylesheets/docbook-xsl.css` CSS stylesheet.
 | ||
| 
 | ||
| You'll find the customized DocBook XSL drivers along with additional
 | ||
| documentation in the distribution `./docbook-xsl` directory. The
 | ||
| examples that follow are executed from the distribution documentation
 | ||
| (`./doc`) directory. These drivers are also used by <<X43,a2x(1)>>.
 | ||
| 
 | ||
| `common.xsl`::
 | ||
|     Shared driver parameters.  This file is not used directly but is
 | ||
|     included in all the following drivers.
 | ||
| 
 | ||
| `chunked.xsl`::
 | ||
|     Generate chunked XHTML (separate HTML pages for each document
 | ||
|     section) in the `./doc/chunked` directory. For example:
 | ||
| 
 | ||
|     $ python ../asciidoc.py -b docbook asciidoc.txt
 | ||
|     $ xsltproc --nonet ../docbook-xsl/chunked.xsl asciidoc.xml
 | ||
| 
 | ||
| `epub.xsl`::
 | ||
|     Used by <<X43,a2x(1)>> to generate EPUB formatted documents.
 | ||
| 
 | ||
| `fo.xsl`::
 | ||
|     Generate XSL Formatting Object (`.fo`) files for subsequent PDF
 | ||
|     file generation using FOP. For example:
 | ||
| 
 | ||
|     $ python ../asciidoc.py -b docbook article.txt
 | ||
|     $ xsltproc --nonet ../docbook-xsl/fo.xsl article.xml > article.fo
 | ||
|     $ fop article.fo article.pdf
 | ||
| 
 | ||
| `htmlhelp.xsl`::
 | ||
|     Generate Microsoft HTML Help source files for the MS HTML Help
 | ||
|     Compiler in the `./doc/htmlhelp` directory. This example is run on
 | ||
|     MS Windows from a Cygwin shell prompt:
 | ||
| 
 | ||
|     $ python ../asciidoc.py -b docbook asciidoc.txt
 | ||
|     $ xsltproc --nonet ../docbook-xsl/htmlhelp.xsl asciidoc.xml
 | ||
|     $ c:/Program\ Files/HTML\ Help\ Workshop/hhc.exe htmlhelp.hhp
 | ||
| 
 | ||
| `manpage.xsl`::
 | ||
|     Generate a `roff(1)` format UNIX man page from a DocBook XML
 | ||
|     'refentry' document. This example generates an `asciidoc.1` man
 | ||
|     page file:
 | ||
| 
 | ||
|     $ python ../asciidoc.py -d manpage -b docbook asciidoc.1.txt
 | ||
|     $ xsltproc --nonet ../docbook-xsl/manpage.xsl asciidoc.1.xml
 | ||
| 
 | ||
| `xhtml.xsl`::
 | ||
|     Convert a DocBook XML file to a single XHTML file. For example:
 | ||
| 
 | ||
|     $ python ../asciidoc.py -b docbook asciidoc.txt
 | ||
|     $ xsltproc --nonet ../docbook-xsl/xhtml.xsl asciidoc.xml > asciidoc.html
 | ||
| 
 | ||
| If you want to see how the complete documentation set is processed
 | ||
| take a look at the A-A-P script `./doc/main.aap`.
 | ||
| 
 | ||
| 
 | ||
| Generating Plain Text Files
 | ||
| ---------------------------
 | ||
| AsciiDoc does not have a text backend (for most purposes AsciiDoc
 | ||
| source text is fine), however you can convert AsciiDoc text files to
 | ||
| formatted text using the AsciiDoc <<X43,a2x(1)>> toolchain wrapper
 | ||
| utility.
 | ||
| 
 | ||
| 
 | ||
| [[X35]]
 | ||
| HTML5 and XHTML 1.1
 | ||
| -------------------
 | ||
| The 'xhtml11' and 'html5' backends embed or link CSS and JavaScript
 | ||
| files in their outputs, there is also a <<X99,themes>> plugin
 | ||
| framework.
 | ||
| 
 | ||
| - If the AsciiDoc 'linkcss' attribute is defined then CSS and
 | ||
|   JavaScript files are linked to the output document, otherwise they
 | ||
|   are embedded (the default behavior).
 | ||
| - The default locations for CSS and JavaScript files can be changed by
 | ||
|   setting the AsciiDoc 'stylesdir' and 'scriptsdir' attributes
 | ||
|   respectively.
 | ||
| - The default locations for embedded and linked files differ and are
 | ||
|   calculated at different times -- embedded files are loaded when
 | ||
|   asciidoc(1) generates the output document, linked files are loaded
 | ||
|   by the browser when the user views the output document.
 | ||
| - Embedded files are automatically inserted in the output files but
 | ||
|   you need to manually copy linked CSS and Javascript files from
 | ||
|   AsciiDoc <<X27,configuration directories>> to the correct location
 | ||
|   relative to the output document.
 | ||
| 
 | ||
| .Stylesheet file locations
 | ||
| [cols="3*",frame="topbot",options="header"]
 | ||
| |====================================================================
 | ||
| |'stylesdir' attribute
 | ||
| |Linked location ('linkcss' attribute defined)
 | ||
| |Embedded location ('linkcss' attribute undefined)
 | ||
| 
 | ||
| |Undefined (default).
 | ||
| |Same directory as the output document.
 | ||
| |`stylesheets` subdirectory in the AsciiDoc configuration directory
 | ||
| (the directory containing the backend conf file).
 | ||
| 
 | ||
| |Absolute or relative directory name.
 | ||
| |Absolute or relative to the output document.
 | ||
| |Absolute or relative to the AsciiDoc configuration directory (the
 | ||
| directory containing the backend conf file).
 | ||
| 
 | ||
| |====================================================================
 | ||
| 
 | ||
| .JavaScript file locations
 | ||
| [cols="3*",frame="topbot",options="header"]
 | ||
| |====================================================================
 | ||
| |'scriptsdir' attribute
 | ||
| |Linked location ('linkcss' attribute defined)
 | ||
| |Embedded location ('linkcss' attribute undefined)
 | ||
| 
 | ||
| |Undefined (default).
 | ||
| |Same directory as the output document.
 | ||
| |`javascripts` subdirectory in the AsciiDoc configuration directory
 | ||
| (the directory containing the backend conf file).
 | ||
| 
 | ||
| |Absolute or relative directory name.
 | ||
| |Absolute or relative to the output document.
 | ||
| |Absolute or relative to the AsciiDoc configuration directory (the
 | ||
| directory containing the backend conf file).
 | ||
| 
 | ||
| |====================================================================
 | ||
| 
 | ||
| [[X99]]
 | ||
| Themes
 | ||
| ~~~~~~
 | ||
| The AsciiDoc 'theme' attribute is used to select an alternative CSS
 | ||
| stylesheet and to optionally include additional JavaScript code.
 | ||
| 
 | ||
| - Theme files reside in an AsciiDoc <<X27,configuration directory>>
 | ||
|   named `themes/<theme>/` (where `<theme>` is the the theme name set
 | ||
|   by the 'theme' attribute). asciidoc(1) sets the 'themedir' attribute
 | ||
|   to the theme directory path name.
 | ||
| - The 'theme' attribute can also be set using the asciidoc(1)
 | ||
|   `--theme` option, the `--theme` option can also be used to manage
 | ||
|   theme <<X101,plugins>>.
 | ||
| - AsciiDoc ships with two themes: 'flask' and 'volnitsky'.
 | ||
| - The `<theme>.css` file replaces the default `asciidoc.css` CSS file.
 | ||
| - The `<theme>.js` file is included in addition to the default
 | ||
|   `asciidoc.js` JavaScript file.
 | ||
| - If the <<X66,data-uri>> attribute is defined then icons are loaded
 | ||
|   from the theme `icons` sub-directory if it exists (i.e.  the
 | ||
|   'iconsdir' attribute is set to theme `icons` sub-directory path).
 | ||
| - Embedded theme files are automatically inserted in the output files
 | ||
|   but you need to manually copy linked CSS and Javascript files to the
 | ||
|   location of the output documents.
 | ||
| - Linked CSS and JavaScript theme files are linked to the same linked
 | ||
|   locations as <<X35,other CSS and JavaScript files>>.
 | ||
| 
 | ||
| For example, the command-line option `--theme foo` (or `--attribute
 | ||
| theme=foo`) will cause asciidoc(1) to search <<"X27","configuration
 | ||
| file locations 1, 2 and 3">> for a sub-directory called `themes/foo`
 | ||
| containing the stylesheet `foo.css` and optionally a JavaScript file
 | ||
| name `foo.js`.
 | ||
| 
 | ||
| 
 | ||
| Document Structure
 | ||
| ------------------
 | ||
| An AsciiDoc document consists of a series of <<X8,block elements>>
 | ||
| starting with an optional document Header, followed by an optional
 | ||
| Preamble, followed by zero or more document Sections.
 | ||
| 
 | ||
| Almost any combination of zero or more elements constitutes a valid
 | ||
| AsciiDoc document: documents can range from a single sentence to a
 | ||
| multi-part book.
 | ||
| 
 | ||
| Block Elements
 | ||
| ~~~~~~~~~~~~~~
 | ||
| Block elements consist of one or more lines of text and may contain
 | ||
| other block elements.
 | ||
| 
 | ||
| The AsciiDoc block structure can be informally summarized as follows
 | ||
| footnote:[This is a rough structural guide, not a rigorous syntax
 | ||
| definition]:
 | ||
| 
 | ||
|   Document      ::= (Header?,Preamble?,Section*)
 | ||
|   Header        ::= (Title,(AuthorInfo,RevisionInfo?)?)
 | ||
|   AuthorInfo    ::= (FirstName,(MiddleName?,LastName)?,EmailAddress?)
 | ||
|   RevisionInfo  ::= (RevisionNumber?,RevisionDate,RevisionRemark?)
 | ||
|   Preamble      ::= (SectionBody)
 | ||
|   Section       ::= (Title,SectionBody?,(Section)*)
 | ||
|   SectionBody   ::= ((BlockTitle?,Block)|BlockMacro)+
 | ||
|   Block         ::= (Paragraph|DelimitedBlock|List|Table)
 | ||
|   List          ::= (BulletedList|NumberedList|LabeledList|CalloutList)
 | ||
|   BulletedList  ::= (ListItem)+
 | ||
|   NumberedList  ::= (ListItem)+
 | ||
|   CalloutList   ::= (ListItem)+
 | ||
|   LabeledList   ::= (ListEntry)+
 | ||
|   ListEntry     ::= (ListLabel,ListItem)
 | ||
|   ListLabel     ::= (ListTerm+)
 | ||
|   ListItem      ::= (ItemText,(List|ListParagraph|ListContinuation)*)
 | ||
| 
 | ||
| Where:
 | ||
| 
 | ||
| - '?' implies zero or one occurrence, '+' implies one or more
 | ||
|   occurrences, '*' implies zero or more occurrences.
 | ||
| - All block elements are separated by line boundaries.
 | ||
| - `BlockId`, `AttributeEntry` and `AttributeList` block elements (not
 | ||
|   shown) can occur almost anywhere.
 | ||
| - There are a number of document type and backend specific
 | ||
|   restrictions imposed on the block syntax.
 | ||
| - The following elements cannot contain blank lines: Header, Title,
 | ||
|   Paragraph, ItemText.
 | ||
| - A ListParagraph is a Paragraph with its 'listelement' option set.
 | ||
| - A ListContinuation is a <<X15,list continuation element>>.
 | ||
| 
 | ||
| [[X95]]
 | ||
| Header
 | ||
| ~~~~~~
 | ||
| The Header contains document meta-data, typically title plus optional
 | ||
| authorship and revision information:
 | ||
| 
 | ||
| - The Header is optional, but if it is used it must start with a
 | ||
|   document <<X17,title>>.
 | ||
| - Optional Author and Revision information immediately follows the
 | ||
|   header title.
 | ||
| - The document header must be separated from the remainder of the
 | ||
|   document by one or more blank lines and cannot contain blank lines.
 | ||
| - The header can include comments.
 | ||
| - The header can include <<X18,attribute entries>>, typically
 | ||
|   'doctype', 'lang', 'encoding', 'icons', 'data-uri', 'toc',
 | ||
|   'numbered'.
 | ||
| - Header attributes are overridden by command-line attributes.
 | ||
| - If the header contains non-UTF-8 characters then the 'encoding' must
 | ||
|   precede the header (either in the document or on the command-line).
 | ||
| 
 | ||
| Here's an example AsciiDoc document header:
 | ||
| 
 | ||
|   Writing Documentation using AsciiDoc
 | ||
|   ====================================
 | ||
|   Joe Bloggs <jbloggs@mymail.com>
 | ||
|   v2.0, February 2003:
 | ||
|   Rewritten for version 2 release.
 | ||
| 
 | ||
| The author information line contains the author's name optionally
 | ||
| followed by the author's email address. The author's name is formatted
 | ||
| like:
 | ||
| 
 | ||
|   firstname[ [middlename ]lastname][ <email>]]
 | ||
| 
 | ||
| i.e. a first name followed by optional middle and last names followed
 | ||
| by an email address in that order.  Multi-word first, middle and last
 | ||
| names can be entered using the underscore as a word separator.  The
 | ||
| email address comes last and must be enclosed in angle <> brackets.
 | ||
| Here a some examples of author information lines:
 | ||
| 
 | ||
|   Joe Bloggs <jbloggs@mymail.com>
 | ||
|   Joe Bloggs
 | ||
|   Vincent Willem van_Gogh
 | ||
| 
 | ||
| If the author line does not match the above specification then the
 | ||
| entire author line is treated as the first name.
 | ||
| 
 | ||
| The optional revision information line follows the author information
 | ||
| line. The revision information can be one of two formats:
 | ||
| 
 | ||
| . An optional document revision number followed by an optional
 | ||
|   revision date followed by an optional revision remark:
 | ||
| +
 | ||
| --
 | ||
|   * If the revision number is specified it must be followed by a
 | ||
|     comma.
 | ||
|   * The revision number must contain at least one numeric character.
 | ||
|   * Any non-numeric characters preceding the first numeric character
 | ||
|     will be dropped.
 | ||
|   * If a revision remark is specified it must be preceded by a colon.
 | ||
|     The revision remark extends from the colon up to the next blank
 | ||
|     line, attribute entry or comment and is subject to normal text
 | ||
|     substitutions.
 | ||
|   * If a revision number or remark has been set but the revision date
 | ||
|     has not been set then the revision date is set to the value of the
 | ||
|     'docdate' attribute.
 | ||
| 
 | ||
| Examples:
 | ||
| 
 | ||
|   v2.0, February 2003
 | ||
|   February 2003
 | ||
|   v2.0,
 | ||
|   v2.0, February 2003: Rewritten for version 2 release.
 | ||
|   February 2003: Rewritten for version 2 release.
 | ||
|   v2.0,: Rewritten for version 2 release.
 | ||
|   :Rewritten for version 2 release.
 | ||
| --
 | ||
| 
 | ||
| . The revision information line can also be an RCS/CVS/SVN $Id$
 | ||
|   marker:
 | ||
| +
 | ||
| --
 | ||
|   * AsciiDoc extracts the 'revnumber', 'revdate', and 'author'
 | ||
|     attributes from the $Id$ revision marker and displays them in the
 | ||
|     document header.
 | ||
|   * If an $Id$ revision marker is used the header author line can be
 | ||
|     omitted.
 | ||
| 
 | ||
| Example:
 | ||
| 
 | ||
|   $Id: mydoc.txt,v 1.5 2009/05/17 17:58:44 jbloggs Exp $
 | ||
| --
 | ||
| 
 | ||
| You can override or set header parameters by passing 'revnumber',
 | ||
| 'revremark', 'revdate', 'email', 'author', 'authorinitials',
 | ||
| 'firstname' and 'lastname' attributes using the asciidoc(1) `-a`
 | ||
| (`--attribute`) command-line option. For example:
 | ||
| 
 | ||
|   $ asciidoc -a revdate=2004/07/27 article.txt
 | ||
| 
 | ||
| Attribute entries can also be added to the header for substitution in
 | ||
| the header template with <<X18,Attribute Entry>> elements.
 | ||
| 
 | ||
| The 'title' element in HTML outputs is set to the AsciiDoc document
 | ||
| title, you can set it to a different value by including a 'title'
 | ||
| attribute entry in the document header.
 | ||
| 
 | ||
| [[X87]]
 | ||
| Additional document header information
 | ||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
 | ||
| AsciiDoc has two mechanisms for optionally including additional
 | ||
| meta-data in the header of the output document:
 | ||
| 
 | ||
| 'docinfo' configuration file sections::
 | ||
| If a <<X7,configuration file>> section named 'docinfo' has been loaded
 | ||
| then it will be included in the document header. Typically the
 | ||
| 'docinfo' section name will be prefixed with a '+' character so that it
 | ||
| is appended to (rather than replace) other 'docinfo' sections.
 | ||
| 
 | ||
| 'docinfo' files::
 | ||
| Two docinfo files are recognized: one named `docinfo` and a second
 | ||
| named like the AsciiDoc source file with a `-docinfo` suffix.  For
 | ||
| example, if the source document is called `mydoc.txt` then the
 | ||
| document information files would be `docinfo.xml` and
 | ||
| `mydoc-docinfo.xml` (for DocBook outputs) and `docinfo.html` and
 | ||
| `mydoc-docinfo.html` (for HTML outputs).  The <<X97,docinfo, docinfo1
 | ||
| and docinfo2>> attributes control which docinfo files are included in
 | ||
| the output files.
 | ||
| 
 | ||
| The contents docinfo templates and files is dependent on the type of
 | ||
| output:
 | ||
| 
 | ||
| HTML::
 | ||
|   Valid 'head' child elements. Typically 'style' and 'script' elements
 | ||
|   for CSS and JavaScript inclusion.
 | ||
| 
 | ||
| DocBook::
 | ||
|   Valid 'articleinfo' or 'bookinfo' child elements.  DocBook defines
 | ||
|   numerous elements for document meta-data, for example: copyrights,
 | ||
|   document history and authorship information.  See the DocBook
 | ||
|   `./doc/article-docinfo.xml` example that comes with the AsciiDoc
 | ||
|   distribution.  The rendering of meta-data elements (or not) is
 | ||
|   DocBook processor dependent.
 | ||
| 
 | ||
| 
 | ||
| [[X86]]
 | ||
| Preamble
 | ||
| ~~~~~~~~
 | ||
| The Preamble is an optional untitled section body between the document
 | ||
| Header and the first Section title.
 | ||
| 
 | ||
| Sections
 | ||
| ~~~~~~~~
 | ||
| In addition to the document title (level 0), AsciiDoc supports four
 | ||
| section levels: 1 (top) to 4 (bottom).  Section levels are delimited
 | ||
| by section <<X17,titles>>.  Sections are translated using
 | ||
| configuration file <<X93,section markup templates>>. AsciiDoc
 | ||
| generates the following <<X60,intrinsic attributes>> specifically for
 | ||
| use in section markup templates:
 | ||
| 
 | ||
| level::
 | ||
| The `level` attribute is the section level number, it is normally just
 | ||
| the <<X17,title>> level number (1..4). However, if the `leveloffset`
 | ||
| attribute is defined it will be added to the `level` attribute. The
 | ||
| `leveloffset` attribute is useful for <<X90,combining documents>>.
 | ||
| 
 | ||
| sectnum::
 | ||
| The `-n` (`--section-numbers`) command-line option generates the
 | ||
| `sectnum` (section number) attribute.  The `sectnum` attribute is used
 | ||
| for section numbers in HTML outputs (DocBook section numbering are
 | ||
| handled automatically by the DocBook toolchain commands).
 | ||
| 
 | ||
| [[X93]]
 | ||
| Section markup templates
 | ||
| ^^^^^^^^^^^^^^^^^^^^^^^^
 | ||
| Section markup templates specify output markup and are defined in
 | ||
| AsciiDoc configuration files.  Section markup template names are
 | ||
| derived as follows (in order of precedence):
 | ||
| 
 | ||
| 1. From the title's first positional attribute or 'template'
 | ||
|    attribute. For example, the following three section titles are
 | ||
|    functionally equivalent:
 | ||
| +
 | ||
| .....................................................................
 | ||
| [[terms]]
 | ||
| [glossary]
 | ||
| List of Terms
 | ||
| -------------
 | ||
| 
 | ||
| ["glossary",id="terms"]
 | ||
| List of Terms
 | ||
| -------------
 | ||
| 
 | ||
| [template="glossary",id="terms"]
 | ||
| List of Terms
 | ||
| -------------
 | ||
| .....................................................................
 | ||
| 
 | ||
| 2. When the title text matches a configuration file
 | ||
|    <<X16,`[specialsections]`>> entry.
 | ||
| 3. If neither of the above the default `sect<level>` template is used
 | ||
|    (where `<level>` is a number from 1 to 4).
 | ||
| 
 | ||
| In addition to the normal section template names ('sect1', 'sect2',
 | ||
| 'sect3', 'sect4') AsciiDoc has the following templates for
 | ||
| frontmatter, backmatter and other special sections: 'abstract',
 | ||
| 'preface', 'colophon', 'dedication', 'glossary', 'bibliography',
 | ||
| 'synopsis', 'appendix', 'index'.  These special section templates
 | ||
| generate the corresponding Docbook elements; for HTML outputs they
 | ||
| default to the 'sect1' section template.
 | ||
| 
 | ||
| Section IDs
 | ||
| ^^^^^^^^^^^
 | ||
| If no explicit section ID is specified an ID will be synthesised from
 | ||
| the section title.  The primary purpose of this feature is to ensure
 | ||
| persistence of table of contents links (permalinks): the missing
 | ||
| section IDs are generated dynamically by the JavaScript TOC generator
 | ||
| *after* the page is loaded. If you link to a dynamically generated TOC
 | ||
| address the page will load but the browser will ignore the (as yet
 | ||
| ungenerated) section ID.
 | ||
| 
 | ||
| The IDs are generated by the following algorithm:
 | ||
| 
 | ||
| - Replace all non-alphanumeric title characters with underscores.
 | ||
| - Strip leading or trailing underscores.
 | ||
| - Convert to lowercase.
 | ||
| - Prepend the `idprefix` attribute (so there's no possibility of name
 | ||
|   clashes with existing document IDs). Prepend an underscore if the
 | ||
|   `idprefix` attribute is not defined.
 | ||
| - A numbered suffix (`_2`, `_3` ...) is added if a same named
 | ||
|   auto-generated section ID exists.
 | ||
| - If the `ascii-ids` attribute is defined then non-ASCII characters
 | ||
|   are replaced with ASCII equivalents. This attribute may be
 | ||
|   deprecated in future releases and *should be avoided*, it's sole
 | ||
|   purpose is to accommodate deficient downstream applications that
 | ||
|   cannot process non-ASCII ID attributes.
 | ||
| 
 | ||
| Example: the title 'Jim's House' would generate the ID `_jim_s_house`.
 | ||
| 
 | ||
| Section ID synthesis can be disabled by undefining the `sectids`
 | ||
| attribute.
 | ||
| 
 | ||
| [[X16]]
 | ||
| Special Section Titles
 | ||
| ^^^^^^^^^^^^^^^^^^^^^^
 | ||
| AsciiDoc has a mechanism for mapping predefined section titles
 | ||
| auto-magically to specific markup templates. For example a title
 | ||
| 'Appendix A: Code Reference' will automatically use the 'appendix'
 | ||
| <<X93,section markup template>>. The mappings from title to template
 | ||
| name are specified in `[specialsections]` sections in the Asciidoc
 | ||
| language configuration files (`lang-*.conf`).  Section entries are
 | ||
| formatted like:
 | ||
| 
 | ||
|   <title>=<template>
 | ||
| 
 | ||
| `<title>` is a Python regular expression and `<template>` is the name
 | ||
| of a configuration file markup template section. If the `<title>`
 | ||
| matches an AsciiDoc document section title then the backend output is
 | ||
| marked up using the `<template>` markup template (instead of the
 | ||
| default `sect<level>` section template). The `{title}` attribute value
 | ||
| is set to the value of the matched regular expression group named
 | ||
| 'title', if there is no 'title' group `{title}` defaults to the whole
 | ||
| of the AsciiDoc section title. If `<template>` is blank then any
 | ||
| existing entry with the same `<title>` will be deleted.
 | ||
| 
 | ||
| .Special section titles vs. explicit template names
 | ||
| *********************************************************************
 | ||
| AsciiDoc has two mechanisms for specifying non-default section markup
 | ||
| templates: you can specify the template name explicitly (using the
 | ||
| 'template' attribute) or indirectly (using 'special section titles').
 | ||
| Specifying a <<X93,section template>> attribute explicitly is
 | ||
| preferred.  Auto-magical 'special section titles' have the following
 | ||
| drawbacks:
 | ||
| 
 | ||
| - They are non-obvious, you have to know the exact matching
 | ||
|   title for each special section on a language by language basis.
 | ||
| - Section titles are predefined and can only be customised with a
 | ||
|   configuration change.
 | ||
| - The implementation is complicated by multiple languages: every
 | ||
|   special section title has to be defined for each language (in each
 | ||
|   of the `lang-*.conf` files).
 | ||
| 
 | ||
| Specifying special section template names explicitly does add more
 | ||
| noise to the source document (the 'template' attribute declaration),
 | ||
| but the intention is obvious and the syntax is consistent with other
 | ||
| AsciiDoc elements c.f.  bibliographic, Q&A and glossary lists.
 | ||
| 
 | ||
| Special section titles have been deprecated but are retained for
 | ||
| backward compatibility.
 | ||
| 
 | ||
| *********************************************************************
 | ||
| 
 | ||
| Inline Elements
 | ||
| ~~~~~~~~~~~~~~~
 | ||
| <<X34,Inline document elements>> are used to format text and to
 | ||
| perform various types of text substitution. Inline elements and inline
 | ||
| element syntax is defined in the asciidoc(1) configuration files.
 | ||
| 
 | ||
| Here is a list of AsciiDoc inline elements in the (default) order in
 | ||
| which they are processed:
 | ||
| 
 | ||
| Special characters::
 | ||
|         These character sequences escape special characters used by
 | ||
|         the backend markup (typically `<`, `>`, and `&` characters).
 | ||
|         See `[specialcharacters]` configuration file sections.
 | ||
| 
 | ||
| Quotes::
 | ||
|         Elements that markup words and phrases; usually for character
 | ||
|         formatting. See `[quotes]` configuration file sections.
 | ||
| 
 | ||
| Special Words::
 | ||
|         Word or word phrase patterns singled out for markup without
 | ||
|         the need for further annotation.  See `[specialwords]`
 | ||
|         configuration file sections.
 | ||
| 
 | ||
| Replacements::
 | ||
|         Each replacement defines a word or word phrase pattern to
 | ||
|         search for along with corresponding replacement text. See
 | ||
|         `[replacements]` configuration file sections.
 | ||
| 
 | ||
| Attribute references::
 | ||
|         Document attribute names enclosed in braces are replaced by
 | ||
|         the corresponding attribute value.
 | ||
| 
 | ||
| Inline Macros::
 | ||
|         Inline macros are replaced by the contents of parametrized
 | ||
|         configuration file sections.
 | ||
| 
 | ||
| 
 | ||
| Document Processing
 | ||
| -------------------
 | ||
| The AsciiDoc source document is read and processed as follows:
 | ||
| 
 | ||
| 1. The document 'Header' is parsed, header parameter values are
 | ||
|    substituted into the configuration file `[header]` template section
 | ||
|    which is then written to the output file.
 | ||
| 2. Each document 'Section' is processed and its constituent elements
 | ||
|    translated to the output file.
 | ||
| 3. The configuration file `[footer]` template section is substituted
 | ||
|    and written to the output file.
 | ||
| 
 | ||
| When a block element is encountered asciidoc(1) determines the type of
 | ||
| block by checking in the following order (first to last): (section)
 | ||
| Titles, BlockMacros, Lists, DelimitedBlocks, Tables, AttributeEntrys,
 | ||
| AttributeLists, BlockTitles, Paragraphs.
 | ||
| 
 | ||
| The default paragraph definition `[paradef-default]` is last element
 | ||
| to be checked.
 | ||
| 
 | ||
| Knowing the parsing order will help you devise unambiguous macro, list
 | ||
| and block syntax rules.
 | ||
| 
 | ||
| Inline substitutions within block elements are performed in the
 | ||
| following default order:
 | ||
| 
 | ||
| 1. Special characters
 | ||
| 2. Quotes
 | ||
| 3. Special words
 | ||
| 4. Replacements
 | ||
| 5. Attributes
 | ||
| 6. Inline Macros
 | ||
| 7. Replacements2
 | ||
| 
 | ||
| The substitutions and substitution order performed on
 | ||
| Title, Paragraph and DelimitedBlock elements is determined by
 | ||
| configuration file parameters.
 | ||
| 
 | ||
| 
 | ||
| Text Formatting
 | ||
| ---------------
 | ||
| [[X51]]
 | ||
| Quoted Text
 | ||
| ~~~~~~~~~~~
 | ||
| Words and phrases can be formatted by enclosing inline text with
 | ||
| quote characters:
 | ||
| 
 | ||
| _Emphasized text_::
 | ||
|         Word phrases \'enclosed in single quote characters' (acute
 | ||
|         accents) or \_underline characters_ are emphasized.
 | ||
| 
 | ||
| *Strong text*::
 | ||
|         Word phrases \*enclosed in asterisk characters* are rendered
 | ||
|         in a strong font (usually bold).
 | ||
| 
 | ||
| [[X81]]+Monospaced text+::
 | ||
|         Word phrases \+enclosed in plus characters+ are rendered in a
 | ||
|         monospaced font. Word phrases \`enclosed in backtick
 | ||
|         characters` (grave accents) are also rendered in a monospaced
 | ||
|         font but in this case the enclosed text is rendered literally
 | ||
|         and is not subject to further expansion (see <<X80,inline
 | ||
|         literal passthrough>>).
 | ||
| 
 | ||
| `Single quoted text'::
 | ||
|         Phrases enclosed with a \`single grave accent to the left and
 | ||
|         a single acute accent to the right' are rendered in single
 | ||
|         quotation marks.
 | ||
| 
 | ||
| ``Double quoted text''::
 | ||
|         Phrases enclosed with \\``two grave accents to the left and
 | ||
|         two acute accents to the right'' are rendered in quotation
 | ||
|         marks.
 | ||
| 
 | ||
| #Unquoted text#::
 | ||
|         Placing \#hashes around text# does nothing, it is a mechanism
 | ||
|         to allow inline attributes to be applied to otherwise
 | ||
|         unformatted text.
 | ||
| 
 | ||
| New quote types can be defined by editing asciidoc(1) configuration
 | ||
| files. See the <<X7,Configuration Files>> section for details.
 | ||
| 
 | ||
| .Quoted text behavior
 | ||
| - Quoting cannot be overlapped.
 | ||
| - Different quoting types can be nested.
 | ||
| - To suppress quoted text formatting place a backslash character
 | ||
|   immediately in front of the leading quote character(s). In the case
 | ||
|   of ambiguity between escaped and non-escaped text you will need to
 | ||
|   escape both leading and trailing quotes, in the case of
 | ||
|   multi-character quotes you may even need to escape individual
 | ||
|   characters.
 | ||
| 
 | ||
| [[X96]]
 | ||
| Quoted text attributes
 | ||
| ^^^^^^^^^^^^^^^^^^^^^^
 | ||
| Quoted text can be prefixed with an <<X21,attribute list>>.  The first
 | ||
| positional attribute ('role' attribute) is translated by AsciiDoc to
 | ||
| an HTML 'span' element 'class' attribute or a DocBook 'phrase' element
 | ||
| 'role' attribute.
 | ||
| 
 | ||
| DocBook XSL Stylesheets translate DocBook 'phrase' elements with
 | ||
| 'role' attributes to corresponding HTML 'span' elements with the same
 | ||
| 'class' attributes; CSS can then be used
 | ||
| http://www.sagehill.net/docbookxsl/UsingCSS.html[to style the
 | ||
| generated HTML].  Thus CSS styling can be applied to both DocBook and
 | ||
| AsciiDoc generated HTML outputs.  You can also specify multiple class
 | ||
| names separated by spaces.
 | ||
| 
 | ||
| CSS rules for text color, text background color, text size and text
 | ||
| decorators are included in the distributed AsciiDoc CSS files and are
 | ||
| used in conjunction with AsciiDoc 'xhtml11', 'html5' and 'docbook'
 | ||
| outputs. The CSS class names are:
 | ||
| 
 | ||
| - '<color>' (text foreground color).
 | ||
| - '<color>-background' (text background color).
 | ||
| - 'big' and 'small' (text size).
 | ||
| - 'underline', 'overline' and 'line-through' (strike through) text
 | ||
|   decorators.
 | ||
| 
 | ||
| Where '<color>' can be any of the
 | ||
| http://en.wikipedia.org/wiki/Web_colors#HTML_color_names[sixteen HTML
 | ||
| color names].  Examples:
 | ||
| 
 | ||
|   [red]#Obvious# and [big red yellow-background]*very obvious*.
 | ||
| 
 | ||
|   [underline]#Underline text#, [overline]#overline text# and
 | ||
|   [blue line-through]*bold blue and line-through*.
 | ||
| 
 | ||
| is rendered as:
 | ||
| 
 | ||
| [red]#Obvious# and [big red yellow-background]*very obvious*.
 | ||
| 
 | ||
| [underline]#Underline text#, [overline]#overline text# and
 | ||
| [bold blue line-through]*bold blue and line-through*.
 | ||
| 
 | ||
| NOTE: Color and text decorator attributes are rendered for XHTML and
 | ||
| HTML 5 outputs using CSS stylesheets.  The mechanism to implement
 | ||
| color and text decorator attributes is provided for DocBook toolchains
 | ||
| via the DocBook 'phrase' element 'role' attribute, but the actual
 | ||
| rendering is toolchain specific and is not part of the AsciiDoc
 | ||
| distribution.
 | ||
| 
 | ||
| [[X52]]
 | ||
| Constrained and Unconstrained Quotes
 | ||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
 | ||
| There are actually two types of quotes:
 | ||
| 
 | ||
| Constrained quotes
 | ||
| ++++++++++++++++++
 | ||
| Quoted must be bounded by white space or commonly adjoining
 | ||
| punctuation characters. These are the most commonly used type of
 | ||
| quote.
 | ||
| 
 | ||
| Unconstrained quotes
 | ||
| ++++++++++++++++++++
 | ||
| Unconstrained quotes have no boundary constraints and can be placed
 | ||
| anywhere within inline text. For consistency and to make them easier
 | ||
| to remember unconstrained quotes are double-ups of the `_`, `*`, `+`
 | ||
| and `#` constrained quotes:
 | ||
| 
 | ||
|   __unconstrained emphasized text__
 | ||
|   **unconstrained strong text**
 | ||
|   ++unconstrained monospaced text++
 | ||
|   ##unconstrained unquoted text##
 | ||
| 
 | ||
| The following example emboldens the letter F:
 | ||
| 
 | ||
|   **F**ile Open...
 | ||
| 
 | ||
| Superscripts and Subscripts
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| Put \^carets on either^ side of the text to be superscripted, put
 | ||
| \~tildes on either side~ of text to be subscripted.  For example, the
 | ||
| following line:
 | ||
| 
 | ||
|   e^πi^+1 = 0. H~2~O and x^10^. Some ^super text^
 | ||
|   and ~some sub text~
 | ||
| 
 | ||
| Is rendered like:
 | ||
| 
 | ||
| e^πi^+1 = 0. H~2~O and x^10^. Some ^super text^
 | ||
| and ~some sub text~
 | ||
| 
 | ||
| Superscripts and subscripts are implemented as <<X52,unconstrained
 | ||
| quotes>> and they can be escaped with a leading backslash and prefixed
 | ||
| with with an attribute list.
 | ||
| 
 | ||
| Line Breaks
 | ||
| ~~~~~~~~~~~
 | ||
| A plus character preceded by at least one space character at the end
 | ||
| of a non-blank line forces a line break. It generates a line break
 | ||
| (`br`) tag for HTML outputs and a custom XML `asciidoc-br` processing
 | ||
| instruction for DocBook outputs. The `asciidoc-br` processing
 | ||
| instruction is handled by <<X43,a2x(1)>>.
 | ||
| 
 | ||
| Page Breaks
 | ||
| ~~~~~~~~~~~
 | ||
| A line of three or more less-than (`<<<`) characters will generate a
 | ||
| hard page break in DocBook and printed HTML outputs.  It uses the CSS
 | ||
| `page-break-after` property for HTML outputs and a custom XML
 | ||
| `asciidoc-pagebreak` processing instruction for DocBook outputs. The
 | ||
| `asciidoc-pagebreak` processing instruction is handled by
 | ||
| <<X43,a2x(1)>>. Hard page breaks are sometimes handy but as a general
 | ||
| rule you should let your page processor generate page breaks for you.
 | ||
| 
 | ||
| Rulers
 | ||
| ~~~~~~
 | ||
| A line of three or more apostrophe characters will generate a ruler
 | ||
| line.  It generates a ruler (`hr`) tag for HTML outputs and a custom
 | ||
| XML `asciidoc-hr` processing instruction for DocBook outputs. The
 | ||
| `asciidoc-hr` processing instruction is handled by <<X43,a2x(1)>>.
 | ||
| 
 | ||
| Tabs
 | ||
| ~~~~
 | ||
| By default tab characters input files will translated to 8 spaces. Tab
 | ||
| expansion is set with the 'tabsize' entry in the configuration file
 | ||
| `[miscellaneous]` section and can be overridden in included files by
 | ||
| setting a 'tabsize' attribute in the `include` macro's attribute list.
 | ||
| For example:
 | ||
| 
 | ||
|   include::addendum.txt[tabsize=2]
 | ||
| 
 | ||
| The tab size can also be set using the attribute command-line option,
 | ||
| for example `--attribute tabsize=4`
 | ||
| 
 | ||
| Replacements
 | ||
| ~~~~~~~~~~~~
 | ||
| The following replacements are defined in the default AsciiDoc
 | ||
| configuration:
 | ||
| 
 | ||
|   (C) copyright, (TM) trademark, (R) registered trademark,
 | ||
|   -- em dash, ... ellipsis, -> right arrow, <- left arrow, => right
 | ||
|   double arrow, <= left double arrow.
 | ||
| 
 | ||
| Which are rendered as:
 | ||
| 
 | ||
| (C) copyright, (TM) trademark, (R) registered trademark,
 | ||
| -- em dash, ... ellipsis, -> right arrow, <- left arrow, => right
 | ||
| double arrow, <= left double arrow.
 | ||
| 
 | ||
| You can also include arbitrary entity references in the AsciiDoc
 | ||
| source. Examples:
 | ||
| 
 | ||
|   ➊ ¶
 | ||
| 
 | ||
| renders:
 | ||
| 
 | ||
| ➊ ¶
 | ||
| 
 | ||
| To render a replacement literally escape it with a leading back-slash.
 | ||
| 
 | ||
| The <<X7,Configuration Files>> section explains how to configure your
 | ||
| own replacements.
 | ||
| 
 | ||
| Special Words
 | ||
| ~~~~~~~~~~~~~
 | ||
| Words defined in `[specialwords]` configuration file sections are
 | ||
| automatically marked up without having to be explicitly notated.
 | ||
| 
 | ||
| The <<X7,Configuration Files>> section explains how to add and replace
 | ||
| special words.
 | ||
| 
 | ||
| 
 | ||
| [[X17]]
 | ||
| Titles
 | ||
| ------
 | ||
| Document and section titles can be in either of two formats:
 | ||
| 
 | ||
| Two line titles
 | ||
| ~~~~~~~~~~~~~~~
 | ||
| A two line title consists of a title line, starting hard against the
 | ||
| left margin, and an underline. Section underlines consist a repeated
 | ||
| character pairs spanning the width of the preceding title (give or
 | ||
| take up to two characters):
 | ||
| 
 | ||
| The default title underlines for each of the document levels are:
 | ||
| 
 | ||
| 
 | ||
|   Level 0 (top level):     ======================
 | ||
|   Level 1:                 ----------------------
 | ||
|   Level 2:                 ~~~~~~~~~~~~~~~~~~~~~~
 | ||
|   Level 3:                 ^^^^^^^^^^^^^^^^^^^^^^
 | ||
|   Level 4 (bottom level):  ++++++++++++++++++++++
 | ||
| 
 | ||
| Examples:
 | ||
| 
 | ||
|   Level One Section Title
 | ||
|   -----------------------
 | ||
| 
 | ||
|   Level 2 Subsection Title
 | ||
|   ~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| 
 | ||
| [[X46]]
 | ||
| One line titles
 | ||
| ~~~~~~~~~~~~~~~
 | ||
| One line titles consist of a single line delimited on either side by
 | ||
| one or more equals characters (the number of equals characters
 | ||
| corresponds to the section level minus one).  Here are some examples:
 | ||
| 
 | ||
|   = Document Title (level 0) =
 | ||
|   == Section title (level 1) ==
 | ||
|   === Section title (level 2) ===
 | ||
|   ==== Section title (level 3) ====
 | ||
|   ===== Section title (level 4) =====
 | ||
| 
 | ||
| [NOTE]
 | ||
| =====================================================================
 | ||
| - One or more spaces must fall between the title and the delimiters.
 | ||
| - The trailing title delimiter is optional.
 | ||
| - The one-line title syntax can be changed by editing the
 | ||
|   configuration file `[titles]` section `sect0`...`sect4` entries.
 | ||
| =====================================================================
 | ||
| 
 | ||
| Floating titles
 | ||
| ~~~~~~~~~~~~~~~
 | ||
| Setting the title's first positional attribute or 'style' attribute to
 | ||
| 'float' generates a free-floating title. A free-floating title is
 | ||
| rendered just like a normal section title but is not formally
 | ||
| associated with a text body and is not part of the regular section
 | ||
| hierarchy so the normal ordering rules do not apply. Floating titles
 | ||
| can also be used in contexts where section titles are illegal: for
 | ||
| example sidebar and admonition blocks.  Example:
 | ||
| 
 | ||
|   [float]
 | ||
|   The second day
 | ||
|   ~~~~~~~~~~~~~~
 | ||
| 
 | ||
| Floating titles do not appear in a document's table of contents.
 | ||
| 
 | ||
| 
 | ||
| [[X42]]
 | ||
| Block Titles
 | ||
| ------------
 | ||
| A 'BlockTitle' element is a single line beginning with a period
 | ||
| followed by the title text. A BlockTitle is applied to the immediately
 | ||
| following Paragraph, DelimitedBlock, List, Table or BlockMacro. For
 | ||
| example:
 | ||
| 
 | ||
| ........................
 | ||
| .Notes
 | ||
| - Note 1.
 | ||
| - Note 2.
 | ||
| ........................
 | ||
| 
 | ||
| is rendered as:
 | ||
| 
 | ||
| .Notes
 | ||
| - Note 1.
 | ||
| - Note 2.
 | ||
| 
 | ||
| 
 | ||
| [[X41]]
 | ||
| BlockId Element
 | ||
| ---------------
 | ||
| A 'BlockId' is a single line block element containing a unique
 | ||
| identifier enclosed in double square brackets. It is used to assign an
 | ||
| identifier to the ensuing block element. For example:
 | ||
| 
 | ||
|   [[chapter-titles]]
 | ||
|   Chapter titles can be ...
 | ||
| 
 | ||
| The preceding example identifies the ensuing paragraph so it can be
 | ||
| referenced from other locations, for example with
 | ||
| `<<chapter-titles,chapter titles>>`.
 | ||
| 
 | ||
| 'BlockId' elements can be applied to Title, Paragraph, List,
 | ||
| DelimitedBlock, Table and BlockMacro elements.  The BlockId element
 | ||
| sets the `{id}` attribute for substitution in the subsequent block's
 | ||
| markup template. If a second positional argument is supplied it sets
 | ||
| the `{reftext}` attribute which is used to set the DocBook `xreflabel`
 | ||
| attribute.
 | ||
| 
 | ||
| The 'BlockId' element has the same syntax and serves the same function
 | ||
| to the <<X30,anchor inline macro>>.
 | ||
| 
 | ||
| [[X79]]
 | ||
| AttributeList Element
 | ||
| ---------------------
 | ||
| An 'AttributeList' block element is an <<X21,attribute list>> on a
 | ||
| line by itself:
 | ||
| 
 | ||
| - 'AttributeList' attributes are only applied to the immediately
 | ||
|   following block element -- the attributes are made available to the
 | ||
|   block's markup template.
 | ||
| - Multiple contiguous 'AttributeList' elements are additively combined
 | ||
|   in the order they appear..
 | ||
| - The first positional attribute in the list is often used to specify
 | ||
|   the ensuing element's <<X23,style>>.
 | ||
| 
 | ||
| Attribute value substitution
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| By default, only substitutions that take place inside attribute list
 | ||
| values are attribute references, this is because not all attributes
 | ||
| are destined to be marked up and rendered as text (for example the
 | ||
| table 'cols' attribute). To perform normal inline text substitutions
 | ||
| (special characters, quotes, macros, replacements) on an attribute
 | ||
| value you need to enclose it in single quotes. In the following quote
 | ||
| block the second attribute value in the AttributeList is quoted to
 | ||
| ensure the 'http' macro is expanded to a hyperlink.
 | ||
| 
 | ||
| ---------------------------------------------------------------------
 | ||
| [quote,'http://en.wikipedia.org/wiki/Samuel_Johnson[Samuel Johnson]']
 | ||
| _____________________________________________________________________
 | ||
| Sir, a woman's preaching is like a dog's walking on his hind legs. It
 | ||
| is not done well; but you are surprised to find it done at all.
 | ||
| _____________________________________________________________________
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| Common attributes
 | ||
| ~~~~~~~~~~~~~~~~~
 | ||
| Most block elements support the following attributes:
 | ||
| 
 | ||
| [cols="1e,1,5a",frame="topbot",options="header"]
 | ||
| |====================================================================
 | ||
| |Name |Backends |Description
 | ||
| 
 | ||
| |id |html4, html5, xhtml11, docbook |
 | ||
| Unique identifier typically serve as link targets.
 | ||
| Can also be set by the 'BlockId' element.
 | ||
| 
 | ||
| |role |html4, html5, xhtml11, docbook |
 | ||
| Role contains a string used to classify or subclassify an element and
 | ||
| can be applied to AsciiDoc block elements.  The AsciiDoc 'role'
 | ||
| attribute is translated to the 'role' attribute in DocBook outputs and
 | ||
| is included in the 'class' attribute in HTML outputs, in this respect
 | ||
| it behaves like the <<X96,quoted text role attribute>>.
 | ||
| 
 | ||
| DocBook XSL Stylesheets translate DocBook 'role' attributes to HTML
 | ||
| 'class' attributes; CSS can then be used
 | ||
| http://www.sagehill.net/docbookxsl/UsingCSS.html[to style the
 | ||
| generated HTML].
 | ||
| 
 | ||
| |reftext |docbook |
 | ||
| 'reftext' is used to set the DocBook 'xreflabel' attribute.
 | ||
| The 'reftext' attribute can an also be set by the 'BlockId' element.
 | ||
| 
 | ||
| |====================================================================
 | ||
| 
 | ||
| 
 | ||
| Paragraphs
 | ||
| ----------
 | ||
| Paragraphs are blocks of text terminated by a blank line, the end of
 | ||
| file, or the start of a delimited block or a list.  There are three
 | ||
| paragraph syntaxes: normal, indented (literal) and admonition which
 | ||
| are rendered, by default, with the corresponding paragraph style.
 | ||
| 
 | ||
| Each syntax has a default style, but you can explicitly apply any
 | ||
| paragraph style to any paragraph syntax. You can also apply
 | ||
| <<X104,delimited block>> styles to single paragraphs.
 | ||
| 
 | ||
| The built-in paragraph styles are: 'normal', 'literal', 'verse',
 | ||
| 'quote', 'listing', 'TIP', 'NOTE', 'IMPORTANT', 'WARNING', 'CAUTION',
 | ||
| 'abstract', 'partintro', 'comment', 'example', 'sidebar', 'source',
 | ||
| 'music', 'latex', 'graphviz'.
 | ||
| 
 | ||
| normal paragraph syntax
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| Normal paragraph syntax consists of one or more non-blank lines of
 | ||
| text. The first line must start hard against the left margin (no
 | ||
| intervening white space). The default processing expectation is that
 | ||
| of a normal paragraph of text.
 | ||
| 
 | ||
| [[X85]]
 | ||
| literal paragraph syntax
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| Literal paragraphs are rendered verbatim in a monospaced font without
 | ||
| any distinguishing background or border.  By default there is no text
 | ||
| formatting or substitutions within Literal paragraphs apart from
 | ||
| Special Characters and Callouts.
 | ||
| 
 | ||
| The 'literal' style is applied implicitly to indented paragraphs i.e.
 | ||
| where the first line of the paragraph is indented by one or more space
 | ||
| or tab characters.  For example:
 | ||
| 
 | ||
| ---------------------------------------------------------------------
 | ||
|   Consul *necessitatibus* per id,
 | ||
|   consetetur, eu pro everti postulant
 | ||
|   homero verear ea mea, qui.
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| Renders:
 | ||
| 
 | ||
|   Consul *necessitatibus* per id,
 | ||
|   consetetur, eu pro everti postulant
 | ||
|   homero verear ea mea, qui.
 | ||
| 
 | ||
| NOTE: Because <<X64,lists>> can be indented it's possible for your
 | ||
| indented paragraph to be misinterpreted as a list -- in situations
 | ||
| like this apply the 'literal' style to a normal paragraph.
 | ||
| 
 | ||
| Instead of using a paragraph indent you could apply the 'literal'
 | ||
| style explicitly, for example:
 | ||
| 
 | ||
| ---------------------------------------------------------------------
 | ||
| [literal]
 | ||
| Consul *necessitatibus* per id,
 | ||
| consetetur, eu pro everti postulant
 | ||
| homero verear ea mea, qui.
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| Renders:
 | ||
| 
 | ||
| [literal]
 | ||
| Consul *necessitatibus* per id,
 | ||
| consetetur, eu pro everti postulant
 | ||
| homero verear ea mea, qui.
 | ||
| 
 | ||
| [[X94]]
 | ||
| quote and verse paragraph styles
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| The optional 'attribution' and 'citetitle' attributes (positional
 | ||
| attributes 2 and 3) specify the author and source respectively.
 | ||
| 
 | ||
| The 'verse' style retains the line breaks, for example:
 | ||
| 
 | ||
| ---------------------------------------------------------------------
 | ||
| [verse, William Blake, from Auguries of Innocence]
 | ||
| To see a world in a grain of sand,
 | ||
| And a heaven in a wild flower,
 | ||
| Hold infinity in the palm of your hand,
 | ||
| And eternity in an hour.
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| Which is rendered as:
 | ||
| 
 | ||
| [verse, William Blake, from Auguries of Innocence]
 | ||
| To see a world in a grain of sand,
 | ||
| And a heaven in a wild flower,
 | ||
| Hold infinity in the palm of your hand,
 | ||
| And eternity in an hour.
 | ||
| 
 | ||
| The 'quote' style flows the text at left and right margins, for
 | ||
| example:
 | ||
| 
 | ||
| ---------------------------------------------------------------------
 | ||
| [quote, Bertrand Russell, The World of Mathematics (1956)]
 | ||
| A good notation has subtlety and suggestiveness which at times makes
 | ||
| it almost seem like a live teacher.
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| Which is rendered as:
 | ||
| 
 | ||
| [quote, Bertrand Russell, The World of Mathematics (1956)]
 | ||
| A good notation has subtlety and suggestiveness which at times makes
 | ||
| it almost seem like a live teacher.
 | ||
| 
 | ||
| [[X28]]
 | ||
| Admonition Paragraphs
 | ||
| ~~~~~~~~~~~~~~~~~~~~~
 | ||
| 'TIP', 'NOTE', 'IMPORTANT', 'WARNING' and 'CAUTION' admonishment
 | ||
| paragraph styles are generated by placing `NOTE:`, `TIP:`,
 | ||
| `IMPORTANT:`, `WARNING:` or `CAUTION:` as the first word of the
 | ||
| paragraph. For example:
 | ||
| 
 | ||
|   NOTE: This is an example note.
 | ||
| 
 | ||
| Alternatively, you can specify the paragraph admonition style
 | ||
| explicitly using an <<X79,AttributeList element>>. For example:
 | ||
| 
 | ||
|   [NOTE]
 | ||
|   This is an example note.
 | ||
| 
 | ||
| Renders:
 | ||
| 
 | ||
| NOTE: This is an example note.
 | ||
| 
 | ||
| TIP: If your admonition requires more than a single paragraph use an
 | ||
| <<X22,admonition block>> instead.
 | ||
| 
 | ||
| [[X47]]
 | ||
| Admonition Icons and Captions
 | ||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
 | ||
| NOTE: Admonition customization with `icons`, `iconsdir`, `icon` and
 | ||
| `caption` attributes does not apply when generating DocBook output. If
 | ||
| you are going the DocBook route then the <<X43,a2x(1)>> `--no-icons`
 | ||
| and `--icons-dir` options can be used to set the appropriate XSL
 | ||
| Stylesheets parameters.
 | ||
| 
 | ||
| By default the asciidoc(1) HTML backends generate text captions
 | ||
| instead of admonition icon image links. To generate links to icon
 | ||
| images define the <<X45,`icons`>> attribute, for example using the `-a
 | ||
| icons` command-line option.
 | ||
| 
 | ||
| The <<X44,`iconsdir`>> attribute sets the location of linked icon
 | ||
| images.
 | ||
| 
 | ||
| You can override the default icon image using the `icon` attribute to
 | ||
| specify the path of the linked image. For example:
 | ||
| 
 | ||
|   [icon="./images/icons/wink.png"]
 | ||
|   NOTE: What lovely war.
 | ||
| 
 | ||
| Use the `caption` attribute to customize the admonition captions (not
 | ||
| applicable to `docbook` backend). The following example suppresses the
 | ||
| icon image and customizes the caption of a 'NOTE' admonition
 | ||
| (undefining the `icons` attribute with `icons=None` is only necessary
 | ||
| if <<X45,admonition icons>> have been enabled):
 | ||
| 
 | ||
|   [icons=None, caption="My Special Note"]
 | ||
|   NOTE: This is my special note.
 | ||
| 
 | ||
| This subsection also applies to <<X22,Admonition Blocks>>.
 | ||
| 
 | ||
| 
 | ||
| [[X104]]
 | ||
| Delimited Blocks
 | ||
| ----------------
 | ||
| Delimited blocks are blocks of text enveloped by leading and trailing
 | ||
| delimiter lines (normally a series of four or more repeated
 | ||
| characters). The behavior of Delimited Blocks is specified by entries
 | ||
| in configuration file `[blockdef-*]` sections.
 | ||
| 
 | ||
| Predefined Delimited Blocks
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| AsciiDoc ships with a number of predefined DelimitedBlocks (see the
 | ||
| `asciidoc.conf` configuration file in the asciidoc(1) program
 | ||
| directory):
 | ||
| 
 | ||
| Predefined delimited block underlines:
 | ||
| 
 | ||
|   CommentBlock:     //////////////////////////
 | ||
|   PassthroughBlock: ++++++++++++++++++++++++++
 | ||
|   ListingBlock:     --------------------------
 | ||
|   LiteralBlock:     ..........................
 | ||
|   SidebarBlock:     **************************
 | ||
|   QuoteBlock:       __________________________
 | ||
|   ExampleBlock:     ==========================
 | ||
|   OpenBlock:        --
 | ||
| 
 | ||
| .Default DelimitedBlock substitutions
 | ||
| [cols="2e,7*^",frame="topbot",options="header,autowidth"]
 | ||
| |=====================================================
 | ||
| | |Attributes |Callouts |Macros | Quotes |Replacements
 | ||
| |Special chars |Special words
 | ||
| 
 | ||
| |PassthroughBlock |Yes |No  |Yes |No  |No  |No  |No
 | ||
| |ListingBlock     |No  |Yes |No  |No  |No  |Yes |No
 | ||
| |LiteralBlock     |No  |Yes |No  |No  |No  |Yes |No
 | ||
| |SidebarBlock     |Yes |No  |Yes |Yes |Yes |Yes |Yes
 | ||
| |QuoteBlock       |Yes |No  |Yes |Yes |Yes |Yes |Yes
 | ||
| |ExampleBlock     |Yes |No  |Yes |Yes |Yes |Yes |Yes
 | ||
| |OpenBlock        |Yes |No  |Yes |Yes |Yes |Yes |Yes
 | ||
| |=====================================================
 | ||
| 
 | ||
| Listing Blocks
 | ||
| ~~~~~~~~~~~~~~
 | ||
| 'ListingBlocks' are rendered verbatim in a monospaced font, they
 | ||
| retain line and whitespace formatting and are often distinguished by a
 | ||
| background or border. There is no text formatting or substitutions
 | ||
| within Listing blocks apart from Special Characters and Callouts.
 | ||
| Listing blocks are often used for computer output and file listings.
 | ||
| 
 | ||
| Here's an example:
 | ||
| 
 | ||
| [listing]
 | ||
| ......................................
 | ||
| --------------------------------------
 | ||
| #include <stdio.h>
 | ||
| 
 | ||
| int main() {
 | ||
|    printf("Hello World!\n");
 | ||
|    exit(0);
 | ||
| }
 | ||
| --------------------------------------
 | ||
| ......................................
 | ||
| 
 | ||
| Which will be rendered like:
 | ||
| 
 | ||
| --------------------------------------
 | ||
| #include <stdio.h>
 | ||
| 
 | ||
| int main() {
 | ||
|     printf("Hello World!\n");
 | ||
|     exit(0);
 | ||
| }
 | ||
| --------------------------------------
 | ||
| 
 | ||
| By convention <<X59,filter blocks>> use the listing block syntax and
 | ||
| are implemented as distinct listing block styles.
 | ||
| 
 | ||
| [[X65]]
 | ||
| Literal Blocks
 | ||
| ~~~~~~~~~~~~~~
 | ||
| 'LiteralBlocks' are rendered just like <<X85,literal paragraphs>>.
 | ||
| Example:
 | ||
| 
 | ||
| ---------------------------------------------------------------------
 | ||
| ...................................
 | ||
| Consul *necessitatibus* per id,
 | ||
| consetetur, eu pro everti postulant
 | ||
| homero verear ea mea, qui.
 | ||
| ...................................
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| Renders:
 | ||
| ...................................
 | ||
| Consul *necessitatibus* per id,
 | ||
| consetetur, eu pro everti postulant
 | ||
| homero verear ea mea, qui.
 | ||
| ...................................
 | ||
| 
 | ||
| If the 'listing' style is applied to a LiteralBlock it will be
 | ||
| rendered as a ListingBlock (this is handy if you have a listing
 | ||
| containing a ListingBlock).
 | ||
| 
 | ||
| Sidebar Blocks
 | ||
| ~~~~~~~~~~~~~~
 | ||
| A sidebar is a short piece of text presented outside the narrative
 | ||
| flow of the main text. The sidebar is normally presented inside a
 | ||
| bordered box to set it apart from the main text.
 | ||
| 
 | ||
| The sidebar body is treated like a normal section body.
 | ||
| 
 | ||
| Here's an example:
 | ||
| 
 | ||
| ---------------------------------------------------------------------
 | ||
| .An Example Sidebar
 | ||
| ************************************************
 | ||
| Any AsciiDoc SectionBody element (apart from
 | ||
| SidebarBlocks) can be placed inside a sidebar.
 | ||
| ************************************************
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| Which will be rendered like:
 | ||
| 
 | ||
| .An Example Sidebar
 | ||
| ************************************************
 | ||
| Any AsciiDoc SectionBody element (apart from
 | ||
| SidebarBlocks) can be placed inside a sidebar.
 | ||
| ************************************************
 | ||
| 
 | ||
| [[X26]]
 | ||
| Comment Blocks
 | ||
| ~~~~~~~~~~~~~~
 | ||
| The contents of 'CommentBlocks' are not processed; they are useful for
 | ||
| annotations and for excluding new or outdated content that you don't
 | ||
| want displayed. CommentBlocks are never written to output files.
 | ||
| Example:
 | ||
| 
 | ||
| ---------------------------------------------------------------------
 | ||
| //////////////////////////////////////////
 | ||
| CommentBlock contents are not processed by
 | ||
| asciidoc(1).
 | ||
| //////////////////////////////////////////
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| See also <<X25,Comment Lines>>.
 | ||
| 
 | ||
| NOTE: System macros are executed inside comment blocks.
 | ||
| 
 | ||
| [[X76]]
 | ||
| Passthrough Blocks
 | ||
| ~~~~~~~~~~~~~~~~~~
 | ||
| By default the block contents is subject only to 'attributes' and
 | ||
| 'macros' substitutions (use an explicit 'subs' attribute to apply
 | ||
| different substitutions).  PassthroughBlock content will often be
 | ||
| backend specific. Here's an example:
 | ||
| 
 | ||
| ---------------------------------------------------------------------
 | ||
| [subs="quotes"]
 | ||
| ++++++++++++++++++++++++++++++++++++++
 | ||
| <table border="1"><tr>
 | ||
|   <td>*Cell 1*</td>
 | ||
|   <td>*Cell 2*</td>
 | ||
| </tr></table>
 | ||
| ++++++++++++++++++++++++++++++++++++++
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| The following styles can be applied to passthrough blocks:
 | ||
| 
 | ||
| pass::
 | ||
|   No substitutions are performed. This is equivalent to `subs="none"`.
 | ||
| 
 | ||
| asciimath, latexmath::
 | ||
|   By default no substitutions are performed, the contents are rendered
 | ||
|   as <<X78,mathematical formulas>>.
 | ||
| 
 | ||
| Quote Blocks
 | ||
| ~~~~~~~~~~~~
 | ||
| 'QuoteBlocks' are used for quoted passages of text. There are two
 | ||
| styles: 'quote' and 'verse'. The style behavior is identical to
 | ||
| <<X94,quote and verse paragraphs>> except that blocks can contain
 | ||
| multiple paragraphs and, in the case of the 'quote' style, other
 | ||
| section elements.  The first positional attribute sets the style, if
 | ||
| no attributes are specified the 'quote' style is used.  The optional
 | ||
| 'attribution' and 'citetitle' attributes (positional attributes 2 and
 | ||
| 3) specify the quote's author and source. For example:
 | ||
| 
 | ||
| ---------------------------------------------------------------------
 | ||
| [quote, Sir Arthur Conan Doyle, The Adventures of Sherlock Holmes]
 | ||
| ____________________________________________________________________
 | ||
| As he spoke there was the sharp sound of horses' hoofs and
 | ||
| grating wheels against the curb, followed by a sharp pull at the
 | ||
| bell. Holmes whistled.
 | ||
| 
 | ||
| "A pair, by the sound," said he. "Yes," he continued, glancing
 | ||
| out of the window. "A nice little brougham and a pair of
 | ||
| beauties. A hundred and fifty guineas apiece. There's money in
 | ||
| this case, Watson, if there is nothing else."
 | ||
| ____________________________________________________________________
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| Which is rendered as:
 | ||
| 
 | ||
| [quote, Sir Arthur Conan Doyle, The Adventures of Sherlock Holmes]
 | ||
| ____________________________________________________________________
 | ||
| As he spoke there was the sharp sound of horses' hoofs and
 | ||
| grating wheels against the curb, followed by a sharp pull at the
 | ||
| bell. Holmes whistled.
 | ||
| 
 | ||
| "A pair, by the sound," said he. "Yes," he continued, glancing
 | ||
| out of the window. "A nice little brougham and a pair of
 | ||
| beauties. A hundred and fifty guineas apiece. There's money in
 | ||
| this case, Watson, if there is nothing else."
 | ||
| ____________________________________________________________________
 | ||
| 
 | ||
| [[X48]]
 | ||
| Example Blocks
 | ||
| ~~~~~~~~~~~~~~
 | ||
| 'ExampleBlocks' encapsulate the DocBook Example element and are used
 | ||
| for, well, examples.  Example blocks can be titled by preceding them
 | ||
| with a 'BlockTitle'.  DocBook toolchains will normally automatically
 | ||
| number examples and generate a 'List of Examples' backmatter section.
 | ||
| 
 | ||
| Example blocks are delimited by lines of equals characters and can
 | ||
| contain any block elements apart from Titles, BlockTitles and
 | ||
| Sidebars) inside an example block. For example:
 | ||
| 
 | ||
| ---------------------------------------------------------------------
 | ||
| .An example
 | ||
| =====================================================================
 | ||
| Qui in magna commodo, est labitur dolorum an. Est ne magna primis
 | ||
| adolescens.
 | ||
| =====================================================================
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| Renders:
 | ||
| 
 | ||
| .An example
 | ||
| =====================================================================
 | ||
| Qui in magna commodo, est labitur dolorum an. Est ne magna primis
 | ||
| adolescens.
 | ||
| =====================================================================
 | ||
| 
 | ||
| A title prefix that can be inserted with the `caption` attribute
 | ||
| (HTML backends). For example:
 | ||
| 
 | ||
| ---------------------------------------------------------------------
 | ||
| [caption="Example 1: "]
 | ||
| .An example with a custom caption
 | ||
| =====================================================================
 | ||
| Qui in magna commodo, est labitur dolorum an. Est ne magna primis
 | ||
| adolescens.
 | ||
| =====================================================================
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| [[X22]]
 | ||
| Admonition Blocks
 | ||
| ~~~~~~~~~~~~~~~~~
 | ||
| The 'ExampleBlock' definition includes a set of admonition
 | ||
| <<X23,styles>> ('NOTE', 'TIP', 'IMPORTANT', 'WARNING', 'CAUTION') for
 | ||
| generating admonition blocks (admonitions containing more than a
 | ||
| <<X28,single paragraph>>).  Just precede the 'ExampleBlock' with an
 | ||
| attribute list specifying the admonition style name. For example:
 | ||
| 
 | ||
| ---------------------------------------------------------------------
 | ||
| [NOTE]
 | ||
| .A NOTE admonition block
 | ||
| =====================================================================
 | ||
| Qui in magna commodo, est labitur dolorum an. Est ne magna primis
 | ||
| adolescens.
 | ||
| 
 | ||
| . Fusce euismod commodo velit.
 | ||
| . Vivamus fringilla mi eu lacus.
 | ||
|   .. Fusce euismod commodo velit.
 | ||
|   .. Vivamus fringilla mi eu lacus.
 | ||
| . Donec eget arcu bibendum
 | ||
|   nunc consequat lobortis.
 | ||
| =====================================================================
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| Renders:
 | ||
| 
 | ||
| [NOTE]
 | ||
| .A NOTE admonition block
 | ||
| =====================================================================
 | ||
| Qui in magna commodo, est labitur dolorum an. Est ne magna primis
 | ||
| adolescens.
 | ||
| 
 | ||
| . Fusce euismod commodo velit.
 | ||
| . Vivamus fringilla mi eu lacus.
 | ||
|   .. Fusce euismod commodo velit.
 | ||
|   .. Vivamus fringilla mi eu lacus.
 | ||
| . Donec eget arcu bibendum
 | ||
|   nunc consequat lobortis.
 | ||
| =====================================================================
 | ||
| 
 | ||
| See also <<X47,Admonition Icons and Captions>>.
 | ||
| 
 | ||
| [[X29]]
 | ||
| Open Blocks
 | ||
| ~~~~~~~~~~~
 | ||
| Open blocks are special:
 | ||
| 
 | ||
| - The open block delimiter is line containing two hyphen characters
 | ||
|   (instead of four or more repeated characters).
 | ||
| 
 | ||
| - They can be used to group block elements for <<X15,List item
 | ||
|   continuation>>.
 | ||
| 
 | ||
| - Open blocks can be styled to behave like any other type of delimited
 | ||
|   block.  The  following built-in styles can be applied to open
 | ||
|   blocks: 'literal', 'verse', 'quote', 'listing', 'TIP', 'NOTE',
 | ||
|   'IMPORTANT', 'WARNING', 'CAUTION', 'abstract', 'partintro',
 | ||
|   'comment', 'example', 'sidebar', 'source', 'music', 'latex',
 | ||
|   'graphviz'. For example, the following open block and listing block
 | ||
|   are functionally identical:
 | ||
| 
 | ||
|   [listing]
 | ||
|   --
 | ||
|   Lorum ipsum ...
 | ||
|   --
 | ||
| 
 | ||
|   ---------------
 | ||
|   Lorum ipsum ...
 | ||
|   ---------------
 | ||
| 
 | ||
| - An unstyled open block groups section elements but otherwise does
 | ||
|   nothing.
 | ||
| 
 | ||
| Open blocks are used to generate document abstracts and book part
 | ||
| introductions:
 | ||
| 
 | ||
| - Apply the 'abstract' style to generate an abstract, for example:
 | ||
| 
 | ||
|   [abstract]
 | ||
|   --
 | ||
|   In this paper we will ...
 | ||
|   --
 | ||
| 
 | ||
| . Apply the 'partintro' style to generate a book part introduction for
 | ||
|   a multi-part book, for example:
 | ||
| 
 | ||
|   [partintro]
 | ||
|   .Optional part introduction title
 | ||
|   --
 | ||
|   Optional part introduction goes here.
 | ||
|   --
 | ||
| 
 | ||
| 
 | ||
| [[X64]]
 | ||
| Lists
 | ||
| -----
 | ||
| .List types
 | ||
| - Bulleted lists. Also known as itemized or unordered lists.
 | ||
| - Numbered lists. Also called ordered lists.
 | ||
| - Labeled lists. Sometimes called variable or definition lists.
 | ||
| - Callout lists (a list of callout annotations).
 | ||
| 
 | ||
| .List behavior
 | ||
| - List item indentation is optional and does not determine nesting,
 | ||
|   indentation does however make the source more readable.
 | ||
| - Another list or a literal paragraph immediately following a list
 | ||
|   item will be implicitly included in the list item; use <<X15, list
 | ||
|   item continuation>> to explicitly append other block elements to a
 | ||
|   list item.
 | ||
| - A comment block or a comment line block macro element will terminate
 | ||
|   a list -- use inline comment lines to put comments inside lists.
 | ||
| - The `listindex` <<X60,intrinsic attribute>> is the current list item
 | ||
|   index (1..). If this attribute is used outside a list then it's value
 | ||
|   is the number of items in the most recently closed list. Useful for
 | ||
|   displaying the number of items in a list.
 | ||
| 
 | ||
| Bulleted Lists
 | ||
| ~~~~~~~~~~~~~~
 | ||
| Bulleted list items start with a single dash or one to five asterisks
 | ||
| followed by some white space then some text. Bulleted list syntaxes
 | ||
| are:
 | ||
| 
 | ||
| ...................
 | ||
| - List item.
 | ||
| * List item.
 | ||
| ** List item.
 | ||
| *** List item.
 | ||
| **** List item.
 | ||
| ***** List item.
 | ||
| ...................
 | ||
| 
 | ||
| Numbered Lists
 | ||
| ~~~~~~~~~~~~~~
 | ||
| List item numbers are explicit or implicit.
 | ||
| 
 | ||
| .Explicit numbering
 | ||
| List items begin with a number followed by some white space then the
 | ||
| item text. The numbers can be decimal (arabic), roman (upper or lower
 | ||
| case) or alpha (upper or lower case). Decimal and alpha numbers are
 | ||
| terminated with a period, roman numbers are terminated with a closing
 | ||
| parenthesis. The different terminators are necessary to ensure 'i',
 | ||
| 'v' and 'x' roman numbers are are distinguishable from 'x', 'v' and
 | ||
| 'x' alpha numbers. Examples:
 | ||
| 
 | ||
| .....................................................................
 | ||
| 1.   Arabic (decimal) numbered list item.
 | ||
| a.   Lower case alpha (letter) numbered list item.
 | ||
| F.   Upper case alpha (letter) numbered list item.
 | ||
| iii) Lower case roman numbered list item.
 | ||
| IX)  Upper case roman numbered list item.
 | ||
| .....................................................................
 | ||
| 
 | ||
| .Implicit numbering
 | ||
| List items begin one to five period characters, followed by some white
 | ||
| space then the item text. Examples:
 | ||
| 
 | ||
| .....................................................................
 | ||
| . Arabic (decimal) numbered list item.
 | ||
| .. Lower case alpha (letter) numbered list item.
 | ||
| ... Lower case roman numbered list item.
 | ||
| .... Upper case alpha (letter) numbered list item.
 | ||
| ..... Upper case roman numbered list item.
 | ||
| .....................................................................
 | ||
| 
 | ||
| You can use the 'style' attribute (also the first positional
 | ||
| attribute) to specify an alternative numbering style.  The numbered
 | ||
| list style can be one of the following values: 'arabic', 'loweralpha',
 | ||
| 'upperalpha', 'lowerroman', 'upperroman'.
 | ||
| 
 | ||
| Here are some examples of bulleted and numbered lists:
 | ||
| 
 | ||
| ---------------------------------------------------------------------
 | ||
| - Praesent eget purus quis magna eleifend eleifend.
 | ||
|   1. Fusce euismod commodo velit.
 | ||
|     a. Fusce euismod commodo velit.
 | ||
|     b. Vivamus fringilla mi eu lacus.
 | ||
|     c. Donec eget arcu bibendum nunc consequat lobortis.
 | ||
|   2. Vivamus fringilla mi eu lacus.
 | ||
|     i)  Fusce euismod commodo velit.
 | ||
|     ii) Vivamus fringilla mi eu lacus.
 | ||
|   3. Donec eget arcu bibendum nunc consequat lobortis.
 | ||
|   4. Nam fermentum mattis ante.
 | ||
| - Lorem ipsum dolor sit amet, consectetuer adipiscing elit.
 | ||
|   * Fusce euismod commodo velit.
 | ||
|   ** Qui in magna commodo, est labitur dolorum an. Est ne magna primis
 | ||
|      adolescens. Sit munere ponderum dignissim et. Minim luptatum et
 | ||
|      vel.
 | ||
|   ** Vivamus fringilla mi eu lacus.
 | ||
|   * Donec eget arcu bibendum nunc consequat lobortis.
 | ||
| - Nulla porttitor vulputate libero.
 | ||
|   . Fusce euismod commodo velit.
 | ||
|   . Vivamus fringilla mi eu lacus.
 | ||
| [upperroman]
 | ||
|     .. Fusce euismod commodo velit.
 | ||
|     .. Vivamus fringilla mi eu lacus.
 | ||
|   . Donec eget arcu bibendum nunc consequat lobortis.
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| Which render as:
 | ||
| 
 | ||
| - Praesent eget purus quis magna eleifend eleifend.
 | ||
|   1. Fusce euismod commodo velit.
 | ||
|     a. Fusce euismod commodo velit.
 | ||
|     b. Vivamus fringilla mi eu lacus.
 | ||
|     c. Donec eget arcu bibendum nunc consequat lobortis.
 | ||
|   2. Vivamus fringilla mi eu lacus.
 | ||
|     i)  Fusce euismod commodo velit.
 | ||
|     ii) Vivamus fringilla mi eu lacus.
 | ||
|   3. Donec eget arcu bibendum nunc consequat lobortis.
 | ||
|   4. Nam fermentum mattis ante.
 | ||
| - Lorem ipsum dolor sit amet, consectetuer adipiscing elit.
 | ||
|   * Fusce euismod commodo velit.
 | ||
|   ** Qui in magna commodo, est labitur dolorum an. Est ne magna primis
 | ||
|      adolescens. Sit munere ponderum dignissim et. Minim luptatum et
 | ||
|      vel.
 | ||
|   ** Vivamus fringilla mi eu lacus.
 | ||
|   * Donec eget arcu bibendum nunc consequat lobortis.
 | ||
| - Nulla porttitor vulputate libero.
 | ||
|   . Fusce euismod commodo velit.
 | ||
|   . Vivamus fringilla mi eu lacus.
 | ||
| [upperroman]
 | ||
|     .. Fusce euismod commodo velit.
 | ||
|     .. Vivamus fringilla mi eu lacus.
 | ||
|   . Donec eget arcu bibendum nunc consequat lobortis.
 | ||
| 
 | ||
| A predefined 'compact' option is available to bulleted and numbered
 | ||
| lists -- this translates to the DocBook 'spacing="compact"' lists
 | ||
| attribute which may or may not be processed by the DocBook toolchain.
 | ||
| Example:
 | ||
| 
 | ||
|   [options="compact"]
 | ||
|   - Compact list item.
 | ||
|   - Another compact list item.
 | ||
| 
 | ||
| TIP: To apply the 'compact' option globally define a document-wide
 | ||
| 'compact-option' attribute, e.g. using the `-a compact-option`
 | ||
| command-line option.
 | ||
| 
 | ||
| You can set the list start number using the 'start' attribute (works
 | ||
| for HTML outputs and DocBook outputs processed by DocBook XSL
 | ||
| Stylesheets). Example:
 | ||
| 
 | ||
|   [start=7]
 | ||
|   . List item 7.
 | ||
|   . List item 8.
 | ||
| 
 | ||
| Labeled Lists
 | ||
| ~~~~~~~~~~~~~
 | ||
| Labeled list items consist of one or more text labels followed by the
 | ||
| text of the list item.
 | ||
| 
 | ||
| An item label begins a line with an alphanumeric character hard
 | ||
| against the left margin and ends with two, three or four colons or two
 | ||
| semi-colons. A list item can have multiple labels, one per line.
 | ||
| 
 | ||
| The list item text consists of one or more lines of text starting
 | ||
| after the last label (either on the same line or a new line) and can
 | ||
| be followed by nested List or ListParagraph elements. Item text can be
 | ||
| optionally indented.
 | ||
| 
 | ||
| Here are some examples:
 | ||
| 
 | ||
| ---------------------------------------------------------------------
 | ||
| In::
 | ||
| Lorem::
 | ||
|   Fusce euismod commodo velit.
 | ||
| 
 | ||
|   Fusce euismod commodo velit.
 | ||
| 
 | ||
| Ipsum:: Vivamus fringilla mi eu lacus.
 | ||
|   * Vivamus fringilla mi eu lacus.
 | ||
|   * Donec eget arcu bibendum nunc consequat lobortis.
 | ||
| Dolor::
 | ||
|   Donec eget arcu bibendum nunc consequat lobortis.
 | ||
|   Suspendisse;;
 | ||
|     A massa id sem aliquam auctor.
 | ||
|   Morbi;;
 | ||
|     Pretium nulla vel lorem.
 | ||
|   In;;
 | ||
|     Dictum mauris in urna.
 | ||
|     Vivamus::: Fringilla mi eu lacus.
 | ||
|     Donec:::   Eget arcu bibendum nunc consequat lobortis.
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| Which render as:
 | ||
| 
 | ||
| In::
 | ||
| Lorem::
 | ||
|   Fusce euismod commodo velit.
 | ||
| 
 | ||
|   Fusce euismod commodo velit.
 | ||
| 
 | ||
| Ipsum:: Vivamus fringilla mi eu lacus.
 | ||
|   * Vivamus fringilla mi eu lacus.
 | ||
|   * Donec eget arcu bibendum nunc consequat lobortis.
 | ||
| Dolor::
 | ||
|   Donec eget arcu bibendum nunc consequat lobortis.
 | ||
|   Suspendisse;;
 | ||
|     A massa id sem aliquam auctor.
 | ||
|   Morbi;;
 | ||
|     Pretium nulla vel lorem.
 | ||
|   In;;
 | ||
|     Dictum mauris in urna.
 | ||
|     Vivamus::: Fringilla mi eu lacus.
 | ||
|     Donec:::   Eget arcu bibendum nunc consequat lobortis.
 | ||
| 
 | ||
| Horizontal labeled list style
 | ||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
 | ||
| The 'horizontal' labeled list style (also the first positional
 | ||
| attribute) places the list text side-by-side with the label instead of
 | ||
| under the label. Here is an example:
 | ||
| 
 | ||
| ---------------------------------------------------------------------
 | ||
| [horizontal]
 | ||
| *Lorem*:: Fusce euismod commodo velit.  Qui in magna commodo, est
 | ||
| labitur dolorum an. Est ne magna primis adolescens.
 | ||
| 
 | ||
|   Fusce euismod commodo velit.
 | ||
| 
 | ||
| *Ipsum*:: Vivamus fringilla mi eu lacus.
 | ||
| - Vivamus fringilla mi eu lacus.
 | ||
| - Donec eget arcu bibendum nunc consequat lobortis.
 | ||
| 
 | ||
| *Dolor*::
 | ||
|   - Vivamus fringilla mi eu lacus.
 | ||
|   - Donec eget arcu bibendum nunc consequat lobortis.
 | ||
| 
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| Which render as:
 | ||
| 
 | ||
| [horizontal]
 | ||
| *Lorem*:: Fusce euismod commodo velit.  Qui in magna commodo, est
 | ||
| labitur dolorum an. Est ne magna primis adolescens.
 | ||
| 
 | ||
|   Fusce euismod commodo velit.
 | ||
| 
 | ||
| *Ipsum*:: Vivamus fringilla mi eu lacus.
 | ||
| - Vivamus fringilla mi eu lacus.
 | ||
| - Donec eget arcu bibendum nunc consequat lobortis.
 | ||
| 
 | ||
| *Dolor*::
 | ||
|   - Vivamus fringilla mi eu lacus.
 | ||
|   - Donec eget arcu bibendum nunc consequat lobortis.
 | ||
| 
 | ||
| [NOTE]
 | ||
| =====================================================================
 | ||
| - Current PDF toolchains do not make a good job of determining
 | ||
|   the relative column widths for horizontal labeled lists.
 | ||
| - Nested horizontal labeled lists will generate DocBook validation
 | ||
|   errors because the 'DocBook XML V4.2' DTD does not permit nested
 | ||
|   informal tables (although <<X13,DocBook XSL Stylesheets>> and
 | ||
|   <<X31,dblatex>> process them correctly).
 | ||
| - The label width can be set as a percentage of the total width by
 | ||
|   setting the 'width' attribute e.g. `width="10%"`
 | ||
| =====================================================================
 | ||
| 
 | ||
| Question and Answer Lists
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| AsciiDoc comes pre-configured with a 'qanda' style labeled list for generating
 | ||
| DocBook question and answer (Q&A) lists. Example:
 | ||
| 
 | ||
| ---------------------------------------------------------------------
 | ||
| [qanda]
 | ||
| Question one::
 | ||
|         Answer one.
 | ||
| Question two::
 | ||
|         Answer two.
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| Renders:
 | ||
| 
 | ||
| [qanda]
 | ||
| Question one::
 | ||
|         Answer one.
 | ||
| Question two::
 | ||
|         Answer two.
 | ||
| 
 | ||
| Glossary Lists
 | ||
| ~~~~~~~~~~~~~~
 | ||
| AsciiDoc comes pre-configured with a 'glossary' style labeled list for
 | ||
| generating DocBook glossary lists. Example:
 | ||
| 
 | ||
| ---------------------------------------------------------------------
 | ||
| [glossary]
 | ||
| A glossary term::
 | ||
|     The corresponding definition.
 | ||
| A second glossary term::
 | ||
|     The corresponding definition.
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| For working examples see the `article.txt` and `book.txt` documents in
 | ||
| the AsciiDoc `./doc` distribution directory.
 | ||
| 
 | ||
| NOTE: To generate valid DocBook output glossary lists must be located
 | ||
| in a section that uses the 'glossary' <<X93,section markup template>>.
 | ||
| 
 | ||
| Bibliography Lists
 | ||
| ~~~~~~~~~~~~~~~~~~
 | ||
| AsciiDoc comes with a predefined 'bibliography' bulleted list style
 | ||
| generating DocBook bibliography entries. Example:
 | ||
| 
 | ||
| ---------------------------------------------------------------------
 | ||
| [bibliography]
 | ||
| .Optional list title
 | ||
| - [[[taoup]]] Eric Steven Raymond. 'The Art of UNIX
 | ||
|   Programming'. Addison-Wesley. ISBN 0-13-142901-9.
 | ||
| - [[[walsh-muellner]]] Norman Walsh & Leonard Muellner.
 | ||
|   'DocBook - The Definitive Guide'. O'Reilly & Associates.
 | ||
|   1999. ISBN 1-56592-580-7.
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| The `[[[<reference>]]]` syntax is a bibliography entry anchor, it
 | ||
| generates an anchor named `<reference>` and additionally displays
 | ||
| `[<reference>]` at the anchor position. For example `[[[taoup]]]`
 | ||
| generates an anchor named `taoup` that displays `[taoup]` at the
 | ||
| anchor position. Cite the reference from elsewhere your document using
 | ||
| `<<taoup>>`, this displays a hyperlink (`[taoup]`) to the
 | ||
| corresponding bibliography entry anchor.
 | ||
| 
 | ||
| For working examples see the `article.txt` and `book.txt` documents in
 | ||
| the AsciiDoc `./doc` distribution directory.
 | ||
| 
 | ||
| NOTE: To generate valid DocBook output bibliography lists must be
 | ||
| located in a <<X93,bibliography section>>.
 | ||
| 
 | ||
| [[X15]]
 | ||
| List Item Continuation
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~
 | ||
| Another list or a literal paragraph immediately following a list item
 | ||
| is implicitly appended to the list item; to append other block
 | ||
| elements to a list item you need to explicitly join them to the list
 | ||
| item with a 'list continuation' (a separator line containing a single
 | ||
| plus character). Multiple block elements can be appended to a list
 | ||
| item using list continuations (provided they are legal list item
 | ||
| children in the backend markup).
 | ||
| 
 | ||
| Here are some examples of list item continuations: list item one
 | ||
| contains multiple continuations; list item two is continued with an
 | ||
| <<X29,OpenBlock>> containing multiple elements:
 | ||
| 
 | ||
| ---------------------------------------------------------------------
 | ||
| 1. List item one.
 | ||
| +
 | ||
| List item one continued with a second paragraph followed by an
 | ||
| Indented block.
 | ||
| +
 | ||
| .................
 | ||
| $ ls *.sh
 | ||
| $ mv *.sh ~/tmp
 | ||
| .................
 | ||
| +
 | ||
| List item continued with a third paragraph.
 | ||
| 
 | ||
| 2. List item two continued with an open block.
 | ||
| +
 | ||
| --
 | ||
| This paragraph is part of the preceding list item.
 | ||
| 
 | ||
| a. This list is nested and does not require explicit item continuation.
 | ||
| +
 | ||
| This paragraph is part of the preceding list item.
 | ||
| 
 | ||
| b. List item b.
 | ||
| 
 | ||
| This paragraph belongs to item two of the outer list.
 | ||
| --
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| Renders:
 | ||
| 
 | ||
| 1. List item one.
 | ||
| +
 | ||
| List item one continued with a second paragraph followed by an
 | ||
| Indented block.
 | ||
| +
 | ||
| .................
 | ||
| $ ls *.sh
 | ||
| $ mv *.sh ~/tmp
 | ||
| .................
 | ||
| +
 | ||
| List item continued with a third paragraph.
 | ||
| 
 | ||
| 2. List item two continued with an open block.
 | ||
| +
 | ||
| --
 | ||
| This paragraph is part of the preceding list item.
 | ||
| 
 | ||
| a. This list is nested and does not require explicit item continuation.
 | ||
| +
 | ||
| This paragraph is part of the preceding list item.
 | ||
| 
 | ||
| b. List item b.
 | ||
| 
 | ||
| This paragraph belongs to item two of the outer list.
 | ||
| --
 | ||
| 
 | ||
| 
 | ||
| [[X92]]
 | ||
| Footnotes
 | ||
| ---------
 | ||
| The shipped AsciiDoc configuration includes three footnote inline
 | ||
| macros:
 | ||
| 
 | ||
| `footnote:[<text>]`::
 | ||
|   Generates a footnote with text `<text>`.
 | ||
| 
 | ||
| `footnoteref:[<id>,<text>]`::
 | ||
|   Generates a footnote with a reference ID `<id>` and text `<text>`.
 | ||
| 
 | ||
| `footnoteref:[<id>]`::
 | ||
|   Generates a reference to the footnote with ID `<id>`.
 | ||
| 
 | ||
| The footnote text can span multiple lines.
 | ||
| 
 | ||
| The 'xhtml11' and 'html5' backends render footnotes dynamically using
 | ||
| JavaScript; 'html4' outputs do not use JavaScript and leave the
 | ||
| footnotes inline; 'docbook' footnotes are processed by the downstream
 | ||
| DocBook toolchain.
 | ||
| 
 | ||
| Example footnotes:
 | ||
| 
 | ||
|   A footnote footnote:[An example footnote.];
 | ||
|   a second footnote with a reference ID footnoteref:[note2,Second footnote.];
 | ||
|   finally a reference to the second footnote footnoteref:[note2].
 | ||
| 
 | ||
| Renders:
 | ||
| 
 | ||
| A footnote footnote:[An example footnote.];
 | ||
| a second footnote with a reference ID footnoteref:[note2,Second footnote.];
 | ||
| finally a reference to the second footnote footnoteref:[note2].
 | ||
| 
 | ||
| 
 | ||
| Indexes
 | ||
| -------
 | ||
| The shipped AsciiDoc configuration includes the inline macros for
 | ||
| generating DocBook index entries.
 | ||
| 
 | ||
| `indexterm:[<primary>,<secondary>,<tertiary>]`::
 | ||
| `(((<primary>,<secondary>,<tertiary>)))`::
 | ||
|     This inline macro generates an index term (the `<secondary>` and
 | ||
|     `<tertiary>` positional attributes are optional). Example:
 | ||
|     `indexterm:[Tigers,Big cats]` (or, using the alternative syntax
 | ||
|     `(((Tigers,Big cats)))`.  Index terms that have secondary and
 | ||
|     tertiary entries also generate separate index terms for the
 | ||
|     secondary and tertiary entries. The index terms appear in the
 | ||
|     index, not the primary text flow.
 | ||
| 
 | ||
| `indexterm2:[<primary>]`::
 | ||
| `((<primary>))`::
 | ||
|     This inline macro generates an index term that appears in both the
 | ||
|     index and the primary text flow.  The `<primary>` should not be
 | ||
|     padded to the left or right with white space characters.
 | ||
| 
 | ||
| For working examples see the `article.txt` and `book.txt` documents in
 | ||
| the AsciiDoc `./doc` distribution directory.
 | ||
| 
 | ||
| NOTE: Index entries only really make sense if you are generating
 | ||
| DocBook markup -- DocBook conversion programs automatically generate
 | ||
| an index at the point an 'Index' section appears in source document.
 | ||
| 
 | ||
| 
 | ||
| [[X105]]
 | ||
| Callouts
 | ||
| --------
 | ||
| Callouts are a mechanism for annotating verbatim text (for example:
 | ||
| source code, computer output and user input). Callout markers are
 | ||
| placed inside the annotated text while the actual annotations are
 | ||
| presented in a callout list after the annotated text. Here's an
 | ||
| example:
 | ||
| 
 | ||
| ---------------------------------------------------------------------
 | ||
|  .MS-DOS directory listing
 | ||
|  -----------------------------------------------------
 | ||
|  10/17/97   9:04         <DIR>    bin
 | ||
|  10/16/97  14:11         <DIR>    DOS            \<1>
 | ||
|  10/16/97  14:40         <DIR>    Program Files
 | ||
|  10/16/97  14:46         <DIR>    TEMP
 | ||
|  10/17/97   9:04         <DIR>    tmp
 | ||
|  10/16/97  14:37         <DIR>    WINNT
 | ||
|  10/16/97  14:25             119  AUTOEXEC.BAT   \<2>
 | ||
|   2/13/94   6:21          54,619  COMMAND.COM    \<2>
 | ||
|  10/16/97  14:25             115  CONFIG.SYS     \<2>
 | ||
|  11/16/97  17:17      61,865,984  pagefile.sys
 | ||
|   2/13/94   6:21           9,349  WINA20.386     \<3>
 | ||
|  -----------------------------------------------------
 | ||
| 
 | ||
|  \<1> This directory holds MS-DOS.
 | ||
|  \<2> System startup code for DOS.
 | ||
|  \<3> Some sort of Windows 3.1 hack.
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| Which renders:
 | ||
| 
 | ||
| .MS-DOS directory listing
 | ||
| -----------------------------------------------------
 | ||
| 10/17/97   9:04         <DIR>    bin
 | ||
| 10/16/97  14:11         <DIR>    DOS            <1>
 | ||
| 10/16/97  14:40         <DIR>    Program Files
 | ||
| 10/16/97  14:46         <DIR>    TEMP
 | ||
| 10/17/97   9:04         <DIR>    tmp
 | ||
| 10/16/97  14:37         <DIR>    WINNT
 | ||
| 10/16/97  14:25             119  AUTOEXEC.BAT   <2>
 | ||
|  2/13/94   6:21          54,619  COMMAND.COM    <2>
 | ||
| 10/16/97  14:25             115  CONFIG.SYS     <2>
 | ||
| 11/16/97  17:17      61,865,984  pagefile.sys
 | ||
|  2/13/94   6:21           9,349  WINA20.386     <3>
 | ||
| -----------------------------------------------------
 | ||
| 
 | ||
| <1> This directory holds MS-DOS.
 | ||
| <2> System startup code for DOS.
 | ||
| <3> Some sort of Windows 3.1 hack.
 | ||
| 
 | ||
| .Explanation
 | ||
| - The callout marks are whole numbers enclosed in angle brackets --
 | ||
|   they refer to the correspondingly numbered item in the following
 | ||
|   callout list.
 | ||
| - By default callout marks are confined to 'LiteralParagraphs',
 | ||
|   'LiteralBlocks' and 'ListingBlocks' (although this is a
 | ||
|   configuration file option and can be changed).
 | ||
| - Callout list item numbering is fairly relaxed -- list items can
 | ||
|   start with `<n>`, `n>` or `>` where `n` is the optional list item
 | ||
|   number (in the latter case list items starting with a single `>`
 | ||
|   character are implicitly numbered starting at one).
 | ||
| - Callout lists should not be nested.
 | ||
| - Callout lists start list items hard against the left margin.
 | ||
| - If you want to present a number inside angle brackets you'll need to
 | ||
|   escape it with a backslash to prevent it being interpreted as a
 | ||
|   callout mark.
 | ||
| 
 | ||
| NOTE: Define the AsciiDoc 'icons' attribute (for example using the `-a
 | ||
| icons` command-line option) to display callout icons.
 | ||
| 
 | ||
| Implementation Notes
 | ||
| ~~~~~~~~~~~~~~~~~~~~
 | ||
| Callout marks are generated by the 'callout' inline macro while
 | ||
| callout lists are generated using the 'callout' list definition. The
 | ||
| 'callout' macro and 'callout' list are special in that they work
 | ||
| together. The 'callout' inline macro is not enabled by the normal
 | ||
| 'macros' substitutions option, instead it has its own 'callouts'
 | ||
| substitution option.
 | ||
| 
 | ||
| The following attributes are available during inline callout macro
 | ||
| substitution:
 | ||
| 
 | ||
| `{index}`::
 | ||
|     The callout list item index inside the angle brackets.
 | ||
| `{coid}`::
 | ||
|     An identifier formatted like `CO<listnumber>-<index>` that
 | ||
|     uniquely identifies the callout mark. For example `CO2-4`
 | ||
|     identifies the fourth callout mark in the second set of callout
 | ||
|     marks.
 | ||
| 
 | ||
| The `{coids}` attribute can be used during callout list item
 | ||
| substitution -- it is a space delimited list of callout IDs that refer
 | ||
| to the explanatory list item.
 | ||
| 
 | ||
| Including callouts in included code
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| You can annotate working code examples with callouts -- just remember
 | ||
| to put the callouts inside source code comments. This example displays
 | ||
| the `test.py` source file (containing a single callout) using the
 | ||
| 'source' (code highlighter) filter:
 | ||
| 
 | ||
| .AsciiDoc source
 | ||
| ---------------------------------------------------------------------
 | ||
|  [source,python]
 | ||
|  -------------------------------------------
 | ||
|  \include::test.py[]
 | ||
|  -------------------------------------------
 | ||
| 
 | ||
|  \<1> Print statement.
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| .Included `test.py` source
 | ||
| ---------------------------------------------------------------------
 | ||
| print 'Hello World!'   # \<1>
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| 
 | ||
| Macros
 | ||
| ------
 | ||
| Macros are a mechanism for substituting parametrized text into output
 | ||
| documents.
 | ||
| 
 | ||
| Macros have a 'name', a single 'target' argument and an 'attribute
 | ||
| list'.  The usual syntax is `<name>:<target>[<attrlist>]` (for
 | ||
| inline macros) and `<name>::<target>[<attrlist>]` (for block
 | ||
| macros).  Here are some examples:
 | ||
| 
 | ||
|   http://www.docbook.org/[DocBook.org]
 | ||
|   include::chapt1.txt[tabsize=2]
 | ||
|   mailto:srackham@gmail.com[]
 | ||
| 
 | ||
| .Macro behavior
 | ||
| - `<name>` is the macro name. It can only contain letters, digits or
 | ||
|   dash characters and cannot start with a dash.
 | ||
| - The optional `<target>` cannot contain white space characters.
 | ||
| - `<attrlist>` is a <<X21,list of attributes>> enclosed in square
 | ||
|   brackets.
 | ||
| - `]` characters inside attribute lists must be escaped with a
 | ||
|   backslash.
 | ||
| - Expansion of macro references can normally be escaped by prefixing a
 | ||
|   backslash character (see the AsciiDoc 'FAQ' for examples of
 | ||
|   exceptions to this rule).
 | ||
| - Attribute references in block macros are expanded.
 | ||
| - The substitutions performed prior to Inline macro macro expansion
 | ||
|   are determined by the inline context.
 | ||
| - Macros are processed in the order they appear in the configuration
 | ||
|   file(s).
 | ||
| - Calls to inline macros can be nested inside different inline macros
 | ||
|   (an inline macro call cannot contain a nested call to itself).
 | ||
| - In addition to `<name>`, `<target>` and `<attrlist>` the
 | ||
|   `<passtext>` and `<subslist>` named groups are available to
 | ||
|   <<X77,passthrough macros>>. A macro is a passthrough macro if the
 | ||
|   definition includes a `<passtext>` named group.
 | ||
| 
 | ||
| Inline Macros
 | ||
| ~~~~~~~~~~~~~
 | ||
| Inline Macros occur in an inline element context. Predefined Inline
 | ||
| macros include 'URLs', 'image' and 'link' macros.
 | ||
| 
 | ||
| URLs
 | ||
| ^^^^
 | ||
| 'http', 'https', 'ftp', 'file', 'mailto' and 'callto' URLs are
 | ||
| rendered using predefined inline macros.
 | ||
| 
 | ||
| - If you don't need a custom link caption you can enter the 'http',
 | ||
|   'https', 'ftp', 'file' URLs and email addresses without any special
 | ||
|   macro syntax.
 | ||
| - If the `<attrlist>` is empty the URL is displayed.
 | ||
| 
 | ||
| Here are some examples:
 | ||
| 
 | ||
|   http://www.docbook.org/[DocBook.org]
 | ||
|   http://www.docbook.org/
 | ||
|   mailto:joe.bloggs@foobar.com[email Joe Bloggs]
 | ||
|   joe.bloggs@foobar.com
 | ||
| 
 | ||
| Which are rendered:
 | ||
| 
 | ||
| http://www.docbook.org/[DocBook.org]
 | ||
| 
 | ||
| http://www.docbook.org/
 | ||
| 
 | ||
| mailto:joe.bloggs@foobar.com[email Joe Bloggs]
 | ||
| 
 | ||
| joe.bloggs@foobar.com
 | ||
| 
 | ||
| If the `<target>` necessitates space characters use `%20`, for example
 | ||
| `large%20image.png`.
 | ||
| 
 | ||
| Internal Cross References
 | ||
| ^^^^^^^^^^^^^^^^^^^^^^^^^
 | ||
| Two AsciiDoc inline macros are provided for creating hypertext links
 | ||
| within an AsciiDoc document. You can use either the standard macro
 | ||
| syntax or the (preferred) alternative.
 | ||
| 
 | ||
| [[X30]]
 | ||
| anchor
 | ||
| ++++++
 | ||
| Used to specify hypertext link targets:
 | ||
| 
 | ||
|   [[<id>,<xreflabel>]]
 | ||
|   anchor:<id>[<xreflabel>]
 | ||
| 
 | ||
| The `<id>` is a unique string that conforms to the output markup's
 | ||
| anchor syntax. The optional `<xreflabel>` is the text to be displayed
 | ||
| by captionless 'xref' macros that refer to this anchor. The optional
 | ||
| `<xreflabel>` is only really useful when generating DocBook output.
 | ||
| Example anchor:
 | ||
| 
 | ||
|   [[X1]]
 | ||
| 
 | ||
| You may have noticed that the syntax of this inline element is the
 | ||
| same as that of the <<X41,BlockId block element>>, this is no
 | ||
| coincidence since they are functionally equivalent.
 | ||
| 
 | ||
| xref
 | ||
| ++++
 | ||
| Creates a hypertext link to a document anchor.
 | ||
| 
 | ||
|   <<<id>,<caption>>>
 | ||
|   xref:<id>[<caption>]
 | ||
| 
 | ||
| The `<id>` refers to an anchor ID. The optional `<caption>` is the
 | ||
| link's displayed text. Example:
 | ||
| 
 | ||
|   <<X21,attribute lists>>
 | ||
| 
 | ||
| If `<caption>` is not specified then the displayed text is
 | ||
| auto-generated:
 | ||
| 
 | ||
| - The AsciiDoc 'xhtml11' and 'html5' backends display the `<id>`
 | ||
|   enclosed in square brackets.
 | ||
| - If DocBook is produced the DocBook toolchain is responsible for the
 | ||
|   displayed text which will normally be the referenced figure, table
 | ||
|   or section title number followed by the element's title text.
 | ||
| 
 | ||
| Here is an example:
 | ||
| 
 | ||
| ---------------------------------------------------------------------
 | ||
| [[tiger_image]]
 | ||
| .Tyger tyger
 | ||
| image::tiger.png[]
 | ||
| 
 | ||
| This can be seen in <<tiger_image>>.
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| Linking to Local Documents
 | ||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^
 | ||
| Hypertext links to files on the local file system are specified using
 | ||
| the 'link' inline macro.
 | ||
| 
 | ||
|   link:<target>[<caption>]
 | ||
| 
 | ||
| The 'link' macro generates relative URLs. The link macro `<target>` is
 | ||
| the target file name (relative to the file system location of the
 | ||
| referring document). The optional `<caption>` is the link's displayed
 | ||
| text. If `<caption>` is not specified then `<target>` is displayed.
 | ||
| Example:
 | ||
| 
 | ||
|   link:downloads/foo.zip[download foo.zip]
 | ||
| 
 | ||
| You can use the `<filename>#<id>` syntax to refer to an anchor within
 | ||
| a target document but this usually only makes sense when targeting
 | ||
| HTML documents.
 | ||
| 
 | ||
| [[X9]]
 | ||
| Images
 | ||
| ^^^^^^
 | ||
| Inline images are inserted into the output document using the 'image'
 | ||
| macro. The inline syntax is:
 | ||
| 
 | ||
|   image:<target>[<attributes>]
 | ||
| 
 | ||
| The contents of the image file `<target>` is displayed. To display the
 | ||
| image its file format must be supported by the target backend
 | ||
| application. HTML and DocBook applications normally support PNG or JPG
 | ||
| files.
 | ||
| 
 | ||
| `<target>` file name paths are relative to the location of the
 | ||
| referring document.
 | ||
| 
 | ||
| [[X55]]
 | ||
| .Image macro attributes
 | ||
| - The optional 'alt' attribute is also the first positional attribute,
 | ||
|   it specifies alternative text which is displayed if the output
 | ||
|   application is unable to display the image file (see also
 | ||
|   http://htmlhelp.com/feature/art3.htm[Use of ALT texts in IMGs]). For
 | ||
|   example:
 | ||
| 
 | ||
|   image:images/logo.png[Company Logo]
 | ||
| 
 | ||
| - The optional 'title' attribute provides a title for the image. The
 | ||
|   <<X49,block image macro>> renders the title alongside the image.
 | ||
|   The inline image macro displays the title as a popup ``tooltip'' in
 | ||
|   visual browsers (AsciiDoc HTML outputs only).
 | ||
| 
 | ||
| - The optional `width` and `height` attributes scale the image size
 | ||
|   and can be used in any combination. The units are pixels.  The
 | ||
|   following example scales the previous example to a height of 32
 | ||
|   pixels:
 | ||
| 
 | ||
|   image:images/logo.png["Company Logo",height=32]
 | ||
| 
 | ||
| - The optional `link` attribute is used to link the image to an
 | ||
|   external document. The following example links a screenshot
 | ||
|   thumbnail to a full size version:
 | ||
| 
 | ||
|   image:screen-thumbnail.png[height=32,link="screen.png"]
 | ||
| 
 | ||
| - The optional `scaledwidth` attribute is only used in DocBook block
 | ||
|   images (specifically for PDF documents). The following example
 | ||
|   scales the images to 75% of the available print width:
 | ||
| 
 | ||
|   image::images/logo.png[scaledwidth="75%",alt="Company Logo"]
 | ||
| 
 | ||
| - The image `scale` attribute sets the DocBook `imagedata` element
 | ||
|   `scale` attribute.
 | ||
| 
 | ||
| - The optional `align` attribute is used for horizontal image
 | ||
|   alignment.  Allowed values are `center`, `left` and `right`. For
 | ||
|   example:
 | ||
| 
 | ||
|   image::images/tiger.png["Tiger image",align="left"]
 | ||
| 
 | ||
| - The optional `float` attribute floats the image `left` or `right` on
 | ||
|   the page (works with HTML outputs only, has no effect on DocBook
 | ||
|   outputs). `float` and `align` attributes are mutually exclusive.
 | ||
|   Use the `unfloat::[]` block macro to stop floating.
 | ||
| 
 | ||
| Comment Lines
 | ||
| ^^^^^^^^^^^^^
 | ||
| See <<X25,comment block macro>>.
 | ||
| 
 | ||
| Block Macros
 | ||
| ~~~~~~~~~~~~
 | ||
| A Block macro reference must be contained in a single line separated
 | ||
| either side by a blank line or a block delimiter.
 | ||
| 
 | ||
| Block macros behave just like Inline macros, with the following
 | ||
| differences:
 | ||
| 
 | ||
| - They occur in a block context.
 | ||
| - The default syntax is `<name>::<target>[<attrlist>]` (two
 | ||
|   colons, not one).
 | ||
| - Markup template section names end in `-blockmacro` instead of
 | ||
|   `-inlinemacro`.
 | ||
| 
 | ||
| Block Identifier
 | ||
| ^^^^^^^^^^^^^^^^
 | ||
| The Block Identifier macro sets the `id` attribute and has the same
 | ||
| syntax as the <<X30,anchor inline macro>> since it performs
 | ||
| essentially the same function -- block templates use the `id`
 | ||
| attribute as a block element ID. For example:
 | ||
| 
 | ||
|   [[X30]]
 | ||
| 
 | ||
| This is equivalent to the `[id="X30"]` <<X79,AttributeList element>>).
 | ||
| 
 | ||
| [[X49]]
 | ||
| Images
 | ||
| ^^^^^^
 | ||
| The 'image' block macro is used to display images in a block context.
 | ||
| The syntax is:
 | ||
| 
 | ||
|   image::<target>[<attributes>]
 | ||
| 
 | ||
| The block `image` macro has the same <<X55,macro attributes>> as it's
 | ||
| <<X9,inline image macro>> counterpart.
 | ||
| 
 | ||
| Block images can be titled by preceding the 'image' macro with a
 | ||
| 'BlockTitle'.  DocBook toolchains normally number titled block images
 | ||
| and optionally list them in an automatically generated 'List of
 | ||
| Figures' backmatter section.
 | ||
| 
 | ||
| This example:
 | ||
| 
 | ||
|   .Main circuit board
 | ||
|   image::images/layout.png[J14P main circuit board]
 | ||
| 
 | ||
| is equivalent to:
 | ||
| 
 | ||
|   image::images/layout.png["J14P main circuit board",
 | ||
|                             title="Main circuit board"]
 | ||
| 
 | ||
| A title prefix that can be inserted with the `caption` attribute
 | ||
| (HTML backends). For example:
 | ||
| 
 | ||
|   .Main circuit board
 | ||
|   [caption="Figure 2: "]
 | ||
|   image::images/layout.png[J14P main circuit board]
 | ||
| 
 | ||
| [[X66]]
 | ||
| .Embedding images in XHTML documents
 | ||
| *********************************************************************
 | ||
| If you define the `data-uri` attribute then images will be embedded in
 | ||
| XHTML outputs using the
 | ||
| http://en.wikipedia.org/wiki/Data:_URI_scheme[data URI scheme].  You
 | ||
| can use the 'data-uri' attribute with the 'xhtml11' and 'html5'
 | ||
| backends to produce single-file XHTML documents with embedded images
 | ||
| and CSS, for example:
 | ||
| 
 | ||
|   $ asciidoc -a data-uri mydocument.txt
 | ||
| 
 | ||
| [NOTE]
 | ||
| ======
 | ||
| - All current popular browsers support data URIs, although versions
 | ||
|   of Internet Explorer prior to version 8 do not.
 | ||
| - Some browsers limit the size of data URIs.
 | ||
| ======
 | ||
| *********************************************************************
 | ||
| 
 | ||
| [[X25]]
 | ||
| Comment Lines
 | ||
| ^^^^^^^^^^^^^
 | ||
| Single lines starting with two forward slashes hard up against the
 | ||
| left margin are treated as comments. Comment lines do not appear in
 | ||
| the output unless the 'showcomments' attribute is defined.  Comment
 | ||
| lines have been implemented as both block and inline macros so a
 | ||
| comment line can appear as a stand-alone block or within block elements
 | ||
| that support inline macro expansion. Example comment line:
 | ||
| 
 | ||
|   // This is a comment.
 | ||
| 
 | ||
| If the 'showcomments' attribute is defined comment lines are written
 | ||
| to the output:
 | ||
| 
 | ||
| - In DocBook the comment lines are enclosed by the 'remark' element
 | ||
|   (which may or may not be rendered by your toolchain).
 | ||
| - The 'showcomments' attribute does not expose <<X26,Comment Blocks>>.
 | ||
|   Comment Blocks are never passed to the output.
 | ||
| 
 | ||
| System Macros
 | ||
| ~~~~~~~~~~~~~
 | ||
| System macros are block macros that perform a predefined task and are
 | ||
| hardwired into the asciidoc(1) program.
 | ||
| 
 | ||
| - You can escape system macros with a leading backslash character
 | ||
|   (as you can with other macros).
 | ||
| - The syntax and tasks performed by system macros is built into
 | ||
|   asciidoc(1) so they don't appear in configuration files.  You can
 | ||
|   however customize the syntax by adding entries to a configuration
 | ||
|   file `[macros]` section.
 | ||
| 
 | ||
| [[X63]]
 | ||
| Include Macros
 | ||
| ^^^^^^^^^^^^^^
 | ||
| The `include` and `include1`  system macros to include the contents of
 | ||
| a named file into the source document.
 | ||
| 
 | ||
| The `include` macro includes a file as if it were part of the parent
 | ||
| document -- tabs are expanded and system macros processed. The
 | ||
| contents of `include1` files are not subject to tab expansion or
 | ||
| system macro processing nor are attribute or lower priority
 | ||
| substitutions performed. The `include1` macro's intended use is to
 | ||
| include verbatim embedded CSS or scripts into configuration file
 | ||
| headers.  Example:
 | ||
| 
 | ||
| ------------------------------------
 | ||
| \include::chapter1.txt[tabsize=4]
 | ||
| ------------------------------------
 | ||
| 
 | ||
| .Include macro behavior
 | ||
| - If the included file name is specified with a relative path then the
 | ||
|   path is relative to the location of the referring document.
 | ||
| - Include macros can appear inside configuration files.
 | ||
| - Files included from within 'DelimitedBlocks' are read to completion
 | ||
|   to avoid false end-of-block underline termination.
 | ||
| - Attribute references are expanded inside the include 'target'; if an
 | ||
|   attribute is undefined then the included file is silently skipped.
 | ||
| - The 'tabsize' macro attribute sets the number of space characters to
 | ||
|   be used for tab expansion in the included file (not applicable to
 | ||
|   `include1` macro).
 | ||
| - The 'depth' macro attribute sets the maximum permitted number of
 | ||
|   subsequent nested includes (not applicable to `include1` macro which
 | ||
|   does not process nested includes). Setting 'depth' to '1' disables
 | ||
|   nesting inside the included file. By default, nesting is limited to
 | ||
|   a depth of ten.
 | ||
| - If the he 'warnings' attribute is set to 'False' (or any other
 | ||
|   Python literal that evaluates to boolean false) then no warning
 | ||
|   message is printed if the included file does not exist. By default
 | ||
|   'warnings' are enabled.
 | ||
| - Internally the `include1` macro is translated to the `include1`
 | ||
|   system attribute which means it must be evaluated in a region where
 | ||
|   attribute substitution is enabled. To inhibit nested substitution in
 | ||
|   included files it is preferable to use the `include` macro and set
 | ||
|   the attribute `depth=1`.
 | ||
| 
 | ||
| Conditional Inclusion Macros
 | ||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
 | ||
| Lines of text in the source document can be selectively included or
 | ||
| excluded from processing based on the existence (or not) of a document
 | ||
| attribute.
 | ||
| 
 | ||
| Document text between the `ifdef` and `endif` macros is included if a
 | ||
| document attribute is defined:
 | ||
| 
 | ||
|   ifdef::<attribute>[]
 | ||
|   :
 | ||
|   endif::<attribute>[]
 | ||
| 
 | ||
| Document text between the `ifndef` and `endif` macros is not included
 | ||
| if a document attribute is defined:
 | ||
| 
 | ||
|   ifndef::<attribute>[]
 | ||
|   :
 | ||
|   endif::<attribute>[]
 | ||
| 
 | ||
| `<attribute>` is an attribute name which is optional in the trailing
 | ||
| `endif` macro.
 | ||
| 
 | ||
| If you only want to process a single line of text then the text can be
 | ||
| put inside the square brackets and the `endif` macro omitted, for
 | ||
| example:
 | ||
| 
 | ||
|   ifdef::revnumber[Version number 42]
 | ||
| 
 | ||
| Is equivalent to:
 | ||
| 
 | ||
|   ifdef::revnumber[]
 | ||
|   Version number 42
 | ||
|   endif::revnumber[]
 | ||
| 
 | ||
| 'ifdef' and 'ifndef' macros also accept multiple attribute names:
 | ||
| 
 | ||
| - Multiple ',' separated attribute names evaluate to defined if one
 | ||
|   or more of the attributes is defined, otherwise it's value is
 | ||
|   undefined.
 | ||
| - Multiple '+' separated attribute names evaluate to defined if all
 | ||
|   of the attributes is defined, otherwise it's value is undefined.
 | ||
| 
 | ||
| Document text between the `ifeval` and `endif` macros is included if
 | ||
| the Python expression inside the square brackets is true. Example:
 | ||
| 
 | ||
|   ifeval::[{rs458}==2]
 | ||
|   :
 | ||
|   endif::[]
 | ||
| 
 | ||
| - Document attribute references are expanded before the expression is
 | ||
|   evaluated.
 | ||
| - If an attribute reference is undefined then the expression is
 | ||
|   considered false.
 | ||
| 
 | ||
| Take a look at the `*.conf` configuration files in the AsciiDoc
 | ||
| distribution for examples of conditional inclusion macro usage.
 | ||
| 
 | ||
| Executable system macros
 | ||
| ^^^^^^^^^^^^^^^^^^^^^^^^
 | ||
| The 'eval', 'sys' and 'sys2' block macros exhibit the same behavior as
 | ||
| their same named <<X24, system attribute references>>. The difference
 | ||
| is that system macros occur in a block macro context whereas system
 | ||
| attributes are confined to inline contexts where attribute
 | ||
| substitution is enabled.
 | ||
| 
 | ||
| The following example displays a long directory listing inside a
 | ||
| literal block:
 | ||
| 
 | ||
|   ------------------
 | ||
|   sys::[ls -l *.txt]
 | ||
|   ------------------
 | ||
| 
 | ||
| NOTE: There are no block macro versions of the 'eval3' and 'sys3'
 | ||
| system attributes.
 | ||
| 
 | ||
| Template System Macro
 | ||
| ^^^^^^^^^^^^^^^^^^^^^
 | ||
| The `template` block macro allows the inclusion of one configuration
 | ||
| file template section within another.  The following example includes
 | ||
| the `[admonitionblock]` section in the `[admonitionparagraph]`
 | ||
| section:
 | ||
| 
 | ||
|   [admonitionparagraph]
 | ||
|   template::[admonitionblock]
 | ||
| 
 | ||
| .Template macro behavior
 | ||
| - The `template::[]` macro is useful for factoring configuration file
 | ||
|   markup.
 | ||
| - `template::[]` macros cannot be nested.
 | ||
| - `template::[]` macro expansion is applied after all configuration
 | ||
|   files have been read.
 | ||
| 
 | ||
| 
 | ||
| [[X77]]
 | ||
| Passthrough macros
 | ||
| ~~~~~~~~~~~~~~~~~~
 | ||
| Passthrough macros are analogous to <<X76,passthrough blocks>> and are
 | ||
| used to pass text directly to the output. The substitution performed
 | ||
| on the text is determined by the macro definition but can be overridden
 | ||
| by the `<subslist>`.  The usual syntax is
 | ||
| `<name>:<subslist>[<passtext>]` (for inline macros) and
 | ||
| `<name>::<subslist>[<passtext>]` (for block macros). Passthroughs, by
 | ||
| definition, take precedence over all other text substitutions.
 | ||
| 
 | ||
| pass::
 | ||
|   Inline and block. Passes text unmodified (apart from explicitly
 | ||
|   specified substitutions). Examples:
 | ||
| 
 | ||
|   pass:[<q>To be or not to be</q>]
 | ||
|   pass:attributes,quotes[<u>the '{author}'</u>]
 | ||
| 
 | ||
| asciimath, latexmath::
 | ||
|   Inline and block. Passes text unmodified.  Used for
 | ||
|   <<X78,mathematical formulas>>.
 | ||
| 
 | ||
| \+++::
 | ||
|   Inline and block. The triple-plus passthrough is functionally
 | ||
|   identical to the 'pass' macro but you don't have to escape `]`
 | ||
|   characters and you can prefix with quoted attributes in the inline
 | ||
|   version. Example:
 | ||
| 
 | ||
|   Red [red]+++`sum_(i=1)\^n i=(n(n+1))/2`$+++ AsciiMathML formula
 | ||
| 
 | ||
| $$::
 | ||
|   Inline and block. The double-dollar passthrough is functionally
 | ||
|   identical to the triple-plus passthrough with one exception: special
 | ||
|   characters are escaped. Example:
 | ||
| 
 | ||
|   $$`[[a,b],[c,d]]((n),(k))`$$
 | ||
| 
 | ||
| [[X80]]`::
 | ||
|   Text quoted with single backtick characters constitutes an 'inline
 | ||
|   literal' passthrough. The enclosed text is rendered in a monospaced
 | ||
|   font and is only subject to special character substitution.  This
 | ||
|   makes sense since monospace text is usually intended to be rendered
 | ||
|   literally and often contains characters that would otherwise have to
 | ||
|   be escaped. If you need monospaced text containing inline
 | ||
|   substitutions use a <<X81,plus character instead of a backtick>>.
 | ||
| 
 | ||
| Macro Definitions
 | ||
| ~~~~~~~~~~~~~~~~~
 | ||
| Each entry in the configuration `[macros]` section is a macro
 | ||
| definition which can take one of the following forms:
 | ||
| 
 | ||
| `<pattern>=<name>[<subslist]`:: Inline macro definition.
 | ||
| `<pattern>=#<name>[<subslist]`:: Block macro definition.
 | ||
| `<pattern>=+<name>[<subslist]`:: System macro definition.
 | ||
| `<pattern>`:: Delete the existing macro with this `<pattern>`.
 | ||
| 
 | ||
| `<pattern>` is a Python regular expression and `<name>` is the name of
 | ||
| a markup template. If `<name>` is omitted then it is the value of the
 | ||
| regular expression match group named 'name'.  The optional
 | ||
| `[<subslist]` is a comma-separated list of substitution names enclosed
 | ||
| in `[]` brackets, it sets the default substitutions for passthrough
 | ||
| text, if omitted then no passthrough substitutions are performed.
 | ||
| 
 | ||
| .Pattern named groups
 | ||
| The following named groups can be used in macro `<pattern>` regular
 | ||
| expressions and are available as markup template attributes:
 | ||
| 
 | ||
| name::
 | ||
|   The macro name.
 | ||
| 
 | ||
| target::
 | ||
|   The macro target.
 | ||
| 
 | ||
| attrlist::
 | ||
|   The macro attribute list.
 | ||
| 
 | ||
| passtext::
 | ||
|   Contents of this group are passed unmodified to the output subject
 | ||
|   only to 'subslist' substitutions.
 | ||
| 
 | ||
| subslist::
 | ||
|   Processed as a comma-separated list of substitution names for
 | ||
|   'passtext' substitution, overrides the the macro definition
 | ||
|   'subslist'.
 | ||
| 
 | ||
| .Here's what happens during macro substitution
 | ||
| - Each contextually relevant macro 'pattern' from the `[macros]`
 | ||
|   section is matched against the input source line.
 | ||
| - If a match is found the text to be substituted is loaded from a
 | ||
|   configuration markup template section named like
 | ||
|   `<name>-inlinemacro` or `<name>-blockmacro` (depending on the macro
 | ||
|   type).
 | ||
| - Global and macro attribute list attributes are substituted in the
 | ||
|   macro's markup template.
 | ||
| - The substituted template replaces the macro reference in the output
 | ||
|   document.
 | ||
| 
 | ||
| 
 | ||
| [[X98]]
 | ||
| HTML 5 audio and video block macros
 | ||
| -----------------------------------
 | ||
| The 'html5' backend 'audio' and 'video' block macros generate the HTML
 | ||
| 5 'audio' and 'video' elements respectively.  They follow the usual
 | ||
| AsciiDoc block macro syntax `<name>::<target>[<attrlist>]` where:
 | ||
| 
 | ||
| [horizontal]
 | ||
| `<name>`:: 'audio' or 'video'.
 | ||
| `<target>`:: The URL or file name of the video or audio file.
 | ||
| `<attrlist>`:: A list of named attributes (see below).
 | ||
| 
 | ||
| .Audio macro attributes
 | ||
| [options="header",cols="1,5",frame="topbot"]
 | ||
| |====================================================================
 | ||
| |Name | Value
 | ||
| |options
 | ||
| |A comma separated list of one or more of the following items:
 | ||
| 'autoplay', 'loop' which correspond to the same-named HTML 5 'audio'
 | ||
| element boolean attributes.  By default the player 'controls' are
 | ||
| enabled, include the 'nocontrols' option value to hide them.
 | ||
| |====================================================================
 | ||
| 
 | ||
| .Video macro attributes
 | ||
| [options="header",cols="1,5",frame="topbot"]
 | ||
| |====================================================================
 | ||
| |Name   | Value
 | ||
| |height | The height of the player in pixels.
 | ||
| |width  | The width of the player in pixels.
 | ||
| |poster | The URL or file name of an image representing the video.
 | ||
| |options
 | ||
| |A comma separated list of one or more of the following items:
 | ||
| 'autoplay', 'loop' and 'nocontrols'. The 'autoplay' and 'loop' options
 | ||
| correspond to the same-named HTML 5 'video' element boolean
 | ||
| attributes.  By default the player 'controls' are enabled, include the
 | ||
| 'nocontrols' option value to hide them.
 | ||
| |====================================================================
 | ||
| 
 | ||
| Examples:
 | ||
| 
 | ||
| ---------------------------------------------------------------------
 | ||
| audio::images/example.ogg[]
 | ||
| 
 | ||
| video::gizmo.ogv[width=200,options="nocontrols,autoplay"]
 | ||
| 
 | ||
| .Example video
 | ||
| video::gizmo.ogv[]
 | ||
| 
 | ||
| video::http://www.808.dk/pics/video/gizmo.ogv[]
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| If your needs are more complex put raw HTML 5 in a markup block, for
 | ||
| example (from http://www.808.dk/?code-html-5-video):
 | ||
| 
 | ||
| ---------------------------------------------------------------------
 | ||
| ++++
 | ||
| <video poster="pics/video/gizmo.jpg" id="video" style="cursor: pointer;" >
 | ||
|   <source src="pics/video/gizmo.mp4" />
 | ||
|   <source src="pics/video/gizmo.webm" type="video/webm" />
 | ||
|   <source src="pics/video/gizmo.ogv" type="video/ogg" />
 | ||
|   Video not playing? <a href="pics/video/gizmo.mp4">Download file</a> instead.
 | ||
| </video>
 | ||
| 
 | ||
| <script type="text/javascript">
 | ||
|   var video = document.getElementById('video');
 | ||
|   video.addEventListener('click',function(){
 | ||
|     video.play();
 | ||
|   },false);
 | ||
| </script>
 | ||
| ++++
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| 
 | ||
| Tables
 | ||
| ------
 | ||
| The AsciiDoc table syntax looks and behaves like other delimited block
 | ||
| types and supports standard <<X73,block configuration entries>>.
 | ||
| Formatting is easy to read and, just as importantly, easy to enter.
 | ||
| 
 | ||
| - Cells and columns can be formatted using built-in customizable styles.
 | ||
| - Horizontal and vertical cell alignment can be set on columns and
 | ||
|   cell.
 | ||
| - Horizontal and vertical cell spanning is supported.
 | ||
| 
 | ||
| .Use tables sparingly
 | ||
| *********************************************************************
 | ||
| When technical users first start creating documents, tables (complete
 | ||
| with column spanning and table nesting) are often considered very
 | ||
| important. The reality is that tables are seldom used, even in
 | ||
| technical documentation.
 | ||
| 
 | ||
| Try this exercise: thumb through your library of technical books,
 | ||
| you'll be surprised just how seldom tables are actually used, even
 | ||
| less seldom are tables containing block elements (such as paragraphs
 | ||
| or lists) or spanned cells. This is no accident, like figures, tables
 | ||
| are outside the normal document flow -- tables are for consulting not
 | ||
| for reading.
 | ||
| 
 | ||
| Tables are designed for, and should normally only be used for,
 | ||
| displaying column oriented tabular data.
 | ||
| *********************************************************************
 | ||
| 
 | ||
| Example tables
 | ||
| ~~~~~~~~~~~~~~
 | ||
| 
 | ||
| .Simple table
 | ||
| [width="15%"]
 | ||
| |=======
 | ||
| |1 |2 |A
 | ||
| |3 |4 |B
 | ||
| |5 |6 |C
 | ||
| |=======
 | ||
| 
 | ||
| .AsciiDoc source
 | ||
| ---------------------------------------------------------------------
 | ||
| [width="15%"]
 | ||
| |=======
 | ||
| |1 |2 |A
 | ||
| |3 |4 |B
 | ||
| |5 |6 |C
 | ||
| |=======
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| .Columns formatted with strong, monospaced and emphasis styles
 | ||
| [width="50%",cols=">s,^m,e",frame="topbot",options="header,footer"]
 | ||
| |==========================
 | ||
| |      2+|Columns 2 and 3
 | ||
| |1       |Item 1  |Item 1
 | ||
| |2       |Item 2  |Item 2
 | ||
| |3       |Item 3  |Item 3
 | ||
| |4       |Item 4  |Item 4
 | ||
| |footer 1|footer 2|footer 3
 | ||
| |==========================
 | ||
| 
 | ||
| .AsciiDoc source
 | ||
| ---------------------------------------------------------------------
 | ||
| .An example table
 | ||
| [width="50%",cols=">s,^m,e",frame="topbot",options="header,footer"]
 | ||
| |==========================
 | ||
| |      2+|Columns 2 and 3
 | ||
| |1       |Item 1  |Item 1
 | ||
| |2       |Item 2  |Item 2
 | ||
| |3       |Item 3  |Item 3
 | ||
| |4       |Item 4  |Item 4
 | ||
| |footer 1|footer 2|footer 3
 | ||
| |==========================
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| .Horizontal and vertical source data
 | ||
| [width="80%",cols="3,^2,^2,10",options="header"]
 | ||
| |=========================================================
 | ||
| |Date |Duration |Avg HR |Notes
 | ||
| 
 | ||
| |22-Aug-08 |10:24 | 157 |
 | ||
| Worked out MSHR (max sustainable heart rate) by going hard
 | ||
| for this interval.
 | ||
| 
 | ||
| |22-Aug-08 |23:03 | 152 |
 | ||
| Back-to-back with previous interval.
 | ||
| 
 | ||
| |24-Aug-08 |40:00 | 145 |
 | ||
| Moderately hard interspersed with 3x 3min intervals (2min
 | ||
| hard + 1min really hard taking the HR up to 160).
 | ||
| 
 | ||
| |=========================================================
 | ||
| 
 | ||
| Short cells can be entered horizontally, longer cells vertically.  The
 | ||
| default behavior is to strip leading and trailing blank lines within a
 | ||
| cell. These characteristics aid readability and data entry.
 | ||
| 
 | ||
| .AsciiDoc source
 | ||
| ---------------------------------------------------------------------
 | ||
| .Windtrainer workouts
 | ||
| [width="80%",cols="3,^2,^2,10",options="header"]
 | ||
| |=========================================================
 | ||
| |Date |Duration |Avg HR |Notes
 | ||
| 
 | ||
| |22-Aug-08 |10:24 | 157 |
 | ||
| Worked out MSHR (max sustainable heart rate) by going hard
 | ||
| for this interval.
 | ||
| 
 | ||
| |22-Aug-08 |23:03 | 152 |
 | ||
| Back-to-back with previous interval.
 | ||
| 
 | ||
| |24-Aug-08 |40:00 | 145 |
 | ||
| Moderately hard interspersed with 3x 3min intervals (2min
 | ||
| hard + 1min really hard taking the HR up to 160).
 | ||
| 
 | ||
| |=========================================================
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| .A table with externally sourced CSV data
 | ||
| [format="csv",cols="^1,4*2",options="header"]
 | ||
| |===================================================
 | ||
| ID,Customer Name,Contact Name,Customer Address,Phone
 | ||
| include::customers.csv[]
 | ||
| |===================================================
 | ||
| 
 | ||
| .AsciiDoc source
 | ||
| ---------------------------------------------------------------------
 | ||
| [format="csv",cols="^1,4*2",options="header"]
 | ||
| |===================================================
 | ||
| ID,Customer Name,Contact Name,Customer Address,Phone
 | ||
| \include::customers.csv[]
 | ||
| |===================================================
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| 
 | ||
| .Cell spans, alignments and styles
 | ||
| [cols="e,m,^,>s",width="25%"]
 | ||
| |============================
 | ||
| |1 >s|2 |3 |4
 | ||
| ^|5 2.2+^.^|6 .3+<.>m|7
 | ||
| ^|8
 | ||
| |9 2+>|10
 | ||
| |============================
 | ||
| 
 | ||
| .AsciiDoc source
 | ||
| ---------------------------------------------------------------------
 | ||
| [cols="e,m,^,>s",width="25%"]
 | ||
| |============================
 | ||
| |1 >s|2 |3 |4
 | ||
| ^|5 2.2+^.^|6 .3+<.>m|7
 | ||
| ^|8
 | ||
| |9 2+>|10
 | ||
| |============================
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| [[X68]]
 | ||
| Table input data formats
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| AsciiDoc table data can be 'psv', 'dsv' or 'csv' formatted.  The
 | ||
| default table format is 'psv'.
 | ||
| 
 | ||
| AsciiDoc 'psv' ('Prefix Separated Values') and 'dsv' ('Delimiter
 | ||
| Separated Values') formats are cell oriented -- the table is treated
 | ||
| as a sequence of cells -- there are no explicit row separators.
 | ||
| 
 | ||
| - 'psv' prefixes each cell with a separator whereas 'dsv' delimits
 | ||
|   cells with a separator.
 | ||
| - 'psv' and 'dsv' separators are Python regular expressions.
 | ||
| - The default 'psv' separator contains <<X84, cell specifier>> related
 | ||
|   named regular expression groups.
 | ||
| - The default 'dsv' separator is `:|\n` (a colon or a new line
 | ||
|   character).
 | ||
| - 'psv' and 'dsv' cell separators can be escaped by preceding them
 | ||
|   with a backslash character.
 | ||
| 
 | ||
| Here are four 'psv' cells (the second item spans two columns; the
 | ||
| last contains an escaped separator):
 | ||
| 
 | ||
|   |One 2+|Two and three |A \| separator character
 | ||
| 
 | ||
| 'csv'  is the quasi-standard row oriented 'Comma Separated Values
 | ||
| (CSV)' format commonly used to import and export spreadsheet and
 | ||
| database data.
 | ||
| 
 | ||
| [[X69]]
 | ||
| Table attributes
 | ||
| ~~~~~~~~~~~~~~~~
 | ||
| Tables can be customized by the following attributes:
 | ||
| 
 | ||
| format::
 | ||
| 'psv' (default), 'dsv' or 'csv' (See <<X68, Table Data Formats>>).
 | ||
| 
 | ||
| separator::
 | ||
| The cell separator. A Python regular expression ('psv' and 'dsv'
 | ||
| formats) or a single character ('csv' format).
 | ||
| 
 | ||
| frame::
 | ||
| Defines the table border and can take the following values: 'topbot'
 | ||
| (top and bottom), 'all' (all sides), 'none' and 'sides' (left and
 | ||
| right sides). The default value is 'all'.
 | ||
| 
 | ||
| grid::
 | ||
| Defines which ruler lines are drawn between table rows and columns.
 | ||
| The 'grid' attribute value can be any of the following values: 'none',
 | ||
| 'cols', 'rows' and 'all'. The default value is 'all'.
 | ||
| 
 | ||
| align::
 | ||
| Use the 'align' attribute to horizontally align the table on the
 | ||
| page (works with HTML outputs only, has no effect on DocBook outputs).
 | ||
| The following values are valid: 'left', 'right', and 'center'.
 | ||
| 
 | ||
| float::
 | ||
| Use the 'float' attribute to float the table 'left' or 'right' on the
 | ||
| page (works with HTML outputs only, has no effect on DocBook outputs).
 | ||
| Floating only makes sense in conjunction with a table 'width'
 | ||
| attribute value of less than 100% (otherwise the table will take up
 | ||
| all the available space).  'float' and 'align' attributes are mutually
 | ||
| exclusive.  Use the `unfloat::[]` block macro to stop floating.
 | ||
| 
 | ||
| halign::
 | ||
| Use the 'halign' attribute to horizontally align all cells in a table.
 | ||
| The following values are valid: 'left', 'right', and 'center'
 | ||
| (defaults to 'left'). Overridden by <<X70,Column specifiers>>  and
 | ||
| <<X84,Cell specifiers>>.
 | ||
| 
 | ||
| valign::
 | ||
| Use the 'valign' attribute to vertically align all cells in a table.
 | ||
| The following values are valid: 'top', 'bottom', and 'middle'
 | ||
| (defaults to 'top'). Overridden by <<X70,Column specifiers>>  and
 | ||
| <<X84,Cell specifiers>>.
 | ||
| 
 | ||
| options::
 | ||
| The 'options' attribute can contain comma separated values, for
 | ||
| example: 'header', 'footer'. By default header and footer rows are
 | ||
| omitted.  See <<X74,attribute options>> for a complete list of
 | ||
| available table options.
 | ||
| 
 | ||
| cols::
 | ||
| The 'cols' attribute is a comma separated list of <<X70,column
 | ||
| specifiers>>. For example `cols="2<p,2*,4p,>"`.
 | ||
| 
 | ||
| - If 'cols' is present it must specify all columns.
 | ||
| - If the 'cols' attribute is not specified the number of columns is
 | ||
|   calculated as the number of data items in the *first line* of the
 | ||
|   table.
 | ||
| - The degenerate form for the 'cols' attribute is an integer
 | ||
|   specifying the number of columns e.g. `cols=4`.
 | ||
| 
 | ||
| width::
 | ||
| The 'width' attribute is expressed as a percentage value
 | ||
| ('"1%"'...'"99%"'). The width specifies the table width relative to
 | ||
| the available width. HTML backends use this value to set the table
 | ||
| width attribute. It's a bit more complicated with DocBook, see the
 | ||
| <<X89,DocBook table widths>> sidebar.
 | ||
| 
 | ||
| filter::
 | ||
| The 'filter' attribute defines an external shell command that is
 | ||
| invoked for each cell. The built-in 'asciidoc' table style is
 | ||
| implemented using a filter.
 | ||
| 
 | ||
| [[X89]]
 | ||
| .DocBook table widths
 | ||
| **********************************************************************
 | ||
| The AsciiDoc docbook backend generates CALS tables. CALS tables do not
 | ||
| support a table width attribute -- table width can only be controlled
 | ||
| by specifying absolute column widths.
 | ||
| 
 | ||
| Specifying absolute column widths is not media independent because
 | ||
| different presentation media have different physical dimensions. To
 | ||
| get round this limitation both
 | ||
| http://www.sagehill.net/docbookxsl/Tables.html#TableWidth[DocBook XSL
 | ||
| Stylesheets] and
 | ||
| http://dblatex.sourceforge.net/doc/manual/ch03s05.html#sec-table-width[dblatex]
 | ||
| have implemented table width processing instructions for setting the
 | ||
| table width as a percentage of the available width. AsciiDoc emits
 | ||
| these processing instructions if the 'width' attribute is set along
 | ||
| with proportional column widths (the AsciiDoc docbook backend
 | ||
| 'pageunits' attribute defaults to '*').
 | ||
| 
 | ||
| To generate DocBook tables with absolute column widths set the
 | ||
| 'pageunits' attribute to a CALS absolute unit such as 'pt' and set the
 | ||
| 'pagewidth' attribute to match the width of the presentation media.
 | ||
| **********************************************************************
 | ||
| 
 | ||
| [[X70]]
 | ||
| Column Specifiers
 | ||
| ~~~~~~~~~~~~~~~~~
 | ||
| Column specifiers define how columns are rendered and appear in the
 | ||
| table <<X69,cols attribute>>.  A column specifier consists of an
 | ||
| optional column multiplier followed by optional alignment, width and
 | ||
| style values and is formatted like:
 | ||
| 
 | ||
|   [<multiplier>*][<align>][<width>][<style>]
 | ||
| 
 | ||
| - All components are optional. The multiplier must be first and the
 | ||
|   style last. The order of `<align>` or `<width>` is not important.
 | ||
| - Column `<width>` can be either an integer proportional value (1...)
 | ||
|   or a percentage (1%...100%). The default value is 1. To ensure
 | ||
|   portability across different backends, there is no provision for
 | ||
|   absolute column widths (not to be confused with output column width
 | ||
|   <<X72,markup attributes>> which are available in both percentage and
 | ||
|   absolute units).
 | ||
| - The '<align>' column alignment specifier is formatted like:
 | ||
| 
 | ||
|   [<horizontal>][.<vertical>]
 | ||
| +
 | ||
| Where `<horizontal>` and `<vertical>` are one of the following
 | ||
| characters: `<`, `^` or `>` which represent 'left', 'center' and
 | ||
| 'right' horizontal alignment or 'top', 'middle' and 'bottom' vertical
 | ||
| alignment respectively.
 | ||
| 
 | ||
| - A `<multiplier>` can be used to specify repeated columns e.g.
 | ||
|   `cols="4*<"` specifies four left-justified columns. The default
 | ||
|   multiplier value is 1.
 | ||
| - The `<style>` name specifies a <<X71,table style>> to used to markup
 | ||
|   column cells (you can use the full style names if you wish but the
 | ||
|   first letter is normally sufficient).
 | ||
| - Column specific styles are not applied to header rows.
 | ||
| 
 | ||
| [[X84]]
 | ||
| Cell Specifiers
 | ||
| ~~~~~~~~~~~~~~~
 | ||
| Cell specifiers allow individual cells in 'psv' formatted tables to be
 | ||
| spanned, multiplied, aligned and styled.  Cell specifiers prefix 'psv'
 | ||
| `|` delimiters and are formatted like:
 | ||
| 
 | ||
|   [<span>*|+][<align>][<style>]
 | ||
| 
 | ||
| - '<span>' specifies horizontal and vertical cell spans ('+' operator) or
 | ||
|   the number of times the cell is replicated ('*' operator). '<span>'
 | ||
|   is formatted like:
 | ||
| 
 | ||
|   [<colspan>][.<rowspan>]
 | ||
| +
 | ||
| Where `<colspan>` and `<rowspan>` are integers specifying the number of
 | ||
| columns and rows to span.
 | ||
| 
 | ||
| - `<align>` specifies horizontal and vertical cell alignment an is the
 | ||
|   same as in <<X70,column specifiers>>.
 | ||
| - A `<style>` value is the first letter of <<X71,table style>> name.
 | ||
| 
 | ||
| For example, the following 'psv' formatted cell will span two columns
 | ||
| and the text will be centered and emphasized:
 | ||
| 
 | ||
|   `2+^e| Cell text`
 | ||
| 
 | ||
| [[X71]]
 | ||
| Table styles
 | ||
| ~~~~~~~~~~~~
 | ||
| Table styles can be applied to the entire table (by setting the
 | ||
| 'style' attribute in the table's attribute list) or on a per column
 | ||
| basis (by specifying the style in the table's <<X69,cols attribute>>).
 | ||
| Table data can be formatted using the following predefined styles:
 | ||
| 
 | ||
| default::
 | ||
| The default style: AsciiDoc inline text formatting; blank lines are
 | ||
| treated as paragraph breaks.
 | ||
| 
 | ||
| emphasis::
 | ||
| Like default but all text is emphasised.
 | ||
| 
 | ||
| monospaced::
 | ||
| Like default but all text is in a monospaced font.
 | ||
| 
 | ||
| strong::
 | ||
| Like default but all text is bold.
 | ||
| 
 | ||
| header::
 | ||
| Apply the same style as the table header. Normally used to create a
 | ||
| vertical header in the first column.
 | ||
| 
 | ||
| asciidoc::
 | ||
| With this style table cells can contain any of the AsciiDoc elements
 | ||
| that are allowed inside document sections. This style runs asciidoc(1)
 | ||
| as a filter to process cell contents. See also <<X83,Docbook table
 | ||
| limitations>>.
 | ||
| 
 | ||
| literal::
 | ||
| No text formatting; monospaced font; all line breaks are retained
 | ||
| (the same as the AsciiDoc <<X65,LiteralBlock>> element).
 | ||
| 
 | ||
| verse::
 | ||
| All line breaks are retained (just like the AsciiDoc <<X94,verse
 | ||
| paragraph style>>).
 | ||
| 
 | ||
| [[X72]]
 | ||
| Markup attributes
 | ||
| ~~~~~~~~~~~~~~~~~
 | ||
| AsciiDoc makes a number of attributes available to table markup
 | ||
| templates and tags. Column specific attributes are available when
 | ||
| substituting the 'colspec' cell data tags.
 | ||
| 
 | ||
| pageunits::
 | ||
| DocBook backend only. Specifies table column absolute width units.
 | ||
| Defaults to '*'.
 | ||
| 
 | ||
| pagewidth::
 | ||
| DocBook backend only. The nominal output page width in 'pageunit'
 | ||
| units. Used to calculate CALS tables absolute column and table
 | ||
| widths. Defaults to '425'.
 | ||
| 
 | ||
| tableabswidth::
 | ||
| Integer value calculated from 'width' and 'pagewidth' attributes.
 | ||
| In 'pageunit' units.
 | ||
| 
 | ||
| tablepcwidth::
 | ||
| Table width expressed as a percentage of the available width. Integer
 | ||
| value (0..100).
 | ||
| 
 | ||
| colabswidth::
 | ||
| Integer value calculated from 'cols' column width, 'width' and
 | ||
| 'pagewidth' attributes.  In 'pageunit' units.
 | ||
| 
 | ||
| colpcwidth::
 | ||
| Column width expressed as a percentage of the table width. Integer
 | ||
| value (0..100).
 | ||
| 
 | ||
| colcount::
 | ||
| Total number of table columns.
 | ||
| 
 | ||
| rowcount::
 | ||
| Total number of table rows.
 | ||
| 
 | ||
| halign::
 | ||
| Horizontal cell content alignment: 'left', 'right' or 'center'.
 | ||
| 
 | ||
| valign::
 | ||
| Vertical cell content alignment: 'top', 'bottom' or 'middle'.
 | ||
| 
 | ||
| colnumber, colstart::
 | ||
| The number of the leftmost column occupied by the cell (1...).
 | ||
| 
 | ||
| colend::
 | ||
| The number of the rightmost column occupied by the cell (1...).
 | ||
| 
 | ||
| colspan::
 | ||
| Number of columns the cell should span.
 | ||
| 
 | ||
| rowspan::
 | ||
| Number of rows the cell should span (1...).
 | ||
| 
 | ||
| morerows::
 | ||
| Number of additional rows the cell should span (0...).
 | ||
| 
 | ||
| Nested tables
 | ||
| ~~~~~~~~~~~~~
 | ||
| An alternative 'psv' separator character '!' can be used (instead of
 | ||
| '|') in nested tables. This allows a single level of table nesting.
 | ||
| Columns containing nested tables must use the 'asciidoc' style. An
 | ||
| example can be found in `./examples/website/newtables.txt`.
 | ||
| 
 | ||
| [[X83]]
 | ||
| DocBook table limitations
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| Fully implementing tables is not trivial, some DocBook toolchains do
 | ||
| better than others.  AsciiDoc HTML table outputs are rendered
 | ||
| correctly in all the popular browsers -- if your DocBook generated
 | ||
| tables don't look right compare them with the output generated by the
 | ||
| AsciiDoc 'xhtml11' backend or try a different DocBook toolchain.  Here
 | ||
| is a list of things to be aware of:
 | ||
| 
 | ||
| - Although nested tables are not legal in DocBook 4 the FOP and
 | ||
|   dblatex toolchains will process them correctly.  If you use `a2x(1)`
 | ||
|   you will need to include the `--no-xmllint` option to suppress
 | ||
|   DocBook validation errors.
 | ||
| +
 | ||
| NOTE: In theory you can nest DocBook 4 tables one level using the
 | ||
| 'entrytbl' element, but not all toolchains process 'entrytbl'.
 | ||
| 
 | ||
| - DocBook only allows a subset of block elements inside table cells so
 | ||
|   not all AsciiDoc elements produce valid DocBook inside table cells.
 | ||
|   If you get validation errors running `a2x(1)` try the `--no-xmllint`
 | ||
|   option, toolchains will often process nested block elements such as
 | ||
|   sidebar blocks and floating titles correctly even though, strictly
 | ||
|   speaking, they are not legal.
 | ||
| 
 | ||
| - Text formatting in cells using the 'monospaced' table style will
 | ||
|   raise validation errors because the DocBook 'literal' element was
 | ||
|   not designed to support formatted text (using the 'literal' element
 | ||
|   is a kludge on the part of AsciiDoc as there is no easy way to set
 | ||
|   the font style in DocBook.
 | ||
| 
 | ||
| - Cell alignments are ignored for 'verse', 'literal' or 'asciidoc'
 | ||
|   table styles.
 | ||
| 
 | ||
| 
 | ||
| [[X1]]
 | ||
| Manpage Documents
 | ||
| -----------------
 | ||
| Sooner or later, if you program in a UNIX environment, you're going
 | ||
| to have to write a man page.
 | ||
| 
 | ||
| By observing a couple of additional conventions (detailed below) you
 | ||
| can write AsciiDoc files that will generate HTML and PDF man pages
 | ||
| plus the native manpage roff format.  The easiest way to generate roff
 | ||
| manpages from AsciiDoc source is to use the a2x(1) command. The
 | ||
| following example generates a roff formatted manpage file called
 | ||
| `asciidoc.1` (a2x(1) uses asciidoc(1) to convert `asciidoc.1.txt` to
 | ||
| DocBook which it then converts to roff using DocBook XSL Stylesheets):
 | ||
| 
 | ||
|   a2x --doctype manpage --format manpage asciidoc.1.txt
 | ||
| 
 | ||
| .Viewing and printing manpage files
 | ||
| **********************************************************************
 | ||
| Use the `man(1)` command to view the manpage file:
 | ||
| 
 | ||
|   $ man -l asciidoc.1
 | ||
| 
 | ||
| To print a high quality man page to a postscript printer:
 | ||
| 
 | ||
|   $ man -l -Tps asciidoc.1 | lpr
 | ||
| 
 | ||
| You could also create a PDF version of the man page by converting
 | ||
| PostScript to PDF using `ps2pdf(1)`:
 | ||
| 
 | ||
|   $ man -l -Tps asciidoc.1 | ps2pdf - asciidoc.1.pdf
 | ||
| 
 | ||
| The `ps2pdf(1)` command is included in the Ghostscript distribution.
 | ||
| **********************************************************************
 | ||
| 
 | ||
| To find out more about man pages view the `man(7)` manpage
 | ||
| (`man 7 man` and `man man-pages` commands).
 | ||
| 
 | ||
| 
 | ||
| Document Header
 | ||
| ~~~~~~~~~~~~~~~
 | ||
| A manpage document Header is mandatory. The title line contains the
 | ||
| man page name followed immediately by the manual section number in
 | ||
| brackets, for example 'ASCIIDOC(1)'. The title name should not contain
 | ||
| white space and the manual section number is a single digit optionally
 | ||
| followed by a single character.
 | ||
| 
 | ||
| The NAME Section
 | ||
| ~~~~~~~~~~~~~~~~
 | ||
| The first manpage section is mandatory, must be titled 'NAME' and must
 | ||
| contain a single paragraph (usually a single line) consisting of a
 | ||
| list of one or more comma separated command name(s) separated from the
 | ||
| command purpose by a dash character. The dash must have at least one
 | ||
| white space character on either side. For example:
 | ||
| 
 | ||
|   printf, fprintf, sprintf - print formatted output
 | ||
| 
 | ||
| The SYNOPSIS Section
 | ||
| ~~~~~~~~~~~~~~~~~~~~
 | ||
| The second manpage section is mandatory and must be titled 'SYNOPSIS'.
 | ||
| 
 | ||
| refmiscinfo attributes
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~
 | ||
| In addition to the automatically created man page <<X60,intrinsic
 | ||
| attributes>> you can assign DocBook
 | ||
| http://www.docbook.org/tdg5/en/html/refmiscinfo.html[refmiscinfo]
 | ||
| element 'source', 'version' and 'manual' values using AsciiDoc
 | ||
| `{mansource}`, `{manversion}` and `{manmanual}` attributes
 | ||
| respectively. This example is from the AsciiDoc header of a man page
 | ||
| source file:
 | ||
| 
 | ||
|   :man source:   AsciiDoc
 | ||
|   :man version:  {revnumber}
 | ||
|   :man manual:   AsciiDoc Manual
 | ||
| 
 | ||
| 
 | ||
| [[X78]]
 | ||
| Mathematical Formulas
 | ||
| ---------------------
 | ||
| The 'asciimath' and 'latexmath' <<X77,passthrough macros>> along with
 | ||
| 'asciimath' and 'latexmath'  <<X76,passthrough blocks>> provide a
 | ||
| (backend dependent) mechanism for rendering mathematical formulas. You
 | ||
| can use the following math markups:
 | ||
| 
 | ||
| NOTE: The 'latexmath' macro used to include 'LaTeX Math' in DocBook
 | ||
| outputs is not the same as the 'latexmath' macro used to include
 | ||
| 'LaTeX MathML' in XHTML outputs.  'LaTeX Math' applies to DocBook
 | ||
| outputs that are processed by <<X31,dblatex>> and is normally used to
 | ||
| generate PDF files.  'LaTeXMathML' is very much a subset of 'LaTeX
 | ||
| Math' and applies to XHTML documents.
 | ||
| 
 | ||
| LaTeX Math
 | ||
| ~~~~~~~~~~
 | ||
| ftp://ftp.ams.org/pub/tex/doc/amsmath/short-math-guide.pdf[LaTeX
 | ||
| math] can be included in documents that are processed by
 | ||
| <<X31,dblatex(1)>>.  Example inline formula:
 | ||
| 
 | ||
|   latexmath:[$C = \alpha + \beta Y^{\gamma} + \epsilon$]
 | ||
| 
 | ||
| For more examples see the {website}[AsciiDoc website] or the
 | ||
| distributed `doc/latexmath.txt` file.
 | ||
| 
 | ||
| ASCIIMathML
 | ||
| ~~~~~~~~~~~
 | ||
| /////////////////////////////////////////////////////////////////////
 | ||
| The older ASCIIMathML 1.47 version is used instead of version 2
 | ||
| because:
 | ||
| 
 | ||
| 1. Version 2 doesn't work when embedded.
 | ||
| 2. Version 2 is much larger.
 | ||
| /////////////////////////////////////////////////////////////////////
 | ||
| 
 | ||
| http://www1.chapman.edu/~jipsen/mathml/asciimath.html[ASCIIMathML]
 | ||
| formulas can be included in XHTML documents generated using the
 | ||
| 'xhtml11' and 'html5' backends. To enable ASCIIMathML support you must
 | ||
| define the 'asciimath' attribute, for example using the `-a asciimath`
 | ||
| command-line option.  Example inline formula:
 | ||
| 
 | ||
|   asciimath:[`x/x={(1,if x!=0),(text{undefined},if x=0):}`]
 | ||
| 
 | ||
| For more examples see the {website}[AsciiDoc website] or the
 | ||
| distributed `doc/asciimathml.txt` file.
 | ||
| 
 | ||
| LaTeXMathML
 | ||
| ~~~~~~~~~~~
 | ||
| /////////////////////////////////////////////////////////////////////
 | ||
| There is an http://math.etsu.edu/LaTeXMathML/[extended LaTeXMathML
 | ||
| version] by Jeff Knisley, in addition to a JavaScript file it requires
 | ||
| the inclusion of a CSS file.
 | ||
| /////////////////////////////////////////////////////////////////////
 | ||
| 
 | ||
| 'LaTeXMathML' allows LaTeX Math style formulas to be included in XHTML
 | ||
| documents generated using the AsciiDoc 'xhtml11' and 'html5' backends.
 | ||
| AsciiDoc uses the
 | ||
| http://www.maths.nottingham.ac.uk/personal/drw/lm.html[original
 | ||
| LaTeXMathML] by Douglas Woodall.  'LaTeXMathML' is derived from
 | ||
| ASCIIMathML and is for users who are more familiar with or prefer
 | ||
| using LaTeX math formulas (it recognizes a subset of LaTeX Math, the
 | ||
| differences are documented on the 'LaTeXMathML' web page).  To enable
 | ||
| LaTeXMathML support you must define the 'latexmath' attribute, for
 | ||
| example using the `-a latexmath` command-line option.  Example inline
 | ||
| formula:
 | ||
| 
 | ||
|   latexmath:[$\sum_{n=1}^\infty \frac{1}{2^n}$]
 | ||
| 
 | ||
| For more examples see the {website}[AsciiDoc website] or the
 | ||
| distributed `doc/latexmathml.txt` file.
 | ||
| 
 | ||
| MathML
 | ||
| ~~~~~~
 | ||
| http://www.w3.org/Math/[MathML] is a low level XML markup for
 | ||
| mathematics. AsciiDoc has no macros for MathML but users familiar with
 | ||
| this markup could use passthrough macros and passthrough blocks to
 | ||
| include MathML in output documents.
 | ||
| 
 | ||
| 
 | ||
| [[X7]]
 | ||
| Configuration Files
 | ||
| -------------------
 | ||
| AsciiDoc source file syntax and output file markup is largely
 | ||
| controlled by a set of cascading, text based, configuration files.  At
 | ||
| runtime The AsciiDoc default configuration files are combined with
 | ||
| optional user and document specific configuration files.
 | ||
| 
 | ||
| Configuration File Format
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| Configuration files contain named sections. Each section begins with a
 | ||
| section name in square brackets []. The section body consists of the
 | ||
| lines of text between adjacent section headings.
 | ||
| 
 | ||
| - Section names consist of one or more alphanumeric, underscore or
 | ||
|   dash characters and cannot begin or end with a dash.
 | ||
| - Lines starting with a '#' character are treated as comments and
 | ||
|   ignored.
 | ||
| - If the section name is prefixed with a '+' character then the
 | ||
|   section contents is appended to the contents of an already existing
 | ||
|   same-named section.
 | ||
| - Otherwise same-named sections and section entries override
 | ||
|   previously loaded sections and section entries (this is sometimes
 | ||
|   referred to as 'cascading').  Consequently, downstream configuration
 | ||
|   files need only contain those sections and section entries that need
 | ||
|   to be overridden.
 | ||
| 
 | ||
| TIP: When creating custom configuration files you only need to include
 | ||
| the sections and entries that differ from the default configuration.
 | ||
| 
 | ||
| TIP: The best way to learn about configuration files is to read the
 | ||
| default configuration files in the AsciiDoc distribution in
 | ||
| conjunction with asciidoc(1) output files. You can view configuration
 | ||
| file load sequence by turning on the asciidoc(1) `-v` (`--verbose`)
 | ||
| command-line option.
 | ||
| 
 | ||
| AsciiDoc reserves the following section names for specific purposes:
 | ||
| 
 | ||
| miscellaneous::
 | ||
|         Configuration options that don't belong anywhere else.
 | ||
| attributes::
 | ||
|         Attribute name/value entries.
 | ||
| specialcharacters::
 | ||
|         Special characters reserved by the backend markup.
 | ||
| tags::
 | ||
|         Backend markup tags.
 | ||
| quotes::
 | ||
|         Definitions for quoted inline character formatting.
 | ||
| specialwords::
 | ||
|         Lists of words and phrases singled out for special markup.
 | ||
| replacements, replacements2, replacements3::
 | ||
|         Find and replace substitution definitions.
 | ||
| specialsections::
 | ||
|         Used to single out special section names for specific markup.
 | ||
| macros::
 | ||
|         Macro syntax definitions.
 | ||
| titles::
 | ||
|         Heading, section and block title definitions.
 | ||
| paradef-*::
 | ||
|         Paragraph element definitions.
 | ||
| blockdef-*::
 | ||
|         DelimitedBlock element definitions.
 | ||
| listdef-*::
 | ||
|         List element definitions.
 | ||
| listtags-*::
 | ||
|         List element tag definitions.
 | ||
| tabledef-*::
 | ||
|         Table element definitions.
 | ||
| tabletags-*::
 | ||
|         Table element tag definitions.
 | ||
| 
 | ||
| Each line of text in these sections is a 'section entry'. Section
 | ||
| entries share the following syntax:
 | ||
| 
 | ||
| name=value::
 | ||
|         The entry value is set to value.
 | ||
| name=::
 | ||
|         The entry value is set to a zero length string.
 | ||
| name!::
 | ||
|         The entry is undefined (deleted from the configuration). This
 | ||
|         syntax only applies to 'attributes' and 'miscellaneous'
 | ||
|         sections.
 | ||
| 
 | ||
| .Section entry behavior
 | ||
| - All equals characters inside the `name` must be escaped with a
 | ||
|   backslash character.
 | ||
| - `name` and `value` are stripped of leading and trailing white space.
 | ||
| - Attribute names, tag entry names and markup template section names
 | ||
|   consist of one or more alphanumeric, underscore or dash characters.
 | ||
|   Names should not begin or end with a dash.
 | ||
| - A blank configuration file section (one without any entries) deletes
 | ||
|   any preceding section with the same name (applies to non-markup
 | ||
|   template sections).
 | ||
| 
 | ||
| 
 | ||
| Miscellaneous section
 | ||
| ~~~~~~~~~~~~~~~~~~~~~
 | ||
| The optional `[miscellaneous]` section specifies the following
 | ||
| `name=value` options:
 | ||
| 
 | ||
| newline::
 | ||
|         Output file line termination characters. Can include any
 | ||
|         valid Python string escape sequences. The default value is
 | ||
|         `\r\n` (carriage return, line feed). Should not be quoted or
 | ||
|         contain explicit spaces (use `\x20` instead). For example:
 | ||
| 
 | ||
|         $ asciidoc -a 'newline=\n' -b docbook mydoc.txt
 | ||
| 
 | ||
| outfilesuffix::
 | ||
|         The default extension for the output file, for example
 | ||
|         `outfilesuffix=.html`. Defaults to backend name.
 | ||
| tabsize::
 | ||
|         The number of spaces to expand tab characters, for example
 | ||
|         `tabsize=4`. Defaults to 8. A 'tabsize' of zero suppresses tab
 | ||
|         expansion (useful when piping included files through block
 | ||
|         filters). Included files can override this option using the
 | ||
|         'tabsize' attribute.
 | ||
| pagewidth, pageunits::
 | ||
|         These global table related options are documented in the
 | ||
|         <<X4,Table Configuration File Definitions>> sub-section.
 | ||
| 
 | ||
| NOTE: `[miscellaneous]` configuration file entries can be set using
 | ||
| the asciidoc(1) `-a` (`--attribute`) command-line option.
 | ||
| 
 | ||
| Titles section
 | ||
| ~~~~~~~~~~~~~~
 | ||
| sectiontitle::
 | ||
|         Two line section title pattern. The entry value is a Python
 | ||
|         regular expression containing the named group 'title'.
 | ||
| 
 | ||
| underlines::
 | ||
|         A comma separated list of document and section title underline
 | ||
|         character pairs starting with the section level 0 and ending
 | ||
|         with section level 4 underline. The default setting is:
 | ||
| 
 | ||
|         underlines="==","--","~~","^^","++"
 | ||
| 
 | ||
| sect0...sect4::
 | ||
|         One line section title patterns. The entry value is a Python
 | ||
|         regular expression containing the named group 'title'.
 | ||
| 
 | ||
| blocktitle::
 | ||
|         <<X42,BlockTitle element>> pattern.  The entry value is a
 | ||
|         Python regular expression containing the named group 'title'.
 | ||
| 
 | ||
| subs::
 | ||
|         A comma separated list of substitutions that are performed on
 | ||
|         the document header and section titles. Defaults to 'normal'
 | ||
|         substitution.
 | ||
| 
 | ||
| Tags section
 | ||
| ~~~~~~~~~~~~
 | ||
| The `[tags]` section contains backend tag definitions (one per
 | ||
| line). Tags are used to translate AsciiDoc elements to backend
 | ||
| markup.
 | ||
| 
 | ||
| An AsciiDoc tag definition is formatted like
 | ||
| `<tagname>=<starttag>|<endtag>`. For example:
 | ||
| 
 | ||
|   emphasis=<em>|</em>
 | ||
| 
 | ||
| In this example asciidoc(1) replaces the | character with the
 | ||
| emphasized text from the AsciiDoc input file and writes the result to
 | ||
| the output file.
 | ||
| 
 | ||
| Use the `{brvbar}` attribute reference if you need to include a | pipe
 | ||
| character inside tag text.
 | ||
| 
 | ||
| Attributes section
 | ||
| ~~~~~~~~~~~~~~~~~~
 | ||
| The optional `[attributes]` section contains predefined attributes.
 | ||
| 
 | ||
| If the attribute value requires leading or trailing spaces then the
 | ||
| text text should be enclosed in quotation mark (") characters.
 | ||
| 
 | ||
| To delete a attribute insert a `name!` entry in a downstream
 | ||
| configuration file or use the asciidoc(1) `--attribute name!`
 | ||
| command-line option (an attribute name suffixed with a `!` character
 | ||
| deletes the attribute)
 | ||
| 
 | ||
| Special Characters section
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| The `[specialcharacters]` section specifies how to escape characters
 | ||
| reserved by the backend markup. Each translation is specified on a
 | ||
| single line formatted like:
 | ||
| 
 | ||
|   <special_character>=<translated_characters>
 | ||
| 
 | ||
| Special characters are normally confined to those that resolve
 | ||
| markup ambiguity (in the case of HTML and XML markups the ampersand,
 | ||
| less than and greater than characters).  The following example causes
 | ||
| all occurrences of the `<` character to be replaced by `<`.
 | ||
| 
 | ||
|   <=<
 | ||
| 
 | ||
| Quoted Text section
 | ||
| ~~~~~~~~~~~~~~~~~~~
 | ||
| Quoting is used primarily for text formatting.  The `[quotes]` section
 | ||
| defines AsciiDoc quoting characters and their corresponding backend
 | ||
| markup tags.  Each section entry value is the name of a of a `[tags]`
 | ||
| section entry. The entry name is the character (or characters) that
 | ||
| quote the text.  The following examples are taken from AsciiDoc
 | ||
| configuration files:
 | ||
| 
 | ||
|   [quotes]
 | ||
|   _=emphasis
 | ||
| 
 | ||
|   [tags]
 | ||
|   emphasis=<em>|</em>
 | ||
| 
 | ||
| You can specify the left and right quote strings separately by
 | ||
| separating them with a | character, for example:
 | ||
| 
 | ||
|   ``|''=quoted
 | ||
| 
 | ||
| Omitting the tag will disable quoting, for example, if you don't want
 | ||
| superscripts or subscripts put the following in a custom configuration
 | ||
| file or edit the global `asciidoc.conf` configuration file:
 | ||
| 
 | ||
|   [quotes]
 | ||
|   ^=
 | ||
|   ~=
 | ||
| 
 | ||
| <<X52,Unconstrained quotes>> are differentiated from constrained
 | ||
| quotes by prefixing the tag name with a hash character, for example:
 | ||
| 
 | ||
|   __=#emphasis
 | ||
| 
 | ||
| .Quoted text behavior
 | ||
| - Quote characters must be non-alphanumeric.
 | ||
| - To minimize quoting ambiguity try not to use the same quote
 | ||
|   characters in different quote types.
 | ||
| 
 | ||
| Special Words section
 | ||
| ~~~~~~~~~~~~~~~~~~~~~
 | ||
| The `[specialwords]` section is used to single out words and phrases
 | ||
| that you want to consistently format in some way throughout your
 | ||
| document without having to repeatedly specify the markup. The name of
 | ||
| each entry corresponds to a markup template section and the entry
 | ||
| value consists of a list of words and phrases to be marked up. For
 | ||
| example:
 | ||
| 
 | ||
|   [specialwords]
 | ||
|   strongwords=NOTE IMPORTANT
 | ||
| 
 | ||
|   [strongwords]
 | ||
|   <strong>{words}</strong>
 | ||
| 
 | ||
| The examples specifies that any occurrence of `NOTE` or `IMPORTANT`
 | ||
| should appear in a bold font.
 | ||
| 
 | ||
| Words and word phrases are treated as Python regular expressions: for
 | ||
| example, the word `^NOTE` would only match `NOTE` if appeared at
 | ||
| the start of a line.
 | ||
| 
 | ||
| AsciiDoc comes with three built-in Special Word types:
 | ||
| 'emphasizedwords', 'monospacedwords' and 'strongwords', each has a
 | ||
| corresponding (backend specific) markup template section. Edit the
 | ||
| configuration files to customize existing Special Words and to add new
 | ||
| ones.
 | ||
| 
 | ||
| .Special word behavior
 | ||
| - Word list entries must be separated by space characters.
 | ||
| - Word list entries with embedded spaces should be enclosed in quotation (")
 | ||
|   characters.
 | ||
| - A `[specialwords]` section entry of the form
 | ||
|   +name=word1{nbsp}[word2...]+ adds words to existing `name` entries.
 | ||
| - A `[specialwords]` section entry of the form `name` undefines
 | ||
|   (deletes) all existing `name` words.
 | ||
| - Since word list entries are processed as Python regular expressions
 | ||
|   you need to be careful to escape regular expression special
 | ||
|   characters.
 | ||
| - By default Special Words are substituted before Inline Macros, this
 | ||
|   may lead to undesirable consequences. For example the special word
 | ||
|   `foobar` would be expanded inside the macro call
 | ||
|   `http://www.foobar.com[]`.  A possible solution is to emphasize
 | ||
|   whole words only by defining the word using regular expression
 | ||
|   characters, for example `\bfoobar\b`.
 | ||
| - If the first matched character of a special word is a backslash then
 | ||
|   the remaining characters are output without markup i.e. the
 | ||
|   backslash can be used to escape special word markup.  For example
 | ||
|   the special word `\\?\b[Tt]en\b` will mark up the words `Ten` and
 | ||
|   `ten` only if they are not preceded by a backslash.
 | ||
| 
 | ||
| [[X10]]
 | ||
| Replacements section
 | ||
| ~~~~~~~~~~~~~~~~~~~~
 | ||
| `[replacements]`, `[replacements2]` and `[replacements3]`
 | ||
| configuration file entries specify find and replace text and are
 | ||
| formatted like:
 | ||
| 
 | ||
|   <find_pattern>=<replacement_text>
 | ||
| 
 | ||
| The find text can be a Python regular expression; the replace text can
 | ||
| contain Python regular expression group references.
 | ||
| 
 | ||
| Use Replacement shortcuts for often used macro references, for
 | ||
| example (the second replacement allows us to backslash escape the
 | ||
| macro name):
 | ||
| 
 | ||
|   NEW!=image:./images/smallnew.png[New!]
 | ||
|   \\NEW!=NEW!
 | ||
| 
 | ||
| The only difference between the three replacement types is how they
 | ||
| are applied. By default 'replacements' and 'replacement2' are applied
 | ||
| in <<X102,normal>> substitution contexts whereas 'replacements3' needs
 | ||
| to be configured explicitly and should only be used in backend
 | ||
| configuration files.
 | ||
| 
 | ||
| .Replacement behavior
 | ||
| - The built-in replacements can be escaped with a backslash.
 | ||
| - If the find or replace text has leading or trailing spaces then the
 | ||
|   text should be enclosed in quotation (") characters.
 | ||
| - Since the find text is processed as a regular expression you need to
 | ||
|   be careful to escape regular expression special characters.
 | ||
| - Replacements are performed in the same order they appear in the
 | ||
|   configuration file replacements section.
 | ||
| 
 | ||
| Markup Template Sections
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| Markup template sections supply backend markup for translating
 | ||
| AsciiDoc elements.  Since the text is normally backend dependent
 | ||
| you'll find these sections in the backend specific configuration
 | ||
| files. Template sections differ from other sections in that they
 | ||
| contain a single block of text instead of per line 'name=value'
 | ||
| entries. A markup template section body can contain:
 | ||
| 
 | ||
| - Attribute references
 | ||
| - System macro calls.
 | ||
| - A document content placeholder
 | ||
| 
 | ||
| The document content placeholder is a single | character and is
 | ||
| replaced by text from the source element.  Use the `{brvbar}`
 | ||
| attribute reference if you need a literal | character in the template.
 | ||
| 
 | ||
| [[X27]]
 | ||
| Configuration file names, precedence and locations
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| Configuration files have a `.conf` file name extension; they are
 | ||
| loaded from the following locations:
 | ||
| 
 | ||
| 1. The directory containing the asciidoc executable.
 | ||
| 2. If there is no `asciidoc.conf` file in the directory containing the
 | ||
|    asciidoc executable then load from the global configuration
 | ||
|    directory (normally `/etc/asciidoc` or `/usr/local/etc/asciidoc`)
 | ||
|    i.e. the global configuration files directory is skipped if
 | ||
|    AsciiDoc configuration files are installed in the same directory as
 | ||
|    the asciidoc executable. This allows both a system wide copy and
 | ||
|    multiple local copies of AsciiDoc to coexist on the same host PC.
 | ||
| 3. The user's `$HOME/.asciidoc` directory (if it exists).
 | ||
| 4. The directory containing the AsciiDoc source file.
 | ||
| 5. Explicit configuration files specified using:
 | ||
|    - The `conf-files` attribute (one or more file names separated by a
 | ||
|      `|` character). These files are loaded in the order they are
 | ||
|      specified and prior to files specified using the `--conf-file`
 | ||
|      command-line option.
 | ||
|    - The asciidoc(1) `--conf-file`) command-line option.  The
 | ||
|      `--conf-file` option can be specified multiple times, in which
 | ||
|      case configuration files will be processed in the same order they
 | ||
|      appear on the command-line.
 | ||
| 6. <<X100,Backend plugin>> configuration files are loaded from
 | ||
|    subdirectories named like `backends/<backend>` in locations 1, 2
 | ||
|    and 3.
 | ||
| 7. <<X59,Filter>> configuration files are loaded from subdirectories
 | ||
|    named like `filters/<filter>` in locations 1, 2 and 3.
 | ||
| 
 | ||
| Configuration files from the above locations are loaded in the
 | ||
| following order:
 | ||
| 
 | ||
| - The `[attributes]` section only from:
 | ||
|   * `asciidoc.conf` in location 3
 | ||
|   * Files from location 5.
 | ||
| +
 | ||
| This first pass makes locally set attributes available in the global
 | ||
| `asciidoc.conf` file.
 | ||
| 
 | ||
| - `asciidoc.conf` from locations 1, 2, 3.
 | ||
| - 'attributes', 'titles' and 'specialcharacters' sections from the
 | ||
|   `asciidoc.conf` in location 4.
 | ||
| - The document header is parsed at this point and we can assume the
 | ||
|   'backend' and 'doctype' have now been defined.
 | ||
| - Backend plugin `<backend>.conf` and `<backend>-<doctype>.conf` files
 | ||
|   from locations 6.  If a backend plugin is not found then try
 | ||
|   locations 1, 2 and 3 for `<backend>.conf` and
 | ||
|   `<backend>-<doctype>.conf` backend configuration files.
 | ||
| - Filter conf files from locations 7.
 | ||
| - `lang-<lang>.conf` from locations 1, 2, 3.
 | ||
| - `asciidoc.conf` from location 4.
 | ||
| - `<backend>.conf` and `<backend>-<doctype>.conf` from location 4.
 | ||
| - Filter conf files from location 4.
 | ||
| - `<docfile>.conf` and `<docfile>-<backend>.conf` from location 4.
 | ||
| - Configuration files from location 5.
 | ||
| 
 | ||
| Where:
 | ||
| 
 | ||
| - `<backend>` and `<doctype>` are values specified by the asciidoc(1)
 | ||
|   `-b` (`--backend`) and `-d` (`--doctype`) command-line options.
 | ||
| - `<infile>` is the path name of the AsciiDoc input file without the
 | ||
|   file name extension.
 | ||
| - `<lang>` is a two letter country code set by the the AsciiDoc 'lang'
 | ||
|   attribute.
 | ||
| 
 | ||
| [NOTE]
 | ||
| =====================================================================
 | ||
| The backend and language global configuration files are loaded *after*
 | ||
| the header has been parsed.  This means that you can set most
 | ||
| attributes in the document header. Here's an example header:
 | ||
| 
 | ||
|   Life's Mysteries
 | ||
|   ================
 | ||
|   :author: Hu Nose
 | ||
|   :doctype: book
 | ||
|   :toc:
 | ||
|   :icons:
 | ||
|   :data-uri:
 | ||
|   :lang: en
 | ||
|   :encoding: iso-8859-1
 | ||
| 
 | ||
| Attributes set in the document header take precedence over
 | ||
| configuration file attributes.
 | ||
| 
 | ||
| =====================================================================
 | ||
| 
 | ||
| TIP: Use the asciidoc(1) `-v` (`--verbose`) command-line option to see
 | ||
| which configuration files are loaded and the order in which they are
 | ||
| loaded.
 | ||
| 
 | ||
| 
 | ||
| Document Attributes
 | ||
| -------------------
 | ||
| A document attribute is comprised of a 'name' and a textual 'value'
 | ||
| and is used for textual substitution in AsciiDoc documents and
 | ||
| configuration files. An attribute reference (an attribute name
 | ||
| enclosed in braces) is replaced by the corresponding attribute
 | ||
| value. Attribute names are case insensitive and can only contain
 | ||
| alphanumeric, dash and underscore characters.
 | ||
| 
 | ||
| There are four sources of document attributes (from highest to lowest
 | ||
| precedence):
 | ||
| 
 | ||
| - Command-line attributes.
 | ||
| - AttributeEntry, AttributeList, Macro and BlockId elements.
 | ||
| - Configuration file `[attributes]` sections.
 | ||
| - Intrinsic attributes.
 | ||
| 
 | ||
| Within each of these divisions the last processed entry takes
 | ||
| precedence.
 | ||
| 
 | ||
| NOTE: If an attribute is not defined then the line containing the
 | ||
| attribute reference is dropped. This property is used extensively in
 | ||
| AsciiDoc configuration files to facilitate conditional markup
 | ||
| generation.
 | ||
| 
 | ||
| 
 | ||
| [[X18]]
 | ||
| Attribute Entries
 | ||
| -----------------
 | ||
| The `AttributeEntry` block element allows document attributes to be
 | ||
| assigned within an AsciiDoc document. Attribute entries are added to
 | ||
| the global document attributes dictionary. The attribute name/value
 | ||
| syntax is a single line like:
 | ||
| 
 | ||
|   :<name>: <value>
 | ||
| 
 | ||
| For example:
 | ||
| 
 | ||
|   :Author Initials: JB
 | ||
| 
 | ||
| This will set an attribute reference `{authorinitials}` to the value
 | ||
| 'JB' in the current document.
 | ||
| 
 | ||
| To delete (undefine) an attribute use the following syntax:
 | ||
| 
 | ||
|   :<name>!:
 | ||
| 
 | ||
| .AttributeEntry behavior
 | ||
| - The attribute entry line begins with colon -- no white space allowed
 | ||
|   in left margin.
 | ||
| - AsciiDoc converts the `<name>` to a legal attribute name (lower
 | ||
|   case, alphanumeric, dash and underscore characters only -- all other
 | ||
|   characters deleted). This allows more human friendly text to be
 | ||
|   used.
 | ||
| - Leading and trailing white space is stripped from the `<value>`.
 | ||
| - Lines ending in a space followed by a plus character are continued
 | ||
|   to the next line, for example:
 | ||
| 
 | ||
|   :description: AsciiDoc is a text document format for writing notes, +
 | ||
|                 documentation, articles, books, slideshows, web pages +
 | ||
|                 and man pages.
 | ||
| 
 | ||
| - If the `<value>` is blank then the corresponding attribute value is
 | ||
|   set to an empty string.
 | ||
| - Attribute references contained in the entry `<value>` will be
 | ||
|   expanded.
 | ||
| - By default AttributeEntry values are substituted for
 | ||
|   `specialcharacters` and `attributes` (see above), if you want to
 | ||
|   change or disable AttributeEntry substitution use the <<X77,pass:[]
 | ||
|   inline macro>> syntax.
 | ||
| - Attribute entries in the document Header are available for header
 | ||
|   markup template substitution.
 | ||
| - Attribute elements override configuration file and intrinsic
 | ||
|   attributes but do not override command-line attributes.
 | ||
| 
 | ||
| Here are some more attribute entry examples:
 | ||
| 
 | ||
| ---------------------------------------------------------------------
 | ||
| AsciiDoc User Manual
 | ||
| ====================
 | ||
| :author:    Stuart Rackham
 | ||
| :email:     srackham@gmail.com
 | ||
| :revdate:   April 23, 2004
 | ||
| :revnumber: 5.1.1
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| Which creates these attributes:
 | ||
| 
 | ||
|   {author}, {firstname}, {lastname}, {authorinitials}, {email},
 | ||
|   {revdate}, {revnumber}
 | ||
| 
 | ||
| The previous example is equivalent to this <<X95,document header>>:
 | ||
| 
 | ||
| ---------------------------------------------------------------------
 | ||
| AsciiDoc User Manual
 | ||
| ====================
 | ||
| Stuart Rackham <srackham@gmail.com>
 | ||
| 5.1.1, April 23, 2004
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| Setting configuration entries
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| A variant of the Attribute Entry syntax allows configuration file
 | ||
| section entries and markup template sections to be set from within an
 | ||
| AsciiDoc document:
 | ||
| 
 | ||
|   :<section_name>.[<entry_name>]: <entry_value>
 | ||
| 
 | ||
| Where `<section_name>` is the configuration section name,
 | ||
| `<entry_name>` is the name of the entry and `<entry_value>` is the
 | ||
| optional entry value. This example sets the default labeled list
 | ||
| style to 'horizontal':
 | ||
| 
 | ||
|   :listdef-labeled.style: horizontal
 | ||
| 
 | ||
| It is exactly equivalent to a configuration file containing:
 | ||
| 
 | ||
|   [listdef-labeled]
 | ||
|   style=horizontal
 | ||
| 
 | ||
| - If the `<entry_name>` is omitted then the entire section is
 | ||
|   substituted with the `<entry_value>`. This feature should only be
 | ||
|   used to set markup template sections. The following example sets the
 | ||
|   'xref2' inline macro markup template:
 | ||
| 
 | ||
|   :xref2-inlinemacro.: <a href="#{1}">{2?{2}}</a>
 | ||
| 
 | ||
| - No substitution is performed on configuration file attribute entries
 | ||
|   and they cannot be undefined.
 | ||
| - This feature can only be used in attribute entries -- configuration
 | ||
|   attributes cannot be set using the asciidoc(1) command `--attribute`
 | ||
|   option.
 | ||
| 
 | ||
| [[X62]]
 | ||
| .Attribute entries promote clarity and eliminate repetition
 | ||
| *********************************************************************
 | ||
| URLs and file names in AsciiDoc macros are often quite long -- they
 | ||
| break paragraph flow and readability suffers.  The problem is
 | ||
| compounded by redundancy if the same name is used repeatedly.
 | ||
| Attribute entries can be used to make your documents easier to read
 | ||
| and write, here are some examples:
 | ||
| 
 | ||
|   :1:         http://freshmeat.net/projects/asciidoc/
 | ||
|   :homepage:  http://methods.co.nz/asciidoc/[AsciiDoc home page]
 | ||
|   :new:       image:./images/smallnew.png[]
 | ||
|   :footnote1: footnote:[A meaningless latin term]
 | ||
| 
 | ||
|   Using previously defined attributes: See the {1}[Freshmeat summary]
 | ||
|   or the {homepage} for something new {new}. Lorem ispum {footnote1}.
 | ||
| 
 | ||
| .Note
 | ||
| - The attribute entry definition must precede it's usage.
 | ||
| - You are not limited to URLs or file names, entire macro calls or
 | ||
|   arbitrary lines of text can be abbreviated.
 | ||
| - Shared attributes entries could be grouped into a separate file and
 | ||
|   <<X63,included>> in multiple documents.
 | ||
| *********************************************************************
 | ||
| 
 | ||
| 
 | ||
| [[X21]]
 | ||
| Attribute Lists
 | ||
| ---------------
 | ||
| - An attribute list is a comma separated list of attribute values.
 | ||
| - The entire list is enclosed in square brackets.
 | ||
| - Attribute lists are used to pass parameters to macros, blocks (using
 | ||
|   the <<X79,AttributeList element>>) and inline quotes.
 | ||
| 
 | ||
| The list consists of zero or more positional attribute values followed
 | ||
| by zero or more named attribute values.  Here are three examples: a
 | ||
| single unquoted positional attribute; three unquoted positional
 | ||
| attribute values; one positional attribute followed by two named
 | ||
| attributes; the unquoted attribute value in the final example contains
 | ||
| comma (`,`) and double-quote (`"`) character entities:
 | ||
| 
 | ||
|   [Hello]
 | ||
|   [quote, Bertrand Russell, The World of Mathematics (1956)]
 | ||
|   ["22 times", backcolor="#0e0e0e", options="noborders,wide"]
 | ||
|   [A footnote, "with an image" image:smallnew.png[]]
 | ||
| 
 | ||
| .Attribute list behavior
 | ||
| - If one or more attribute values contains a comma the all string
 | ||
|   values must be quoted (enclosed in double quotation mark
 | ||
|   characters).
 | ||
| - If the list contains any named or quoted attributes then all string
 | ||
|   attribute values must be quoted.
 | ||
| - To include a double quotation mark (") character in a quoted
 | ||
|   attribute value the the quotation mark must be escaped with a
 | ||
|   backslash.
 | ||
| - List attributes take precedence over existing attributes.
 | ||
| - List attributes can only be referenced in configuration file markup
 | ||
|   templates and tags, they are not available elsewhere in the
 | ||
|   document.
 | ||
| - Setting a named attribute to `None` undefines the attribute.
 | ||
| - Positional attributes are referred to as `{1}`,`{2}`,`{3}`,...
 | ||
| - Attribute `{0}` refers to the entire list (excluding the enclosing
 | ||
|   square brackets).
 | ||
| - Named attribute names cannot contain dash characters.
 | ||
| 
 | ||
| [[X75]]
 | ||
| Options attribute
 | ||
| ~~~~~~~~~~~~~~~~~
 | ||
| If the attribute list contains an attribute named `options` it is
 | ||
| processed as a comma separated list of option names:
 | ||
| 
 | ||
| - Each name generates an attribute named like `<option>-option` (where
 | ||
|   `<option>` is the option name) with an empty string value.  For
 | ||
|   example `[options="opt1,opt2,opt3"]` is equivalent to setting the
 | ||
|   following three attributes
 | ||
|   `[opt1-option="",opt2-option="",opt2-option=""]`.
 | ||
| - If you define a an option attribute globally (for example with an
 | ||
|   <<X18,attribute entry>>) then it will apply to all elements in the
 | ||
|   document.
 | ||
| - AsciiDoc implements a number of predefined options which are listed
 | ||
|   in the <<X74,Attribute Options appendix>>.
 | ||
| 
 | ||
| Macro Attribute lists
 | ||
| ~~~~~~~~~~~~~~~~~~~~~
 | ||
| Macros calls are suffixed with an attribute list. The list may be
 | ||
| empty but it cannot be omitted. List entries are used to pass
 | ||
| attribute values to macro markup templates.
 | ||
| 
 | ||
| 
 | ||
| Attribute References
 | ||
| --------------------
 | ||
| An attribute reference is an attribute name (possibly followed by an
 | ||
| additional parameters) enclosed in curly braces.  When an attribute
 | ||
| reference is encountered it is evaluated and replaced by its
 | ||
| corresponding text value.  If the attribute is undefined the line
 | ||
| containing the attribute is dropped.
 | ||
| 
 | ||
| There are three types of attribute reference: 'Simple', 'Conditional'
 | ||
| and 'System'.
 | ||
| 
 | ||
| .Attribute reference evaluation
 | ||
| - You can suppress attribute reference expansion by placing a
 | ||
|   backslash character immediately in front of the opening brace
 | ||
|   character.
 | ||
| - By default attribute references are not expanded in
 | ||
|   'LiteralParagraphs', 'ListingBlocks' or 'LiteralBlocks'.
 | ||
| - Attribute substitution proceeds line by line in reverse line order.
 | ||
| - Attribute reference evaluation is performed in the following order:
 | ||
|   'Simple' then 'Conditional' and finally 'System'.
 | ||
| 
 | ||
| Simple Attributes References
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| Simple attribute references take the form `{<name>}`. If the
 | ||
| attribute name is defined its text value is substituted otherwise the
 | ||
| line containing the reference is dropped from the output.
 | ||
| 
 | ||
| Conditional Attribute References
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| Additional parameters are used in conjunction with attribute names to
 | ||
| calculate a substitution value. Conditional attribute references take
 | ||
| the following forms:
 | ||
| 
 | ||
| `{<names>=<value>}`::
 | ||
|         `<value>` is substituted if the attribute `<names>` is
 | ||
|         undefined otherwise its value is substituted. `<value>` can
 | ||
|         contain simple attribute references.
 | ||
| 
 | ||
| `{<names>?<value>}`::
 | ||
|         `<value>` is substituted if the attribute `<names>` is defined
 | ||
|         otherwise an empty string is substituted.  `<value>` can
 | ||
|         contain simple attribute references.
 | ||
| 
 | ||
| `{<names>!<value>}`::
 | ||
|         `<value>` is substituted if the attribute `<names>` is
 | ||
|         undefined otherwise an empty string is substituted.  `<value>`
 | ||
|         can contain simple attribute references.
 | ||
| 
 | ||
| `{<names>#<value>}`::
 | ||
|         `<value>` is substituted if the attribute `<names>` is defined
 | ||
|         otherwise the undefined attribute entry causes the containing
 | ||
|         line to be dropped.  `<value>` can contain simple attribute
 | ||
|         references.
 | ||
| 
 | ||
| `{<names>%<value>}`::
 | ||
|         `<value>` is substituted if the attribute `<names>` is not
 | ||
|         defined otherwise the containing line is dropped.  `<value>`
 | ||
|         can contain simple attribute references.
 | ||
| 
 | ||
| `{<names>@<regexp>:<value1>[:<value2>]}`::
 | ||
|         `<value1>` is substituted if the value of attribute `<names>`
 | ||
|         matches the regular expression `<regexp>` otherwise `<value2>`
 | ||
|         is substituted. If attribute `<names>` is not defined the
 | ||
|         containing line is dropped. If `<value2>` is omitted an empty
 | ||
|         string is assumed. The values and the regular expression can
 | ||
|         contain simple attribute references.  To embed colons in the
 | ||
|         values or the regular expression escape them with backslashes.
 | ||
| 
 | ||
| `{<names>$<regexp>:<value1>[:<value2>]}`::
 | ||
|         Same behavior as the previous ternary attribute except for
 | ||
|         the following cases:
 | ||
| 
 | ||
|         `{<names>$<regexp>:<value>}`;;
 | ||
|                 Substitutes `<value>` if `<names>` matches `<regexp>`
 | ||
|                 otherwise the result is undefined and the containing
 | ||
|                 line is dropped.
 | ||
| 
 | ||
|         `{<names>$<regexp>::<value>}`;;
 | ||
|                 Substitutes `<value>` if `<names>` does not match
 | ||
|                 `<regexp>` otherwise the result is undefined and the
 | ||
|                 containing line is dropped.
 | ||
| 
 | ||
| The attribute `<names>` parameter normally consists of a single
 | ||
| attribute name but it can be any one of the following:
 | ||
| 
 | ||
| - A single attribute name which evaluates to the attributes value.
 | ||
| - Multiple ',' separated attribute names which evaluates to an empty
 | ||
|   string if one or more of the attributes is defined, otherwise it's
 | ||
|   value is undefined.
 | ||
| - Multiple '+' separated attribute names which evaluates to an empty
 | ||
|   string if all of the attributes are defined, otherwise it's value is
 | ||
|   undefined.
 | ||
| 
 | ||
| Conditional attributes with single attribute names are evaluated first
 | ||
| so they can be used inside the multi-attribute conditional `<value>`.
 | ||
| 
 | ||
| Conditional attribute examples
 | ||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
 | ||
| Conditional attributes are mainly used in AsciiDoc configuration
 | ||
| files -- see the distribution `.conf` files for examples.
 | ||
| 
 | ||
| Attribute equality test::
 | ||
|   If `{backend}` is 'docbook45' or 'xhtml11' the example evaluates to
 | ||
|   ``DocBook 4.5 or XHTML 1.1 backend'' otherwise it evaluates to
 | ||
|   ``some other backend'':
 | ||
| 
 | ||
|   {backend@docbook45|xhtml11:DocBook 4.5 or XHTML 1.1 backend:some other backend}
 | ||
| 
 | ||
| Attribute value map::
 | ||
|   This example maps the `frame` attribute values [`topbot`, `all`,
 | ||
|   `none`, `sides`] to [`hsides`, `border`, `void`, `vsides`]:
 | ||
| 
 | ||
|   {frame@topbot:hsides}{frame@all:border}{frame@none:void}{frame@sides:vsides}
 | ||
| 
 | ||
| 
 | ||
| [[X24]]
 | ||
| System Attribute References
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| System attribute references generate the attribute text value by
 | ||
| executing a predefined action that is parametrized by one or more
 | ||
| arguments. The syntax is `{<action>:<arguments>}`.
 | ||
| 
 | ||
| `{counter:<attrname>[:<seed>]}`::
 | ||
|         Increments the document attribute (if the attribute is
 | ||
|         undefined it is set to `1`). Returns the new attribute value.
 | ||
| 
 | ||
|         - Counters generate global (document wide) attributes.
 | ||
|         - The optional `<seed>` specifies the counter's initial value;
 | ||
|           it can be a number or a single letter; defaults to '1'.
 | ||
|         - `<seed>` can contain simple and conditional attribute
 | ||
|           references.
 | ||
|         - The 'counter' system attribute will not be executed if the
 | ||
|           containing line is dropped by the prior evaluation of an
 | ||
|           undefined attribute.
 | ||
| 
 | ||
| `{counter2:<attrname>[:<seed>]}`::
 | ||
|         Same as `counter` except the it always returns a blank string.
 | ||
| 
 | ||
| `{eval:<expression>}`::
 | ||
|         Substitutes the result of the Python `<expression>`.
 | ||
| 
 | ||
|         - If `<expression>` evaluates to `None` or `False` the
 | ||
|           reference is deemed undefined and the line containing the
 | ||
|           reference is dropped from the output.
 | ||
|         - If the expression evaluates to `True` the attribute
 | ||
|           evaluates to an empty string.
 | ||
|         - `<expression>` can contain simple and conditional attribute
 | ||
|           references.
 | ||
|         - The 'eval' system attribute can be nested inside other
 | ||
|           system attributes.
 | ||
| 
 | ||
| `{eval3:<command>}`::
 | ||
|         Passthrough version of `{eval:<expression>}` -- the generated
 | ||
|         output is written directly to the output without any further
 | ||
|         substitutions.
 | ||
| 
 | ||
| `{include:<filename>}`::
 | ||
|         Substitutes contents of the file named `<filename>`.
 | ||
| 
 | ||
|         - The included file is read at the time of attribute
 | ||
|           substitution.
 | ||
|         - If the file does not exist a warning is emitted and the line
 | ||
|           containing the reference is dropped from the output file.
 | ||
|         - Tabs are expanded based on the current 'tabsize' attribute
 | ||
|           value.
 | ||
| 
 | ||
| `{set:<attrname>[!][:<value>]}`::
 | ||
|         Sets or unsets document attribute. Normally only used in
 | ||
|         configuration file markup templates (use
 | ||
|         <<X18,AttributeEntries>> in AsciiDoc documents).
 | ||
| 
 | ||
|         - If the attribute name is followed by an exclamation mark
 | ||
|           the attribute becomes undefined.
 | ||
|         - If `<value>` is omitted the attribute is set to a blank
 | ||
|           string.
 | ||
|         - `<value>` can contain simple and conditional attribute
 | ||
|           references.
 | ||
|         - Returns a blank string unless the attribute is undefined in
 | ||
|           which case the return value is undefined and the enclosing
 | ||
|           line will be dropped.
 | ||
| 
 | ||
| `{set2:<attrname>[!][:<value>]}`::
 | ||
|         Same as `set` except that the attribute scope is local to the
 | ||
|         template.
 | ||
| 
 | ||
| `{sys:<command>}`::
 | ||
|         Substitutes the stdout generated by the execution of the shell
 | ||
|         `<command>`.
 | ||
| 
 | ||
| `{sys2:<command>}`::
 | ||
|         Substitutes the stdout and stderr generated by the execution
 | ||
|         of the shell `<command>`.
 | ||
| 
 | ||
| `{sys3:<command>}`::
 | ||
|         Passthrough version of `{sys:<command>}` -- the generated
 | ||
|         output is written directly to the output without any further
 | ||
|         substitutions.
 | ||
| 
 | ||
| `{template:<template>}`::
 | ||
|         Substitutes the contents of the configuration file section
 | ||
|         named `<template>`. Attribute references contained in the
 | ||
|         template are substituted.
 | ||
| 
 | ||
| .System reference behavior
 | ||
| - System attribute arguments can contain non-system attribute
 | ||
|   references.
 | ||
| - Closing brace characters inside system attribute arguments must be
 | ||
|   escaped with a backslash.
 | ||
| 
 | ||
| [[X60]]
 | ||
| Intrinsic Attributes
 | ||
| --------------------
 | ||
| Intrinsic attributes are simple attributes that are created
 | ||
| automatically from: AsciiDoc document header parameters; asciidoc(1)
 | ||
| command-line arguments; attributes defined in the default
 | ||
| configuration files; the execution context.  Here's the list of
 | ||
| predefined intrinsic attributes:
 | ||
| 
 | ||
|   {amp}                 ampersand (&) character entity
 | ||
|   {asciidoc-args}       used to pass inherited arguments to asciidoc filters
 | ||
|   {asciidoc-confdir}    the asciidoc(1) global configuration directory
 | ||
|   {asciidoc-dir}        the asciidoc(1) application directory
 | ||
|   {asciidoc-file}       the full path name of the asciidoc(1) script
 | ||
|   {asciidoc-version}    the version of asciidoc(1)
 | ||
|   {author}              author's full name
 | ||
|   {authored}            empty string '' if {author} or {email} defined,
 | ||
|   {authorinitials}      author initials (from document header)
 | ||
|   {backend-<backend>}   empty string ''
 | ||
|   {<backend>-<doctype>} empty string ''
 | ||
|   {backend}             document backend specified by `-b` option
 | ||
|   {backend-confdir}     the directory containing the <backend>.conf file
 | ||
|   {backslash}           backslash character
 | ||
|   {basebackend-<base>}  empty string ''
 | ||
|   {basebackend}         html or docbook
 | ||
|   {blockname}           current block name (note 8).
 | ||
|   {brvbar}              broken vertical bar (|) character
 | ||
|   {docdate}             document last modified date
 | ||
|   {docdir}              document input directory name  (note 5)
 | ||
|   {docfile}             document file name  (note 5)
 | ||
|   {docname}             document file name without extension (note 6)
 | ||
|   {doctime}             document last modified time
 | ||
|   {doctitle}            document title (from document header)
 | ||
|   {doctype-<doctype>}   empty string ''
 | ||
|   {doctype}             document type specified by `-d` option
 | ||
|   {email}               author's email address (from document header)
 | ||
|   {empty}               empty string ''
 | ||
|   {encoding}            specifies input and output encoding
 | ||
|   {filetype-<fileext>}  empty string ''
 | ||
|   {filetype}            output file name file extension
 | ||
|   {firstname}           author first name (from document header)
 | ||
|   {gt}                  greater than (>) character entity
 | ||
|   {id}                  running block id generated by BlockId elements
 | ||
|   {indir}               input file directory name (note 2,5)
 | ||
|   {infile}              input file name (note 2,5)
 | ||
|   {lastname}            author last name (from document header)
 | ||
|   {ldquo}               Left double quote character (note 7)
 | ||
|   {level}               title level 1..4 (in section titles)
 | ||
|   {listindex}           the list index (1..) of the most recent list item
 | ||
|   {localdate}           the current date
 | ||
|   {localtime}           the current time
 | ||
|   {lsquo}               Left single quote character (note 7)
 | ||
|   {lt}                  less than (<) character entity
 | ||
|   {manname}             manpage name (defined in NAME section)
 | ||
|   {manpurpose}          manpage (defined in NAME section)
 | ||
|   {mantitle}            document title minus the manpage volume number
 | ||
|   {manvolnum}           manpage volume number (1..8) (from document header)
 | ||
|   {middlename}          author middle name (from document header)
 | ||
|   {nbsp}                non-breaking space character entity
 | ||
|   {notitle}             do not display the document title
 | ||
|   {outdir}              document output directory name (note 2)
 | ||
|   {outfile}             output file name (note 2)
 | ||
|   {python}              the full path name of the Python interpreter executable
 | ||
|   {rdquo}               Right double quote character (note 7)
 | ||
|   {reftext}             running block xreflabel generated by BlockId elements
 | ||
|   {revdate}             document revision date (from document header)
 | ||
|   {revnumber}           document revision number (from document header)
 | ||
|   {rsquo}               Right single quote character (note 7)
 | ||
|   {sectnum}             formatted section number (in section titles)
 | ||
|   {sp}                  space character
 | ||
|   {showcomments}        send comment lines to the output
 | ||
|   {title}               section title (in titled elements)
 | ||
|   {two-colons}          Two colon characters
 | ||
|   {two-semicolons}      Two semicolon characters
 | ||
|   {user-dir}            the ~/.asciidoc directory (if it exists)
 | ||
|   {verbose}             defined as '' if --verbose command option specified
 | ||
|   {wj}                  Word-joiner
 | ||
|   {zwsp}                Zero-width space character entity
 | ||
| 
 | ||
| [NOTE]
 | ||
| ======
 | ||
| 1. Intrinsic attributes are global so avoid defining custom attributes
 | ||
|    with the same names.
 | ||
| 2. `{outfile}`, `{outdir}`, `{infile}`, `{indir}` attributes are
 | ||
|    effectively read-only (you can set them but it won't affect the
 | ||
|    input or output file paths).
 | ||
| 3.  See also the <<X88,Backend Attributes>> section for attributes
 | ||
|     that relate to AsciiDoc XHTML file generation.
 | ||
| 4. The entries that translate to blank strings are designed to be used
 | ||
|    for conditional text inclusion. You can also use the `ifdef`,
 | ||
|    `ifndef` and `endif` System macros for conditional inclusion.
 | ||
|    footnote:[Conditional inclusion using `ifdef` and `ifndef` macros
 | ||
|    differs from attribute conditional inclusion in that the former
 | ||
|    occurs when the file is read while the latter occurs when the
 | ||
|    contents are written.]
 | ||
| 5. `{docfile}` and `{docdir}` refer to root document specified on the
 | ||
|    asciidoc(1) command-line; `{infile}` and `{indir}` refer to the
 | ||
|    current input file which may be the root document or an included
 | ||
|    file. When the input is being read from the standard input
 | ||
|    (`stdin`) these attributes are undefined.
 | ||
| 6. If the input file is the standard input and the output file is not
 | ||
|    the standard output then `{docname}` is the output file name sans
 | ||
|    file extension.
 | ||
| 7. See
 | ||
|    http://en.wikipedia.org/wiki/Non-English_usage_of_quotation_marks[non-English
 | ||
|    usage of quotation marks].
 | ||
| 8. The `{blockname}` attribute identifies the style of the current
 | ||
|    block. It applies to delimited blocks, lists and tables. Here is a
 | ||
|    list of `{blockname}` values (does not include filters or custom
 | ||
|    block and style names):
 | ||
| 
 | ||
|    delimited blocks:: comment, sidebar, open, pass, literal, verse,
 | ||
|    listing, quote, example, note, tip, important, caution, warning,
 | ||
|    abstract, partintro
 | ||
| 
 | ||
|    lists:: arabic, loweralpha, upperalpha, lowerroman, upperroman,
 | ||
|    labeled, labeled3, labeled4, qanda, horizontal, bibliography,
 | ||
|    glossary
 | ||
| 
 | ||
|    tables:: table
 | ||
| 
 | ||
| ======
 | ||
| 
 | ||
| 
 | ||
| [[X73]]
 | ||
| Block Element Definitions
 | ||
| -------------------------
 | ||
| The syntax and behavior of Paragraph, DelimitedBlock, List and Table
 | ||
| block elements is determined by block definitions contained in
 | ||
| <<X7,AsciiDoc configuration file>> sections.
 | ||
| 
 | ||
| Each definition consists of a section title followed by one or more
 | ||
| section entries. Each entry defines a block parameter controlling some
 | ||
| aspect of the block's behavior. Here's an example:
 | ||
| 
 | ||
| ---------------------------------------------------------------------
 | ||
| [blockdef-listing]
 | ||
| delimiter=^-{4,}$
 | ||
| template=listingblock
 | ||
| presubs=specialcharacters,callouts
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| Configuration file block definition sections are processed
 | ||
| incrementally after each configuration file is loaded. Block
 | ||
| definition section entries are merged into the block definition, this
 | ||
| allows block parameters to be overridden and extended by later
 | ||
| <<X27,loading configuration files>>.
 | ||
| 
 | ||
| AsciiDoc Paragraph, DelimitedBlock, List and Table block elements
 | ||
| share a common subset of configuration file parameters:
 | ||
| 
 | ||
| delimiter::
 | ||
|   A Python regular expression that matches the first line of a block
 | ||
|   element -- in the case of DelimitedBlocks and Tables it also matches
 | ||
|   the last line.
 | ||
| 
 | ||
| template::
 | ||
|   The name of the configuration file markup template section that will
 | ||
|   envelope the block contents. The pipe ('|') character is substituted
 | ||
|   for the block contents. List elements use a set of (list specific)
 | ||
|   tag parameters instead of a single template. The template name can
 | ||
|   contain attribute references allowing dynamic template selection a
 | ||
|   the time of template substitution.
 | ||
| 
 | ||
| options::
 | ||
|   A comma delimited list of element specific option names. In addition
 | ||
|   to being used internally, options are available during markup tag
 | ||
|   and template substitution as attributes with an empty string value
 | ||
|   named like `<option>-option` (where `<option>` is the option name).
 | ||
|   See <<X74,attribute options>> for a complete list of available
 | ||
|   options.
 | ||
| 
 | ||
| subs, presubs, postsubs::
 | ||
|   * 'presubs' and 'postsubs' are lists of comma separated substitutions that are
 | ||
|     performed on the block contents. 'presubs' is applied first,
 | ||
|     'postsubs' (if specified) second.
 | ||
| 
 | ||
|   * 'subs' is an alias for 'presubs'.
 | ||
| 
 | ||
|   * If a 'filter' is allowed (Paragraphs, DelimitedBlocks and Tables)
 | ||
|     and has been specified then 'presubs' and 'postsubs' substitutions
 | ||
|     are performed before and after the filter is run respectively.
 | ||
| 
 | ||
|   * Allowed values: 'specialcharacters', 'quotes', 'specialwords',
 | ||
|     'replacements', 'macros', 'attributes', 'callouts'.
 | ||
| 
 | ||
|   * [[X102]]The following composite values are also allowed:
 | ||
| 
 | ||
|     'none';;
 | ||
|         No substitutions.
 | ||
|     'normal';;
 | ||
|         The following substitutions in the following order:
 | ||
|         'specialcharacters', 'quotes', 'attributes', 'specialwords',
 | ||
|         'replacements', 'macros', 'replacements2'.
 | ||
|     'verbatim';;
 | ||
|         The following substitutions in the following order:
 | ||
|         'specialcharacters' and 'callouts'.
 | ||
| 
 | ||
|   * 'normal' and 'verbatim' substitutions can be redefined by with
 | ||
|     `subsnormal` and `subsverbatim` entries in a configuration file
 | ||
|     `[miscellaneous]` section.
 | ||
| 
 | ||
|   * The substitutions are processed in the order in which they are
 | ||
|     listed and can appear more than once.
 | ||
| 
 | ||
| filter::
 | ||
|   This optional entry specifies an executable shell command for
 | ||
|   processing block content (Paragraphs, DelimitedBlocks and Tables).
 | ||
|   The filter command can contain attribute references.
 | ||
| 
 | ||
| posattrs::
 | ||
|   Optional comma separated list of positional attribute names. This
 | ||
|   list maps positional attributes (in the block's <<X21,attribute
 | ||
|   list>>) to named block attributes. The following example, from the
 | ||
|   QuoteBlock definition, maps the first and section positional
 | ||
|   attributes:
 | ||
| 
 | ||
|   posattrs=attribution,citetitle
 | ||
| 
 | ||
| style::
 | ||
|   This optional parameter specifies the default style name.
 | ||
| 
 | ||
| 
 | ||
| <stylename>-style::
 | ||
|   Optional style definition (see <<X23,Styles>> below).
 | ||
| 
 | ||
| The following block parameters behave like document attributes and can
 | ||
| be set in block attribute lists and style definitions: 'template',
 | ||
| 'options', 'subs', 'presubs', 'postsubs', 'filter'.
 | ||
| 
 | ||
| [[X23]]
 | ||
| Styles
 | ||
| ~~~~~~
 | ||
| A style is a set of block parameter bundled as a single named
 | ||
| parameter. The following example defines a style named 'verbatim':
 | ||
| 
 | ||
|   verbatim-style=template="literalblock",subs="verbatim"
 | ||
| 
 | ||
| If a block's <<X21,attribute list>> contains a 'style' attribute then
 | ||
| the corresponding style parameters are be merged into the default
 | ||
| block definition parameters.
 | ||
| 
 | ||
| - All style parameter names must be suffixed with `-style` and the
 | ||
|   style parameter value is in the form of a list of <<X21,named
 | ||
|   attributes>>.
 | ||
| - The 'template' style parameter is mandatory, other parameters can be
 | ||
|   omitted in which case they inherit their values from the default
 | ||
|   block definition parameters.
 | ||
| - Multi-item style parameters ('subs','presubs','postsubs','posattrs')
 | ||
|   must be specified using Python tuple syntax (rather than a simple
 | ||
|   list of values as they in separate entries) e.g.
 | ||
|   `postsubs=("callouts",)` not `postsubs="callouts"`.
 | ||
| 
 | ||
| Paragraphs
 | ||
| ~~~~~~~~~~
 | ||
| Paragraph translation is controlled by `[paradef-*]` configuration
 | ||
| file section entries. Users can define new types of paragraphs and
 | ||
| modify the behavior of existing types by editing AsciiDoc
 | ||
| configuration files.
 | ||
| 
 | ||
| Here is the shipped Default paragraph definition:
 | ||
| 
 | ||
| --------------------------------------------------------------------
 | ||
| [paradef-default]
 | ||
| delimiter=(?P<text>\S.*)
 | ||
| template=paragraph
 | ||
| --------------------------------------------------------------------
 | ||
| 
 | ||
| The normal paragraph definition has a couple of special properties:
 | ||
| 
 | ||
| 1. It must exist and be defined in a configuration file section named
 | ||
|    `[paradef-default]`.
 | ||
| 2. Irrespective of its position in the configuration files default
 | ||
|    paragraph document matches are attempted only after trying all
 | ||
|    other paragraph types.
 | ||
| 
 | ||
| Paragraph specific block parameter notes:
 | ||
| 
 | ||
| delimiter::
 | ||
|   This regular expression must contain the named group 'text' which
 | ||
|   matches the text on the first line.  Paragraphs are terminated by a
 | ||
|   blank line, the end of file, or the start of a DelimitedBlock.
 | ||
| 
 | ||
| options::
 | ||
|   The 'listelement' option specifies that paragraphs of this type will
 | ||
|   automatically be considered part of immediately preceding list
 | ||
|   items.  The 'skip' option causes the paragraph to be treated as a
 | ||
|   comment (see <<X26,CommentBlocks>>).
 | ||
| 
 | ||
| .Paragraph processing proceeds as follows:
 | ||
| 1. The paragraph text is aligned to the left margin.
 | ||
| 2. Optional 'presubs' inline substitutions are performed on the
 | ||
|    paragraph text.
 | ||
| 3. If a filter command is specified it is executed and the paragraph
 | ||
|    text piped to its standard input; the filter output replaces the
 | ||
|    paragraph text.
 | ||
| 4. Optional 'postsubs' inline substitutions are performed on the
 | ||
|    paragraph text.
 | ||
| 5. The paragraph text is enveloped by the paragraph's markup template
 | ||
|    and written to the output file.
 | ||
| 
 | ||
| Delimited Blocks
 | ||
| ~~~~~~~~~~~~~~~~
 | ||
| DelimitedBlock 'options' values are:
 | ||
| 
 | ||
| sectionbody::
 | ||
|     The block contents are processed as a SectionBody.
 | ||
| 
 | ||
| skip::
 | ||
|     The block is treated as a comment (see <<X26,CommentBlocks>>).
 | ||
|     Preceding <<X21,attribute lists>> and <<X42,block titles>> are not
 | ||
|     consumed.
 | ||
| 
 | ||
| 'presubs', 'postsubs' and 'filter' entries are ignored when
 | ||
| 'sectionbody' or 'skip' options are set.
 | ||
| 
 | ||
| DelimitedBlock processing proceeds as follows:
 | ||
| 
 | ||
| 1. Optional 'presubs' substitutions are performed on the block
 | ||
|    contents.
 | ||
| 2. If a filter is specified it is executed and the block's contents
 | ||
|    piped to its standard input. The filter output replaces the block
 | ||
|    contents.
 | ||
| 3. Optional 'postsubs' substitutions are performed on the block
 | ||
|    contents.
 | ||
| 4. The block contents is enveloped by the block's markup template and
 | ||
|    written to the output file.
 | ||
| 
 | ||
| TIP: Attribute expansion is performed on the block filter command
 | ||
| before it is executed, this is useful for passing arguments to the
 | ||
| filter.
 | ||
| 
 | ||
| Lists
 | ||
| ~~~~~
 | ||
| List behavior and syntax is determined by `[listdef-*]` configuration
 | ||
| file sections. The user can change existing list behavior and add new
 | ||
| list types by editing configuration files.
 | ||
| 
 | ||
| List specific block definition notes:
 | ||
| 
 | ||
| type::
 | ||
|   This is either 'bulleted','numbered','labeled' or 'callout'.
 | ||
| 
 | ||
| delimiter::
 | ||
|   A Python regular expression that matches the first line of a
 | ||
|   list element entry. This expression can contain the named groups
 | ||
|   'text' (bulleted groups), 'index' and 'text' (numbered lists),
 | ||
|   'label' and 'text' (labeled lists).
 | ||
| 
 | ||
| tags::
 | ||
|   The `<name>` of the `[listtags-<name>]` configuration file section
 | ||
|   containing list markup tag definitions.  The tag entries ('list',
 | ||
|   'entry', 'label', 'term', 'text') map the AsciiDoc list structure to
 | ||
|   backend markup; see the 'listtags' sections in the AsciiDoc
 | ||
|   distributed backend `.conf` configuration files for examples.
 | ||
| 
 | ||
| Tables
 | ||
| ~~~~~~
 | ||
| Table behavior and syntax is determined by `[tabledef-*]` and
 | ||
| `[tabletags-*]` configuration file sections. The user can change
 | ||
| existing table behavior and add new table types by editing
 | ||
| configuration files.  The following `[tabledef-*]` section entries
 | ||
| generate table output markup elements:
 | ||
| 
 | ||
| colspec::
 | ||
|   The table 'colspec' tag definition.
 | ||
| 
 | ||
| headrow, footrow, bodyrow::
 | ||
|   Table header, footer and body row tag definitions. 'headrow' and
 | ||
|   'footrow' table definition entries default to 'bodyrow' if
 | ||
|   they are undefined.
 | ||
| 
 | ||
| headdata, footdata, bodydata::
 | ||
|   Table header, footer and body data tag definitions. 'headdata' and
 | ||
|   'footdata' table definition entries default to 'bodydata' if they
 | ||
|   are undefined.
 | ||
| 
 | ||
| paragraph::
 | ||
|   If the 'paragraph' tag is specified then blank lines in the cell
 | ||
|   data are treated as paragraph delimiters and marked up using this
 | ||
|   tag.
 | ||
| 
 | ||
| [[X4]]
 | ||
| Table behavior is also influenced by the following `[miscellaneous]`
 | ||
| configuration file entries:
 | ||
| 
 | ||
| pagewidth::
 | ||
|   This integer value is the printable width of the output media. See
 | ||
|   <<X69,table attributes>>.
 | ||
| 
 | ||
| pageunits::
 | ||
|   The units of width in output markup width attribute values.
 | ||
| 
 | ||
| .Table definition behavior
 | ||
| - The output markup generation is specifically designed to work with
 | ||
|   the HTML and CALS (DocBook) table models, but should be adaptable to
 | ||
|   most XML table schema.
 | ||
| - Table definitions can be ``mixed in'' from multiple cascading
 | ||
|   configuration files.
 | ||
| - New table definitions inherit the default table and table tags
 | ||
|   definitions (`[tabledef-default]` and `[tabletags-default]`) so you
 | ||
|   only need to override those conf file entries that require
 | ||
|   modification.
 | ||
| 
 | ||
| 
 | ||
| [[X59]]
 | ||
| Filters
 | ||
| -------
 | ||
| AsciiDoc filters allow external commands to process AsciiDoc
 | ||
| 'Paragraphs', 'DelimitedBlocks' and 'Table' content. Filters are
 | ||
| primarily an extension mechanism for generating specialized outputs.
 | ||
| Filters are implemented using external commands which are specified in
 | ||
| configuration file definitions.
 | ||
| 
 | ||
| There's nothing special about the filters, they're just standard UNIX
 | ||
| filters: they read text from the standard input, process it, and write
 | ||
| to the standard output.
 | ||
| 
 | ||
| The asciidoc(1) command `--filter` option can be used to install and
 | ||
| remove filters. The same option is used to unconditionally load a
 | ||
| filter.
 | ||
| 
 | ||
| Attribute substitution is performed on the filter command prior to
 | ||
| execution -- attributes can be used to pass parameters from the
 | ||
| AsciiDoc source document to the filter.
 | ||
| 
 | ||
| WARNING: Filters sometimes included executable code. Before installing
 | ||
| a filter you should verify that it is from a trusted source.
 | ||
| 
 | ||
| Filter Search Paths
 | ||
| ~~~~~~~~~~~~~~~~~~~
 | ||
| If the filter command does not specify a directory path then
 | ||
| asciidoc(1) recursively searches for the executable filter command:
 | ||
| 
 | ||
| - First it looks in the user's `$HOME/.asciidoc/filters` directory.
 | ||
| - Next the global filters directory (usually `/etc/asciidoc/filters`
 | ||
|   or `/usr/local/etc/asciidoc`) directory is searched.
 | ||
| - Then it looks in the asciidoc(1) `./filters` directory.
 | ||
| - Finally it relies on the executing shell to search the environment
 | ||
|   search path (`$PATH`).
 | ||
| 
 | ||
| Standard practice is to install each filter in it's own sub-directory
 | ||
| with the same name as the filter's style definition. For example the
 | ||
| music filter's style name is 'music' so it's configuration and filter
 | ||
| files are stored in the `filters/music` directory.
 | ||
| 
 | ||
| Filter Configuration Files
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| Filters are normally accompanied by a configuration file containing a
 | ||
| Paragraph or DelimitedBlock definition along with corresponding markup
 | ||
| templates.
 | ||
| 
 | ||
| While it is possible to create new 'Paragraph' or 'DelimitedBlock'
 | ||
| definitions the preferred way to implement a filter is to add a
 | ||
| <<X23,style>> to the existing Paragraph and ListingBlock definitions
 | ||
| (all filters shipped with AsciiDoc use this technique). The filter is
 | ||
| applied to the paragraph or delimited block by preceding it with an
 | ||
| attribute list: the first positional attribute is the style name,
 | ||
| remaining attributes are normally filter specific parameters.
 | ||
| 
 | ||
| asciidoc(1) auto-loads all `.conf` files found in the filter search
 | ||
| paths unless the container directory also contains a file named
 | ||
| `__noautoload__` (see previous section). The `__noautoload__` feature
 | ||
| is used for filters that will be loaded manually using the `--filter`
 | ||
| option.
 | ||
| 
 | ||
| [[X56]]
 | ||
| Example Filter
 | ||
| ~~~~~~~~~~~~~~
 | ||
| AsciiDoc comes with a toy filter for highlighting source code keywords
 | ||
| and comments.  See also the `./filters/code/code-filter-readme.txt`
 | ||
| file.
 | ||
| 
 | ||
| NOTE: The purpose of this toy filter is to demonstrate how to write a
 | ||
| filter -- it's much to simplistic to be passed off as a code syntax
 | ||
| highlighter.  If you want a full featured multi-language highlighter
 | ||
| use the {website}source-highlight-filter.html[source code highlighter
 | ||
| filter].
 | ||
| 
 | ||
| Built-in filters
 | ||
| ~~~~~~~~~~~~~~~~
 | ||
| The AsciiDoc distribution includes 'source', 'music', 'latex' and
 | ||
| 'graphviz' filters, details are on the
 | ||
| {website}index.html#_filters[AsciiDoc website].
 | ||
| 
 | ||
| [cols="1e,5",frame="topbot",options="header"]
 | ||
| .Built-in filters list
 | ||
| |====================================================================
 | ||
| |Filter name |Description
 | ||
| 
 | ||
| |music
 | ||
| |A {website}music-filter.html[music filter] is included in the
 | ||
| distribution `./filters/` directory. It translates music in
 | ||
| http://lilypond.org/[LilyPond] or http://abcnotation.org.uk/[ABC]
 | ||
| notation to standard classical notation.
 | ||
| 
 | ||
| |source
 | ||
| |A {website}source-highlight-filter.html[source code highlight filter]
 | ||
| is included in the distribution `./filters/` directory.
 | ||
| 
 | ||
| |latex
 | ||
| |The {website}latex-filter.html[AsciiDoc LaTeX filter] translates
 | ||
| LaTeX source to a PNG image that is automatically inserted into the
 | ||
| AsciiDoc output documents.
 | ||
| 
 | ||
| |graphviz
 | ||
| |Gouichi Iisaka has written a http://www.graphviz.org/[Graphviz]
 | ||
| filter for AsciiDoc.  Graphviz generates diagrams from a textual
 | ||
| specification. Gouichi Iisaka's Graphviz filter is included in the
 | ||
| AsciiDoc distribution. Here are some
 | ||
| {website}asciidoc-graphviz-sample.html[AsciiDoc Graphviz examples].
 | ||
| 
 | ||
| |====================================================================
 | ||
| 
 | ||
| [[X58]]
 | ||
| Filter plugins
 | ||
| ~~~~~~~~~~~~~~
 | ||
| Filter <<X101,plugins>> are a mechanism for distributing AsciiDoc
 | ||
| filters.  A filter plugin is a Zip file containing the files that
 | ||
| constitute a filter.  The asciidoc(1) `--filter` option is used to
 | ||
| load and manage filer <<X101,plugins>>.
 | ||
| 
 | ||
| - Filter plugins <<X27,take precedence>> over built-in filters with
 | ||
|   the same name.
 | ||
| - By default filter plugins are installed in
 | ||
|   `$HOME/.asciidoc/filters/<filter>` where `<filter>` is the filter
 | ||
|   name.
 | ||
| 
 | ||
| 
 | ||
| [[X101]]
 | ||
| Plugins
 | ||
| -------
 | ||
| The AsciiDoc plugin architecture is an extension mechanism that allows
 | ||
| additional <<X100,backends>>, <<X58,filters>> and <<X99,themes>> to be
 | ||
| added to AsciiDoc.
 | ||
| 
 | ||
| - A plugin is a Zip file containing an AsciiDoc backend, filter or
 | ||
|   theme (configuration files, stylesheets, scripts, images).
 | ||
| - The asciidoc(1) `--backend`, `--filter` and `--theme` command-line
 | ||
|   options are used to load and manage plugins. Each of these options
 | ||
|   responds to the plugin management 'install', 'list', 'remove' and
 | ||
|   'build' commands.
 | ||
| - The plugin management command names are reserved and cannot be used
 | ||
|   for filter, backend or theme names.
 | ||
| - The plugin Zip file name always begins with the backend, filter or
 | ||
|   theme name.
 | ||
| 
 | ||
| Plugin commands and conventions are documented in the asciidoc(1) man
 | ||
| page.  You can find lists of plugins on the
 | ||
| {website}plugins.html[AsciiDoc website].
 | ||
| 
 | ||
| 
 | ||
| [[X36]]
 | ||
| Help Commands
 | ||
| -------------
 | ||
| The asciidoc(1) command has a `--help` option which prints help topics
 | ||
| to stdout. The default topic summarizes asciidoc(1) usage:
 | ||
| 
 | ||
|   $ asciidoc --help
 | ||
| 
 | ||
| To print a help topic specify the topic name as a command argument.
 | ||
| Help topic names can be shortened so long as they are not ambiguous.
 | ||
| Examples:
 | ||
| 
 | ||
|   $ asciidoc --help manpage
 | ||
|   $ asciidoc -h m              # Short version of previous example.
 | ||
|   $ asciidoc --help syntax
 | ||
|   $ asciidoc -h s              # Short version of previous example.
 | ||
| 
 | ||
| Customizing Help
 | ||
| ~~~~~~~~~~~~~~~~
 | ||
| To change, delete or add your own help topics edit a help
 | ||
| configuration file.  The help file name `help-<lang>.conf` is based on
 | ||
| the setting of the `lang` attribute, it defaults to `help.conf`
 | ||
| (English).  The <<X27,help file location>> will depend on whether you
 | ||
| want the topics to apply to all users or just the current user.
 | ||
| 
 | ||
| The help topic files have the same named section format as other
 | ||
| <<X7,configuration files>>. The `help.conf` files are stored in the
 | ||
| same locations and loaded in the same order as other configuration
 | ||
| files.
 | ||
| 
 | ||
| When the `--help` command-line option is specified AsciiDoc loads the
 | ||
| appropriate help files and then prints the contents of the section
 | ||
| whose name matches the help topic name.  If a topic name is not
 | ||
| specified `default` is used. You don't need to specify the whole help
 | ||
| topic name on the command-line, just enough letters to ensure it's not
 | ||
| ambiguous. If a matching help file section is not found a list of
 | ||
| available topics is printed.
 | ||
| 
 | ||
| 
 | ||
| Tips and Tricks
 | ||
| ---------------
 | ||
| 
 | ||
| Know Your Editor
 | ||
| ~~~~~~~~~~~~~~~~
 | ||
| Writing AsciiDoc documents will be a whole lot more pleasant if you
 | ||
| know your favorite text editor. Learn how to indent and reformat text
 | ||
| blocks, paragraphs, lists and sentences. <<X20,Tips for 'vim' users>>
 | ||
| follow.
 | ||
| 
 | ||
| [[X20]]
 | ||
| Vim Commands for Formatting AsciiDoc
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| Text Wrap Paragraphs
 | ||
| ^^^^^^^^^^^^^^^^^^^^
 | ||
| Use the vim `:gq` command to reformat paragraphs. Setting the
 | ||
| 'textwidth' sets the right text wrap margin; for example:
 | ||
| 
 | ||
|   :set textwidth=70
 | ||
| 
 | ||
| To reformat a paragraph:
 | ||
| 
 | ||
| 1. Position the cursor at the start of the paragraph.
 | ||
| 2. Type `gq}`.
 | ||
| 
 | ||
| Execute `:help gq` command to read about the vim gq command.
 | ||
| 
 | ||
| [TIP]
 | ||
| =====================================================================
 | ||
| - Assign the `gq}` command to the Q key with the `nnoremap Q gq}`
 | ||
|   command or put it in your `~/.vimrc` file to so it's always
 | ||
|   available (see the <<X61, Example `~/.vimrc` file>>).
 | ||
| - Put `set` commands in your `~/.vimrc` file so you don't have to
 | ||
|   enter them manually.
 | ||
| - The Vim website (http://www.vim.org) has a wealth of resources,
 | ||
|   including scripts for automated spell checking and ASCII Art
 | ||
|   drawing.
 | ||
| =====================================================================
 | ||
| 
 | ||
| Format Lists
 | ||
| ^^^^^^^^^^^^
 | ||
| The `gq` command can also be used to format bulleted, numbered and
 | ||
| callout lists. First you need to set the `comments`, `formatoptions`
 | ||
| and `formatlistpat` (see the <<X61, Example `~/.vimrc` file>>).
 | ||
| 
 | ||
| Now you can format simple lists that use dash, asterisk, period and
 | ||
| plus bullets along with numbered ordered lists:
 | ||
| 
 | ||
| 1. Position the cursor at the start of the list.
 | ||
| 2. Type `gq}`.
 | ||
| 
 | ||
| Indent Paragraphs
 | ||
| ^^^^^^^^^^^^^^^^^
 | ||
| Indent whole paragraphs by indenting the fist line with the desired
 | ||
| indent and then executing the `gq}` command.
 | ||
| 
 | ||
| [[X61]]
 | ||
| Example `~/.vimrc` File
 | ||
| ^^^^^^^^^^^^^^^^^^^^^^^
 | ||
| ---------------------------------------------------------------------
 | ||
| " Use bold bright fonts.
 | ||
| set background=dark
 | ||
| 
 | ||
| " Show tabs and trailing characters.
 | ||
| set listchars=tab:<3A><>,trail:<3A>
 | ||
| set list
 | ||
| 
 | ||
| " Don't highlight searched text.
 | ||
| highlight clear Search
 | ||
| 
 | ||
| " Don't move to matched text while search pattern is being entered.
 | ||
| set noincsearch
 | ||
| 
 | ||
| " Reformat paragraphs and list.
 | ||
| nnoremap R gq}
 | ||
| 
 | ||
| " Delete trailing white space and Dos-returns and to expand tabs to spaces.
 | ||
| nnoremap S :set et<CR>:retab!<CR>:%s/[\r \t]\+$//<CR>
 | ||
| 
 | ||
| autocmd BufRead,BufNewFile *.txt,README,TODO,CHANGELOG,NOTES
 | ||
|         \ setlocal autoindent expandtab tabstop=8 softtabstop=2 shiftwidth=2 filetype=asciidoc
 | ||
|         \ textwidth=70 wrap formatoptions=tcqn
 | ||
|         \ formatlistpat=^\\s*\\d\\+\\.\\s\\+\\\\|^\\s*<\\d\\+>\\s\\+\\\\|^\\s*[a-zA-Z.]\\.\\s\\+\\\\|^\\s*[ivxIVX]\\+\\.\\s\\+
 | ||
|         \ comments=s1:/*,ex:*/,://,b:#,:%,:XCOMM,fb:-,fb:*,fb:+,fb:.,fb:>
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| Troubleshooting
 | ||
| ~~~~~~~~~~~~~~~
 | ||
| AsciiDoc diagnostic features are detailed in the <<X82,Diagnostics
 | ||
| appendix>>.
 | ||
| 
 | ||
| Gotchas
 | ||
| ~~~~~~~
 | ||
| Incorrect character encoding::
 | ||
|     If you get an error message like `'UTF-8' codec can't decode ...`
 | ||
|     then you source file contains invalid UTF-8 characters -- set the
 | ||
|     AsciiDoc <<X54,encoding attribute>> for the correct character set
 | ||
|     (typically ISO-8859-1 (Latin-1) for European languages).
 | ||
| 
 | ||
| Invalid output::
 | ||
|     AsciiDoc attempts to validate the input AsciiDoc source but makes
 | ||
|     no attempt to validate the output markup, it leaves that to
 | ||
|     external tools such as `xmllint(1)` (integrated into `a2x(1)`).
 | ||
|     Backend validation cannot be hardcoded into AsciiDoc because
 | ||
|     backends are dynamically configured. The following example
 | ||
|     generates valid HTML but invalid DocBook (the DocBook `literal`
 | ||
|     element cannot contain an `emphasis` element):
 | ||
| 
 | ||
|     +monospaced text with an _emphasized_ word+
 | ||
| 
 | ||
| Misinterpreted text formatting::
 | ||
|     You can suppress markup expansion by placing a backslash character
 | ||
|     immediately in front of the element. The following example
 | ||
|     suppresses inline monospaced formatting:
 | ||
| 
 | ||
|     \+1 for C++.
 | ||
| 
 | ||
| Overlapping text formatting::
 | ||
|     Overlapping text formatting will generate illegal overlapping
 | ||
|     markup tags which will result in downstream XML parsing errors.
 | ||
|     Here's an example:
 | ||
| 
 | ||
|     Some *strong markup _that overlaps* emphasized markup_.
 | ||
| 
 | ||
| Ambiguous underlines::
 | ||
|     A DelimitedBlock can immediately follow a paragraph without an
 | ||
|     intervening blank line, but be careful, a single line paragraph
 | ||
|     underline may be misinterpreted as a section title underline
 | ||
|     resulting in a ``closing block delimiter expected'' error.
 | ||
| 
 | ||
| Ambiguous ordered list items::
 | ||
|     Lines beginning with numbers at the end of sentences will be
 | ||
|     interpreted as ordered list items.  The following example
 | ||
|     (incorrectly) begins a new list with item number 1999:
 | ||
| 
 | ||
|     He was last sighted in
 | ||
|     1999. Since then things have moved on.
 | ||
| +
 | ||
| The 'list item out of sequence' warning makes it unlikely that this
 | ||
| problem will go unnoticed.
 | ||
| 
 | ||
| Special characters in attribute values::
 | ||
|     Special character substitution precedes attribute substitution so
 | ||
|     if attribute values contain special characters you may, depending
 | ||
|     on the substitution context, need to escape the special characters
 | ||
|     yourself. For example:
 | ||
| 
 | ||
|     $ asciidoc -a 'orgname=Bill & Ben Inc.' mydoc.txt
 | ||
| 
 | ||
| Attribute lists::
 | ||
|     If any named attribute entries are present then all string
 | ||
|     attribute values must be quoted.  For example:
 | ||
| 
 | ||
|     ["Desktop screenshot",width=32]
 | ||
| 
 | ||
| [[X90]]
 | ||
| Combining separate documents
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| You have a number of stand-alone AsciiDoc documents that you want to
 | ||
| process as a single document. Simply processing them with a series of
 | ||
| `include` macros won't work because the documents contain (level 0)
 | ||
| document titles.  The solution is to create a top level wrapper
 | ||
| document and use the `leveloffset` attribute to push them all down one
 | ||
| level. For example:
 | ||
| 
 | ||
| [listing]
 | ||
| .....................................................................
 | ||
| Combined Document Title
 | ||
| =======================
 | ||
| 
 | ||
| // Push titles down one level.
 | ||
| :leveloffset: 1
 | ||
| 
 | ||
| \include::document1.txt[]
 | ||
| 
 | ||
| // Return to normal title levels.
 | ||
| :leveloffset: 0
 | ||
| 
 | ||
| A Top Level Section
 | ||
| -------------------
 | ||
| Lorum ipsum.
 | ||
| 
 | ||
| // Push titles down one level.
 | ||
| :leveloffset: 1
 | ||
| 
 | ||
| \include::document2.txt[]
 | ||
| 
 | ||
| \include::document3.txt[]
 | ||
| .....................................................................
 | ||
| 
 | ||
| The document titles in the included documents will now be processed as
 | ||
| level 1 section titles, level 1 sections as level 2 sections and so
 | ||
| on.
 | ||
| 
 | ||
| - Put a blank line between the `include` macro lines to ensure the
 | ||
|   title of the included document is not seen as part of the last
 | ||
|   paragraph of the previous document.
 | ||
| - You won't want non-title document header lines (for example, Author
 | ||
|   and Revision lines) in the included files -- conditionally exclude
 | ||
|   them if they are necessary for stand-alone processing.
 | ||
| 
 | ||
| Processing document sections separately
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| You have divided your AsciiDoc document into separate files (one per
 | ||
| top level section) which are combined and processed with the following
 | ||
| top level document:
 | ||
| 
 | ||
| ---------------------------------------------------------------------
 | ||
| Combined Document Title
 | ||
| =======================
 | ||
| Joe Bloggs
 | ||
| v1.0, 12-Aug-03
 | ||
| 
 | ||
| \include::section1.txt[]
 | ||
| 
 | ||
| \include::section2.txt[]
 | ||
| 
 | ||
| \include::section3.txt[]
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| You also want to process the section files as separate documents.
 | ||
| This is easy because asciidoc(1) will quite happily process
 | ||
| `section1.txt`, `section2.txt` and `section3.txt` separately -- the
 | ||
| resulting output documents contain the section but have no document
 | ||
| title.
 | ||
| 
 | ||
| Processing document snippets
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| Use the `-s` (`--no-header-footer`) command-line option to suppress
 | ||
| header and footer output, this is useful if the processed output is to
 | ||
| be included in another file. For example:
 | ||
| 
 | ||
|   $ asciidoc -sb docbook section1.txt
 | ||
| 
 | ||
| asciidoc(1) can be used as a filter, so you can pipe chunks of text
 | ||
| through it. For example:
 | ||
| 
 | ||
|   $ echo 'Hello *World!*' | asciidoc -s -
 | ||
|   <div class="paragraph"><p>Hello <strong>World!</strong></p></div>
 | ||
| 
 | ||
| Badges in HTML page footers
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| See the `[footer]` section in the AsciiDoc distribution `xhtml11.conf`
 | ||
| configuration file.
 | ||
| 
 | ||
| Pretty printing AsciiDoc output
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| If the indentation and layout of the asciidoc(1) output is not to your
 | ||
| liking you can:
 | ||
| 
 | ||
| 1. Change the indentation and layout of configuration file markup
 | ||
|    template sections. The `{empty}` attribute is useful for outputting
 | ||
|    trailing blank lines in markup templates.
 | ||
| 
 | ||
| 2. Use Dave Raggett's http://tidy.sourceforge.net/[HTML Tidy] program
 | ||
|    to tidy asciidoc(1) output. Example:
 | ||
| 
 | ||
|    $ asciidoc -b docbook -o - mydoc.txt | tidy -indent -xml >mydoc.xml
 | ||
| 
 | ||
| 3. Use the `xmllint(1)` format option. Example:
 | ||
| 
 | ||
|    $ xmllint --format mydoc.xml
 | ||
| 
 | ||
| Supporting minor DocBook DTD variations
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| The conditional inclusion of DocBook SGML markup at the end of the
 | ||
| distribution `docbook45.conf` file illustrates how to support minor
 | ||
| DTD variations. The included sections override corresponding entries
 | ||
| from preceding sections.
 | ||
| 
 | ||
| Creating stand-alone HTML documents
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| If you've ever tried to send someone an HTML document that includes
 | ||
| stylesheets and images you'll know that it's not as straight-forward
 | ||
| as exchanging a single file.  AsciiDoc has options to create
 | ||
| stand-alone documents containing embedded images, stylesheets and
 | ||
| scripts.  The following AsciiDoc command creates a single file
 | ||
| containing <<X66,embedded images>>, CSS stylesheets, and JavaScript
 | ||
| (for table of contents and footnotes):
 | ||
| 
 | ||
|   $ asciidoc -a data-uri -a icons -a toc -a max-width=55em article.txt
 | ||
| 
 | ||
| You can view the HTML file here: {website}article-standalone.html[]
 | ||
| 
 | ||
| Shipping stand-alone AsciiDoc source
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| Reproducing presentation documents from someone else's source has one
 | ||
| major problem: unless your configuration files are the same as the
 | ||
| creator's you won't get the same output.
 | ||
| 
 | ||
| The solution is to create a single backend specific configuration file
 | ||
| using the asciidoc(1) `-c` (`--dump-conf`) command-line option. You
 | ||
| then ship this file along with the AsciiDoc source document plus the
 | ||
| `asciidoc.py` script. The only end user requirement is that they have
 | ||
| Python installed (and that they consider you a trusted source). This
 | ||
| example creates a composite HTML configuration file for `mydoc.txt`:
 | ||
| 
 | ||
|   $ asciidoc -cb xhtml11 mydoc.txt > mydoc-xhtml11.conf
 | ||
| 
 | ||
| Ship `mydoc.txt`, `mydoc-html.conf`, and `asciidoc.py`. With
 | ||
| these three files (and a Python interpreter) the recipient can
 | ||
| regenerate the HMTL output:
 | ||
| 
 | ||
|   $ ./asciidoc.py -eb xhtml11 mydoc.txt
 | ||
| 
 | ||
| The `-e` (`--no-conf`) option excludes the use of implicit
 | ||
| configuration files, ensuring that only entries from the
 | ||
| `mydoc-html.conf` configuration are used.
 | ||
| 
 | ||
| Inserting blank space
 | ||
| ~~~~~~~~~~~~~~~~~~~~~
 | ||
| Adjust your style sheets to add the correct separation between block
 | ||
| elements. Inserting blank paragraphs containing a single non-breaking
 | ||
| space character `{nbsp}` works but is an ad hoc solution compared
 | ||
| to using style sheets.
 | ||
| 
 | ||
| Closing open sections
 | ||
| ~~~~~~~~~~~~~~~~~~~~~
 | ||
| You can close off section tags up to level `N` by calling the
 | ||
| `eval::[Section.setlevel(N)]` system macro. This is useful if you
 | ||
| want to include a section composed of raw markup. The following
 | ||
| example includes a DocBook glossary division at the top section level
 | ||
| (level 0):
 | ||
| 
 | ||
| ---------------------------------------------------------------------
 | ||
| \ifdef::basebackend-docbook[]
 | ||
| 
 | ||
| \eval::[Section.setlevel(0)]
 | ||
| 
 | ||
| +++++++++++++++++++++++++++++++
 | ||
| <glossary>
 | ||
|   <title>Glossary</title>
 | ||
|   <glossdiv>
 | ||
|   ...
 | ||
|   </glossdiv>
 | ||
| </glossary>
 | ||
| +++++++++++++++++++++++++++++++
 | ||
| \endif::basebackend-docbook[]
 | ||
| ---------------------------------------------------------------------
 | ||
| 
 | ||
| Validating output files
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~~
 | ||
| Use `xmllint(1)` to check the AsciiDoc generated markup is both well
 | ||
| formed and valid. Here are some examples:
 | ||
| 
 | ||
|   $ xmllint --nonet --noout --valid docbook-file.xml
 | ||
|   $ xmllint --nonet --noout --valid xhtml11-file.html
 | ||
|   $ xmllint --nonet --noout --valid --html html4-file.html
 | ||
| 
 | ||
| The `--valid` option checks the file is valid against the document
 | ||
| type's DTD, if the DTD is not installed in your system's catalog then
 | ||
| it will be fetched from its Internet location. If you omit the
 | ||
| `--valid` option the document will only be checked that it is well
 | ||
| formed.
 | ||
| 
 | ||
| The online http://validator.w3.org/#validate_by_uri+with_options[W3C
 | ||
| Markup Validation Service] is the defacto standard when it comes to
 | ||
| validating HTML (it validates all HTML standards including HTML5).
 | ||
| 
 | ||
| 
 | ||
| :numbered!:
 | ||
| 
 | ||
| [glossary]
 | ||
| Glossary
 | ||
| --------
 | ||
| [glossary]
 | ||
| [[X8]] Block element::
 | ||
|     An AsciiDoc block element is a document entity composed of one or
 | ||
|     more whole lines of text.
 | ||
| 
 | ||
| [[X34]] Inline element::
 | ||
|     AsciiDoc inline elements occur within block element textual
 | ||
|     content, they perform formatting and substitution tasks.
 | ||
| 
 | ||
| Formal element::
 | ||
|     An AsciiDoc block element that has a BlockTitle. Formal elements
 | ||
|     are normally listed in front or back matter, for example lists of
 | ||
|     tables, examples and figures.
 | ||
| 
 | ||
| Verbatim element::
 | ||
|     The word verbatim indicates that white space and line breaks in
 | ||
|     the source document are to be preserved in the output document.
 | ||
| 
 | ||
| 
 | ||
| [appendix]
 | ||
| Migration Notes
 | ||
| ---------------
 | ||
| [[X53]]
 | ||
| Version 7 to version 8
 | ||
| ~~~~~~~~~~~~~~~~~~~~~~
 | ||
| - A new set of quotes has been introduced which may match inline text
 | ||
|   in existing documents -- if they do you'll need to escape the
 | ||
|   matched text with backslashes.
 | ||
| - The index entry inline macro syntax has changed -- if your documents
 | ||
|   include indexes you may need to edit them.
 | ||
| - Replaced a2x(1) `--no-icons` and `--no-copy` options with their
 | ||
|   negated equivalents: `--icons` and `--copy` respectively. The
 | ||
|   default behavior has also changed -- the use of icons and copying of
 | ||
|   icon and CSS files must be specified explicitly with the `--icons`
 | ||
|   and `--copy` options.
 | ||
| 
 | ||
| The rationale for the changes can be found in the AsciiDoc
 | ||
| `CHANGELOG`.
 | ||
| 
 | ||
| NOTE: If you want to disable unconstrained quotes, the new alternative
 | ||
| constrained quotes syntax and the new index entry syntax then you can
 | ||
| define the attribute `asciidoc7compatible` (for example by using the
 | ||
| `-a asciidoc7compatible` command-line option).
 | ||
| 
 | ||
| [[X38]]
 | ||
| [appendix]
 | ||
| Packager Notes
 | ||
| --------------
 | ||
| Read the `README` and `INSTALL` files (in the distribution root
 | ||
| directory) for install prerequisites and procedures.  The distribution
 | ||
| `Makefile.in` (used by `configure` to generate the `Makefile`) is the
 | ||
| canonical installation procedure.
 | ||
| 
 | ||
| 
 | ||
| [[X39]]
 | ||
| [appendix]
 | ||
| AsciiDoc Safe Mode
 | ||
| -------------------
 | ||
| AsciiDoc 'safe mode' skips potentially dangerous scripted sections in
 | ||
| AsciiDoc source files by inhibiting the execution of arbitrary code or
 | ||
| the inclusion of arbitrary files.
 | ||
| 
 | ||
| The safe mode is disabled by default, it can be enabled with the
 | ||
| asciidoc(1) `--safe` command-line option.
 | ||
| 
 | ||
| .Safe mode constraints
 | ||
| - `eval`, `sys` and `sys2` executable attributes and block macros are
 | ||
|   not executed.
 | ||
| - `include::<filename>[]` and `include1::<filename>[]` block macro
 | ||
|   files must reside inside the parent file's directory.
 | ||
| - `{include:<filename>}` executable attribute files must reside
 | ||
|   inside the source document directory.
 | ||
| - Passthrough Blocks are dropped.
 | ||
| 
 | ||
| [WARNING]
 | ||
| =====================================================================
 | ||
| The safe mode is not designed to protect against unsafe AsciiDoc
 | ||
| configuration files. Be especially careful when:
 | ||
| 
 | ||
| 1. Implementing filters.
 | ||
| 2. Implementing elements that don't escape special characters.
 | ||
| 3. Accepting configuration files from untrusted sources.
 | ||
| =====================================================================
 | ||
| 
 | ||
| 
 | ||
| [appendix]
 | ||
| Using AsciiDoc with non-English Languages
 | ||
| -----------------------------------------
 | ||
| AsciiDoc can process UTF-8 character sets but there are some things
 | ||
| you need to be aware of:
 | ||
| 
 | ||
| - If you are generating output documents using a DocBook toolchain
 | ||
|   then you should set the AsciiDoc `lang` attribute to the appropriate
 | ||
|   language (it defaults to `en` (English)). This will ensure things
 | ||
|   like table of contents, figure and table captions and admonition
 | ||
|   captions are output in the specified language.  For example:
 | ||
| 
 | ||
|   $ a2x -a lang=es doc/article.txt
 | ||
| 
 | ||
| - If you are outputting HTML directly from asciidoc(1) you'll
 | ||
|   need to set the various `*_caption` attributes to match your target
 | ||
|   language (see the list of captions and titles in the `[attributes]`
 | ||
|   section of the distribution `lang-*.conf` files). The easiest way is
 | ||
|   to create a language `.conf` file (see the AsciiDoc's `lang-en.conf`
 | ||
|   file).
 | ||
| +
 | ||
| NOTE: You still use the 'NOTE', 'CAUTION', 'TIP', 'WARNING',
 | ||
| 'IMPORTANT' captions in the AsciiDoc source, they get translated in
 | ||
| the HTML output file.
 | ||
| 
 | ||
| - asciidoc(1) automatically loads configuration files named like
 | ||
|   `lang-<lang>.conf` where `<lang>` is a two letter language code that
 | ||
|   matches the current AsciiDoc `lang` attribute. See also
 | ||
|   <<X27,Configuration File Names and Locations>>.
 | ||
| 
 | ||
| 
 | ||
| [appendix]
 | ||
| Vim Syntax Highlighter
 | ||
| ----------------------
 | ||
| Syntax highlighting is incredibly useful, in addition to making
 | ||
| reading AsciiDoc documents much easier syntax highlighting also helps
 | ||
| you catch AsciiDoc syntax errors as you write your documents.
 | ||
| 
 | ||
| The AsciiDoc `./vim/` distribution directory contains Vim syntax
 | ||
| highlighter and filetype detection scripts for AsciiDoc.  Syntax
 | ||
| highlighting makes it much easier to spot AsciiDoc syntax errors.
 | ||
| 
 | ||
| If Vim is installed on your system the AsciiDoc installer
 | ||
| (`install.sh`) will automatically install the vim scripts in the Vim
 | ||
| global configuration directory (`/etc/vim`).
 | ||
| 
 | ||
| You can also turn on syntax highlighting by adding the following line
 | ||
| to the end of you AsciiDoc source files:
 | ||
| 
 | ||
|   // vim: set syntax=asciidoc:
 | ||
| 
 | ||
| TIP: Bold fonts are often easier to read, use the Vim `:set
 | ||
| background=dark` command to set bold bright fonts.
 | ||
| 
 | ||
| NOTE: There are a number of alternative syntax highlighters for
 | ||
| various editors listed on the {website}[AsciiDoc website].
 | ||
| 
 | ||
| Limitations
 | ||
| ~~~~~~~~~~~
 | ||
| The current implementation does a reasonable job but on occasions gets
 | ||
| things wrong:
 | ||
| 
 | ||
| - Nested quoted text formatting is highlighted according to the outer
 | ||
|   format.
 | ||
| - If a closing Example Block delimiter is sometimes mistaken for a
 | ||
|   title underline. A workaround is to insert a blank line before the
 | ||
|   closing delimiter.
 | ||
| - Lines within a paragraph starting with equals characters may be
 | ||
|   highlighted as single-line titles.
 | ||
| - Lines within a paragraph beginning with a period may be highlighted
 | ||
|   as block titles.
 | ||
| 
 | ||
| 
 | ||
| [[X74]]
 | ||
| [appendix]
 | ||
| Attribute Options
 | ||
| -----------------
 | ||
| Here is the list of predefined <<X75,attribute list options>>:
 | ||
| 
 | ||
| 
 | ||
| [cols="2e,2,2,5",frame="topbot",options="header"]
 | ||
| |====================================================================
 | ||
| |Option|Backends|AsciiDoc Elements|Description
 | ||
| 
 | ||
| |autowidth |xhtml11, html5, html4 |table|
 | ||
| The column widths are determined by the browser, not the AsciiDoc
 | ||
| 'cols' attribute. If there is no 'width' attribute the table width is
 | ||
| also left up to the browser.
 | ||
| 
 | ||
| |unbreakable |xhtml11, html5 |block elements|
 | ||
| 'unbreakable' attempts to keep the block element together on a single
 | ||
| printed page c.f. the 'breakable' and 'unbreakable' docbook (XSL/FO)
 | ||
| options below.
 | ||
| 
 | ||
| |breakable, unbreakable |docbook (XSL/FO) |table, example, block image|
 | ||
| The 'breakable' options allows block elements to break across page
 | ||
| boundaries; 'unbreakable' attempts to keep the block element together
 | ||
| on a single page. If neither option is specified the default XSL
 | ||
| stylesheet behavior prevails.
 | ||
| 
 | ||
| |compact |docbook, xhtml11, html5 |bulleted list, numbered list|
 | ||
| Minimizes vertical space in the list
 | ||
| 
 | ||
| |footer |docbook, xhtml11, html5, html4 |table|
 | ||
| The last row of the table is rendered as a footer.
 | ||
| 
 | ||
| |header |docbook, xhtml11, html5, html4 |table|
 | ||
| The first row of the table is rendered as a header.
 | ||
| 
 | ||
| |pgwide |docbook (XSL/FO) |table, block image, horizontal labeled list|
 | ||
| Specifies that the element should be rendered across the full text
 | ||
| width of the page irrespective of the current indentation.
 | ||
| 
 | ||
| |strong |xhtml11, html5, html4 |labeled lists|
 | ||
| Emboldens label text.
 | ||
| |====================================================================
 | ||
| 
 | ||
| 
 | ||
| [[X82]]
 | ||
| [appendix]
 | ||
| Diagnostics
 | ||
| -----------
 | ||
| The `asciidoc(1)` `--verbose` command-line option prints additional
 | ||
| information to stderr: files processed, filters processed, warnings,
 | ||
| system attribute evaluation.
 | ||
| 
 | ||
| A special attribute named 'trace' enables the output of
 | ||
| element-by-element diagnostic messages detailing output markup
 | ||
| generation to stderr.  The 'trace' attribute can be set on the
 | ||
| command-line or from within the document using <<X18,Attribute
 | ||
| Entries>> (the latter allows tracing to be confined to specific
 | ||
| portions of the document).
 | ||
| 
 | ||
| - Trace messages print the source file name and line number and the
 | ||
|   trace name followed by related markup.
 | ||
| - 'trace names' are normally the names of AsciiDoc elements (see the
 | ||
|   list below).
 | ||
| - The trace message is only printed if the 'trace' attribute value
 | ||
|   matches the start of a 'trace name'. The 'trace' attribute value can
 | ||
|   be any Python regular expression.  If a trace value is not specified
 | ||
|   all trace messages will be printed (this can result in large amounts
 | ||
|   of output if applied to the whole document).
 | ||
| 
 | ||
| - In the case of inline substitutions:
 | ||
|   * The text before and after the substitution is printed; the before
 | ||
|     text is preceded by a line containing `<<<` and the after text by
 | ||
|     a line containing `>>>`.
 | ||
|   * The 'subs' trace value is an alias for all inline substitutions.
 | ||
| 
 | ||
| .Trace names
 | ||
| .....................................................................
 | ||
| <blockname> block close
 | ||
| <blockname> block open
 | ||
| <subs>
 | ||
| dropped line (a line containing an undefined attribute reference).
 | ||
| floating title
 | ||
| footer
 | ||
| header
 | ||
| list close
 | ||
| list entry close
 | ||
| list entry open
 | ||
| list item close
 | ||
| list item open
 | ||
| list label close
 | ||
| list label open
 | ||
| list open
 | ||
| macro block (a block macro)
 | ||
| name (man page NAME section)
 | ||
| paragraph
 | ||
| preamble close
 | ||
| preamble open
 | ||
| push blockname
 | ||
| pop blockname
 | ||
| section close
 | ||
| section open: level <level>
 | ||
| subs (all inline substitutions)
 | ||
| table
 | ||
| .....................................................................
 | ||
| 
 | ||
| Where:
 | ||
| 
 | ||
| - `<level>` is section level number '0...4'.
 | ||
| - `<blockname>` is a delimited block name: 'comment', 'sidebar',
 | ||
|   'open', 'pass', 'listing', 'literal', 'quote', 'example'.
 | ||
| - `<subs>` is an inline substitution type:
 | ||
|   'specialcharacters','quotes','specialwords', 'replacements',
 | ||
|   'attributes','macros','callouts', 'replacements2', 'replacements3'.
 | ||
| 
 | ||
| Command-line examples:
 | ||
| 
 | ||
| . Trace the entire document.
 | ||
| 
 | ||
|   $ asciidoc -a trace mydoc.txt
 | ||
| 
 | ||
| . Trace messages whose names start with `quotes` or `macros`:
 | ||
| 
 | ||
|   $ asciidoc -a 'trace=quotes|macros'  mydoc.txt
 | ||
| 
 | ||
| . Print the first line of each trace message:
 | ||
| 
 | ||
|   $ asciidoc -a trace mydoc.txt 2>&1 | grep ^TRACE:
 | ||
| 
 | ||
| Attribute Entry examples:
 | ||
| 
 | ||
| . Begin printing all trace messages:
 | ||
| 
 | ||
|   :trace:
 | ||
| 
 | ||
| . Print only matched trace messages:
 | ||
| 
 | ||
|   :trace: quotes|macros
 | ||
| 
 | ||
| . Turn trace messages off:
 | ||
| 
 | ||
|   :trace!:
 | ||
| 
 | ||
| 
 | ||
| [[X88]]
 | ||
| [appendix]
 | ||
| Backend Attributes
 | ||
| ------------------
 | ||
| This table contains a list of optional attributes that influence the
 | ||
| generated outputs.
 | ||
| 
 | ||
| [cols="1e,1,5a",frame="topbot",options="header"]
 | ||
| |====================================================================
 | ||
| |Name |Backends |Description
 | ||
| 
 | ||
| |badges |xhtml11, html5 |
 | ||
| Link badges ('XHTML 1.1' and 'CSS') in document footers. By default
 | ||
| badges are omitted ('badges' is undefined).
 | ||
| 
 | ||
| NOTE: The path names of images, icons and scripts are relative path
 | ||
| names to the output document not the source document.
 | ||
| 
 | ||
| |data-uri |xhtml11, html5 |
 | ||
| Embed images using the <<X66,data: uri scheme>>.
 | ||
| 
 | ||
| |css-signature |html5, xhtml11 |
 | ||
| Set a 'CSS signature' for the document (sets the 'id' attribute of the
 | ||
| HTML 'body' element). CSS signatures provide a mechanism that allows
 | ||
| users to personalize the document appearance. The term 'CSS signature'
 | ||
| was http://archivist.incutio.com/viewlist/css-discuss/13291[coined by
 | ||
| Eric Meyer].
 | ||
| 
 | ||
| 
 | ||
| |disable-javascript |xhtml11, html5 |
 | ||
| If the `disable-javascript` attribute is defined the `asciidoc.js`
 | ||
| JavaScript is not embedded or linked to the output document.  By
 | ||
| default AsciiDoc automatically embeds or links the `asciidoc.js`
 | ||
| JavaScript to the output document. The script dynamically generates
 | ||
| <<X91,table of contents>> and <<X92,footnotes>>.
 | ||
| 
 | ||
| |[[X97]] docinfo, docinfo1, docinfo2 |All backends |
 | ||
| These three attributes control which <<X87,document information
 | ||
| files>> will be included in the the header of the output file:
 | ||
| 
 | ||
| docinfo:: Include `<filename>-docinfo.<ext>`
 | ||
| docinfo1:: Include `docinfo.<ext>`
 | ||
| docinfo2:: Include `docinfo.<ext>` and `<filename>-docinfo.<ext>`
 | ||
| 
 | ||
| Where `<filename>` is the file name (sans extension) of the AsciiDoc
 | ||
| input file and `<ext>` is `.html` for HTML outputs or `.xml` for
 | ||
| DocBook outputs. If the input file is the standard input then the
 | ||
| output file name is used. The following example will include the
 | ||
| `mydoc-docinfo.xml` docinfo file in the DocBook `mydoc.xml` output
 | ||
| file:
 | ||
| 
 | ||
|   $ asciidoc -a docinfo -b docbook mydoc.txt
 | ||
| 
 | ||
| This next example will include `docinfo.html` and `mydoc-docinfo.html`
 | ||
| docinfo files in the HTML output file:
 | ||
| 
 | ||
|   $ asciidoc -a docinfo2 -b html4 mydoc.txt
 | ||
| 
 | ||
| 
 | ||
| |[[X54]]encoding |html4, html5, xhtml11, docbook |
 | ||
| Set the input and output document character set encoding. For example
 | ||
| the `--attribute encoding=ISO-8859-1` command-line option will set the
 | ||
| character set encoding to `ISO-8859-1`.
 | ||
| 
 | ||
| - The default encoding is UTF-8.
 | ||
| - This attribute specifies the character set in the output document.
 | ||
| - The encoding name must correspond to a Python codec name or alias.
 | ||
| - The 'encoding' attribute can be set using an AttributeEntry inside
 | ||
|   the document header. For example:
 | ||
| 
 | ||
|   :encoding: ISO-8859-1
 | ||
| 
 | ||
| |[[X45]]icons |xhtml11, html5 |
 | ||
| Link admonition paragraph and admonition block icon images and badge
 | ||
| images. By default 'icons' is undefined and text is used in place of
 | ||
| icon images.
 | ||
| 
 | ||
| |[[X44]]iconsdir |html4, html5, xhtml11, docbook |
 | ||
| The name of the directory containing linked admonition icons,
 | ||
| navigation icons and the `callouts` sub-directory (the `callouts`
 | ||
| sub-directory contains <<X105,callout>> number images). 'iconsdir'
 | ||
| defaults to `./images/icons`.
 | ||
| 
 | ||
| |imagesdir |html4, html5, xhtml11, docbook |
 | ||
| If this attribute is defined it is prepended to the target image file
 | ||
| name paths in inline and block image macros.
 | ||
| 
 | ||
| |keywords, description, title |html4, html5, xhtml11 |
 | ||
| The 'keywords' and 'description' attributes set the correspondingly
 | ||
| named HTML meta tag contents; the 'title' attribute sets the HTML
 | ||
| title tag contents.  Their principle use is for SEO (Search Engine
 | ||
| Optimisation).  All three are optional, but if they are used they must
 | ||
| appear in the document header (or on the command-line). If 'title' is
 | ||
| not specified the AsciiDoc document title is used.
 | ||
| 
 | ||
| |linkcss |html5, xhtml11 |
 | ||
| Link CSS stylesheets and JavaScripts. By default 'linkcss' is
 | ||
| undefined in which case stylesheets and scripts are automatically
 | ||
| embedded in the output document.
 | ||
| 
 | ||
| |[[X103]]max-width |html5, xhtml11 |
 | ||
| Set the document maximum display width (sets the 'body' element CSS
 | ||
| 'max-width' property).
 | ||
| 
 | ||
| |numbered |html4, html5, xhtml11, docbook (XSL Stylesheets) |
 | ||
| Adds section numbers to section titles. The 'docbook' backend ignores
 | ||
| 'numbered' attribute entries after the document header.
 | ||
| 
 | ||
| |plaintext | All backends |
 | ||
| If this global attribute is defined all inline substitutions are
 | ||
| suppressed and block indents are retained.  This option is useful when
 | ||
| dealing with large amounts of imported plain text.
 | ||
| 
 | ||
| |quirks |xhtml11 |
 | ||
| Include the `xhtml11-quirks.conf` configuration file and
 | ||
| `xhtml11-quirks.css` <<X35,stylesheet>> to work around IE6 browser
 | ||
| incompatibilities. This feature is deprecated and its use is
 | ||
| discouraged -- documents are still viewable in IE6 without it.
 | ||
| 
 | ||
| |revremark |docbook |
 | ||
| A short summary of changes in this document revision. Must be defined
 | ||
| prior to the first document section. The document also needs to be
 | ||
| dated to output this attribute.
 | ||
| 
 | ||
| |scriptsdir |html5, xhtml11 |
 | ||
| The name of the directory containing linked JavaScripts.
 | ||
| See <<X35,HTML stylesheets and JavaScript locations>>.
 | ||
| 
 | ||
| |sgml |docbook45 |
 | ||
| The `--backend=docbook45` command-line option produces DocBook 4.5
 | ||
| XML.  You can produce the older DocBook SGML format using the
 | ||
| `--attribute sgml` command-line option.
 | ||
| 
 | ||
| |stylesdir |html5, xhtml11 |
 | ||
| The name of the directory containing linked or embedded
 | ||
| <<X35,stylesheets>>.
 | ||
| See <<X35,HTML stylesheets and JavaScript locations>>.
 | ||
| 
 | ||
| |stylesheet |html5, xhtml11 |
 | ||
| The file name of an optional additional CSS <<X35,stylesheet>>.
 | ||
| 
 | ||
| |theme |html5, xhtml11 |
 | ||
| Use alternative stylesheet (see <<X35,Stylesheets>>).
 | ||
| 
 | ||
| |[[X91]]toc |html5, xhtml11, docbook (XSL Stylesheets) |
 | ||
| Adds a table of contents to the start of an article or book document.
 | ||
| The `toc` attribute can be specified using the `--attribute toc`
 | ||
| command-line option or a `:toc:` attribute entry in the document
 | ||
| header. The 'toc' attribute is defined by default when the 'docbook'
 | ||
| backend is used. To disable table of contents generation undefine the
 | ||
| 'toc' attribute by putting a `:toc!:` attribute entry in the document
 | ||
| header or from the command-line with an `--attribute toc!` option.
 | ||
| 
 | ||
| *xhtml11 and html5 backends*
 | ||
| 
 | ||
| - JavaScript needs to be enabled in your browser.
 | ||
| - The following example generates a numbered table of contents using a
 | ||
|   JavaScript embedded in the `mydoc.html` output document:
 | ||
| 
 | ||
|   $ asciidoc -a toc -a numbered mydoc.txt
 | ||
| 
 | ||
| |toc2 |html5, xhtml11 |
 | ||
| Adds a scrollable table of contents in the left hand margin of an
 | ||
| article or book document. Use the 'max-width' attribute to change the
 | ||
| content width. In all other respects behaves the same as the 'toc'
 | ||
| attribute.
 | ||
| 
 | ||
| |toc-placement |html5, xhtml11 |
 | ||
| When set to 'auto' (the default value) asciidoc(1) will place the
 | ||
| table of contents in the document header. When 'toc-placement' is set
 | ||
| to 'manual' the TOC can be positioned anywhere in the document by
 | ||
| placing the `toc::[]` block macro at the point you want the TOC to
 | ||
| appear.
 | ||
| 
 | ||
| NOTE: If you use 'toc-placement' then you also have to define the
 | ||
| <<X91,toc>> attribute.
 | ||
| 
 | ||
| |toc-title |html5, xhtml11 |
 | ||
| Sets the table of contents title (defaults to 'Table of Contents').
 | ||
| 
 | ||
| |toclevels |html5, xhtml11 |
 | ||
| Sets the number of title levels (1..4) reported in the table of
 | ||
| contents (see the 'toc' attribute above). Defaults to 2 and must be
 | ||
| used with the 'toc' attribute. Example usage:
 | ||
| 
 | ||
|   $ asciidoc -a toc -a toclevels=3 doc/asciidoc.txt
 | ||
| 
 | ||
| |====================================================================
 | ||
| 
 | ||
| 
 | ||
| [appendix]
 | ||
| License
 | ||
| -------
 | ||
| AsciiDoc is free software; you can redistribute it and/or modify it
 | ||
| under the terms of the 'GNU General Public License version 2' (GPLv2)
 | ||
| as published by the Free Software Foundation.
 | ||
| 
 | ||
| AsciiDoc 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.  See the GNU
 | ||
| General Public License version 2 for more details.
 | ||
| 
 | ||
| AsciiDoc Highlighter sponsored by O'Reilly Media
 | ||
| 
 | ||
| Copyright (C) 2002-2011 Stuart Rackham.
 |