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 = "build/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.3.tar.gz (117.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.3-py3-none-any.whl (14.4 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: hatch_mojo-0.1.3.tar.gz
  • Upload date:
  • Size: 117.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.3.tar.gz
Algorithm Hash digest
SHA256 b4215e1307c162f5d56d53236627bfc0968efddd922f551799083dc353852e3e
MD5 2323571fa0bb0ec041896cf8e979d163
BLAKE2b-256 bf7c07875444a93ff70f66e65fe0697b8f853a5af6ccf7abdad0a276c84ba69c

See more details on using hashes here.

Provenance

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

File metadata

  • Download URL: hatch_mojo-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 14.4 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.3-py3-none-any.whl
Algorithm Hash digest
SHA256 3f5e30ab6d33843e34d3a19fbb90445aa9e7874bd9e1b38fe8250c19f7d79165
MD5 128206f57894be5b6cecbd4839c2e457
BLAKE2b-256 a6899b58baefe6d95997575c354f3831ade7850cdec35a3c1a42fad7bd80de48

See more details on using hashes here.

Provenance

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