Skip to main content

Orkid Build Tools

Project description

OBT (Orkid Build Tool)

OBT Logo

Build environment orchestrator for complex multi-language projects

Python 3.10+ License: BSD-3-Clause Platform: Linux/macOS/WSL2


What is OBT?

OBT manages build environments for complex software projects with extensive dependency trees. Unlike package managers that install system-wide, OBT creates isolated staging environments where all your project dependencies coexist without polluting your system.

Key Features

  • 🔧 100+ Pre-configured Dependencies - Boost, Qt5, OpenCV, LLVM, and more
  • 🎯 Project Composition - Combine multiple projects with --project arguments
  • 🌍 Cross-Platform - Identical commands on Linux, macOS, and WSL2
  • 🏗️ Multi-Language - C++, Python, Rust, JavaScript, and more
  • 📦 Isolated Environments - No system pollution, everything in staging directories
  • 🎨 Extensible - Add custom dependencies and modules per project

Quick Start

# Install OBT
pip3 install ork.build

# Create environment
obt.env.create.py --stagedir ~/.obt-staging

# Launch with projects
obt.env.launch.py --stagedir ~/.obt-staging --numcores 16 \
  --project ~/projects/myproject \
  --project ~/projects/shared

# Build dependencies
obt.dep.build.py boost
obt.dep.build.py opencv

Documentation

Getting Started

Reference

Advanced Topics


Requirements

  • Python 3.10+
  • Virtual environment (PEP-668 compliance)
  • Clean base shell environment (why?)

Platform-Specific

macOS: Xcode, Homebrew
Linux: Build essentials, sudo access
Windows: WSL2 with Ubuntu


Project Composition

Make any project OBT-aware by adding:

myproject/
├── obt.project/
│   ├── obt.manifest          # {"name": "myproject", "autoexec": "scripts/init_env.py"}
│   └── scripts/
│       └── init_env.py       # Environment setup script

Then compose multiple projects:

obt.env.launch.py --project project1 --project project2 --project project3

Philosophy

OBT doesn't replace package managers or build systems - it orchestrates them. When you need a library, you need it. OBT ensures you get it with the right version, in the right place, without breaking anything else.


Support


License

BSD 3-Clause License - See LICENSE and license.rst for details.

Copyright (c) 2010-2024, Michael T. Mayers. All rights reserved.

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

ork_build-0.0.298.tar.gz (510.8 kB view details)

Uploaded Source

Built Distribution

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

ork_build-0.0.298-py3-none-any.whl (776.3 kB view details)

Uploaded Python 3

File details

Details for the file ork_build-0.0.298.tar.gz.

File metadata

  • Download URL: ork_build-0.0.298.tar.gz
  • Upload date:
  • Size: 510.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.10

File hashes

Hashes for ork_build-0.0.298.tar.gz
Algorithm Hash digest
SHA256 a9ef19b28d232e8b575a53b37eb153b45222a8844d5c714193c0e3c12462592c
MD5 b71097c4c8fd1fb7f8825e5877228e0f
BLAKE2b-256 8261e4bc372653ff0fab6e7e0be76305431089ae0f801774dea958e552832e66

See more details on using hashes here.

File details

Details for the file ork_build-0.0.298-py3-none-any.whl.

File metadata

  • Download URL: ork_build-0.0.298-py3-none-any.whl
  • Upload date:
  • Size: 776.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.10

File hashes

Hashes for ork_build-0.0.298-py3-none-any.whl
Algorithm Hash digest
SHA256 3e9cbcbd77e1c54d67a8937054be3a6684d78cddede4dbe4a277d1c71e47b5e8
MD5 2e966c7495ade00f6c941ffdcabb1ee1
BLAKE2b-256 2ad9efaf142635d547b4ef2fc35f2eb4c8cf39df803eb944d460eed3e241c620

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