Skip to main content

NTSC encoder implemented as a pybind11 extension

Project description

ntsc-encoder (pybind11)

This directory builds the ntsc_encoder Python extension module using C++/pybind11.

Requirements

  • Python 3.9+
  • A C++ compiler + CMake 3.18+
  • OpenCV development package (headers + libs)
    • macOS (Homebrew): brew install opencv
    • Ubuntu: sudo apt-get install libopencv-dev
  • Build tools:
    • python -m pip install -U build twine

Build a wheel/sdist locally

From this directory (Code/Encoder):

python -m pip install -U pip
python -m pip install -U build twine scikit-build-core pybind11 numpy
python -m build

Artifacts will appear in dist/.

Check metadata:

twine check dist/*

Upload to PyPI

Recommended: upload to TestPyPI first.

# TestPyPI
python -m twine upload -r testpypi dist/*

# PyPI
python -m twine upload dist/*

You’ll need an API token configured in ~/.pypirc or exported via environment variables.

Building wheels for multiple platforms (recommended)

To avoid requiring end users to have a compiler + OpenCV dev libs, publish prebuilt wheels. Typical approach: GitHub Actions + cibuildwheel.

High-level steps:

  1. Add cibuildwheel workflow
  2. Build wheels for Linux (manylinux), macOS, Windows
  3. Upload wheels + sdist with twine

If you want, I can add a ready-to-use GitHub Actions workflow for cibuildwheel.

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

ntsc_encoder-0.1.0.tar.gz (5.2 kB view details)

Uploaded Source

Built Distribution

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

ntsc_encoder-0.1.0-cp314-cp314-macosx_26_0_arm64.whl (1.7 kB view details)

Uploaded CPython 3.14macOS 26.0+ ARM64

File details

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

File metadata

  • Download URL: ntsc_encoder-0.1.0.tar.gz
  • Upload date:
  • Size: 5.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.3

File hashes

Hashes for ntsc_encoder-0.1.0.tar.gz
Algorithm Hash digest
SHA256 b4b80d83f742d4494ad4bd2ab061e07422639076191ec45a08b5d47ed5cc217a
MD5 29b50acea377a20c5cfb46777bc71822
BLAKE2b-256 e96dcee5054e7e6329fa21a3158c91a311d5f26b6fa35ca45b87daecdd510c1f

See more details on using hashes here.

File details

Details for the file ntsc_encoder-0.1.0-cp314-cp314-macosx_26_0_arm64.whl.

File metadata

File hashes

Hashes for ntsc_encoder-0.1.0-cp314-cp314-macosx_26_0_arm64.whl
Algorithm Hash digest
SHA256 e8389e8f112dbf27da575124f03f3f12198bd1a86c4f9f8168a0139d9ea87b84
MD5 2b81c764d3e303941dc343f3525a54a8
BLAKE2b-256 ecffede7b74dc588bd7a130ee0ec37af17bbdc23aeb588f13d5949462b9549ce

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