spix


Namespix JSON
Version 1.5.0 PyPI version JSON
download
home_pagehttp://framagit.org/spalax/spix
SummaryYet another TeX compilation tool: simple, human readable, no option, no magic.
upload_time2024-12-26 23:19:43
maintainerNone
docs_urlNone
authorLouis Paternault
requires_python<4,>=3.8
licenseGPLv3 or any later version
keywords tex latex compilation
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # 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"
}
        
Elapsed time: 0.46000s