Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Substitutions inside literals in Asciidoc

Tags:

asciidoc

There doesn't appear to be a way to have variables (attributes, substitutions) parsed within literal text in Asciidoc, or else I'm missing something. I want to be able to set a variable and then call it inside a code block or literal string as such:

:version: 1.0.1
[code]
----
tar -xzvf mysoftware-{version}.tar.gz
----

And have it parse to:

tar -xzvf mysoftware-1.0.1.tar.gz

This can't be impossible, right?

like image 888
Brian D Avatar asked Mar 18 '15 14:03

Brian D


2 Answers

You can enable it for any block by using the subs attribute to the block. The subs attribute accepts any of the following (in a list):

  • 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 (+)

More info can be found in the User Manual, including an example very close to what you're trying to accomplish.

like image 93
LightGuard Avatar answered Nov 04 '22 03:11

LightGuard


Substitutions inside listing blocks are off by default, but can be controlled with the subs parameter:

:version: 1.0.1
[code, subs="attributes"]
----
tar -xzvf mysoftware-{version}.tar.gz
----
like image 20
Daniel Darabos Avatar answered Nov 04 '22 02:11

Daniel Darabos