Build a LaTeX file.
Project description
latex-runner
A wrapper around LaTeX to build files which
- reads magic comments to determine the TeX program and options to be used.
- filters the output to show only errors, warnings, over-/underfull boxes, tracing commands and prompts.
- runs biber and makeglossaries if necessary.
- reruns LaTeX up to -n times if necessary.
Magic Comments
This program supports the following magic comments. For performance reasons this program stops looking for magic comments at the first non-empty line which is not a comment.
% !TeX root = ../main.tex
Run the TeX program with the given file instead.
This is useful if you have split up your document into multiple files, the current file is included in the main file with \input or \include and you have told vim to build the currently opened file with this program.
Magic comments from the root file are loaded immediately when this magic comment is encountered.
% !TeX program = pdflatex
The program used to build the tex file.
For security reasons programs not listed in the allowed-tex-programs setting are not executed.
By default the allowed programs are pdflatex, xelatex, lualatex, latex, tex and pdftex.
You can change these with latex-runner --edit-config.
% !TeX option = -shell-escape
A command line option which should be passed to the TeX program.
You can repeat this comment to enable several command line options.
I have introduced this type of comment because at the time of this writing % !TeX program = pdflatex -shell-escape breaks compilation in TeX studio.
For security reasons options not listed in the allowed-tex-options setting are not passed to the TeX program.
By default the allowed options are --shell-escape, --8bit, --interaction=batchmode, --interaction=nonstopmode, --interaction=scrollmode and --interaction=errorstopmode.
You can change these with latex-runner --edit-config.
% !TeX [new] jobname = content:*.tex
The jobname to pass to LaTeX. If this is a glob pattern matching several files the LaTeX file will be built several times, once for each jobname. The file extension is stripped from the jobname. Optionally a path may be specified before, separated by a colon, specifying the directory in which to look for the glob pattern. You can use this magic comment multiple times in order to specify multiple glob patterns or literal jobnames. (This is not a standard comment supported by other programs as well, I have defined it.)
For example, let's assume there is a directory called content next to the main file.
This directory contains four files a.tex, b.tex, c.tex and c.log.
- Then
% !TeX jobname = content:*.texcauses the main file to be built three times with the jobnamesa,bandc, generating three pdf filesa.pdf,b.pdfandc.pdf. - Then
% !TeX jobname = content/*.texcauses the main file to be built three times with the jobnamescontent/a,content/bandcontent/c, generating three pdf filescontent/a.pdf,content/b.pdfandcontent/c.pdf.
You can access the jobname in TeX with the macro \jobname.
For example:
-
\input{content/\jobname} -
or
\def\comparejobname{a} \edef\expandedjobname{\jobname} \ifx\comparejobname\expandedjobname This is job a. \else This is not job a. \fi
If you use new jobname all previously encountered jobnames are forgotten.
If you use jobname without new the list of jobnames will be expanded.
If the value is % it is replaced by the name of the file.
(Inspired by vim which uses % as a wildcard for the name of the current file when running shell commands.)
For example:
-
main.tex:
% !TeX jobname = characters:*.tex \documentclass{article} \newcommand\SetName[2]{\expandafter\newcommand\csname name:#1\endcsname{#2}} \newcommand\GetName[1]{\csname name:#1\endcsname} \input{characters/alice} \input{characters/bob} \input{characters/charly} \begin{document} List of all characters: \begin{itemize} \item \GetName{alice} \item \GetName{bob} \item \GetName{charly} \end{itemize} This is \GetName{\jobname}. \end{document}
-
characters/alice.tex:
% !TeX root = ../main.tex % !TeX new jobname = % \SetName{alice}{Alice}
-
characters/bob.tex:
% !TeX root = ../main.tex % !TeX new jobname = % \SetName{bob}{Bob}
-
characters/charly.tex:
% !TeX root = ../main.tex % !TeX new jobname = % \SetName{charly}{Charly}
Running latex-runner main.tex generates all three: alice.pdf, bob.pdf and charly.pdf.
Running latex-runner characters/alice.tex generates alice.pdf only.
Note that %!TeX new jobname is specified after %!TeX root.
This is important because %!TeX root = ../main.tex loads the %!TeX jobname = characters:*.tex from main.tex.
Config
You can change settings with
latex-runner --edit-config
You can get help how to configure this program with
latex-runner --help-config
Installation
You can install this program via the python package manager pipx:
pipx install latex-runner
vim integration
Copy the following into ~/.vim/after/ftplugin/tex.vim.
This will allow you to run LaTeX once with F5, build the pdf completely with Control+F5 and open the pdf at the cursor position in zathura with Shift+F5 or F6. You can open the log file with F7.
" build pdf
nnoremap <buffer> <F5> :exec "!latex-runner -n1 -synctex=1 " .. expand('%:p:S')<cr>
nnoremap <buffer> <C-F5> :exec "!latex-runner -n5 -synctex=1 " .. expand('%:p:S')<cr>
" open pdf
nnoremap <buffer> <S-F5> :exec "silent! !zathura --synctex-forward " .. line('.') .. ":" .. col('.') .. ":" .. expand('%:p') .. " " .. trim(system('latex-runner --get-pdf ' .. expand('%:p:S') .. " 2>/dev/null")) .. " >/dev/null 2>/dev/null &"<cr>:redraw!<cr>
nnoremap <buffer> <F6> :exec "silent! !zathura --synctex-forward " .. line('.') .. ":" .. col('.') .. ":" .. expand('%:p') .. " " .. trim(system('latex-runner --get-pdf ' .. expand('%:p:S') .. " 2>/dev/null")) .. " >/dev/null 2>/dev/null &"<cr>:redraw!<cr>
" open log file, return with :bp
nnoremap <buffer> <F7> :exec "edit " .. trim(system('latex-runner --get-log ' .. expand('%:p:S') .. " 2>/dev/null"))<cr>
" texdoc, to be used when cursor is in argument of \usepackage
nnoremap <buffer> K :silent exec '!texdoc <c-r>=expand("<cfile>")<cr> >/dev/null 2>&1 &' \| redraw!<cr>
" inserting magic comments
command InsertMagicCommentXelatex :0put ='% !TeX program = xelatex'
command InsertMagicCommentPdflatex :0put ='% !TeX program = pdflatex'
command InsertMagicCommentShellEscape :1put ='% !TeX option = -shell-escape'
command InsertMagicCommentRoot :0put ='% !TeX root = ../main.tex'
Running the tests
I am using mypy for static type checking and pytest for dynamic testing.
tox creates a virtual environment and installs all dependencies for you.
You can install tox with pipx (pipx install tox).
$ tox
In order to make tox work without an internet connection install devpi:
$ pipx install devpi-server
$ devpi-init
$ devpi-gen-config
$ su
# cp gen-config/devpi.service /etc/systemd/system/
# systemctl start devpi.service
# systemctl enable devpi.service
and add the following line to your bashrc:
export PIP_INDEX_URL=http://localhost:3141/root/pypi/+simple/
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file latex_runner-1.2.0.tar.gz.
File metadata
- Download URL: latex_runner-1.2.0.tar.gz
- Upload date:
- Size: 27.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: python-requests/2.32.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f1c82a1b403ec532a78499af9def5cecc6bb6416941e1f109f39b3bd0caf797f
|
|
| MD5 |
09e3b65505d60f27fc2e4a276b636c18
|
|
| BLAKE2b-256 |
8720d64476c42ee46bae218eae3dfaf7a2ce009881205be0052cff968baf563c
|
File details
Details for the file latex_runner-1.2.0-py3-none-any.whl.
File metadata
- Download URL: latex_runner-1.2.0-py3-none-any.whl
- Upload date:
- Size: 14.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: python-requests/2.32.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b51b9ea7ed4b2ce58abf8567e656e4db090d737c36dbb7ba7d93dd7c7278209a
|
|
| MD5 |
4caa84bf869a300c2c38d6cb8939bfed
|
|
| BLAKE2b-256 |
6cb1c9049e77a7abed2312e25fec13d817072c405c2bfa1b561eb7cffb94d40d
|