A dockerized build tool for paper compilation
Project description
texbld
Although we expect LaTeX compilation to be a declarative process (source to
PDF), the compilations for large projects eventually require a large number of
custom external programs and dependencies. For example, a compilation step might
require running a script written in haskell, piping that output into pandoc,
then putting everything into a LaTeX file for compilation with pdflatex
. Good
luck installing all of those programs (ESPECIALLY the pesky ghc dependencies) in
a production system!
Furthermore, different LaTeX distributions will have ever so slightly different outputs (especially when working with biblatex), which is an issue for reproducibility.
The first take on these problems was mktex. Although it solves some dependency issues, it suffers from the various fragility and reproducibility issues that come with using pre-built docker images. Furthermore, because of its design, these images were forced to be monolithic, bloated, and ultimately inflexible. Each build should have exactly the dependencies that it requires and nothing more!
texbld
aims to solve these problems by providing an environment where build
images are fully reproducible and shareable. It uses docker for absolute system
reproducibility and for usage across all platforms which it supports (MacOS, its
native Linux, and Windows (untested)).
Image hashes are used to ensure that any docker image is completely immutable, preventing dependency modification issues.
Users can specify their build image in a simple TOML file (along with associated files) and upload them to github, from which it can be inherited and used by other people in their own projects.
Images can be inherited from packages in the local filesystem, GitHub, or Docker.
Installation
The project is live on pypi.
Various installation methods are described here.
NixOS
Check the nix expressions in the release branch and configure accordingly.
In order to build the master branch, run nix-build
or nix build
(to use
flakes).
Setting Up This Project
NixOS
Running nix develop
should set up everything. Note, however, that the
resulting poetry virtual environment will be installed in
~/.cache/pypoetry/virtualenvs
, so it's not completely nix-based.
Non-NixOS
This project uses poetry as its dependency manager. Simply run poetry install
and poetry shell
inside the project directory, and you should land in a
virtual environment with all of your dependencies.
Testing
In order to run tests in the virtual environment, run pytest
.
The Local Environment
The project configuration file should be in (project root)/texbld.toml
, while
local image configurations should be in $HOME/.config/texbld/packages
.
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
Built Distribution
File details
Details for the file texbld-0.4.1.tar.gz
.
File metadata
- Download URL: texbld-0.4.1.tar.gz
- Upload date:
- Size: 29.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.1.13 CPython/3.10.5 Linux/5.18.13-200.fc36.x86_64
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6be620bf4d59706cf020196aa84ebdf58751789778cbd204626b80f3fec72e92 |
|
MD5 | cf51b13dc8e8ebe6ba7232323e61ff2e |
|
BLAKE2b-256 | ad274bdfd951ede1ca316af99fc5f2f1847171a60e4b5d4141a8d94e2f01c201 |
File details
Details for the file texbld-0.4.1-py3-none-any.whl
.
File metadata
- Download URL: texbld-0.4.1-py3-none-any.whl
- Upload date:
- Size: 39.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.1.13 CPython/3.10.5 Linux/5.18.13-200.fc36.x86_64
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 722d7d9915ebc3e6f1a1649815e3c05ad82278df1f760cf02381803f65f4cde8 |
|
MD5 | dad82ab8132b94700378f78ba3963eca |
|
BLAKE2b-256 | b5ef485aeab90028b4d0b63b986bcb78ff78cd57afe8980748603c94a9c6565c |