Skip to main content

Yet another TeX compilation tool: simple, human readable, no option, no magic.

Project description

SpiX 🦜 Yet another TeX compilation tool: simple, human readable, no option, no magic

SpiX is yet another compilation tool for .tex files. It aims at being simple and human readable. Every piece of configuration is written in the .tex file itself, in a clear format (a list of console commands).

Why SpiX?

With SpiX, the compilation process of a .tex file (Is it compiled using latex? pdflatex? xelatex? lualatex? Should I process its bibliography? with bibtex or biber? Is there an index?) is written in the .tex file itself, in a human-readable format (a shell script). That way:

  • when you want to compile two years later, you don't have to guess the compilation process;
  • you can send the .tex file to someone, and that's it: no need to send detailed instructions or a Makefile along with it (everything is in the .tex file);
  • the compilation process is human readable: it can be understood by anyone who is able to read a very basic shell script. In particular, one can read it even if she does not know SpiX.

The .tex file

Write the compilation process of your .tex file as a shell script, before the preamble, as lines starting with %$:

% Compile this file twice with lualatex.
%$ lualatex foo.tex
%$ lualatex foo.tex

\documentclass{article}
\begin{document}
Hello, world!
\end{document}

You can also replace the file name with $texname. That way, you don't have to worry about the file name when writing your commands.

% Compile this file twice with lualatex.
%$ lualatex $texname
%$ lualatex $texname

Compilation

To compile the .tex file, run SpiX:

spix foo.tex

Spix will parse the .tex file, looking for shell snippets (lines before the preamble starting with %$), and run them.

That's all!

Documentation

The complete documentation is available on readthedocs.

To compile it from source, download and run:

cd doc && make html

What's new?

See changelog.

Download and install

  • The preferred way to get SpiX working is by using your distribution package manager. With Debian (and Ubuntu, and surely other distributions that inherit from Debian), it is in package texlive-extra-utils (since version 2020.20210202-3)::

    sudo apt install texlive-extra-utils

  • Otherwise, you can install SpiX using pip:

    python3 -m pip install spix

  • Other installation methods can be found in the documentation.

License

Copyright 2020-2023 Louis Paternault

SpiX is licensed under the Gnu GPL 3 license, or any later version.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

spix-1.4.0.tar.gz (1.2 MB view details)

Uploaded Source

Built Distribution

spix-1.4.0-py3-none-any.whl (18.1 kB view details)

Uploaded Python 3

File details

Details for the file spix-1.4.0.tar.gz.

File metadata

  • Download URL: spix-1.4.0.tar.gz
  • Upload date:
  • Size: 1.2 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.5

File hashes

Hashes for spix-1.4.0.tar.gz
Algorithm Hash digest
SHA256 3f0d44441872de51b3c164c7e0628bad6871cac3deb3b117bc1fd0f225365174
MD5 a5bef31d3f764a24dc48d9953fc68ce5
BLAKE2b-256 79974aeb6f2b40a2790a8b68b4383bcf3bd7eda2af94fa2a37885abfa193c002

See more details on using hashes here.

File details

Details for the file spix-1.4.0-py3-none-any.whl.

File metadata

  • Download URL: spix-1.4.0-py3-none-any.whl
  • Upload date:
  • Size: 18.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.5

File hashes

Hashes for spix-1.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c2b0f26144fa463649025bbf2c66c1939418990c5304ad90228b0e9c240cb2cc
MD5 01092673b0e22618b0cb24136e15029b
BLAKE2b-256 17caf9889117b679de5b84b7cc7c23e7402251b9e326208026b3d4001e3e573c

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page