Appendix P CLI versions 1 vs 2
This appendix describes the differences between the PreTeXt-CLI version 1.x and 2.x. Generally, projects started in version 1 of the CLI will continue to work in version 2.
The primary difference between the versions of the CLI is the format of the project manifest (
project.ptx
): in version 1, most properties were described as XML elements, where they are now given as attributes. The functions of each attribute for the version 2 manifest is described in Subsection 5.2.7. Here we illustrate how these relate to the legacy elements.In Listing P.0.1 we show a project manifest containing almost all options available. Then Listing P.0.2 shows the same project manifest in version 2 format.
One advantage of version 2 of the CLI is that many of the options are now optional, or can be applied at the project level to all targets. The example shown above can be further simplified, as shown in Listing P.0.3, since most values are the defaults anyway.
Attributes for the
<project>
element that describe paths are common roots for any paths specified in <target>
elements.Notice that there is no longer a place to specify your executables in the manifest. This is because your executables are generally specific to a particular system, not a project. So instead, you specify executables in the file
executables.ptx
which is ignored by git. As with the version 2 manifest, the name or path to the executables are given as values of attributes. An example is shown in Listing 5.2.8.The project manifest can be further simplified by setting attributes for the
<project>
element. See Subsection 5.2.7 for details.Hopefully the examples above make it clear how the two versions compare for basic options. Below we list a few more differences between how you specify options in the version 1 and version 2 manifests.
@ptx-version
- For the CLI to know you are using a version 2 manifest, you must include the
@ptx-version
attribute in the<project>
element, with value “2”. - string parameters
- In version 1, you would specify string parameters as a sequence of
<stringparam>
elements, each with@key
and@value
attributes. In version 2, you use a single<stringparams>
element with attributes for each key set to the value for the string parameter’s value. See the example in Listing P.0.2 - zipped output
- In version 1, you could get a zipped version of your html output by setting the format of the target to
html-zipped
. In version 2, this is replaced by setting the@compression
attribute to “zip” in the<target>
element. - Braille options
- In version 2, you specify what embossing method you use for Braille formatted targets using the
@braille-mode
attribute, with value either “emboss” or “electronic”. - WeBWorK Sets
- In version 1, you could generate webwork sets using the "webwork-sets" format. In version 2, this is replaced by setting the
@format
attribute to “webwork” in the<target>
element. Such a target can be compressed using the@compression
attribute. - Local asymptote
- In version 2, you can require that asymptote elements are generated using a local version of asymptote (instead of the server). You can specify this by setting the
@asy-method
attribute to “local”, in either the<target>
element, or as an attribute of<project>
to use this method for all targets.