36 releases (13 breaking)

0.15.0 Jan 3, 2025
0.14.1 Dec 28, 2024
0.13.1 Dec 4, 2024
0.13.0 Nov 7, 2024
0.3.8 Nov 14, 2022

#84 in Text processing

Download history 427/week @ 2024-09-21 84/week @ 2024-09-28 4/week @ 2024-10-05 102/week @ 2024-11-02 19/week @ 2024-11-09 4/week @ 2024-11-16 1/week @ 2024-11-23 126/week @ 2024-11-30 100/week @ 2024-12-07 2/week @ 2024-12-14 81/week @ 2024-12-21 196/week @ 2024-12-28 60/week @ 2025-01-04

340 downloads per month

MIT license

210KB
5.5K SLoC

vesti

A transpiler that compiles into LaTeX.

Why need a LaTeX transpiler?

I used to make several documentations using LaTeX (or plainTeX, but TeX is quite cumbersome to write a document, especially very complex tables or put an image, for example). However, its markdown like syntax is not confortable to use it. For example, there is a simple LaTeX document.

% coprime is my custom class. See https://github.com/e0328eric/coprime.
\documentclass[tikz, geometry]{coprime}

\settitle{My First Document}{Sungbae Jeong}{}
\setgeometry{a4paper, margin = 2.5cm}

\begin{document}
\section{Foo}
Hello, World!
\begin{figure}[ht]
    \centering
    \begin{tikzpicture}
        \draw (0,0) -- (1,1);
    \end{tikzpicture}
\end{figure}

Upper code is a figure using tikz.

\end{document}

What I am anoying about to use it is \begin and \end block. Is there a way to write much simpler? This question makes me to start this project. Currently, below code is generated into upper LaTeX code using vesti except comments.

% coprime is my custom class. See https://github.com/e0328eric/coprime.
docclass coprime (tikz, geometry)

\settitle{My First Document}{Sungbae Jeong}{}
\setgeometry{a4paper, margin = 2.5cm}

startdoc

\section{Foo}
Hello, World!
useenv figure [ht] {
    \centering
    useenv tikzpicture {
        \draw (0,0) -- (1,1);
    }
}

Upper code is a figure using tikz.

Installation

Prerequisits

Python 3.12 is need to use vesti. Vesti can be installed using cargo.

$ cargo install vesti

tectonic backend compilation issue

For a higher version of the rust compiler, somewhat tectonic backend is not compilable. See vesti-tectonic-git if one want to use tectonic backend for vesti.

config file

In default, it uses local pdflatex to compile vesti. If you want to change the default behavior, add config.yaml in $CONFIG_PATH/vesti and type like the following:

engine:
  main:
    "tectonic"

This example defaults vesti to run tectonic backend. (You must download vesti using tectonic-backend to use tectonic). The full list for main engine is in src/commands.rs.

Warning

This language is in beta version, so future break changes can be exist. Beware to use in the large projects.

Dependencies

~14–62MB
~1M SLoC