Skip to main content

PEP 517 / PEP 660 build backend for Mojo libraries (compiles .mojo → .mojopkg → wheel).

Project description

mojox-build

PEP 517 + PEP 660 build backend that compiles a Mojo library into a .whl.

Quickstart

# pyproject.toml
[project]
name = "boucle"
version = "0.2.0"
description = "Async event loop primitives for Mojo"
readme = "README.md"
license = "Apache-2.0"
requires-python = ">=3.10"
dependencies = ["mojox", "mojo-compiler>=0.26,<0.27"]

[build-system]
requires      = ["mojox-build>=0.2", "mojo-compiler>=0.26,<0.27"]
build-backend = "mojox_build"

[tool.mojox-build]
# Either a src/ layout (default):
package-root = "src"
# Or an explicit list of packages at the repo root:
# packages = ["boucle"]

uv build produces dist/boucle-0.2.0-py3-none-<platform>.whl containing boucle.mojopkg at boucle-0.2.0.data/platlib/mojo_packages/boucle.mojopkg. When installed, it lands in the venv's site-packages/mojo_packages/, which mojox discovers automatically.

[tool.mojox-build] reference

Key Type Default Purpose
package-root str "src" Directory containing top-level package dirs to compile.
packages list[str] (auto-scan package-root) Explicit list of source directories. Each becomes one .mojopkg.
native-libs list[str] [] Pre-built .so / .dylib files to copy into mojo_packages/lib/.
defines table {} -D KEY=VALUE flags passed to mojo package.
flags list[str] [] Extra flags appended to every mojo package invocation.
source-include list[str] (sensible default) Glob patterns of files to include in the sdist.
source-exclude list[str] [] Glob patterns to exclude from the sdist.
wheel-exclude list[str] [] Glob patterns to exclude from the wheel.

What you get

  • Platform-tagged wheels. .mojopkg is compiled native code, so wheels are tagged with the host platform (e.g. manylinux_2_34_x86_64, macosx_13_0_arm64). Cross-platform installs are correctly rejected by uv/pip.
  • Native lib bundling. Drop .so / .dylib paths in native-libs; they ride along in mojo_packages/lib/, where mojox's runtime adds them to LD_LIBRARY_PATH.
  • PEP 660 editable installs. uv pip install -e . works. For rebuild-on-change semantics, add cache-keys = [{ file = "pyproject.toml" }, { file = "**/*.mojo" }] to [tool.uv].
  • Reproducible builds. ZIP and tar timestamps respect SOURCE_DATE_EPOCH.
  • Parallel compilation. Multi-package repos compile their .mojopkg files in parallel (capped at 8 workers).
  • Preflight checks. Missing mojo, missing dirs, missing native libs, dynamic-version configs → one clean error message, not a stderr dump.
  • Full PEP 621 / PEP 639 metadata. authors, maintainers, urls, keywords, classifiers, optional-dependencies, license-files (copied into .dist-info/licenses/) all flow into the wheel METADATA.
  • --config-setting verbose=true. Streams mojo package output during builds when you need to debug.

How it works (architecture in five lines)

__init__.py re-exports the hook surface. _hooks is thin glue that calls into _config (parse pyproject), _preflight (environment checks), _build (compile + assemble), and _metadata (METADATA/WHEEL rendering). The whole backend has only one runtime dep beyond the stdlib: packaging for platform tags.

Limitations / known gaps

  • Dynamic project.version is not supported. Declare it statically.
  • Editable installs rebuild the full wheel on every invocation; there's no source-import fast path because .mojopkg is compiled bytecode.
  • Cross-compilation (--target per platform) is not exposed yet. Today's wheels are host-platform only.

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

mojox_build-0.2.3.tar.gz (9.8 kB view details)

Uploaded Source

Built Distribution

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

mojox_build-0.2.3-py3-none-any.whl (12.7 kB view details)

Uploaded Python 3

File details

Details for the file mojox_build-0.2.3.tar.gz.

File metadata

  • Download URL: mojox_build-0.2.3.tar.gz
  • Upload date:
  • Size: 9.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.14 {"installer":{"name":"uv","version":"0.11.14","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for mojox_build-0.2.3.tar.gz
Algorithm Hash digest
SHA256 26c6c6beeff3fab27d5dadda4674efd12163f4492331856adc96aad90fd263db
MD5 67c89d813626fdb2ee3e86f59059f979
BLAKE2b-256 4696e7bb17406b22fb43db47ce45c5dc136bc618a36eeef7055d986d76475ef0

See more details on using hashes here.

File details

Details for the file mojox_build-0.2.3-py3-none-any.whl.

File metadata

  • Download URL: mojox_build-0.2.3-py3-none-any.whl
  • Upload date:
  • Size: 12.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.14 {"installer":{"name":"uv","version":"0.11.14","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for mojox_build-0.2.3-py3-none-any.whl
Algorithm Hash digest
SHA256 67ee796392a52c73f528a42d97a3b9cbcb75ca55d26e499050a15b025028b200
MD5 fd7858b71196173be88dc015aa4045cc
BLAKE2b-256 dd55a11f99b034d5585f93bf7655bb370bf2cace99dceb77935af8b3796cc8a7

See more details on using hashes here.

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