DITA Open Toolkit 4.1 Help

Building output using the `dita` command

You can generate output using the dita command-line tool. Build parameters can be specified on the command line or with .properties files.

  1. At the command-line prompt, enter the following command:

    ``dita`` **--input**=*input-file* **--format**=*format* \[*options*\]

    where:

    • input-file is the DITA map or DITA file that you want to process.

    • format is the output format (transformation type). This argument corresponds to the common parameter transtype. Use the same values as for the transtype build parameter, for example html5 or pdf.

      You can create plug-ins to add new output formats; by default, the following values are available:

      • dita

      • eclipsehelp

      • html5

      • htmlhelp

      • markdown, markdown_gitbook, and markdown_github

      • pdf

      • xhtml Tip: See DITA-OT transformations (output formats) for sample command line syntax and more information on each transformation.

    • [options] include the following optional build parameters:

      • --debug -d

        Debug logging prints considerably more additional information. The debug log includes all information from the verbose log, plus details on Java classes, additional Ant properties and overrides, preprocessing filters, parameters, and stages, and the complete build sequence. Debug logging requires additional resources and can slow down the build process, so it should only be enabled when further details are required to diagnose problems.

      • --output=dir -o dir

        Specifies the path of the output directory; the path can be absolute or relative to the current directory.

        This option corresponds to the common parameter output.dir.

        By default, the output is written to the out subdirectory of the current directory.

      • --filter=files

        Specifies filter file(s) used to include, exclude, or flag content. Relative paths are resolved against the current directory and internally converted to absolute paths.

        Note:

        To specify multiple filter files, use the system path separator character to delimit individual file paths (semicolon ‘ ;’ on Windows, and colon ‘ :’ on macOS and Linux) and wrap the value in quotes:

        --filter="filter1.ditaval;filter2.ditaval;filter3.ditaval"

        As of DITA-OT 3.6, the --filter option can also be passed multiple times:

        --filter=filter1.ditaval --filter=filter2.ditaval --filter=filter3.ditaval

        DITAVAL files are evaluated in the order specified, so conditions specified in the first file take precedence over matching conditions specified in later files, just as conditions at the start of a DITAVAL document take precedence over matching conditions later in the same document.

      • --force

        Force-install an existing plug-in.

        Passed as an additional option to the installation subcommand: dita install plug-in-zip --force

      • --help -h

        Print a list of available arguments, options, and subcommands.

      • --logfile=file -l file

        Write logging messages to a file.

      • --parameter=value_ -D___parameter=value

        Specify a value for a DITA-OT or Ant build parameter.

        The GNU-style --parameter=value form is only available for parameters that are configured in the plug-in configuration file; the Java-style -D form can also be used to specify additional non-configured parameters or set system properties.

        Parameters not implemented by the specified transformation type or referenced in a .properties file are ignored.

        Tip: If you are building in different environments where the location of the input files is not consistent, set args.input.dir with the dita command and reference its value with ${args.input.dir} in your .properties file.

      • --propertyfile=file

        Use build parameters defined in the referenced .properties file.

        Build parameters specified on the command line override those set in the .properties file.

      • --repeat=N

        Repeat the transformation N number of times.

        This option can be used by plug-in developers to measure performance. To run a conversion five times, for example, use --repeat=5. The duration of each execution will appear in the console when the final transformation is complete.

        $ `dita` **--input**=`docsrc/samples/sequence.ditamap` **--format**=html5 \ **--repeat**=5 1 11281ms 2 4132ms 3 3690ms 4 4337ms 5 3634ms
      • --resource=file -r file

        Specifies resource files.

        This argument corresponds to the common parameter args.resources.

        Resource files can be used to convert partial documentation sets by processing input with additional information.

        For example, to process a single topic file with a map that contains key definitions, use a command like this:

        `dita` **--input**=`topic.dita` **--resource**=`keys.ditamap` **--format**=html5

        To convert a chapter map to HTML5 and insert related links from relationship tables in a separate map, use:

        `dita` **--input**=`chapter.ditamap` **--resource**=`reltables.ditamap` **--format**=html5
      • --temp=dir -t dir

        Specifies the location of the temporary directory.

        This option corresponds to the common parameter dita.temp.dir.

        The temporary directory is where DITA-OT writes intermediate files that are generated during the transformation process.

      • --verbose -v

        Verbose logging prints additional information to the console, including directory settings, effective values for Ant properties, input/output files, and informational messages to assist in troubleshooting.

    If processing is successful, nothing is printed in the terminal window. The built output is written to the specified output directory (by default, in the out subdirectory of the current directory).

For example, from *dita-ot-dir*/docsrc/samples, run:

`dita` **--input**=`sequence.ditamap` **--format**=html5 \ **--output**=`output/sequence` \ **--args.input.dir**=`*/absolute/path/to/dita-ot-dir*/docsrc/samples` \ **--propertyfile**=`properties/sequence-html5.properties`

This builds sequence.ditamap to HTML5 output in output/sequence using the following additional parameters specified in the properties/sequence-html5.properties file:

# Directory that contains the custom .css file: args.cssroot = ${args.input.dir}/css/ # Custom .css file used to style output: args.css = style.css # Copy the custom .css file to the output directory: args.copycss = yes # Location of the copied .css file relative to the output: args.csspath = branding # Generate a full navigation TOC in topic pages: nav-toc = full

Usually, you will want to specify a set of reusable build parameters in a .properties file.

Related information

Arguments and options for the dita command

Accessing help for the dita command

DITA-OT parameters

Internal Ant properties

Why "startcmd" is not your friend

Last modified: 13 February 2024