# SpiX 🦜 Yet another TeX compilation tool: simple, human readable, no option, no magic
SpiX is [yet another compilation tool](https://www.ctan.org/topic/compilation) 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](http://spix.readthedocs.io).
To compile it from source, download and run:
cd doc && make html
## What's new?
See [changelog](https://framagit.org/spalax/spix/blob/main/CHANGELOG.md).
## 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`](https://packages.debian.org/search?keywords=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](https://spix.readthedocs.io/en/latest/install/).
## License
*Copyright 2020-2024 Louis Paternault*
SpiX is licensed under the [Gnu GPL 3 license](https://www.gnu.org/licenses/gpl-3.0.html), or any later version.
Raw data
{
"_id": null,
"home_page": "http://framagit.org/spalax/spix",
"name": "spix",
"maintainer": null,
"docs_url": null,
"requires_python": "<4,>=3.8",
"maintainer_email": null,
"keywords": "tex latex compilation",
"author": "Louis Paternault",
"author_email": "spalax@gresille.org",
"download_url": "https://files.pythonhosted.org/packages/3a/64/9654de8367070478d4b57228f33273394f8dbd1f9dd8f5f5abf14859c746/spix-1.5.0.tar.gz",
"platform": null,
"description": "# SpiX \ud83e\udd9c Yet another TeX compilation tool: simple, human readable, no option, no magic\n\nSpiX is [yet another compilation tool](https://www.ctan.org/topic/compilation) 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).\n\n## Why SpiX?\n\nWith 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:\n\n- when you want to compile two years later, you don't have to guess the compilation process;\n- 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);\n- 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.\n\n### The ``.tex`` file\n\nWrite the compilation process of your ``.tex`` file as a shell script, before the preamble, as lines starting with ``%$``:\n\n % Compile this file twice with lualatex.\n %$ lualatex foo.tex\n %$ lualatex foo.tex\n \n \\documentclass{article}\n \\begin{document}\n Hello, world!\n \\end{document}\n\nYou can also replace the file name with ``$texname``. That way, you don't have to worry about the file name when writing your commands.\n\n % Compile this file twice with lualatex.\n %$ lualatex $texname\n %$ lualatex $texname\n\n### Compilation\n\nTo compile the ``.tex`` file, run SpiX:\n\n spix foo.tex\n\nSpix will parse the ``.tex`` file, looking for shell snippets (lines before the preamble starting with ``%$``), and run them.\n\nThat's all!\n\n## Documentation\n\nThe complete documentation is available on [readthedocs](http://spix.readthedocs.io).\n\nTo compile it from source, download and run:\n\n cd doc && make html\n\n## What's new?\n\nSee [changelog](https://framagit.org/spalax/spix/blob/main/CHANGELOG.md).\n\n## Download and install\n\n* 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`](https://packages.debian.org/search?keywords=texlive-extra-utils) (since version 2020.20210202-3)::\n\n sudo apt install texlive-extra-utils\n\n* Otherwise, you can install SpiX using pip:\n\n python3 -m pip install spix\n\n* Other installation methods can be found in the [documentation](https://spix.readthedocs.io/en/latest/install/).\n\n## License\n\n*Copyright 2020-2024 Louis Paternault*\n\nSpiX is licensed under the [Gnu GPL 3 license](https://www.gnu.org/licenses/gpl-3.0.html), or any later version.\n",
"bugtrack_url": null,
"license": "GPLv3 or any later version",
"summary": "Yet another TeX compilation tool: simple, human readable, no option, no magic.",
"version": "1.5.0",
"project_urls": {
"Documentation": "http://spix.readthedocs.io",
"Homepage": "http://framagit.org/spalax/spix",
"Source": "https://framagit.org/spalax/spix",
"Tracker": "https://framagit.org/spalax/spix/issues"
},
"split_keywords": [
"tex",
"latex",
"compilation"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "4b027bb1bac5a13f0e1722ef4d2e39dd629579cf6381e843c5ae7bfb66145325",
"md5": "54654e94e3d58be2fadc16ec157d5e31",
"sha256": "9420fc252e25f5a5addd9a305806b2189b1df04184b586f20f2d6945444ad520"
},
"downloads": -1,
"filename": "spix-1.5.0-py3-none-any.whl",
"has_sig": false,
"md5_digest": "54654e94e3d58be2fadc16ec157d5e31",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": "<4,>=3.8",
"size": 18105,
"upload_time": "2024-12-26T23:19:42",
"upload_time_iso_8601": "2024-12-26T23:19:42.186942Z",
"url": "https://files.pythonhosted.org/packages/4b/02/7bb1bac5a13f0e1722ef4d2e39dd629579cf6381e843c5ae7bfb66145325/spix-1.5.0-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "3a649654de8367070478d4b57228f33273394f8dbd1f9dd8f5f5abf14859c746",
"md5": "4d79ec3f8fe78dbb12350ec02043cff2",
"sha256": "a9f036d139cbe4c1639cdaaa93b31fc124178c0a519ef460627e47fd19eef56c"
},
"downloads": -1,
"filename": "spix-1.5.0.tar.gz",
"has_sig": false,
"md5_digest": "4d79ec3f8fe78dbb12350ec02043cff2",
"packagetype": "sdist",
"python_version": "source",
"requires_python": "<4,>=3.8",
"size": 1168151,
"upload_time": "2024-12-26T23:19:43",
"upload_time_iso_8601": "2024-12-26T23:19:43.930085Z",
"url": "https://files.pythonhosted.org/packages/3a/64/9654de8367070478d4b57228f33273394f8dbd1f9dd8f5f5abf14859c746/spix-1.5.0.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-12-26 23:19:43",
"github": false,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"lcname": "spix"
}