Skip to main content

A Markdown to LaTeX converter.

Project description

TeXSmith

CI Coverage PyPI Repo Size Python Versions License

MkDocs MkDocs Material Python

TeXSmith is a Python package and CLI tool to convert Markdown or HTML documents into LaTeX format. It is designed to be extensible via templates and integrates with MkDocs for generating printable documents from documentation sites.

TL;DR

pip install texsmith
texsmith input.md input.bib -o build/ --build

Key features

  • MkDocs-native Markdown – Ships with the same Material + pymdown extension stack you use in MkDocs, so tabs, callouts, annotations, tooltips, and data tables survive the conversion.
  • Template-first runtime – Bundle multiple fragments into slots, merge front matter metadata, and emit LaTeX projects ready for Tectonic or latexmk with Docker-friendly manifests.
  • CLI and Python parity – The Typer-powered CLI wraps the same ConversionService you can consume as a library, making CI/CD and notebooks behave like local runs.
  • Actionable diagnostics – Structured emitters, verbosity switches, and --debug traces keep LaTeX issues debuggable even in automated pipelines.
  • Extensible converters – Override Markdown parsers, hook into RenderPhase handlers, or ship diagram transformers (Mermaid, Draw.io, Svgbob) that plug directly into the engine.

Installation

# uv (recommended for isolated CLI installs)
uv tool install texsmith

# pip / pipx
pip install texsmith
pipx install texsmith

TeXSmith targets Python 3.10+ and expects a LaTeX distribution (TeX Live, MiKTeX, or MacTeX) when you pass --build. Optional converters such as Mermaid rely on Docker (minlag/mermaid-cli) unless you register custom handlers.

Platform notes

  • Linux – Install TeX Live (full) via your package manager or install-tl. When running inside CI containers, cache ~/.texliveYY so repeated latexmk runs stay fast—or use the default Tectonic engine to minimise setup.
  • macOS – Use MacTeX or BasicTeX plus the tlmgr packages reported by texsmith --template <name> --template-info. Homebrew’s mactex cask works well when paired with uv.
  • Windows – TeXSmith runs via native Python or WSL. For PDF builds we recommend MiKTeX + PowerShell, or WSL2 with TeX Live and Docker Desktop (needed for Mermaid).
  • Docker workflows – Run texsmith --build inside a TeX Live container, mounting your project plus the template directory. Copy tlmgr prerequisites from --template-info so images compile without network access.

See the Getting Started guide for a step-by-step walkthrough, verification commands, and Python API examples.

Documentation

Browse the full documentation at yves-chevallier.github.io/texsmith for:

Template catalog

Inspect templates by name or path to understand their slots, metadata attributes, TeX Live requirements, and declared assets:

texsmith --template article --template-info
# or inspect a local path
texsmith --template ./templates/nature --template-info
texsmith templates  # view discovery order across built-ins/packages/local/home

Use this command before wiring slots or when you need to confirm which tlmgr packages to preinstall in CI.

Examples

The examples/ directory includes reproducible demos:

  • examples/paper – end-to-end render with bibliographies and latexmk (or Tectonic with --engine tectonic).
  • examples/diagrams – Mermaid and Draw.io conversions.
  • examples/markdown – exhaustive Markdown showcase with diagram/front-matter overrides.

Each example ships build instructions inside docs/examples/index.md.

Project layout

The source tree is organised around three top-level namespaces:

  • texsmith.core contains the conversion pipeline, document models, diagnostics, and template helpers.
  • texsmith.adapters hosts infrastructure integrations such as Markdown parsing, LaTeX rendering, Docker helpers, and transformer utilities.
  • texsmith.ui provides end-user interfaces, including the Typer-powered CLI.

Core architecture highlights

  • ConversionService encapsulates the orchestration that previously lived in texsmith.api.service helpers. Provide a ConversionRequest and receive a ConversionResponse with rendered bundles and diagnostics.
  • TemplateRenderer now owns slot aggregation and LaTeX assembly. TemplateSession focuses on session state, template options, and bibliography tracking.
  • DocumentSlots unify slot directives from front matter, CLI flags, and programmatic overrides. Every entry point now speaks the same data model.
  • DiagnosticEmitter replaces ad-hoc callback bags so warnings, errors, and structured events flow through a predictable interface (CLI uses CliEmitter; libraries can plug in their own).
  • Fragments use a BaseFragment + config dataclass model (fragment = YourFragment() export referenced by fragment.toml entrypoints). No legacy factories remain.

Programmatic conversions with ConversionService

from pathlib import Path

from texsmith.api.service import ConversionRequest, ConversionService

service = ConversionService()
request = ConversionRequest(
    documents=[Path("docs/index.html")],
    bibliography_files=[Path("references.bib")],
    template="article",
    render_dir=Path("build"),
)
prepared = service.prepare_documents(request)
response = service.execute(request, prepared=prepared)

print("Main TeX:", response.render_result.main_tex_path)
print("Diagnostics:", [event.name for event in response.diagnostics])

If you only need a quick conversion, the high-level helpers (texsmith.Document, texsmith.convert_documents, texsmith.TemplateSession) continue to work, but they now reuse the same ConversionService plumbing as the CLI.

Refer to UPGRADE.md for release notes and migration guidance from earlier builds.

Render engine phases

The rendering pipeline walks the BeautifulSoup tree four times. Each pass maps to a value of RenderPhase so handlers can opt into the point where their transform should fire:

  • RenderPhase.PRE: Early normalisation. Use it to clean the DOM and replace nodes before structural changes happen (e.g. unwrap unwanted tags, turn inline <code> into LaTeX).
  • RenderPhase.BLOCK: Block-level transformations once the tree structure is stable. Typical consumers convert paragraphs, lists, or blockquotes into LaTeX environments.
  • RenderPhase.INLINE: Inline formatting where block layout is already resolved. It is the right place for emphasis, inline math, or link handling.
  • RenderPhase.POST: Final pass after children are processed. Use it for tasks that depend on previous passes such as heading numbering or emitting collected assets.

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

texsmith-0.2.1.tar.gz (3.4 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

texsmith-0.2.1-py3-none-any.whl (514.0 kB view details)

Uploaded Python 3

File details

Details for the file texsmith-0.2.1.tar.gz.

File metadata

  • Download URL: texsmith-0.2.1.tar.gz
  • Upload date:
  • Size: 3.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for texsmith-0.2.1.tar.gz
Algorithm Hash digest
SHA256 7c6ea99f548eca0854d2b3ba0e1c54cd6c440cc4cbb7e401c5670869ee0dfd65
MD5 6e1d4e78b4dfb0106f197d053dcd6649
BLAKE2b-256 676ffad85a8a2f8c3e5ba5fb8fb74ee589f5e0421ca2768e5b1c51813e72f774

See more details on using hashes here.

Provenance

The following attestation bundles were made for texsmith-0.2.1.tar.gz:

Publisher: ci.yml on yves-chevallier/texsmith

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file texsmith-0.2.1-py3-none-any.whl.

File metadata

  • Download URL: texsmith-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 514.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for texsmith-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 18fa4bd09153fb58c1e69ff5067260e7754c4ac96f505fd7dbe6aaa4485da947
MD5 cdfd553907f426fb6f420d9ed48fdd58
BLAKE2b-256 21b6fea8c082035f20d4a6e845635585794e7d14dec40859e942cffd9c354450

See more details on using hashes here.

Provenance

The following attestation bundles were made for texsmith-0.2.1-py3-none-any.whl:

Publisher: ci.yml on yves-chevallier/texsmith

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page