Directory support/texplate
TeXplate
TeXplate is a tool for creating document structures based on templates. The application name is a word play on TeX and template, so the purpose seems quite obvious: we want to provide an easy and straightforward framework for reducing the typical code boilerplate when writing TeX documents. Also note that one can easily extrapolate the use beyond articles and theses: the application is powerful enough to generate any text-based structure, given that a corresponding template exists.
Basic use
Our tool is a typical command line application, so we need to invoke it by simply typing texplate
in the terminal:
$ texplate ______ __ __ ___ __ /\__ _\ /\ \ /\ \ /\_ \ /\ \__ \/_/\ \/ __ \ `\`\/'/' _____\//\ \ __ \ \ ,_\ __ \ \ \ /'__`\`\/ > < /\ '__`\\ \ \ /'__`\ \ \ \/ /'__`\ \ \ \/\ __/ \/'/\`\\ \ \L\ \\_\ \_/\ \L\.\_\ \ \_/\ __/ \ \_\ \____\ /\_\\ \_\ \ ,__//\____\ \__/.\_\\ \__\ \____\ \/_/\/____/ \/_/ \/_/\ \ \/ \/____/\/__/\/_/ \/__/\/____/ \ \_\ \/_/ TeXplate 1.0.4, a document structure creation tool Copyright (c) 2020, Island of TeX All rights reserved. Missing required option '--output=<output>' Usage: texplate [-c=<configuration>] -o=<output> [-t=<template>] [-m=<String=String>...]... -c, --config=<configuration> The configuration file in which the tool can read template data, for automation purposes. Make sure to follow the correct specification when writing a configuration file. -m, --map=<String=String>... The contextual map that provides the data to be merged in the template. This parameter can be used multiple times. You can specify a map entry with the key=value syntax (mind the entry separator). -o, --output=<output> The output file in which the chosen template will be effectively written. Make sure the directory has the correct permissions for writing the output file. -t, --template=<template> The template and. The tool will search both user and system locations and set the template model accordingly, based on your specs.
Provided that TeXplate is properly available in the underlying operating system, we will get a lovely, colorful output in our terminal, along with a couple of scary messages telling that some required options are missing. Our tool provides four options, described as follows. Strictly speaking, there is only one mandatory option. The remainder might be optional, depending on certain scenarios.
Output
Referred as either-o
(short representation) or --output
(long representation), this option holds the output file in which the chosen template will be effectively written. The name is arbitrary, so you can use anything to your heart's desires. Keep in mind, however, that an existing file will be mercilessly overwritten. Also, make sure the path has the proper permissions for writing the output file.
Template
Referred as either -t
(short representation) or --template
(long representation), this option holds the reference to the template to be potentially merged with data and properly generated. The provided string should match the template identifier, otherwise TeXplate will raise an error complaining about the missing reference.
Map
Referred as either -m
(short representation) or --map
(long representation), this option holds a map entry, defined as a key=value
ordered pair (mind the =
symbol used as entry separator). This option can be used multiple times. The map entry denotes a variable in the template context, where the key is the variable name and the value is set to be the initial state of such variable.
Examples
For instance, let us generate a document named doc1.tex
, based on the standard article
class:
$ texplate -t article -o doc1.tex ______ __ __ ___ __ /\__ _\ /\ \ /\ \ /\_ \ /\ \__ \/_/\ \/ __ \ `\`\/'/' _____\//\ \ __ \ \ ,_\ __ \ \ \ /'__`\`\/ > < /\ '__`\\ \ \ /'__`\ \ \ \/ /'__`\ \ \ \/\ __/ \/'/\`\\ \ \L\ \\_\ \_/\ \L\.\_\ \ \_/\ __/ \ \_\ \____\ /\_\\ \_\ \ ,__//\____\ \__/.\_\\ \__\ \____\ \/_/\/____/ \/_/ \/_/\ \ \/ \/____/\/__/\/_/ \/__/\/____/ \ \_\ \/_/ TeXplate 1.0.4, a document structure creation tool Copyright (c) 2020, Island of TeX All rights reserved. Configuration file mode disabled .................. [ DONE ] Entering full command line mode ................... [ DONE ] Please, wait... Obtaining reference ............................... [ DONE ] Composing template ................................ [ DONE ] Validating data ................................... [ DONE ] Merging template and data ......................... [ DONE ] Done! Enjoy your template! Written: 112 B
And that is it! We provided the template name (-t article
) and the output (-o
doc1.tex). Checking the contents of
doc1.tex:
\documentclass{article} \usepackage[T1]{fontenc} \usepackage[utf8]{inputenc} \begin{document} \end{document}
We could enhance the template generation by providing further options to it. Let us say we want to include A4 as the paper size for our document and use XeTeX as engine. The command line is as follows (we omitted the full output for reducing verbosity):
$ texplate -t article -o doc2.tex -m options=a4paper -m xetex=true
For this example, we added two map entries referring to the class option and the support for newer engines (please refer to the user manual for more details on template options). The newly generated doc2.tex
document is as follows:
\documentclass[a4paper]{article} \usepackage{fontspec} \begin{document} \end{document}
Now, let us provide some packages to our document, as well as language support:
$ texplate -t article -o doc3.tex -m options=a4paper -m xetex=true \
-m babel=spanish,english -m packages=longtable,siunitx,array
Checking the contents of doc3.tex
:
\documentclass[a4paper]{article} \usepackage{fontspec} \usepackage[spanish,english]{babel} \usepackage{longtable} \usepackage{siunitx} \usepackage{array} \begin{document} \end{document}
And that is it! Make sure to take a look at the user manual to learn more about TeXplate!
License
This application is licensed under the New BSD License. Please note that the New BSD License has been verified as a GPL-compatible free software license by the Free Software Foundation, and has been vetted as an open source license by the Open Source Initiative.
The team
TeXplate is brought to you by the Island of TeX. If you want to support TeX development by a donation, the best way to do this is donating to the TeX Users Group.
Download the contents of this package in one zip archive (3.4M).
texplate – A tool for creating document structures based on templates
TeXplate is a tool for creating document structures based on templates. The application name is a word play on TeX and template, so the purpose seems quite obvious: we want to provide an easy and straightforward framework for reducing the typical code boilerplate when writing TeX documents. Also note that one can easily extrapolate the use beyond articles and theses: the application is powerful enough to generate any text-based structure, given that a corresponding template exists.
Package | texplate |
Bug tracker | https://gitlab.com/islandoftex/texplate/-/issues |
Repository | https://gitlab.com/islandoftex/texplate |
Version | 1.0.6 |
Licenses | 3-clause BSD License |
Copyright | 2021 Island of TeX |
Maintainer | Paulo Roberto Massa Cereda |
TDS archive | texplate.tds.zip |
Contained in | TeX Live as texplate MiKTeX as texplate |
Topics | Document generation Generate TeX Document template |