Skip to main content

Terminal-based circular plasmid map viewer, sequence editor, and Primer3/Golden Braid primer design workbench

Project description

SpliceCraft

SpliceCraft Logo

PyPI Python 100% Python TUI: Textual Tests License: MIT Status: Pre-release

A plasmid workbench you live in. SpliceCraft is a terminal-native viewer, sequence editor, primer + mutagenesis designer, Golden Braid / MoClo cloning workbench, and in-process BLAST / HMMscan engine — all rendered as crisp Unicode braille graphics in any modern terminal.

Built by a practicing bioengineer for daily lab work. Bug reports come from the bench; releases ship from the bench.

SpliceCraft screenshot

Quick start

pipx install splicecraft
splicecraft                      # empty canvas
splicecraft L09137               # fetch pUC19 from NCBI on launch
splicecraft myplasmid.gb         # local GenBank or .dna

Press ? once running for the full keyboard-shortcut reference.

See docs/install.md for pip / uv / conda / source installs and the user-data directory location.

What it does

  • View circular and linear braille-dot maps, per-base sequence panel with two-strand display, AA translation, restriction overlays (200+ NEB enzymes incl. Type IIS).
  • Edit in-place with deepcopy undo / redo, feature CRUD, 3-second-debounced crash-recovery autosave.
  • Clone through a multi-tab Constructor (Traditional / Gibson / Golden Braid / MoClo / custom grammar) with a 4-source part picker.
  • Design primers via Primer3 (detection / cloning / GB / generic) with a persistent Designed → Ordered → Validated lifecycle.
  • Mutagenize any CDS via SOE-PCR site-directed mutagenesis with edge-case fallback to 2-primer modified-outer PCR.
  • Simulate PCR + agarose gels (0.5–4% with the Helling-Goodman- Boyer mobility curve and form corrections).
  • Align sequencing runs from the Sequencing toolbar — drop in a Plasmidsaurus .zip, browse a nested 4-tab view of the run (General overview · per-Samples table · Quality metrics including k-mer + contamination + coverage · Align), pick a sample + target plasmid; the pairwise alignment lands as a sequencing-read lane on the linear map right next to the rail, and the target's library entry auto-tags to linear view for future opens.
  • Search your library with in-process BLASTN / BLASTP / HMMscan (via pyhmmer — no external blast+ install).
  • Drive from outside via a 60+ endpoint localhost JSON API (splicecraft --agent) and a stdlib-only CLI sidecar (splicecraft-cli).

Full feature reference: docs/features.md.

Robustness is a feature

  • Four-layer JSON safety net per save: atomic write + .bak + rotating timestamped backups + daily snapshots + suspicious-shrink guard.
  • Pre-update snapshots before any pip / pipx / uv subprocess; stored in a sibling directory so a hypothetical recursive-wipe bug in a new version cannot kill recovery.
  • 2,600+ tests anchored on 41 sacred invariants (see CLAUDE.md), hypothesis property-based fuzzing on biology primitives.
  • Defence-in-depth size caps on every external input (NCBI / PyPI / Kazusa fetch, .dna history packets, JSON saves, agent-API bodies, CLI responses).
  • Lock-file PID-fsync + stale-PID detection so a SpliceCraft killed on a shared filesystem releases its lock on next launch.

Full data-safety writeup: docs/data-safety.md. Security policy: SECURITY.md.

Documentation

Topic Where
Install methods docs/install.md
First five seconds with pUC19 docs/getting-started.md
Full feature list docs/features.md
Keybindings + menus docs/keybindings.md
Data safety + backups docs/data-safety.md
Agent API (HTTP) docs/agent-api.md
CLI sidecar docs/cli.md
Architecture docs/architecture.md
Sacred invariants CLAUDE.md
Contributing CONTRIBUTING.md
Security policy SECURITY.md
v1.0.0 acceptance gate V1_GATE.md
Changelog CHANGELOG.md
Release checklist RELEASE_CHECKLIST.md

Tests

python3 -m pytest -n auto -q                  # full suite (~5–6 min on 8 cores)
python3 -m pytest tests/test_dna_sanity.py    # biology correctness only (< 2 s)
python3 -m pytest tests/test_perf_regression.py  # perf gates (~3 s)

All tests run offline against synthetic SeqRecords and monkeypatched data paths; the autouse _protect_user_data fixture in tests/conftest.py guarantees no test can write to real user files.

Maintenance

SpliceCraft is actively maintained. The maintainer is a practicing bioengineer running real cloning workflows in it daily; releases typically go out the same week a problem surfaces at the bench. Issues and PRs welcome at github.com/Binomica-Labs/SpliceCraft/issues.

See CONTRIBUTING.md before opening a non-trivial PR — it walks through the sacred invariants, the test cadence, and the security-sensitive code surfaces.

License

MIT

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

splicecraft-0.9.5.tar.gz (1.8 MB view details)

Uploaded Source

Built Distribution

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

splicecraft-0.9.5-py3-none-any.whl (866.2 kB view details)

Uploaded Python 3

File details

Details for the file splicecraft-0.9.5.tar.gz.

File metadata

  • Download URL: splicecraft-0.9.5.tar.gz
  • Upload date:
  • Size: 1.8 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for splicecraft-0.9.5.tar.gz
Algorithm Hash digest
SHA256 b2569a69fd26daeb4c9773181fb5d0fb60201ead463c3805a0f9478b4b676ce4
MD5 2e4b9506a37f5d244a1a7feefc783f25
BLAKE2b-256 94a318315824cd6c131ceb89bfc66c18d7f4426b61c83e2e89e7c24d6a69a7c3

See more details on using hashes here.

Provenance

The following attestation bundles were made for splicecraft-0.9.5.tar.gz:

Publisher: publish.yml on Binomica-Labs/SpliceCraft

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

File details

Details for the file splicecraft-0.9.5-py3-none-any.whl.

File metadata

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

File hashes

Hashes for splicecraft-0.9.5-py3-none-any.whl
Algorithm Hash digest
SHA256 14e65e4a4c07b77ce9a94e70a01c5d27167145e2f7372f9be9dd58cb5ae2dbf7
MD5 02f629b74831f32370b483586c0e1eda
BLAKE2b-256 8d8d59246fbdb0d09e0bd597d40839ed5e7074e37d124582597b49a50f7e1d1d

See more details on using hashes here.

Provenance

The following attestation bundles were made for splicecraft-0.9.5-py3-none-any.whl:

Publisher: publish.yml on Binomica-Labs/SpliceCraft

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