246 lines
8.2 KiB

////
Included in:
- user-manual: docinfo
////
You can add custom content to the head or footer of an output document using docinfo files.
Docinfo files are useful for injecting auxiliary metadata, stylesheet, and script information into the output not added by the converter.
Different docinfo files get used depending on whether you are converting to HTML or DocBook (but don't yet apply when converting to PDF).
=== Head docinfo files
The content of head docinfo files gets injected into the top of the document.
For HTML, the content is append to the `<head>` element.
For DocBook, the content is appended to the root `<info>` element.
The docinfo file for HTML output may contain valid elements to populate the HTML `<head>` element, including:
* `<base>`
* `<link>`
* `<meta>`
* `<noscript>`
* `<script>`
* `<style>`
CAUTION: Use of the `<title>` element is not recommend as it's already emitted by the converter.
You do not need to include the enclosing `<head>` tag as it's assumed to be the envelope.
Here's an example:
.A head docinfo file for HTML output
[source,html]
----
<meta name="keywords" content="open source, documentation">
<meta name="description" content="The dangerous and thrilling adventures of an open source documentation team.">
<link rel="stylesheet" href="basejump.css">
<script src="map.js"></script>
----
Docinfo files for HTML output must be saved with the `.html` file extension.
See <<Naming docinfo files>> for more details.
The docinfo file for DocBook 5.0 output may include any of the {docbook-info-ref}[`<info>` element's children], such as:
* `<address>`
* `<copyright>`
* `<edition>`
* `<keywordset>`
* `<publisher>`
* `<subtitle>`
* `<revhistory>`
The following example shows some of the content a docinfo file for DocBook might contain.
.A docinfo file for DocBook 5.0 output
[source,xml]
----
<author>
<personname>
<firstname>Karma</firstname>
<surname>Chameleon</surname>
</personname>
<affiliation>
<jobtitle>Word SWAT Team Leader</jobtitle>
</affiliation>
</author>
<keywordset>
<keyword>open source</keyword>
<keyword>documentation</keyword>
<keyword>adventure</keyword>
</keywordset>
<printhistory>
<para>April, 2019. Twenty-sixth printing.</para>
</printhistory>
----
Docinfo files for DocBook output must be saved with the `.xml` file extension.
See <<Naming docinfo files>> for more details.
To see a real-world example of a docinfo file for DocBook, checkout the {richfaces-docinfo}[RichFaces Developer Guide docinfo file].
=== Footer docinfo files
Footer docinfo files are differentiated from head docinfo files by the addition of `-footer` to the file name.
In the HTML output, the footer content is inserted immediately after the footer div (i.e., `<div id="footer">`).
In the DocBook output, the footer content is inserted immediately before the ending tag (e.g., `</article>` or `</book>`).
TIP: One possible use of the footer docinfo file is to completely replace the default footer in the standard stylesheet.
Just set the attribute `nofooter`, then apply a custom footer docinfo file.
// Not here! Good info, but does nothing to clarify the previous paragraphs and could confuse.
////
TIP: To change the text in the "Last updated" line in the footer, set the text in the attribute `last-update-label` (for example, `:last-update-label: <your text> Last Updated`). +
To disable the "Last updated" line in the footer, unassign the attribute `last-update-label` (however, this leaves an empty footer div). +
To disable the footer completely, set the attribute `nofooter`. Then having a footer docinfo file effectively replaces the default footer with your custom footer.
////
=== Naming docinfo files
The file that gets selected to provide the docinfo depends on which converter is in use (html, docbook, etc) and whether the docinfo scope is configured for a specific document ("`private`") or for all documents in the same directory ("`shared`").
The file extension of the docinfo file must match the file extension of the output file (as specified by the `outfilesuffix` attribute, a value which always begins with a period (`.`)).
.Docinfo file naming
[cols="<10,<20,<30,<30"]
|====
|Mode |Location |Behavior |Docinfo file name
.2+|Private
|Head
|Adds content to `<head>`/`<info>` for <docname>.adoc files.
|`<docname>-docinfo<outfilesuffix>`
|Footer
|Adds content to end of document for <docname>.adoc files.
|`<docname>-docinfo-footer<outfilesuffix>`
.2+|Shared
|Head
|Adds content to `<head>`/`<info>` for any document in same directory.
|`docinfo<outfilesuffix>`
|Footer
|Adds content to end of document for any document in same directory.
|`docinfo-footer<outfilesuffix>`
|====
To specify which file(s) you want to apply, set the `docinfo` attribute to any combination of these values:
* `private-head`
* `private-footer`
* `private` (alias for `private-head,private-footer`)
* `shared-head`
* `shared-footer`
* `shared` (alias for `shared-head,shared-footer`)
Setting `docinfo` with no value is equivalent to setting the value to `private`.
For example:
[source]
----
:docinfo: shared,private-footer
----
This docinfo configuration will apply the shared docinfo head and footer files, if they exist, as well as the private footer file, if it exists.
// NOTE migrate this NOTE to the migration guide once 1.6 is released
[NOTE]
====
`docinfo` attribute values were introduced in Asciidoctor 1.5.5 to replace the less descriptive `docinfo1` and `docinfo2` attributes.
Here are the equivalents of the old attributes using the new values:
* `:docinfo:` = `:docinfo: private`
* `:docinfo1:` = `:docinfo: shared`
* `:docinfo2:` = `:docinfo: shared,private`
====
Let's apply this to an example:
You have two AsciiDoc documents, adventure.adoc and insurance.adoc, saved in the same folder.
You want to add the same content to the head of both documents when they're converted to HTML.
. Create a docinfo file containing `<head>` elements.
. Save it as docinfo.html.
. Set the `docinfo` attribute in adventure.adoc and insurance.adoc to `shared`.
You also want to include some additional content, but only to the head of adventure.adoc.
. Create *another* docinfo file containing `<head>` elements.
. Save it as adventure-docinfo.html.
. Set the `docinfo` attribute in adventure.adoc to `shared,private-head`
If other AsciiDoc files are added to the same folder, and `docinfo` is set to `shared` in those files, only the docinfo.html file will be added when converting those files.
=== Locating docinfo files
By default, docinfo files are searched for in the same folder as the document file.
If you want to keep them anywhere else, set the `docinfodir` attribute to their location:
[source]
----
:docinfodir: common/meta
----
Note that if you use this attribute, only the specified folder will be searched; docinfo files in the document folder will no longer be found.
=== Attribute substitution in docinfo files
Docinfo files may include attribute references.
Which substitutions get applied is controlled by the `docinfosubs` attribute, which takes a comma-separated list of substitution names.
The value of this attribute defaults to `attributes`.
For example, if you created the following docinfo file:
.Docinfo file containing a revnumber attribute reference
[source,xml]
----
<edition>{revnumber}</edition>
----
And this source document:
.Source document including a revision number
[source,asciidoc]
----
= Document Title
Author Name
v1.0, 2019-06-01
:doctype: book
:backend: docbook
:docinfo:
----
Then the converted DocBook output would be:
[source,xml]
----
<?xml version="1.0" encoding="UTF-8"?>
<book xmlns="http://docbook.org/ns/docbook"
xmlns:xlink="http://www.w3.org/1999/xlink" version="5.0" lang="en">
<info>
<title>Document Title</title>
<date>2019-06-01</date>
<author>
<personname>
<firstname>Author</firstname>
<surname>Name</surname>
</personname>
</author>
<authorinitials>AN</authorinitials>
<revhistory>
<revision>
<revnumber>1.0</revnumber> <!--1-->
<date>2019-06-01</date>
<authorinitials>AN</authorinitials>
</revision>
</revhistory>
</info>
</book>
----
<1> The revnumber attribute reference was replaced by the source document's revision number in the converted output.