Asciidoc to Asciidoc: Exploding includes
One of my favourite features in AsciiDoc is the ability to include other files, but when using lots of includes is that it becomes difficult to read the whole document unless you convert it to one of the supported backends.
$ asciidoctor --help Usage: asciidoctor [OPTION]... FILE... Translate the AsciiDoc source FILE or FILE(s) into the backend output format (e.g., HTML 5, DocBook 4.5, etc.) By default, the output is written to a file with the basename of the source file and the appropriate extension. Example: asciidoctor -b html5 source.asciidoc -b, --backend BACKEND set output format backend: [html5, xhtml5, docbook5, docbook45, manpage] (default: html5) additional backends are supported via extensions (e.g., pdf, latex)
I don’t want to have to convert my code to one of these formats each time – I want to convert asciidoc to asciidoc!
For example, given the following files:
mydoc.adoc
= My Blog example == Heading 1 Some awesome text == Heading 2 include::blog_include.adoc[]
Some included text
I want to generate another asciidoc file where the contents of the include file are exploded and displayed inline.
After a lot of searching I came across an excellent script written by Dan Allen and put it in a file called adoc.rb. We can then call it like this:
$ ruby adoc.rb mydoc.adoc = My Blog example == Heading 1 Some awesome text == Heading 2 Some included text
Problem solved!
In my case I actually wanted to explode HTTP includes so I needed to pass the -a allow-uri-read flag to the script:
$ ruby adoc.rb mydoc.adoc -a allow-uri-read
And now I can generate asciidoc files until my heart’s content.
Published on System Code Geeks with permission by Mark Needham, partner at our SCG program. See the original article here: Asciidoc to Asciidoc: Exploding includes Opinions expressed by System Code Geeks contributors are their own. |