TeXbld projects are scaffolded and built from TeXbld images.
In order to scaffold a project into a currently non-existent directory
$PROJECT_DIR
(replace this with the directory you want to scaffold into), run
texbld generate project (image) $PROJECT_DIR
.
After scaffolding is complete, you will see that $PROJECT_DIR
contains a
texbld.toml
file and other files specified by image configurations.
TeXbld only accepts Resource Schemes for passing an image.
Use the --config (file)
option allows you to specify a different toml file
than the default image.toml
. This is useful when a repository has multiple
different configurations
Change your working directory to $PROJECT_DIR
and run texbld build
. This
will build out the corresponding docker image.
Check the commands
table of your texbld.toml
file and execute the
appropriate alias.
For example, if your configuration has the following lines
[commands]
compile = "pandoc -o main.pdf main.md"
Running texbld run compile
will run pandoc -o main.pdf main.md
in a docker
container specified by your project's image. If you run
texbld run nonexistent
, TeXbld will throw an error.
Run texbld validate project .
.
This checks that the texbld project located in your current working directory is valid. If no errors are thrown, you're all set.
This specifies the name of your project and is included for future use cases.
For this version of TeXbld, the only permitted version is "1". This option was proactively made in order to allow new configurations in the future.
The value of this specifies either a Docker image, a GitHub image, or a LocalImage.
Below are a set of mutually exclusive examples:
github = {owner = "texbld", repository = "templates", revision = "(revision sha)", sha256 = "(tarball sha256)", config = "md.toml" }
local = {name = "template", config = "image.toml"}
docker = "alpine"
You may notice that the GitHub and local image hashes have an extra (and
optional) "config" key. The default is always "image.toml", but this value
allows authors to share multiple different configurations stored in a single
repository. For example, an image might have a template for a vanilla assignment
in the image.toml
file, while having a template for biology papers with
specific dependencies in the bio.toml
file.
See above.