Edit online

Programming Elements

Programming Elements are used to render lines of programming code. These elements have preserved line endings and use a monospace font in the output.

Edit online

How to Change Font in Code Blocks

You can change fonts in code blocks to make them easier to read or compliant with your company fonts. To do so, add the following rule to your customization CSS:
*[class ~= 'pr-d/codeblock'],
*[class ~= "pr-d/codeblock"] > code {
  font-family: 'Consolas', monospace;
}
Edit online

How to Enable Syntax Highlight in Code Blocks

Note:
This topic refers only to the DITA Map PDF - based on HTML5 & CSS transformation type.

You can use syntax highlighting to make it easier to read your code snippets by displaying each type of code in different colors and fonts. In the DITA topics, set the @outputclass attribute on the <codeblock> elements to one of these values:

  • language-json
  • language-yaml
  • language-xml
  • language-bourne
  • language-c
  • language-cmd
  • language-cpp
  • language-csharp
  • language-css
  • language-dtd
  • language-ini
  • language-java
  • language-javascript
  • language-lua
  • language-perl
  • language-powershell
  • language-php
  • language-python
  • language-ruby
  • language-sql
  • language-xquery
For example, for a java snippet:
<codeblock outputclass="language-java">
   for (int i=0; i <100; i++) {
     // do something
   }
</codeblock>
The resulting HTML fragment in the merged HTML5 document is:
 <pre class="+ topic/pre pr-d/codeblock pre codeblock language-java" 
    xml:space="preserve">
   <strong class="hl-keyword" style="color:#7f0055">for</strong> 
       (<strong class="hl-keyword" style="color:#7f0055">int</strong> 
         i=<span class="hl-number">0</span>; i 
            <<span class="hl-number">100</span>; i++) {
     <em class="hl-comment" style="color:#006400">// do something</em>
   }
</pre>

And in the output, it is rendered as:

Changing the Colors for the Syntax Highlighting

As you can see in the above example, the HTML elements <span> and <strong> are used to color the content. Since they have a @style attribute set, the overriding properties need to be marked with !important.

Suppose you want to color the keywords in red and the comments in blue. To do so, add the following to your customization CSS:

.hl-keyword {
  color: red !important;
}
.hl-comment {
  color: blue !important;
}
Edit online

How to Add Line Numbering in Code Blocks

Note:
This topic refers only to the DITA Map PDF - based on HTML5 & CSS transformation type.

You can add line numbering to make your code snippets easier to read. In the DITA topics, set the @outputclass attribute on the <codeblock> elements to the show-line-numbers value.

Note:
It is possible to use the @outputclass="show-line-numbers" together with any of the language @outputclass value (e.g. @outputclass="language-java show-line-numbers").
For example, for a java snippet:
<codeblock outputclass="show-line-numbers">
public void convert(String systemId, InputStream is) {
 return new FileInputStream();
}
</codeblock>
The resulting HTML fragment in the merged HTML5 document is:
<pre class="+ topic/pre pr-d/codeblock pre codeblock show-line-numbers"
outputclass="show-line-numbers" xml:space="preserve">
<span class="+ topic/pre-new-line pre-new-line"></span>
<span class="+ topic/pre-new-line pre-new-line">
</span>public void convert(String systemId, InputStream is) {
<span class="+ topic/pre-new-line pre-new-line"></span> return new FileInputStream();
<span class="+ topic/pre-new-line pre-new-line"></span>}
<span class="+ topic/pre-new-line pre-new-line"></span></pre>

And in the output, it is rendered as:

Edit online

How to Display Whitespaces in Code Blocks

Note:
This topic refers only to the DITA Map PDF - based on HTML5 & CSS transformation type.

You can display whitespace characters in code blocks to visualize indentation in the PDF. In the DITA topics, set the @outputclass attribute on the <codeblock> elements to the show-whitespace value.

Note:
It is possible to use the @outputclass="show-whitespace" together with any of the language or show-line-numbers @outputclass values (e.g. @outputclass="language-java show-line-numbers show-whitespace").
For example, for a java snippet:
<codeblock outputclass="show-whitespace">
public void convert(String systemId, InputStream is) {
  return new FileInputStream();
}
</codeblock>
The resulting HTML fragment in the merged HTML5 document is:
<pre class="+ topic/pre pr-d/codeblock pre codeblock show-whitespaces"
outputclass="show-whitespaces" xml:space="preserve">
public·void·convert(String·systemId,·InputStream·is)·{
··return·new·FileInputStream();
}
</pre>

And in the output, it is rendered as:

Edit online

How to Disable Line Wrapping in Code Blocks

By default, code blocks have the content wrapped to avoid the bleeding of long lines out of the page. To avoid wrapping, add the following in your customization CSS:

*[class~="pr-d/codeblock"] {
   white-space: pre;
}

For the DITA Map PDF - based on HTML5 & CSS transformation type, the best solution to distinguish between lines is to leave them wrapped, but color each line with a different background (zebra coloring). An example is provided here: XSLT Extensions for PDF Transformations.

Edit online

How to Enable Line Wrap in Code Phrases

By default, line wrapping does not apply on inline elements, which could cause some lines of code to bleed out of the page. To allow line wrapping, the property should be set on the parent block with the following rule in your customization CSS:
*:has(*[class ~= 'pr-d/codeph']) {
  overflow-wrap: break-word;
}
Notes:
  • It is possible to use hyphens: auto instead of overflow-wrap: break-word.
  • It is possible to use the same rule for software domain elements (e.g. <filepath> or <cmdname>).
Edit online

How to Deal with Unwanted Returns in Code Blocks

There are cases where the source file contains long lines of code that need to continue onto the next line in the rendered PDF (to wrap visually).

When the user copies the block from the PDF reader, they get two separated lines. This means that the command fails when users copy it from the PDF to the command-line terminal (because it comes in as two commands).

For example, the command:
$gist = ls -l * | count -n | some more
May be rendered in the PDF on two lines:
$gist = ls -l * | count -n
| some more
And this is invalid when used in the terminal.
There is no CSS workaround for this, but you can manually format the command using a continuation character:
$gist = ls -l * | count -n ^
| some more
$gist = ls -l * | count -n \
| some more
The command-line processor will automatically know that the command continues on the second line.