Skip to main content

A context engine for the AI era

Project description

Colin Logo

Colin

A context engine that keeps agent skills fresh.


Colin is a context engine. Write templates that reference live sources like GitHub files, MCP servers, and other documents. Colin compiles them, tracks dependencies, and rebuilds only what's stale.

---
name: deployment-process
description: How to deploy code to staging and production
---

# Deployment

{{ colin.github.file('acme/platform', 'docs/DEPLOY.md').content }}

## Environments

{{ ref('infrastructure/environments').content }}

## Recent Incidents

{{ colin.mcp.pagerduty.resource('incidents?team=platform&days=30') | llm_extract('deployment-related issues and how they were resolved') }}

Run colin run. Colin fetches the deployment guide from GitHub, resolves the reference to your environments doc, extracts incident summaries through an LLM, and writes the compiled skill. Run it again tomorrow—if nothing changed upstream, nothing rebuilds. If the deployment guide in GitHub was updated, Colin detects the new commit and recompiles.

Install

pip install colin-py

Documentation

Full documentation at colin.prefect.io/docs.

Quick Start

colin init my-skill
cd my-skill

Edit models/hello.md or create new documents in models/. Each document can reference others with ref() and pull from external sources.

colin run

Colin compiles your documents to output/. Update a source file and run again—only affected documents recompile.

Output to Claude Code

Configure Colin to write directly to Claude Code's skills folder:

[project.output]
target = "claude-skill"
scope = "user"

Skills appear in ~/.claude/skills/ and become available immediately.

How It Works

When Colin compiles a document, it records what sources were used and their versions—commit SHAs for GitHub files, timestamps for HTTP resources, version identifiers for MCP resources. This information is stored in a manifest alongside the compiled output.

On subsequent runs, Colin checks the manifest against current source versions. Documents whose sources haven't changed skip compilation entirely. When a source does change, Colin recompiles the affected document and any documents that depend on it.

LLM calls are cached separately by input hash. If a document recompiles but the input to an LLM block is unchanged, the cached LLM response is reused.

About the Name

Colin stands for Context Lineage. It's also a nod to Colin the robot from the Hitchhiker's Guide to the Galaxy—a security robot who feels genuinely delighted whenever he's being helpful.


Colin is built with 💙 by Prefect.

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

colin_py-0.0.1.tar.gz (109.7 kB view details)

Uploaded Source

Built Distribution

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

colin_py-0.0.1-py3-none-any.whl (147.9 kB view details)

Uploaded Python 3

File details

Details for the file colin_py-0.0.1.tar.gz.

File metadata

  • Download URL: colin_py-0.0.1.tar.gz
  • Upload date:
  • Size: 109.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.9.26 {"installer":{"name":"uv","version":"0.9.26","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":true}

File hashes

Hashes for colin_py-0.0.1.tar.gz
Algorithm Hash digest
SHA256 be24e3119316df358313fa3469a6b78489796843ac6694a235976ca3160100b2
MD5 fe839f129806afbffb758371e21a7687
BLAKE2b-256 c05a1d18b75254daa955286f80dfbfd8f17345f0652c564ed694ee1f9aaebe33

See more details on using hashes here.

File details

Details for the file colin_py-0.0.1-py3-none-any.whl.

File metadata

  • Download URL: colin_py-0.0.1-py3-none-any.whl
  • Upload date:
  • Size: 147.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.9.26 {"installer":{"name":"uv","version":"0.9.26","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":true}

File hashes

Hashes for colin_py-0.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 e2abc2ee16f5bc94f9941509fb5bf4f99c4b9c647173ef310f89fb776e449b4c
MD5 e91566282e3216aaea392f689075622f
BLAKE2b-256 11a8c0130a83cd0b1db32ccdd70108f04b8b1d8ee9b5b48a9efe9b6c618e05e1

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