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.1.tar.gz (113.1 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.1-py3-none-any.whl (12.1 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: hatch_mojo-0.1.1.tar.gz
  • Upload date:
  • Size: 113.1 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.1.tar.gz
Algorithm Hash digest
SHA256 bc53c2d4e41ca0bbe3b03cf83a1bcd843dab277b1b9d299efd9482e8b73b34da
MD5 0ef948c40531f09b5a2393e9014b7d49
BLAKE2b-256 f604210823104d79b3c1e2496afc3823cbe4d111d436eaaaca225ad045408472

See more details on using hashes here.

Provenance

The following attestation bundles were made for hatch_mojo-0.1.1.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.1-py3-none-any.whl.

File metadata

  • Download URL: hatch_mojo-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 12.1 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.1-py3-none-any.whl
Algorithm Hash digest
SHA256 8d438e4f3883e3dae922ccffe1d50b429e1d9d87b07ba899b424658f25d60691
MD5 bb745229e56ddfcdf9883041903d15ea
BLAKE2b-256 ba2a36ac07b5c6cb6fc4df5b18e188db195ca1cc4d3c04fb16c19b6292beefaf

See more details on using hashes here.

Provenance

The following attestation bundles were made for hatch_mojo-0.1.1-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