Skip to main content

Semi-QUalified Agent Companion Kit — the stateful intelligence + MCP server layer for fledgling-equipped agents.

Project description

squackit

PyPI Docs License

Semi-QUalified Agent Companion Kit. A code intelligence toolkit that works two ways: as an MCP server for AI agents, and as a CLI for humans.

Built on pluckit (CSS selectors over ASTs) and fledgling (SQL macros over DuckDB).

Install

pip install squackit

CLI usage

# Run any tool from the shell
squackit tool list
squackit tool view "src/**/*.py" ".fn#main"
squackit tool find_names "**/*.py" ".class"
squackit tool complexity "src/**/*.py" ".fn"

# JSON output for scripting
squackit --json tool find "src/**/*.py" ".fn"

# Pluckit chain queries
squackit pluck "src/**/*.py" find .fn containing cache names
squackit pluck "src/api.py" find .class#Handler children find .fn names

# Start the MCP server
squackit mcp serve

Tool names resolve in three conventions: find_names, find-names, FindNames. Tab completion is built in (eval "$(_SQUACKIT_COMPLETE=bash_source squackit)").

What agents get via MCP

  • 20 tools — CSS-selector code queries (via pluckit), file I/O, git history, doc navigation, diagnostics
  • 4 compound workflowsexplore, investigate, review, search
  • 3 prompt templates — pre-loaded with live project data
  • 5 resources — project overview, docs, git status, session log, diagnostics
  • pluck tool — full pluckit chain grammar for multi-step AST queries, with mutation safety (blocked by default, opt-in via allow_mutations=true)
  • Smart defaults — infers language, doc layout, main branch automatically
  • Token-aware output — configurable truncation with max_results/max_lines

Architecture

Layer 4   Consumers (Claude Code, agents, IDE extensions)
              │
Layer 3b  squackit ─── CLI + MCP server + intelligence
              │        smart defaults, caching, truncation,
              │        workflows, pluckit tools, mutation safety
              │
Layer 3a  pluckit ──── fluent Python API (CSS selectors over ASTs)
              │
Layer 2   fledgling ── SQL macros + Python bundler
              │
Layer 0   DuckDB extensions (sitting_duck, markdown, duck_tails, read_lines)

Pluckit tools take priority over fledgling equivalents when both provide a capability (e.g., pluckit's find supersedes fledgling's find_definitions).

Note: pluckit is published on PyPI as ast-pluckit. The import name is pluckit.

Documentation

Full docs at squackit.readthedocs.io.

License

Apache 2.0

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

squackit-0.5.0.tar.gz (312.4 kB view details)

Uploaded Source

Built Distribution

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

squackit-0.5.0-py3-none-any.whl (59.3 kB view details)

Uploaded Python 3

File details

Details for the file squackit-0.5.0.tar.gz.

File metadata

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

File hashes

Hashes for squackit-0.5.0.tar.gz
Algorithm Hash digest
SHA256 e583cdd455ffb6e247a382bc70ee65ef29ff09bfe0ed59ab79c9b182e1ae290f
MD5 f617db7ae83ca2ad38ea8173c890f203
BLAKE2b-256 4fffa626965d5990be13f35d91ac582099c3afcb59d72bbae00823d34a8e6762

See more details on using hashes here.

Provenance

The following attestation bundles were made for squackit-0.5.0.tar.gz:

Publisher: release.yml on teaguesterling/squackit

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

File details

Details for the file squackit-0.5.0-py3-none-any.whl.

File metadata

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

File hashes

Hashes for squackit-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 2e338e720f104fee766b53f6751f90060c28efa00a1dce6c1d856f02bf8db747
MD5 97449a5746e29d6eabcc66889a92d49a
BLAKE2b-256 74b40851ba175ee9d2eba2e74672e3a8a971ed4658a2bc7018c9967515c72699

See more details on using hashes here.

Provenance

The following attestation bundles were made for squackit-0.5.0-py3-none-any.whl:

Publisher: release.yml on teaguesterling/squackit

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