118 lines
4.1 KiB

////
Included in:
- user-manual: Text Substitutions: Applying substitutions
////
Specific substitution elements can be applied to any block or paragraph by setting the `subs` attribute.
The `subs` attribute can be assigned a comma separated list of the following substitution elements and groups.
// tag::group[]
[horizontal]
`none`:: Disables substitutions
`normal`:: Performs all substitutions except for callouts
`verbatim`:: Replaces special characters and processes callouts
`specialchars`, `specialcharacters`:: Replaces `<`, `>`, and `&` with their corresponding entities
`quotes`:: Applies text formatting
`attributes`:: Replaces attribute references
`replacements`:: Substitutes textual and character reference replacements
`macros`:: Processes macros
`post_replacements`:: Replaces the line break character (`{plus}`)
// end::group[]
Let's look at an example where you only want to process special characters, formatting markup, and callouts in a literal block.
By default, literal blocks are only subject to special characters substitution.
But you can change this behavior by setting the `subs` attribute in the block's attribute list.
....
include::ex-subs.adoc[tag=subs-in]
....
<1> The subs attribute is set in the attribute list and assigned the `verbatim` and `quotes` values.
<2> The formatting markup in this line will be replaced when the quotes substitution runs.
====
include::ex-subs.adoc[tag=subs-out]
====
<1> The `verbatim` value enables the callouts to be processed.
<2> The `quotes` value enables the text formatting to be processed.
[TIP]
====
If you are applying the same set of substitutions to numerous blocks, you should consider making them an attribute entry to ensure consistency.
[source]
....
include::ex-subs.adoc[tag=subs-attr]
....
Another way to ensure consistency and keep your documents clean and simple is to use the <<user-manual#tree-processor-example,TreeProcessor extension>>.
====
=== Incremental Substitutions
When you set the subs attribute on a block, you automatically remove all of its default substitutions.
For example, if you set subs on a literal block, and assign it a value of `attributes`, only attributes are substituted.
The verbatim substitution will not be applied.
To remedy this situation, Asciidoctor provides a syntax to append or remove substitutions instead of replacing them outright.
You can add or remove a substitution from the default substitution list using the plus (`+`) and minus (`-`) modifiers.
These are known as [.term]_incremental substitutions_.
[horizontal]
`<substitution>+`::
Prepends the substitution to the default list.
`+<substitution>`::
Appends the substitution to the default list.
`-<substitution>`::
Removes the substitution from the default list.
For example, you can add the `attributes` substitution to a listing block's default substitution list.
.Add attributes substitution to a default substitution list
[source]
....
include::ex-subs.adoc[tag=subs-add]
....
Similarly, you can remove the `callouts` substitution.
.Remove callouts substitution from a default substitution list
[source,subs=-callouts]
....
include::ex-subs.adoc[tag=subs-sub]
....
You can also specify whether the substitution is placed at the beginning or end of the substitution list.
If a `+` comes before the name of the substitution, then it's added to the end of the existing list, and if a `+` comes after the name, it's added to the beginning of the list.
[source,subs=-callouts]
....
include::ex-subs.adoc[tag=subs-multi]
....
In the above example, the quotes, then the special characters, and then the attributes substitutions will be applied to the listing block.
// NOTE: More examples are pending. Information about the callouts substitution also needs to be included here.
==== Applying Substitutions to Inline Elements
Custom substitutions can also be applied to some inline elements, such as the <<user-manual#pass-macros,pass macro>>.
For example, the quotes text substitution value is assigned in the inline pass macro below.
[source]
----
include::ex-pass.adoc[tag=s-macro]
----
====
include::ex-pass.adoc[tag=s-macro]
====