66 lines
3.1 KiB
66 lines
3.1 KiB
////
|
|
Included in:
|
|
|
|
- user-manual: Process multiple source files from the CLI
|
|
////
|
|
|
|
You can pass multiple source files or a filename pattern to the Asciidoctor CLI and it will convert each file given in turn.
|
|
|
|
Let's assume there exist two AsciiDoc files in the current directory, [.path]_a.adoc_ and [.path]_b.adoc_.
|
|
You can pass both files to Asciidoctor using a single command, as follows:
|
|
|
|
$ asciidoctor a.adoc b.adoc
|
|
|
|
Asciidoctor will convert both files, transforming [.path]_a.adoc_ to [.path]_a.html_ and [.path]_b.adoc_ to [.path]_b.html_.
|
|
|
|
To save some typing, you can use the glob operator (`+*+`) to match all AsciiDoc files in the current directory using a single argument:
|
|
|
|
$ asciidoctor *.adoc
|
|
|
|
Your shell will automatically expand the pattern and interpret the command exactly as you had typed it above:
|
|
|
|
$ asciidoctor a.adoc b.adoc
|
|
|
|
You can pass all AsciiDoc files inside direct subfolders using the glob operator (`+*+`) in place of the directory name:
|
|
|
|
$ asciidoctor */*.adoc
|
|
|
|
To match all files in the current directory and direct subfolders, combine both glob patterns:
|
|
|
|
$ asciidoctor *.adoc */*.adoc
|
|
|
|
Since the globs in this command rely on shell expansion, the command is not portable across platforms.
|
|
To make it portable, you can allow the Asciidoctor CLI to expand the globs.
|
|
To do so, instruct the shell to not expand the glob by quoting the pattern, as shown here:
|
|
|
|
$ asciidoctor '*.adoc' '*/*.adoc'
|
|
|
|
This time, the arguments `+*.adoc+` and `+*/*.adoc+` are passed directly to Asciidoctor instead of being expanded.
|
|
Asciidoctor handles the glob matching in a manner that is portable across platforms.
|
|
|
|
CAUTION: If you process multiple nested AsciiDoc files at once and are also applying a custom stylesheet to them, you'll need to <<user-manual#style-nest-doc,manage the stylesheet's location>>.
|
|
|
|
But it gets better.
|
|
The glob handling in Asciidoctor (which matches the rules of file globbing in Ruby) is likely more powerful than what your shell offers.
|
|
For example, you can match AsciiDoc files in the current folder and in folders of any depth using the double glob operator (`+**+`).
|
|
|
|
$ asciidoctor '**/*.adoc'
|
|
|
|
Most shells do not honor the double glob pattern.
|
|
Thus, to ensure both portability and flexibility when specifying a glob pattern, always enclose the argument in quotes.
|
|
|
|
If you specify an output folder, the source folders are not preserved by default.
|
|
To preserve the folders, specify which portion of the path to remove using the `-R` flag:
|
|
|
|
$ asciidoctor -D out -R src 'src/**/*.adoc'
|
|
|
|
In this case, the folder structure under the `src` folder will be replicated.
|
|
|
|
You can use the special value `.` to indicate you want the folder structure of the source and output to be mirrored exactly.
|
|
For example:
|
|
|
|
$ asciidoctor -D out -R . '**/*.adoc'
|
|
|
|
If you find yourself pushing the boundaries of what can be achieved using the CLI to convert multiple AsciiDoc files (including processing resources like images), consider switching to a build tool like Maven or Gradle.
|
|
Both tools provide excellent Asciidoctor integration.
|
|
Refer to the <<asciidoctor-maven-plugin.adoc#,Asciidoctor Maven plugin>> or <<asciidoctor-gradle-plugin.adoc#,Asciidoctor Gradle plugin>> for details.
|
|
|