Skip to main content

A build tool for multi-projects that leverages package registries (pypi, npmjs, etc.)

Project description

PBT

pbt — a build tool for multi-packages that leverages package registries (pypi, npmjs, etc.).

PyPI Python GitHub Issues Contributions welcome License

Introduction

Having all packages in the same repository make it much easier to develop, share, reuse, and refactor code. Building and publishing the packages should not be done manually because it is time-consuming and may be frustrated if the projects are depending on each other. pbt is a tool designed to help make the process easier and faster. It supports building, installing, and updating versions of your packages and their dependencies consistently. It also provides utility commands to help you work with your packages in multi-repositories as if you are working with a monorepo.

Installation

pip install -U pab  # not pbt

Usage

Note: currently, pbt supports Python packages configured with Poetry (an awesome dependency management that you should consider using).

Assuming that you organized your packages to different sub-folders, each has their own project configuration file (e.g., pyproject.toml). You can run the following commands in the root directory (containing your projects). Note: pbt will discover the project based on the project name in its configuration file not the folder name.

You can also discover the list of commands by running pbt --help. Many commands have an option --cwd to override the current working directory.

  1. List all packages in the current project, and their dependencies if required
pbt list [-d]
  • -d, --dev: Whether to print to the local (inter-) dependencies
  1. Create virtual environment of a package and install its dependencies
pbt install [-e] [-d] [-v] [-p <package>]
  • -e: install the package, and its local (inter-) dependencies in editable mode
  • -d: also install dev-dependencies of the package
  • -v: verbose
  • -p: specify the package we want to build, if empty build all packages.

If you have encounter some errors during the installation, you can checkout the pyproject.failed.toml file that is generated by pbt in ./cache/<package> folder (relative to your current working directory). For example, on M1 chip, if your python version is ^3.8, you can't use the newer scipy (e.g., >1.8 as it requires python <3.11), poetry lock chooses to use an old version 1.6.0, which typically can't build on M1 due to no pre-built numpy for it.

  1. Update all package inter-dependencies
pbt update
  1. Clean packages' build & lock files
pbt clean [-p <package>]
  • -p: specify the package we want to build, if empty build all packages.
  1. Create setup.py

Generate a setup.py file that can be used to manually install in editable mode as poetry does not provide it out of the box at the time of writing. This is usually used for debugging. Note that if you install pip install -e ., you need to rename the file pyproject.toml temporary so that pip will use setup.py instead of pyproject.toml.

pbt create-setuppy -p <project>
  1. Git clone a multi-repository project
pbt git clone --repo <repo_url>

Clone a repository and check out all of its submodules to their correct branches that we were using last time.

  1. Git update a multi-repository project
pbt git update

Pull latest changes from the repository, and check out all of its submodules to their correct branches.

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

pab-2.2.12.tar.gz (25.9 kB view details)

Uploaded Source

Built Distribution

pab-2.2.12-py3-none-any.whl (30.3 kB view details)

Uploaded Python 3

File details

Details for the file pab-2.2.12.tar.gz.

File metadata

  • Download URL: pab-2.2.12.tar.gz
  • Upload date:
  • Size: 25.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.8.12

File hashes

Hashes for pab-2.2.12.tar.gz
Algorithm Hash digest
SHA256 993db9bfa242b99c661a5bec839df0eca1036b2b665f4e2205efb61515e427ce
MD5 603f633be1ed4c7d514b47bbba3cfa6b
BLAKE2b-256 77dd2adbe72213a8a6cb022a0dac9ce63bd4fa1e4a0dd6634adcadbe7c4ff872

See more details on using hashes here.

File details

Details for the file pab-2.2.12-py3-none-any.whl.

File metadata

  • Download URL: pab-2.2.12-py3-none-any.whl
  • Upload date:
  • Size: 30.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.8.12

File hashes

Hashes for pab-2.2.12-py3-none-any.whl
Algorithm Hash digest
SHA256 147bd10edc06dac150ff6e4d69f5275fad561e5906fb4e1b2a789ed0b7010762
MD5 3743c408996c9b9384e0048bc3d68931
BLAKE2b-256 fcf482e735ab79ae489d7530d7fb2e2289c915a7e4bfec99ef292bbb57d466c8

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page