7 Structure and markup #
This chapter contains instructions on using the correct markup to create consistent and legible documents, and structuring the content in the way that it effectively helps readers find answers to their queries.
In the Doc Kit repository, you can see examples of how books and articles are rendered in our documentation.
SUSE uses the GeekoDoc Relax NG schema which is compatible with DocBook 5.2. For more information about the XML elements described here, see the DocBook 5.2: The Definitive Guide sections listed in Table 7.1, “Important elements”.
| Element | Web link | 
|---|---|
| <appendix/> | https://tdg.docbook.org/tdg/5.2/appendix.html | 
| <book/> | https://tdg.docbook.org/tdg/5.2/book.html | 
| <chapter/> | https://tdg.docbook.org/tdg/5.2/chapter.html | 
| <glossary/> | https://tdg.docbook.org/tdg/5.2/glossary.html | 
| <part/> | https://tdg.docbook.org/tdg/5.2/part.html | 
| <preface/> | https://tdg.docbook.org/tdg/5.2/preface.html | 
| <sect1/> | https://tdg.docbook.org/tdg/5.2/sect1.html | 
7.1 Admonitory and advisory paragraphs #
To make readers aware of potential problems and recent changes, or to give them tips, use an admonition element. Avoid using more than one admonition per page of PDF output.
- <warning/>. Use these elements to warn of security issues, potential loss of data, damage to hardware, or physical hazards. Warnings must always precede the action to which they apply.
- <important/>. Use these elements to give vital information.
- <tip/>. Use these elements to introduce guidelines or give tips.
- <note/>. Use these elements to highlight software version differences.
Follow these rules when writing admonitions:
- Add a title to admonitions. In the title, state the subject of the admonition and, in the case of a warning, also the source of danger. 
- <warning/>or- <important/>: In the first paragraph, clearly state possible consequences of ignoring the danger.
- <warning/>or- <important/>: In the second paragraph, explain how to avoid the danger. If there are multiple ways to avoid a danger, use an unordered list. If fewer than five consecutive steps must be taken to avoid a danger, use an ordered list. If more than five consecutive steps need to be taken, use a cross-reference to another part of the documentation.
<warning> <title>Do not interrupt creation of file systems</title> <para> Creating a file system can take multiple hours. Interrupting this process will result in a corrupt file system and an unusable installation. </para> <para> Always wait until formatting has finished. </para> </warning>
Creating a file system can take multiple hours. Interrupting this process will result in a corrupt file system and an unusable installation.
Always wait until formatting has finished.
7.2 Application names #
      When referring to an application, add a <phrase
      role="productname"/> element around it:
    
<phrase role="productname">LibreOffice</phrase> is an office suite.
This will not result in a visual change but disables hyphenation in browsers. This markup sidesteps hyphenation issues of CamelCased names.
7.3 Callouts #
Callouts allow annotating examples, such as configuration files or commands with many options. Add callout elements directly after the part of a verbatim block that you want to annotate. Do not try to align them above the part of a screen to annotate. Do not use more than ten callouts per example.
See also Section 7.7, “Examples”.
<screen>color white/blue black/light-gray <co xml:id="co-color"/> default 0 <co xml:id="co-default"/></screen> <calloutlist> <callout arearefs="co-color"> <para> Colors of the boot loader menu. </para> </callout> <callout arearefs="co-default"> <para> Defines the preselected option. </para> </callout> </calloutlist>
<callout/> #| Element | Web link | 
|---|---|
| 
 | https://tdg.docbook.org/tdg/5.2/co.html | 
| 
 | https://tdg.docbook.org/tdg/5.2/calloutlist.html | 
| 
 | https://tdg.docbook.org/tdg/5.2/callout.html | 
You can group different callouts to point to the same annotation. This helps to avoid repeating the same annotation. To do this, complete the following steps:
- Create the - <co/>element with the- <xml:id/>attribute to comment on the first line.
- On another line, use the - <xref/>element to point to the ID from the previous step.
d1 = dict() <co xml:id="co-dict"/>
  d2 = {} <xref linkend="co-dict"/>
  l1 = list() <co xml:id="co-list"/>
  l2 = [] <xref xml:id="co-list"/>
    <calloutlist>
    <callout arearefs="co-dict">
      <para>A dictionary.</para>
    </callout>
    <callout arearefs="co-list">
      <para>A list.</para>
    </callout>
  </calloutlist>7.4 Command-line input and command-line output #
      When dealing with user input and system output shorter than 30 characters,
      surround it with an inline element, such as
      <command/> or
      <filename/>. In all other
      cases, close the current paragraph and enclose the user input and/or
      system output in a verbatim block. See also Section 7.7, “Examples”.
    
When using a stand-alone command elements outside of a verbatim block, do not use prompt elements before or within them. For more information about prompts, see Section 7.4.5, “Prompts”.
| Element | Web link | 
|---|---|
| 
 | https://tdg.docbook.org/tdg/5.2/screen.html | 
| 
 | https://tdg.docbook.org/tdg/5.2/command.html | 
| 
 | https://tdg.docbook.org/tdg/5.2/option.html | 
| 
 | https://tdg.docbook.org/tdg/5.2/replaceable.html | 
| 
 | https://tdg.docbook.org/tdg/5.2/filename.html | 
| 
 | https://tdg.docbook.org/tdg/5.2/varname.html | 
7.4.1 Commands #
        Commands can be embedded in running text or presented as part of a
        screen environment. In running text, use
        
        <command/> when referring to
        an actual command you would use on a command line:
      
To start LibreOffice from the command line, use <command>loffice</command>.
Where options or subcommands belong with a command, include them within the command itself:
To start LibreOffice Writer from the command line, use <command>loffice --writer</command>.
        If options or subcommands stand for themselves in a text, wrap them in
        the element
        <option/>.
      
        Use markup for commands even inside
        <screen/> environments. To
        avoid spelling or capitalization errors, whenever possible, try commands
        before adding them to the documentation.
      
See also Section 7.4.5, “Prompts”.
7.4.2 File names #
A file name is the name of a file on a local or network disk. Can contain a simple name or include a path or other elements specific to the operating system. See also Section 6.9, “File and directory names”.
Find the log file <filename>configuration.xml</filename> in the directory <filename>/etc/sysconfig</filename>.
To assign standard names to files and images in DocBook and AsciiDoc, follow the naming conventions at https://github.com/SUSE/doc-modular/blob/main/templates/README.md.
7.4.3 Literals #
        Use
        <literal/> to mark up data taken literally from a
        computer system.
      
To create a comment, insert <literal>#</literal> characters.
7.4.4 Placeholders #
        To mark up text that readers need to replace, use
        the
        <replaceable/>
        element. Capitalize placeholder text in all contexts where
        this is not detrimental to content intelligibility. Do not use spaces
        within placeholders. Instead, use underscores (_).
      
To list the contents of a directory, execute <command>ls <replaceable>DIRECTORY</replaceable></command>.
7.4.5 Prompts #
When documenting commands entered into Bash with a verbatim block, always prefix them with a prompt marked up this way:
<prompt>> </prompt><command>ls</command>
To avoid making prompts longer than necessary, do not include paths, user or host names, unless this is vital to understanding. The first restricted user must always be named tux. For more information about names of restricted users, see Chapter 3, Names of example items.
        Whenever you provide commands in a verbatim block, make it clear if the
        user needs regular or elevated privileges. Avoid using root prompts in
        your documentation by using the sudo command where
        applicable. If you do need a root prompt, always mark it up as follows:
      
<prompt role="root"># </prompt><command>yast</command>
When documenting prompts other than the one of Bash, use a custom prompt that is as generic as possible.
For consistency, it is helpful to create entities (attributes) for the prompts used in your documentation. Doc Kit repository contains entities for user, root and sudo prompts. For more information, see Section 9.3, “Entities”.
7.4.6 Verbatim blocks #
Verbatim blocks (“screens”) are used to present:
- long commands and commands together with their output 
- system output, such as system messages 
- code or configuration examples - <screen><prompt>tux > </prompt><command>ls /</command> bin dev lib mnt proc sbin suse usr boot etc lib64 mounts root selinux sys var data home lost+found opt run srv tmp</screen> 
- Use screens only where necessary for understanding the documentation. Present longer screens as examples. For more information, see Section 7.7, “Examples”. 
- Do not add empty lines at the beginning or end of screens. They can be cut away by the SUSE style sheets. However, most other style sheets do not have such functionality. 
- Text in screens must not follow the indentation level of the XML around them: All indentation will be reproduced verbatim. 
- Lines in a screen must be at most 80 characters long. If you are working in a structure with less available space, such as within a list or within a table, work with appropriate shorter line lengths. 
- Avoid command output that contains dates, version numbers, or other version-specific information that frequently changes. 
- To make long shell commands less unwieldy, split them into multiple lines at appropriate positions, such as after the end of an option. At the end of each line but the last, append a - \. The character- \informs the shell that the command invocation will continue after the end of the line. Splitting commands into lines can also be helpful for aligning callouts with the right option.
- You can combine multiple commands within a - <screen/>element, if:- all commands are explained unambiguously before the - <screen/>element and
- all commands are strictly consecutive and none is optional. 
 - In all other cases, do not combine multiple commands within one - <screen/>element. Instead, use multiple- <screen/>elements. For example, as part of a multi-step procedure.- If you show multiple commands within a single - <screen/>, use prompts before each command and- <command/>elements around commands. This effectively separates commands from each other and their output.
- To work with long output, especially tabular output, use either of the following strategies: - Remove or replace items that are irrelevant to your goal. For example, replace long file names with shorter ones or remove a table column and replace it with - [...].
- Use a processing instruction at the beginning of the screen to decrease font size: - <?dbsuse-fo font-size="SIZEem"?> - Replace SIZE with a suitable value, such - 0.7. Choose a value between- 0.55and- 1. Values outside that range will lead to either unreadably small or unsuitably large text.
 
- To enable automatic syntax highlighting for programming languages or formats, add a - languageattribute for the respective language format. Valid language formats:- apache,- bash,- c++,- css,- diff,- html,- xml,- http,- ini,- json,- java,- javascript,- makefile,- nginx,- php,- perl,- python,- ruby,- sql,- crmsh,- dockerfile,- lisp, and- yaml.- Note that syntax highlighting may not be supported in all target formats. 
See also Section 7.7, “Examples”, Section 7.4.1, “Commands”, Section 7.4.5, “Prompts”, and Section 7.3, “Callouts”.
7.4.7 Variable names #
        To reference to names of variables, use the
        <varname/>
        element:
      
To select another display manager, start the YaST system configuration editor and change the value of <varname>DISPLAYMANAGER</varname>.
7.5 Cross-references #
      Use the
      <xref/> element (read: “cross
      ref”) when referring to an appendix, chapter, example,
      figure, part, preface, section, table or question and answer set. The
      element referenced needs to have  an
      xml:id attribute, an identifier
      (ID). Create identifiers to reference from cross-references using the
      rules under Section 7.12, “Identifiers”. Note that a cross-reference only
      works when it links to documentation within the same set, for example, the
      same book or set of books.
    
Other types of references to resources are described in Section 7.20, “References to other external resources” and Section 7.8, “External links”.
<sect2 xml:id="sec-cross-reference">
  <title>Cross-references</title>
  <para>
   Use the <sgmltag class="emptytag">xref</sgmltag> element ...
  </para>
 ...
  <para>
   See <xref linkend="sec-cross-reference"/>.
  </para>
 </sect2>
      This example shows the default display of a cross-reference. To change it,
      use the xrefstyle attribute, either with
      select: or
      template:. Do not use custom
      “named” xrefstyle attributes
      that require support from the style sheets. For more info, refer to
      DocBook
      XSL: The Complete Guide: Customizing cross-references.
    
Keep in mind the following cases where listing cross-references is discouraged and must be avoided:
- Do not insert cross-references into title elements. The title must not be clickable, and a cross-reference in a title can create issues when linking to such a title in a different paragraph. 
- Do not create references to paragraphs or other elements that have no title. An exception to this rule is the element procedure steps to which you may create references. If a reference to an element without a title is essential to the document, specify a custom label for the cross-reference to assign a title. 
Do not prefix or suffix cross-references with text labels such as “appendix,” “chapter,” “table,” or “figure.” Such labels are generated automatically.
7.6 Emphasis #
      Where possible, indicate stress with language only. If that is not
      possible, use the
      <emphasis/>
      element to indicate stress.
    
      Where added emphasis is needed, use the
      role="bold"
      attribute.
    
This will be displayed in <emphasis>italics</emphasis>. This will be displayed in <emphasis role="bold">bold</emphasis>
7.7 Examples #
Use examples to illustrate complex processes. The rules established in Section 7.10.1, “Graphics” also apply to examples.
      Examples usually contain
      <screen/>
      elements. Additionally, there can be callouts and explanatory text.
    
Always give examples a title and an identifier.
For more information about screen environments, see Section 7.4.6, “Verbatim blocks”. For more information about displaying computer input and output, see Section 7.4, “Command-line input and command-line output”. To annotate examples, use callouts. Callouts are described in Section 7.3, “Callouts”.
<example xml:id="ex-example"> <title>Example of an example</title> <screen><prompt>tux > </prompt><command>ps -xa</command> 5170 ? S 0:00 kdeinit: khotkeys 5172 ? S 0:02 kdeinit: kdesktop 5174 ? S 0:04 kdeinit: kicker</screen> </example>
<example/> #| Element | Web link | 
|---|---|
| 
 | https://tdg.docbook.org/tdg/5.2/example.html | 
| 
 | https://tdg.docbook.org/tdg/5.2/screen.html | 
7.8 External links #
Information that is relevant within SUSE documentation is often available from other Web sites already. In such cases, choose between linking to these sites or including their content in edited form. Adhere to the following guidelines when selecting sites to link to:
- Link to credible sources, such as suse.com, upstream projects or developer sites. Avoid linking to direct competitors of SUSE. Do not link to obvious clickbait sites. 
- Prefer larger, well-kept sites over blogs that may vanish overnight. If you need to link to smaller blogs, save an archive version of the site at https://web.archive.org/. 
- Avoid linking to sites that feature controversial or political content. 
In certain cases, product managers request avoiding all or selected external links to avoid issues for customers impacted by restrictive firewall rules.
      Use the <link/> element to mark up URLs that can
      be opened with a Web browser, such as
      https://www.example.org/. Always add the correct
      protocol prefix (for example, https://), otherwise
      links will not work. If possible, use the secure protocol prefix
      (https://).
    
      Never use filename for a link, as that would both disable the
      link checker and make the link unclickable. Avoid entering a text label
      between <link/> start and end tags. Instead, use
      a self-closing tag:
    
<link xlink:href="https://www.example.org/"/>
      Make URLs as short as possible before adding them to documentation. Many
      long URLs can be shortened by leaving away non-essential pieces, such as
      the _utm parameters used for marketing purposes. If a
      Web site provides a built-in URL shortener, use it.
    
Do not use third-party URL shorteners, such as bit.ly. Third-party URL shorteners have the following disadvantages:
- They obscure the destination a link points to. 
- They introduce an extra element of uncertainty, as the shortening service may disappear or become unreliable in the future. 
- The providers of these services usually run Web analytics that may introduce privacy issues. 
Do not link to SUSE documentation outside of the current document set. Instead, use the appropriate entity for the book title. Always reference the book itself, as chapter names can change.
For consistency, do not use the article in front of the name of the referenced book or chapter. For example, “The general concept of Podman is described in Containers and Podman.”
Where possible, collect links in a “More information” section at the end of the chapter. This helps readers focus on your documentation instead of leading them immediately to other resources. This is described in Section 4.1, “Books”.
      To mark up multiple links, create an
      <itemizedlist/> around
      them. Do not use a list environment for a single link.
      If you need to present many links, group them by topic and create a
      separate list environment for each group. Provide a comprehensive title
      for each of the groups or an introductory sentence. For more information
      about creating lists, see Section 7.13.1, “Itemized lists”.
    
Where possible, provide translators with localized versions of links in the comments of the source file.
Other types of references to resources are described in Section 7.5, “Cross-references” and Section 7.20, “References to other external resources”.
7.9 External links to SUSE documentation #
      The SUSE documentation is hosted under
      documentation.suse.com. This is the URL that must be provided
      in all documents. The abbreviated URLs such as doc.suse.com and
      docs.suse.com also work but must be avoided for SEO reasons.
    
Make sure to use complete URLs instead of entities for an easy copy and paste.
      Most links in our documentation that goes to
      documentation.suse.com refer to a specific product and release.
      However, sometimes it makes sense to not include the
      SP or even the major release. These are so-called SP-independent
      links.
    
The following reasons give you an idea when to use them:
- Your linked information is independent from any SP 
- You cannot or do not need to pick a specific SP 
- You want to link to the most recent SP without checking which one it is 
- You want to support SEO where the most prominent SP is more important than previous, older SPs 
Make sure to follow this syntax:
documentation.suse.com/<PRODUCT>[/<MAJOR_RELEASE>]/<DEEP_LINK>
The placeholders mean the following:
- PRODUCT: the abbreviation of the product, like “sle” for SUSE Linux Enterprise, “sle-ha” for SUSE Linux Enterprise Server High Availability Extension, etc. 
- MAJOR_RELEASE: an optional major release like 12 or 15. If you omit it, your link will be redirected to use the most recent release. 
- DEEP_LINK: the link that points to a specific chapter or section within a book 
      Make sure you use html and not
      single-html. This is needed for SEO reasons.
    
For example, the link https://documentation.suse.com/sle-ha/15-SP3/html/SLE-HA-all/article-installation.html#sec-ha-inst-quick-req/ points to the “System requirements” for SUSE Linux Enterprise Server High Availability Extension. To turn this link into an SP-independent link, you need to identify the different components first:
- PRODUCT is - sle-ha
- MAJOR_RELEASE is 15 (no SP mentioned) 
- DEEP_LINK is - /html/SLE-HA-all/article-installation.html#sec-ha-inst-quick-req
With the above parts, the redirection rules on our server allow expressing SP-independent links in several ways:
- https://documentation.suse.com/sle-ha-15/html/SLE-HA-all/article-installation.html#sec-ha-inst-quick-req- Redirects to the most recent SP for the major release 15 
- https://documentation.suse.com/sle-ha/html/SLE-HA-all/article-installation.html#sec-ha-inst-quick-req- Redirects to the most recent major release, latest SP available 
If IDs have been changed between releases or SPs, this is what happens:
- If the hash part (everything after #) is not found, the browser will jump to the beginning of the file. 
- If the file cannot be found (in our example, article-installation.html), the server will respond with a 404 error (file not found). 
7.10 Figures #
      Use the <figure/> element for all figures. Avoid
      using the <informalfigure/> element, as it allows
      skipping alternative text, which is essential for accessibility. When
      updating existing content, replace all
      <informalfigure/> elements with
      <figure/>. Always assign an
      xml:id attribute to
      <figure/> elements. Reference figures from the
      text by means of a cross-reference. For more information, see
      Section 7.5, “Cross-references”.
    
All referenced image files must have a lowercase alphanumeric file name. When specifying figure names, follow the naming conventions at https://github.com/SUSE/doc-modular/blob/main/templates/README.md.
      Provide an appropriate image width using the
      width attribute. For both figure types, formal
      and informal, always add a <textobject
      role="description"/> as in Example 7.9, “Example of a figure” to provide an
      alternative text for the HTML output.
    
<figure xml:id="fig-picture"> <title>An interesting picture</title> <mediaobject> <imageobject role="fo"> <imagedata fileref="picture.eps" width="80%" format="EPS"/> </imageobject> <imageobject role="html"> <imagedata fileref="picture.png" width="80%" format="PNG"/> </imageobject> <textobject role="description"> <phrase>Cat chasing Geeko</phrase> </textobject> </mediaobject> </figure>
<figure/> #| Element | Web link | 
|---|---|
| 
 | https://tdg.docbook.org/tdg/5.2/figure.html | 
| 
 | https://tdg.docbook.org/tdg/5.2/informalfigure.html | 
| 
 | https://tdg.docbook.org/tdg/5.2/mediaobject.html | 
| 
 | https://tdg.docbook.org/tdg/5.2/imageobject.html | 
| 
 | https://tdg.docbook.org/tdg/5.2/imagedata.html | 
| 
 | https://tdg.docbook.org/tdg/5.2/textobject.html | 
7.10.1 Graphics #
Keep graphics as simple as possible. Use as little text as possible. To allow for translation, reserve twice as much space for runs of text as the English version of it consumes.
7.10.2 Screenshots #
Use screenshots to illustrate complex situations in which the user cannot easily follow the instructions otherwise.
- Be selective. Only illustrate steps in which meaningful user interactions are necessary. Do not create screenshots of progress bars or confirmation windows. Usually, it is unnecessary to create a screenshot of every step of an instruction. 
- Avoid creating screenshots of verbatim blocks or a terminal screen output. Instead, paste such content in a verbatim block. Find more details in Section 7.4.6, “Verbatim blocks”. 
- Always create screenshots illustrating the situation right before an action has been taken. 
- Insert screenshots directly after the textual description of the action. 
- Make sure screenshots focus on what they are supposed to illustrate. When documenting application windows, create a screenshot of the window only. When documenting Web applications, only reproduce the contents of the tab instead of the entire browser window. 
- Do not scale screenshots using graphics software. Embed screenshots at their original resolution and use DocBook attributes to scale them appropriately. 
- Avoid creating screenshots of windows higher or wider than 800 pixels at 96 pixels per inch. When creating screenshots of applications scaled for a higher pixel-per-inch count, apply a proportionally larger maximum window size. 
- To ensure readability and consistency, scale screenshots with the - widthattribute. Choose the appropriate scaling from the following list:- Screenshots of the whole desktop should be scaled to 90–99% page width. 
- Screenshots of individual application windows should be scaled to 75–99% page width. 
- Small windows such as message boxes should be scaled to 50–60% page width. 
 
- Create screenshots that are recognizable to readers. For example, create screenshots of KDE applications on a KDE desktop with the default KDE theme and disable toolbar modifications you have made. 
- Use grayscale font antialiasing (default on SUSE operating systems). Subpixel font antialiasing (default on Windows and macOS operating systems) creates colored letter edges when zoomed or printed. 
- Where applicable, follow the rules in Chapter 3, Names of example items. 
- Avoid editing screenshots. To anonymize portions of a screenshot, pixelize it. To highlight parts of a screenshot, use rectangles or arrows. Never add callouts, text or freely drawn objects. Always select colors that provide a good contrast with their background. 
- If possible, avoid screenshots with dates, version numbers, or other version-specific information that frequently changes. 
7.11 Glossaries #
An optional glossary contains terms and their definitions. Make sure that the glossary entries are appropriate to the intended audience. Define unfamiliar terms and special jargon.
Define infinitive forms of verbs and singular nouns. Do not start the definition with the term itself. Use lowercase for the term unless it is a proper noun.
To keep definitions consistent, check SUSE's official terminology database called TermWeb (https://suse.termweb.eu/search/terms). It contains company-specific terminology in English and all our supported languages. When defining a term, consult TermWeb first to ensure you are using the approved wording and preferred spelling.
      Where applicable, group your terms with the
      <glossdiv/> tag for higher ordering.
    
      To support automatic alphabetical ordering in localized versions, use
      <glosslist/> so that glossary items are sorted in
      alphabetical order by default.
    
Use cross-references in the following cases:
- To direct the reader to another glossary entry, use the - <glosssee/>tag. This is helpful, for example, when linking acronyms with their written out forms.
- To provide the reader with additional information about related glossary entries, use - <glossseealso/>.
The markup for a glossary entry is shown in Example 7.10, “A typical example of a glossary”.
<glossary xmlns="http://docbook.org/ns/docbook" version="5.2">
  <title>Glossary</title>
  <glossentry xml:id="gt-docbook">
      <glossterm>DocBook</glossterm>
      <glossdef><para>...</para></glossdef>
  </glossentry>
  <glossentry xml:id="gt-svg">
      <glossterm>SVG</glossterm>
      <glossdef><para>...</para></glossdef>
  </glossentry>
  <glossentry xml:id="gt-extensible-markup-language">
      <glossterm>Extensible Markup Language</glossterm>
      <glossdef>
          <para> A markup language that defines a set of rules for encoding
              documents in a format that is both human-readable and
              machine-readable. </para>
          <glossseealso linkend="gt-docbook"/>
          <glossseealso linkend="gt-svg">SVG (Scalable Vector Graphics)</glossseealso>
      </glossdef>
  </glossentry>
  <glossentry xml:id="gt-xml">
      <glossterm>XML</glossterm>
      <glosssee linkend="gt-extensible-markup-language" />
  </glossentry>
</glossary>7.12 Identifiers #
- Always use - xml:idattributes in parts, chapters, appendixes, sections, figures, glossaries, tables and examples. Identifiers can be used in block elements as well, for example, procedures.
- In identifiers, only use lowercase basic Latin alphabetic and numeric characters and - -(hyphen). Follow the regular expression pattern- [\-0-9a-zA-Z]+. Do not use- _and- .characters, as they may hurt search engine optimization.
- Identifiers can consist of multiple parts. Join these parts with a - -(hyphen).- Prefix. Signifies the type of XML element. Prefixes aid writers in creating logically named identifiers for elements. Use identifiers in accordance with Table 7.6, “Abbreviations for different elements in an - xml:idattribute”.- Do not add prefixes to identifiers for XML elements that are used to determine the name of HTML pages (such as section and chapter elements). Such exposure of identifiers can hurt SEO. 
- Chapter title label. Shortened version of the title of the parent chapter or parent chapter-level element (preface, appendix, etc.). Do not add a chapter title label to chapters and chapter-level elements themselves. Do not add chapter title identifiers within articles. 
- Element title label. Shortened version of name of the title of the element itself. 
 Example 7.11: Examples of identifiers #- xml:id="pro-install-sles" xml:id="install-yast" xml:id="tab-install-source" 
- Use short, memorable, English terms or phrases as title labels. Favor longer terms over non-obvious abbreviations. Always use the singular of nouns and the infinitive of verbs. For example, a section about installing with YaST could be called - install-yast.- A figure in that section showing language selection could use the identifier - fig-install-yast-language.
- Keep in mind that section and chapter identifiers are used in the online documentation URLs. Choosing understandable keywords helps readers to understand what the page is about and also improves the search engine ranking. 
Do not rework identifiers in existing documentation, instead apply these rules to newly created documentation only.
xml:id attribute #| Element | Prefix | 
|---|---|
| <appendix/> | No prefix | 
| <book/> | No prefix | 
| <co/> | co | 
| <chapter/> | No prefix | 
| <example/> | ex | 
| <figure/> | fig | 
| <glossary/> | No prefix | 
| <glossterm/> | gl | 
| <itemizedlist/> | il[a] | 
| <listitem/> | li | 
| <indexterm/> | idx[b] | 
| <orderedlist/> | ol | 
| <part/> | No prefix | 
| <preface/> | No prefix | 
| <procedure/> | pro | 
| <qandaset/>,<qandadiv/>,<qandaentry/> | qa | 
| <sect1/>,<sect2/>, etc.,<section/> | No prefix | 
| <set/> | No prefix | 
| <step/> | st | 
| <table/> | tab | 
| <topic/> | No prefix | 
| <variablelist/> | vl | 
| <varlistentry/> | vle | 
| [a] 
                  Only add an  [b] Only add when creating index ranges | |
7.13 Lists #
SUSE documentation uses the following types of lists (the respective XML elements are given in parentheses):
- Itemized lists ( - <itemizedlist/>). Also known as bullet lists or unordered lists.
- Ordered lists ( - <orderedlist/>). Also known as numbered lists.
- Variable lists ( - <variablelist/>). Also known as definition lists or description lists.
- Procedures ( - <procedure/>). Also known as step-by-step instructions or step lists. Described in Section 7.16, “Procedures”.
Follow these rules when creating or editing lists:
- Always introduce a list in the text. If needed for reference or better coordination with the related text, add a title and an identifier. 
- A list must contain at least two items. If items are few, short and simple in structure, consider incorporating them in the flowing text instead of creating a list. 
- If all list items are nouns only, do not capitalize their first letter. Use sentence-style capitalization for list items that are full sentences and for terms in descriptive lists. 
- Use a period after every list item that is a sentence. Do not use a period after the items that are not complete sentences. Use either all full sentences in your bullet lists or all fragments. Avoid a mix. - Do not use commas and semicolons to end punctuation. 
- Wherever possible, use parallel phrasing and grammatical construction between list items. This provides a pattern that makes it easier to follow the text. 
- Lists are visually distinct and can break up text flow. Do not overuse them. 
Never nest more than three lists within each other. Instead, restructure the information using a combination of lists and running texts.
      To be able to reference untitled lists, use the
      xreflabel
      attribute. For more information, see
      Section 7.5, “Cross-references”.
    
| Element | Web link | 
|---|---|
| 
 | https://tdg.docbook.org/tdg/5.2/itemizedlist.html | 
| 
 | https://tdg.docbook.org/tdg/5.2/orderedlist.html | 
| 
 | https://tdg.docbook.org/tdg/5.2/variablelist.html | 
| 
 | https://tdg.docbook.org/tdg/5.2/varlistentry.html | 
| 
 | https://tdg.docbook.org/tdg/5.2/term.html | 
| 
 | https://tdg.docbook.org/tdg/5.2/listitem.html | 
7.13.1 Itemized lists #
Use itemized lists whenever the order of list items is irrelevant. They are often used to provide an overview of information or to introduce or summarize information.
<para> The following operating systems are supported: </para> <itemizedlist> <listitem> <para> Linux, Kernel 2.4 and newer </para> </listitem> <listitem> <para> FreeBSD 7 and newer </para> </listitem> </itemizedlist>
The following operating systems are supported:
- Linux, Kernel 2.4 and newer 
- FreeBSD 7 and newer 
7.13.2 Ordered lists #
Use ordered lists when items have a strict order, hierarchy or importance. Do not use ordered lists to describe sequential user actions (step-by-step instructions). For sequential user actions, use a procedure, as described in Section 7.16, “Procedures”. If order is not relevant, use an itemized list or a variable list.
<para> Before installing, make sure of the following: </para> <orderedlist> <listitem> <para> The network connection of the computer is configured properly. </para> </listitem> <listitem> <para> The latest security updates are installed. If you are in doubt, run an online update. </para> </listitem> </orderedlist>
Before installing, make sure of the following:
- The network connection of the computer is configured properly. 
- The latest security updates are installed. If you are in doubt, run an online update. 
7.13.3 Variable lists #
Use variable lists when defining terms or describing options. Each item of a variable list contains a short term that is then further explained by an explanatory paragraph.
Use sentence-style capitalization for both the term and the list item.
To reference the list, assign it an identifier and add a title. Individual list items may be referenced by assigning an identifier as well. The entry is then identified by the value of the identifier and referenced by the term.
<para>
 This book consists of several parts:
</para>
<variablelist>
 <varlistentry>
  <term>Installation</term>
  <listitem>
   <para>
    Learn about the installation and initial configuration of a Linux system.
   </para>
  </listitem>
 </varlistentry>
 <varlistentry>
  <term>System</term>
  <listitem>
   <para>
    Get a basic understanding of the system components.
   </para>
  </listitem>
 </varlistentry>
</variablelist>This book consists of several parts:
- Installation
- Learn about the installation and initial configuration of a Linux system. 
- System
- Get a basic understanding of the system components. 
7.14 Keys and key combinations #
Capitalize all keys as printed on a standard keyboard. Capitalize all letter keys. To refer to a capitalized character, use Shift–Z, for example. Introduce this convention in the “Typographical Conventions” section of the introduction.
      To mark up key combinations, use
      <keycombo/> as a wrapper for multiple
      <keycap/> elements. Separators between
      <keycap/> elements are then created
      automatically.
    
      If a key is listed in Table 7.8, “Elements related to <keycap/>”, use the
      function attribute with the appropriate
      value. When using the function attribute,
      make the tag self-closing—DocBook's language files will insert key
      names automatically. This simplifies both your work and the work of
      translators.
    
To create a screenshot, press <keycap>Print Screen</keycap>.
To save a file, press <keycombo><keycap function="control"/><keycap>S</keycap></keycombo>.
<keycap/> #| Element | Web link | 
|---|---|
| 
 | https://tdg.docbook.org/tdg/5.2/keycombo.html | 
| 
 
 | https://tdg.docbook.org/tdg/5.2/keycap.html | 
7.15 Outline levels and sectioning #
      Create sections using the
      <sect1/>, <sect2/>
      and <sect3/> elements. Avoid outlines that
      require <sect4/> and
      <sect5/> elements.
      
      Instead, create a flatter structure in which more elements are visible at
      a glance.
    
Provide at least one paragraph of introductory information directly within each section.
Do not create lone subsections. A lone subsection is a section that is the only subsection of its parent section.
For more information about writing headlines, see Section 6.10, “Headings”.
7.16 Procedures #
Use procedures to describe sequential tasks. A procedure consists of the following elements and attributes:
- An identifier. 
- A title. 
- An introductory phrase establishing the purpose of the procedure. If the procedure is otherwise the only element in its section, place the introductory phrase before the procedure. 
- If there are preconditions or prerequisites, add them as a second paragraph after the introduction. 
- Short, simple steps and, if necessary, substeps describing the actions to be performed. See also Section 6.18, “Sentence structure”. 
      To link alternative actions inside the same substep element, use
      “or.” Apply a
      performance=optional attribute to optional
      steps.
    
Steps may contain a link to an explanatory subsection providing further details on the step.
<procedure xml:id="pro-procedure"> <title>Example of a procedure</title> <para> To add a new user to the system, perform the following steps: </para> <step> <para> In the <phrase role="productname">YaST</phrase> window, click <guimenu>User and group management</guimenu>. </para> </step> <step> <para> To open the <guimenu>Add a new user</guimenu> dialog, click <guimenu>Add</guimenu>. </para> </step> <step> <para> Type in the user name and click <guimenu>Create</guimenu>. </para> </step> </procedure>
To add a new user to the system, perform the following steps:
- In the YaST window, click . 
- To open the dialog, click . 
- Type in the user name and click . 
<procedure/> #| Element | Web link | 
|---|---|
| 
 | https://tdg.docbook.org/tdg/5.2/procedure.html | 
| 
 | https://tdg.docbook.org/tdg/5.2/step.html | 
| 
 | https://tdg.docbook.org/tdg/5.2/substeps.html | 
7.17 Products #
      Always use the preferred product name instead of, for example, an acronym.
      When referring to a product, add a <phrase
      role="productname"/> element around it. This will not result in a
      visual change but disables hyphenation:
    
<phrase role="productname">LibreOffice</phrase> is an office suite.
7.18 Profiling #
Profiling is convenient for the creation of consistent documentation across different products or product lines. This is especially beneficial when similar products share a considerable amount of features, with only a few differences. Instead of maintaining separate documentation for each product, you can share most of the source code and only vary text snippets where necessary. When profiling, you can mark specific elements as conditional and specify which conditions apply to the output when processing the files to generate output. The style sheets will then include or exclude the marked text, according to the conditions.
Profiling allows you to keep both common and product-specific content in one file and select at production time which information to include in the output.
If you need to use profiling in your writing, adhere to the following guidelines:
- Identify different variants that you want to apply to the general piece of text and assign clear and short identifiers to them, sticking to lowercase. These identifiers act as “aliases” for longer products or deliverables. To apply more than one identifier to an element, separate them with a semicolon. 
- Select one or more profiling attributes and add them to the text snippets that are conditional. The tagged snippets are only included in the output if all required conditions are fulfilled. In most cases, the attribute to use is - os. For different processor architectures, use- arch. The general-purpose attribute is- condition.
- Mark the variants in your text with the relevant identifiers. Any content that is valid for all conditions does not need any profiling attributes. The respective content is always included in the output formats generated from the sources. 
- Create a different DC file for each variant. Add the respective profiling variable and its value to the DC file. 
- You can use multiple profiling attributes to handle more complex scenarios. For example, if you have conditions for architecture and operating system, you can create different versions of a document for different combinations of these conditions, as shown in Example 7.23, “Multiple profiling with attributes - osand- arch”.
os #<?xml version="1.0" encoding="UTF-8"?> [...] <phrase os="sles;sled">Note that the official update repository is only available after registering your SUSE Linux Enterprise Server installation.</phrase>
MAIN="MAIN.SLEDS.xml" ROOTID=book-administration ## Profiling PROFOS="sles" ...
os and arch #<?xml version="1.0" encoding="UTF-8"?> [...] Entire hard disks are listed as devices without numbers, such as <filename>/dev/sda</filename><phrase arch="zseries;aarch64" os="sles;sled;slemicro"></phrase>.
7.19 Questions and answers #
Use question and answer sections to present information about troubleshooting or commonly asked questions about a product. Never use question and answer sections to explain trivia, such as how a product got its name. Keep your audience in mind. See also Chapter 1, Writing technical documentation.
      Questions must always end in a ?. Where explanations
      longer than three paragraphs are necessary for an answer, add a
      cross-reference to an explanation outside of the question and answer
      section. See also Section 7.5, “Cross-references”.
    
      When a question and answer section contains over 10 questions and there
      are clear topical divisions, add <qandadiv/>
      elements to further structure the section.
    
<qandaset>
 <title>Example of a question and answer section</title>
 <qandaentry>
  <question>
   <para>
    How can I check if the product was correctly installed?
   </para>
  </question>
  <answer>
   <para>
    Open the log file.
    Look for entries starting with <literal>Failed</literal>.
   </para>
  </answer>
 </qandaentry>
 <qandaentry>
  <question>
   <para>
    Why does the error <literal>Not enough disk space</literal> occur
    during installation?
   </para>
  </question>
  <answer>
   <para>
    There are less than 4 GB of space available on the selected partition.
   </para>
  </answer>
 </qandaentry>
</qandaset>Example of a question and answer section (output)
- 1. How can I check if the product was correctly installed?
- Open the log file. Look for entries starting with - Failed.
- 2. 
            Why does the error Not enough disk spaceoccur during installation?
- There are less than 4 GB of space available on the selected partition. 
<qandaset/> #| Element | Web link | 
|---|---|
| 
 | https://tdg.docbook.org/tdg/5.2/qandaset.html | 
| 
 | https://tdg.docbook.org/tdg/5.2/qandadiv.html | 
| 
 | https://tdg.docbook.org/tdg/5.2/qandaentry.html | 
| 
 | https://tdg.docbook.org/tdg/5.2/question.html | 
| 
 | https://tdg.docbook.org/tdg/5.2/answer.html | 
7.20 References to other external resources #
      To reference file names, use the
      <filename/> element without the
      file:// prefix. To reference e-mail addresses, use the
      <email/>
      element without the mailto: prefix. See also
      Section 7.4.2, “File names”.
    
Reference man pages and info pages in this format:
- “the man page of - command”
- “the info page of - command”
      In a situation where the category of the page is needed, append the
      category in parentheses. For example, use
      “(man 9
      command)”.
    
To learn more about subcommands, see the man page of <command>command</command>.
      Insert references to external (non-SUSE) physical books in the format
      “Title by Author (ISBN #00000000).” Inclusion of the ISBN is
      optional. Place the title in a
      <citetitle/>
      element.
      For example:
    
<citetitle>Lorem Ipsum</citetitle> by Dolores S. Amet (ISBN 0-246-52044-7) is a useful guide.
      Note that <citetitle/> is not translated.
    
As an author, where possible, provide language-specific references to translators in XML comments (see also Section 9.2, “Comments”). As a translator, look for corresponding language-specific resources where none have been provided. For URLs, provide only the language-specific version of a site. Use the English version as a fallback. For books, provide the title of the translated version along with the original title if such a translation exists.
Other types of references to resources are described in Section 7.5, “Cross-references” and Section 7.8, “External links”.
7.21 Revision information #
Every HTML file generated from our documentation sources must include at least one revision date. Revision dates signal content freshness to human readers, search engines and LLMs.
Every chapter, part or book that is included in our builds contains a revision history. For product documentation up to SLE 15 SP7, this revision history typically consists of a single revision entry with an empty description. The revision date is updated in place every time the content undergoes a significant change.
Starting with SLE 16 releases, product documentation includes a complete revision history with several dates and descriptions. Follow the instructions in Section 11.2, “Revision history”.
To determine whether a change you made warrants a revision date, use this table:
| Change | Change revision date? | 
|---|---|
| Added a new feature or deleted an obsolete one | Yes | 
| Image change (non-cosmetic) | Yes | 
| Fixed a broken link | Yes | 
| Metadata fix (new description, change in product name and/or version, ...) | Yes | 
| Typo and grammar fixes, editorial reviews | No | 
| Formatting changes | No | 
<revhistory xml:id="rh-use-rootid">
  <revision><date>YYYY-MM-DD</date>
    <revdescription />
  </revision>
</revhistory>7.22 Tables #
Use tables to present many similar facts. Tables are easy to scan and compare. Always keep tables simple enough to not require long explanations, even for readers unfamiliar with the topic.
A table always has a title and should have an identifier.
Typical use cases of tables include:
- Lookup tables for specific information
- Whenever users need to check for data that applies to them, create lookup tables. For example, use a table to sum up system requirements. 
- Matrix tables
- Whenever users need to quickly check whether a specific combination of options works or not. For example, use a matrix table to visualize supported combinations or update options. 
As there are use cases for tables, there are cases when not to use tables:
- Value and description pairs are better handled by a descriptive list. 
- Wordy explanations or descriptions should not be used in tables. 
- Complex layout constructs (screens, code) should not be used in tables. 
Some general style tips for tables:
- Structure the table to have more rows than columns
- Readers prefer to skim for information that is aligned vertically. When designing tables, consider swapping rows and columns to provide a consistent user experience. 
- Narrow down columns
- Compress the data in your table as much as you can. Table cells with less content are more easily parsed by readers. Consider using icons, adding repeating words into column titles, or using shorter number formats. 
- Use colors to lead the reader's eyes
- Use colors to make the information stand out. If you just want to highlight small bits, use bright colors. If you need to color entire cells, use pastels. This option should only be used with matrix type tables. 
- Use striped rows
- Color every second row in light gray to make sure readers do not accidentally slip between lines. This should be the default for long tables. Do not use striped rows in matrix type tables with additional cell background coloring. You may also consider disabling striped rows for short tables to not confuse readers. 
<table>
  <title>File System Maximums</title>
 <tgroup cols="2">
  <thead>
   <row>
    <entry>File System</entry>
    <entry>Maximum File Size</entry>
   </row>
  </thead>
  <tbody>
   <row>
    <entry>Ext2 (1 kB block size)</entry>
    <entry>16 GB</entry>
   </row>
   <row>
    <entry>Ext2 (2 kB block size)</entry>
    <entry>256 GB</entry>
   </row>
  </tbody>
 </tgroup>
</informaltable>| File System | Maximum File Size | 
|---|---|
| Ext2 (1 kB block size) | 16 GB | 
| Ext2 (2 kB block size) | 256 GB | 
<table/> #| Element | Web link | 
|---|---|
| 
 | https://tdg.docbook.org/tdg/5.2/cals.table.html | 
| 
 | https://tdg.docbook.org/tdg/5.2/cals.informaltable.html | 
| 
 | https://tdg.docbook.org/tdg/5.2/tgroup.html | 
| 
 | https://tdg.docbook.org/tdg/5.2/colspec.html | 
| 
 | https://tdg.docbook.org/tdg/5.2/cals.thead.html | 
| 
 | https://tdg.docbook.org/tdg/5.2/cals.tbody.html | 
| 
 | https://tdg.docbook.org/tdg/5.2/row.html | 
| 
 | https://tdg.docbook.org/tdg/5.2/entry.html | 
7.23 User interface items #
      To mark up single user interface items, use
      <guimenu/>. To mark up nested menu structures,
      use <menuchoice/> as a wrapper for multiple
      <guimenu/> elements. Separators between
      <guimenu/> elements are then created
      automatically.
    
For more information about language aspects, see Section 6.23, “User interface items”.
To open a file, click <guimenu>Open</guimenu>.
To save a file, use <menuchoice><guimenu>File</guimenu><guimenu>Save</guimenu></menuchoice>.