184 lines
5.9 KiB
184 lines
5.9 KiB
4 years ago
|
////
|
||
|
Included in:
|
||
|
|
||
|
- user-manual: Syntax Highlighting Source Code
|
||
|
////
|
||
|
|
||
|
Developers are accustomed to seeing source code colorized to emphasize the code's structure (i.e., keywords, types, delimiters, etc.).
|
||
|
This technique is known as [.term]_syntax highlighting_.
|
||
|
Since this technique is so prevalent--one could say expected--Asciidoctor integrates a wealth of libraries to syntax highlight the source code blocks in your document.
|
||
|
The list of integrated libraries includes Rouge, CodeRay, Pygments, highlight.js, and prettify.
|
||
|
|
||
|
=== Enabling Source Highlighting
|
||
|
|
||
|
When enabled, syntax highlighting gets applied to listing or literal blocks that have the `source` block style and a source language.
|
||
|
However, syntax highlighting is _not_ enabled by default.
|
||
|
|
||
|
To enable syntax highlighting in a document, you must set the `source-highlighter` document attribute.
|
||
|
You can set this attribute in the document or from the CLI or API.
|
||
|
|
||
|
If you set the attribute in the document, it _must_ be defined in the <<user-manual#doc-header,document header>>.
|
||
|
|
||
|
[source]
|
||
|
----
|
||
|
= Document Title
|
||
|
:source-highlighter: <value>
|
||
|
----
|
||
|
|
||
|
For example, here's how to enable syntax highlighting using Rouge:
|
||
|
|
||
|
[source]
|
||
|
----
|
||
|
= Document Title
|
||
|
:source-highlighter: rouge
|
||
|
----
|
||
|
|
||
|
.Source Highlighter vs. Syntax Highlighter
|
||
|
****
|
||
|
You might notice that the `source-highlighter` attribute uses the term "`source highlighter`", whereas the library that performs the highlighting is referred to as a "`syntax highlighter`".
|
||
|
What's the difference?
|
||
|
|
||
|
* The generally accepted term for a syntax (aka code) highlighter is "`syntax highlighter`".
|
||
|
* The syntax highlighter is applied to source blocks in AsciiDoc, hence why we say "`source highlighter`".
|
||
|
|
||
|
In other words, the `source-highlighter` attribute means "`use this syntax highlighter to colorize source blocks`".
|
||
|
****
|
||
|
|
||
|
=== Available Source Highlighters
|
||
|
|
||
|
The following table lists the recognized values for the `source-highlighter` attribute.
|
||
|
|
||
|
.Recognized values and supported environments for the `source-highlighter` attribute
|
||
|
[cols="1,1m,2"]
|
||
|
|===
|
||
|
|Library Name |Attribute Value |Supported Environments
|
||
|
|
||
|
|http://coderay.rubychan.de[CodeRay]
|
||
|
|coderay
|
||
|
|Asciidoctor, AsciidoctorJ, Asciidoctor PDF
|
||
|
|
||
|
|https://highlightjs.org[highlight.js]
|
||
|
|highlightjs
|
||
|
|Asciidoctor, AsciidoctorJ, Asciidoctor.js
|
||
|
|
||
|
|https://github.com/google/code-prettify[prettify]
|
||
|
|prettify
|
||
|
|Asciidoctor, AsciidoctorJ, Asciidoctor.js
|
||
|
|
||
|
|http://pygments.org[Pygments]
|
||
|
|pygments
|
||
|
|Asciidoctor, Asciidoctor PDF
|
||
|
|
||
|
|http://rouge.jneen.net[Rouge]
|
||
|
|rouge
|
||
|
|Asciidoctor, Asciidoctor PDF
|
||
|
|===
|
||
|
|
||
|
[IMPORTANT]
|
||
|
====
|
||
|
To use Rouge, CodeRay, or Pygments, you must have the appropriate library installed on your system.
|
||
|
See the <<rouge>>, <<coderay>>, or <<pygments>> section to find installation instructions.
|
||
|
|
||
|
On the other hand, if you're using a client-side syntax highlighting library like highlight.js or prettify, there's no need to install additional libraries.
|
||
|
The generated HTML will load the required source files from a CDN (or custom URL or file path).
|
||
|
====
|
||
|
|
||
|
=== Applying Source Highlighting
|
||
|
|
||
|
To apply highlighting to source code, you must add the `source` block style to a listing block, literal block, or paragraph and also specify a source language.
|
||
|
|
||
|
[listing]
|
||
|
.Code block with title and syntax highlighting
|
||
|
....
|
||
|
include::ex-src.adoc[tag=src-base-co]
|
||
|
....
|
||
|
<1> An optional title can be added to the block.
|
||
|
<2> An optional ID can be added to the block. See <<anchordef>>.
|
||
|
<3> Assign the block name `source` to the first position in the attribute list.
|
||
|
<4> Assign a source language to the second position.
|
||
|
<5> The source block name is typically assigned to listing and literal blocks.
|
||
|
|
||
|
.Result: Source block with title and syntax highlighting
|
||
|
====
|
||
|
include::ex-src.adoc[tag=src-base-co-res]
|
||
|
====
|
||
|
|
||
|
.Source paragraph
|
||
|
----
|
||
|
include::ex-src.adoc[tag=src-para-co]
|
||
|
----
|
||
|
<1> Place the attribute list directly on the paragraph.
|
||
|
<2> Once an empty line is encountered the syntax highlighting is unset.
|
||
|
|
||
|
.Result: Source paragraph
|
||
|
====
|
||
|
include::ex-src.adoc[tag=src-para]
|
||
|
====
|
||
|
|
||
|
If the majority of your source blocks use the same source language, you can set the `source-language` attribute in the document header and assign a language to it.
|
||
|
|
||
|
[listing]
|
||
|
.Source language attribute
|
||
|
....
|
||
|
include::ex-src.adoc[tag=src-lang]
|
||
|
....
|
||
|
|
||
|
Additionally, you can use an <<user-manual#include-directive,include directive>> to insert source code into an AsciiDoc document directly from a file.
|
||
|
|
||
|
[listing]
|
||
|
.Code block inserted from another file
|
||
|
....
|
||
|
include::ex-src.adoc[tag=src-inc]
|
||
|
....
|
||
|
|
||
|
//TODO mention the use of AsciiDoc tags to include code snippets and the indent flag to reset indentation
|
||
|
|
||
|
TIP: If you specify custom substitutions on the source block using the `subs` attribute, make sure to include the `specialcharacters` substitution if you want to preserve syntax highlighting.
|
||
|
However, if you do plan to modify the substitutions, we recommend using <<incremental-substitutions,incremental substitutions>> instead.
|
||
|
|
||
|
.Highlighting PHP source code
|
||
|
****
|
||
|
The PHP language has two modes.
|
||
|
It can either be used as a standalone language (pure mode) or it can be mixed with HTML (mixed mode) by putting it inside PHP tags (a form that resembles an XML processing instruction).
|
||
|
This presents some challenges for the syntax highlighter.
|
||
|
|
||
|
If the code in the source block is pure PHP, you should use the language tag `php`.
|
||
|
For example:
|
||
|
|
||
|
[listing]
|
||
|
....
|
||
|
[source,php]
|
||
|
----
|
||
|
echo "Hello, World!";
|
||
|
----
|
||
|
....
|
||
|
|
||
|
If the PHP source is mixed with HTML, you should either use the language tag `html+php`, as shown here:
|
||
|
|
||
|
[listing]
|
||
|
....
|
||
|
[source,html+php]
|
||
|
----
|
||
|
<p>
|
||
|
<?php echo "Hello, World!"; ?>
|
||
|
</p>
|
||
|
----
|
||
|
....
|
||
|
|
||
|
Or you could use the language tag `php` and set the `mixed` option on the source block, as shown here:
|
||
|
|
||
|
|
||
|
[listing]
|
||
|
....
|
||
|
[source%mixed,php]
|
||
|
----
|
||
|
<p>
|
||
|
<?php echo "Hello, World!"; ?>
|
||
|
</p>
|
||
|
----
|
||
|
....
|
||
|
|
||
|
Under the covers, the syntax highlighter is configured to assume an implicit start PHP tag is present when the language tag is `php`.
|
||
|
Both the `mixed` option and the language tag `html+php` disable this setting.
|
||
|
****
|