Skip to main content

Subshell + MLX LLM-calling backends (Claude/Codex CLI, local MLX) shared across tools.

Project description

spawnllm

PyPI Python Docs License: MIT

Subshell + MLX LLM-calling backends (Claude/Codex CLI, local MLX) shared across tools.

spawnllm centralizes the LLM-calling plumbing that small tools keep re-inventing: driving the claude and codex CLIs as subshells — with structured Pydantic output, model tiers, and faithful error capture — and running local Apple-Silicon MLX models with adapter fusion, prompt-cache reuse, and batched generation. Depend on it once and each tool keeps only its domain logic instead of its own copy of the backends.

Install

No install needed — run everything through uvx:

uvx spawnllm --help

uvx fetches spawnllm into a throwaway environment and runs it. To add it to a project instead:

uv add spawnllm

For the local MLX engine (Apple Silicon only), pull the extra:

uv add "spawnllm[mlx]"

Quickstart

List the backends spawnllm can drive:

uvx spawnllm backends
claude
codex
mlx

What problems does this solve?

  • Duplicate subshell plumbing. Building claude/codex argv, piping stdin/stdout, teeing stderr, and turning non-zero exits into useful errors — written once, not re-derived per tool.
  • Structured-output boilerplate. A Pydantic model becomes a JSON-schema constraint and a parsed, validated result the same way for every backend.
  • Local MLX is fiddly. Adapter fusion, prompt-cache reuse, worker-thread lifecycle, and batched single-token generation live behind one engine instead of in every consumer.
  • Behavior drift. Two tools that call the same models stay byte-for-byte consistent because they share the backend layer rather than each maintaining a copy.

Docs

Read the docs for the full guide and API reference.

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

spawnllm-0.1.3.tar.gz (13.4 kB view details)

Uploaded Source

Built Distribution

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

spawnllm-0.1.3-py3-none-any.whl (19.1 kB view details)

Uploaded Python 3

File details

Details for the file spawnllm-0.1.3.tar.gz.

File metadata

  • Download URL: spawnllm-0.1.3.tar.gz
  • Upload date:
  • Size: 13.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for spawnllm-0.1.3.tar.gz
Algorithm Hash digest
SHA256 2533e5b76c2b4b51bbf0c572df68c49b8a90b45923fee1c1d483517bcf0bdc6b
MD5 a7015d0903da203e695f5462515d250c
BLAKE2b-256 6e3ffa14651cc6e900e2e99c34deb50f424e7f41c1b121bdb5dbeeb1b30a1847

See more details on using hashes here.

Provenance

The following attestation bundles were made for spawnllm-0.1.3.tar.gz:

Publisher: release-pypi.yml on yasyf/spawnllm

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file spawnllm-0.1.3-py3-none-any.whl.

File metadata

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

File hashes

Hashes for spawnllm-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 2e0831252211f60d67fe52dfcdbcd0bc1926d232eefa88d85ca35c4428c31884
MD5 94ce9c8d0fbb6eb83c347f2df00a9781
BLAKE2b-256 c37df03994edc20a0d68f0d9c33d236065617f18d407e9c3138f3cb20fc1dee0

See more details on using hashes here.

Provenance

The following attestation bundles were made for spawnllm-0.1.3-py3-none-any.whl:

Publisher: release-pypi.yml on yasyf/spawnllm

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