Skip to main content

Hatch build hook for compiling Mojo sources into Python and native artifacts

Project description

hatch-mojo

A Hatch build hook plugin that compiles Mojo sources during package builds.

Supports Python extension modules and standalone artifacts (shared libraries, executables, etc.).

Installation

uv add hatch-mojo

Quickstart

Add the hook to your pyproject.toml:

[build-system]
build-backend = "hatchling.build"
requires = ["hatchling", "hatch-mojo"]

[tool.hatch.build.targets.wheel.hooks.mojo]
targets = ["wheel"]

[[tool.hatch.build.targets.wheel.hooks.mojo.jobs]]
name = "core"
input = "src/mo/my_pkg/core.mojo"
emit = "python-extension"
module = "my_pkg._core"
include-dirs = ["src/mo"]

Then build:

hatch build -t wheel

Configuration

All configuration lives under [tool.hatch.build.targets.wheel.hooks.mojo] in pyproject.toml.

Global options

[tool.hatch.build.targets.wheel.hooks.mojo]
mojo-bin = "/opt/mojo/bin/mojo"    # path to mojo binary (default: $HATCH_MOJO_BIN or "mojo")
parallel = true                     # compile jobs in parallel
fail-fast = true                    # stop on first failure (only with parallel)
clean-before-build = false          # remove build-dir before compiling
clean-after-build = false           # remove build-dir after compiling
skip-editable = true                # skip Mojo compilation for editable installs
build-dir = ".hatch_mojo"           # working directory for compiled artifacts
targets = ["wheel"]                 # hatch build targets that trigger this hook
include = ["src/mo/**/*.mojo"]      # git-style globs to include
exclude = ["**/experimental*.mojo"] # git-style globs to exclude

Profiles

Profiles define reusable sets of job options. Jobs reference them by name, and profile values are merged into the job config.

[tool.hatch.build.targets.wheel.hooks.mojo.profiles.default]
include-dirs = ["src/mo"]
flags = ["-I", "vendor/include"]
[[tool.hatch.build.targets.wheel.hooks.mojo.jobs]]
name = "core"
profiles = ["default"]
input = "src/mo/my_pkg/core.mojo"
emit = "python-extension"
module = "my_pkg._core"

Jobs

Each job compiles a single Mojo source into an output artifact.

Python extension:

[[tool.hatch.build.targets.wheel.hooks.mojo.jobs]]
name = "core"
input = "src/mo/my_pkg/core.mojo"
emit = "python-extension"
module = "my_pkg._core"
include-dirs = ["src/mo"]

Non-Python artifact (requires an install mapping):

[[tool.hatch.build.targets.wheel.hooks.mojo.jobs]]
name = "cli"
input = "src/mo/my_pkg/cli.mojo"
emit = "executable"
install = { kind = "scripts", path = "my-cli" }

Job options reference

Option Type Description
name string Unique identifier for the job
input string Path to the Mojo source file (supports globs)
emit string python-extension, shared-lib, static-lib, object, executable
output string Explicit output path (overrides default)
module string Dotted import path (required for python-extension)
install object Install mapping for non-Python artifacts: { kind, path }
profiles list Profile names to inherit settings from
include-dirs list Additional include directories passed as -I
defines list Values passed as -D flags to the compiler
flags list Extra flags passed to mojo build
env object Environment variables set during compilation
platforms list Restrict job to specific sys.platform values
arch list Restrict job to specific platform.machine() values
marker string PEP 508 marker expression for conditional inclusion
depends-on list Job names that must complete before this one

Supported install kinds: package, data, scripts, root, force-include

Troubleshooting

Error Fix
mojo executable not found Set mojo-bin, HATCH_MOJO_BIN, or add mojo to PATH
No build jobs resolved Check input paths, include/exclude globs, and targets
unknown dependencies Ensure depends-on references valid job names
Wheel missing binaries Set module for extension jobs or install for non-Python jobs

License

MIT

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

hatch_mojo-0.1.0.tar.gz (111.9 kB view details)

Uploaded Source

Built Distribution

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

hatch_mojo-0.1.0-py3-none-any.whl (11.2 kB view details)

Uploaded Python 3

File details

Details for the file hatch_mojo-0.1.0.tar.gz.

File metadata

  • Download URL: hatch_mojo-0.1.0.tar.gz
  • Upload date:
  • Size: 111.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for hatch_mojo-0.1.0.tar.gz
Algorithm Hash digest
SHA256 9afd20b669fed8113f9857443b18c27bfce170d0d8b9ac88815ff0e26e21f07f
MD5 646a5c7cd8b6a8295567ab627947b30a
BLAKE2b-256 90e216f7fed0289657eed654f4f52024b9c2bc86958c132f1659acbc911fd568

See more details on using hashes here.

Provenance

The following attestation bundles were made for hatch_mojo-0.1.0.tar.gz:

Publisher: publish.yml on cofin/hatch-mojo

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

File details

Details for the file hatch_mojo-0.1.0-py3-none-any.whl.

File metadata

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

File hashes

Hashes for hatch_mojo-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 1a8e8716bf17312645c57c1a542ba42bbff983439d0fe636cd6ae370b8b3707c
MD5 a3f8c70281583a0c45bac6a1bd190b98
BLAKE2b-256 bec4fec2e58a5278398f571ed2b497c1daa02b5ca6d362036e2efe820a2dca81

See more details on using hashes here.

Provenance

The following attestation bundles were made for hatch_mojo-0.1.0-py3-none-any.whl:

Publisher: publish.yml on cofin/hatch-mojo

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