Skip to main content

A dynamic versioning, Cython, PyBind11, and Raw C API building. Experimental.

Project description

Build Cub

pypi version Python 3.12+

A Hatch build hook for compiling native Python extensions. Supports Cython, PyBind11, Native C/C++, PyO3/Rust, and Gperf preprocessing with configuration-driven builds.

Features

  • Multiple Backends: Cython, PyBind11, Native C/C++, PyO3/Rust, and Gperf support out of the box
  • Configuration-Driven: All build settings defined in bear_build.toml
  • Cross-Platform: Automatic compiler/linker arg selection for Unix and Windows
  • Settings Inheritance: Define defaults once, override per-backend as needed
  • Flexible Templates: Generate version files and headers with Jinja2 templates
  • VCS Versioning: Automatic version extraction from git tags

NOTE

The project isn't fully ready yet so please do not use it quite yet.

Installation

pip install build-cub

With uv:

uv add build-cub

Quick Start

1. Add to your build system

In your pyproject.toml:

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

[tool.hatch.build.hooks.custom]
path = "hatch_build.py"

2. Create the build hook

Create hatch_build.py in your project root:

from build_cub.plugins import BuildCubHook

class CustomBuildHook(BuildCubHook):
    PLUGIN_NAME = "custom"

3. Configure your build

Create bear_build.toml in your project root:

[general]
name = "my_package"
enabled = true

[defaults.settings]
extra_compile_args = ["-O3", "-ffast-math"]
extra_link_args = ["-O3"]

[cython]
enabled = true
targets = ["src/my_package/fast.pyx"]

[cython.compiler_directives]
language_level = "3"
boundscheck = false
wraparound = false

4. Build your package

uv build
# or
pip wheel .

Configuration Reference

General Settings

[general]
name = "my_package"        # Package name
enabled = true             # Master switch for all compilation
debug_symbols = false      # Include debug symbols (-g flag)

Compiler Defaults

[defaults.settings]
extra_compile_args = ["-O3", "-std=c++20"]
extra_link_args = ["-O3"]
extra_compile_args_windows = ["/O2", "/std:c++20"]
extra_link_args_windows = ["/IGNORE:4099"]
include_dirs = []
library_dirs = []
libraries = []

[defaults.output_files]
lib_files = [".so", ".pyd"]

Cython Backend

[cython]
enabled = true
annotate = false           # Generate HTML annotation files
quiet = true               # Suppress compiler output
cleanup = true             # Remove intermediate .c/.cpp files
targets = ["src/pkg/module.pyx"]

[cython.settings]
# Override defaults for this backend only
extra_compile_args = ["-O2"]

[cython.compiler_directives]
language_level = "3"
embedsignature = true
boundscheck = false
wraparound = false
cdivision = true

PyBind11 Backend

[pybind11]
enabled = true
targets = [
    { name = "bindings", sources = ["src/pkg/_cpp/bindings.cpp"] }
]

Native C/C++ Backend

[native]
enabled = true
targets = [
    { name = "core", sources = ["src/pkg/_c/core.c", "src/pkg/_cpp/utils.cpp"] }
]

PyO3 Backend

[pyo3]
enabled = true
release = true             # Build in release mode (optimized)
quiet = false              # Show cargo build output
features = []              # Cargo features to enable

Gperf Preprocessing

[gperf]
enabled = true
binary = "/usr/bin/gperf"
language = "C++"

Version Templates

Generate version files from Jinja2 templates:

[versioning.variables]
database = { major = 2, minor = 0, patch = 0 }

[[versioning.templates]]
output = "src/my_package/_version.py"
content = '''
__version__ = "{{ version.major }}.{{ version.minor }}.{{ version.patch }}"
__db_version__ = "{{ database.major }}.{{ database.minor }}.{{ database.patch }}"
'''

[[versioning.templates]]
output = "src/my_package/_cpp/version.hpp"
content = '''
#pragma once
constexpr int VERSION_MAJOR = {{ version.major }};
constexpr int DB_VERSION_MAJOR = {{ database.major }};
'''

The version variable is automatically injected from VCS (git tags).

Requirements

  • Python 3.12+
  • Hatchling build backend
  • Backend-specific requirements:
    • Cython backend: cython
    • PyBind11 backend: pybind11
    • PyO3 backend: Rust toolchain (rustup + cargo)
    • Gperf backend: gperf binary installed

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

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

build_cub-0.0.28-py3-none-any.whl (66.3 kB view details)

Uploaded Python 3

File details

Details for the file build_cub-0.0.28-py3-none-any.whl.

File metadata

  • Download URL: build_cub-0.0.28-py3-none-any.whl
  • Upload date:
  • Size: 66.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for build_cub-0.0.28-py3-none-any.whl
Algorithm Hash digest
SHA256 1a41e551e27ea04e6bfb11a7f8c8af02a414e7ba5f1f698bafb6bcecf82901a8
MD5 188d575297cc824e587b1f9d3ab83021
BLAKE2b-256 87f375cfa0a21217e095964d7da0bb8bb64bd705dcc4b3350e265ea2374db44c

See more details on using hashes here.

Provenance

The following attestation bundles were made for build_cub-0.0.28-py3-none-any.whl:

Publisher: build-wheels.yml on sicksubroutine/build-cub

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