Skip to main content

Create and run a BigConfig CLI from a language-specific GitHub package.

Project description

bc-pkg

bc-pkg creates or reuses a BigConfig CLI in the current directory, then forwards your command to that CLI.

The PyPI package and the npm package expose the same behavior. The target package can be implemented in Clojure, TypeScript, or Python; bc-pkg infers that language from the pinned GitHub content.

Usage

uvx bc-pkg <owner/repo@ref> package validate
uvx bc-pkg package validate

ref can be a branch name or a full 40-character commit SHA:

uvx bc-pkg bigconfig-ai/once@python package validate
uvx bc-pkg bigconfig-ai/once@2f4e8c0d0b4c4b8f0c3a9f6e2a1b5c7d8e9f0123 package validate

On the first run, bc-pkg resolves the ref to a full SHA and pins it. Later runs omit <owner/repo@ref> and keep using the pinned SHA.

Local repositories

For live local development you can point bc-pkg at a local checkout of a target package instead of a GitHub spec. The first argument is treated as a local path when it starts with /, ./, ../, ~, or is ./..:

uvx bc-pkg ../once/python package build
uvx bc-pkg /abs/path/to/once/clojure package build

Local targets are wired up live — your uncommitted edits in the local package are picked up on the next run, with no SHA pinning and no push:

Target language Local dependency
Clojure deps.edn / bb.edn use :local/root
TypeScript package.json uses a file: dependency
Python pyproject.toml uses an editable [tool.uv.sources] path

The run file is symlinked (not copied) so run-file edits are also live. Run bc-pkg from a separate directory; pointing it at the current directory is refused so it never overwrites the package's own manifest. Switching an initialized directory between local and GitHub (or to a different local path) is a hard error, just like a repo/ref/SHA mismatch.

Notes: TypeScript local dev requires the local package to be built (its dist/); Python local dev installs the package editable and exposes its resources/ from the source tree.

What is created

The launcher copies the target package's root run file into the current directory and writes language-native metadata:

Target language Manifest Runtime command
Clojure deps.edn bb run ...
TypeScript package.json node run ...
Python pyproject.toml uv run python run ...

For Clojure targets, a small bb.edn runtime dependency file is also written so Babashka can load the pinned Git dependency.

If the directory is already initialized for a different repo/ref/SHA, bc-pkg exits with an error instead of updating it implicitly.

Requirements

  • Python launcher: Python >= 3.11.
  • TypeScript target packages: Node.js and npm must already be installed.
  • Python target packages: Python and uv must already be installed.
  • Clojure target packages: bc-pkg downloads pinned Babashka and Temurin JDK versions into a shared user cache and checks/installs git on Linux.

Environment

Variable Effect
GITHUB_TOKEN Used for private GitHub repos or higher API rate limits.
BB_VERSION Override the Babashka version for Clojure targets.
JDK_VERSION Override the Temurin JDK feature version for Clojure targets.

Cache

Babashka and JDK downloads are shared across projects under:

  • macOS/Linux: $XDG_CACHE_HOME/bc-pkg or ~/.cache/bc-pkg
  • Windows: %LOCALAPPDATA%/bc-pkg

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

bc_pkg-1.0.2.tar.gz (11.2 kB view details)

Uploaded Source

Built Distribution

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

bc_pkg-1.0.2-py3-none-any.whl (12.1 kB view details)

Uploaded Python 3

File details

Details for the file bc_pkg-1.0.2.tar.gz.

File metadata

  • Download URL: bc_pkg-1.0.2.tar.gz
  • Upload date:
  • Size: 11.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.16 {"installer":{"name":"uv","version":"0.11.16","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":null}

File hashes

Hashes for bc_pkg-1.0.2.tar.gz
Algorithm Hash digest
SHA256 e273f17c741ddea33f04524e5b0dc22e9097f94c39bd1d372c0a0162cc245353
MD5 0c78fd7ef7df85372714247f24fa4207
BLAKE2b-256 97578e71696d9d23140c2f46c837b2fd4eac9acb9848dec73bbc79f41d613717

See more details on using hashes here.

File details

Details for the file bc_pkg-1.0.2-py3-none-any.whl.

File metadata

  • Download URL: bc_pkg-1.0.2-py3-none-any.whl
  • Upload date:
  • Size: 12.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.16 {"installer":{"name":"uv","version":"0.11.16","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":null}

File hashes

Hashes for bc_pkg-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 c3aaae0cde79ac632d7e692efcea54bae36427ae9dfe1786adc16c7d7c9141d7
MD5 569c2b98ceff2365fa3f385d6fe4e004
BLAKE2b-256 326a83e9d987318abcde90336efcb726feb027aecaa40900003ca79af38232e0

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