Kin is a semantic, graph-first repository and collaboration substrate for AI-native software development. Unlike traditional file-first, diff-first systems (like Git), Kin represents software as a semantic graph of entities (functions, methods, classes, structs, traits, enums, interfaces, types, constants) and relations (calls, imports, references, inheritance).
In Kin, the graph is the source of authority. The filesystem is a derived projection over that graph truth, made transparently available to existing editors and compilers through the kin-vfs virtual filesystem.
- Semantic VCS: Version control at the level of entities and relations instead of lines and files.
- AI-native context packs: Build structured context packs containing a target entity plus its caller/callee neighborhood in a single call (
kin context). - Trace & dataflow: Trace call chains and dataflow dependencies in one step instead of looping over file reads (
kin trace,kin trace-data-flow). - Ejectable brownfield compatibility: Works alongside Git and traditional toolchains.
kin ejectremoves Kin and restores files to their pre-init state, so there is no data lock-in.
Install Kin with a single command:
curl -fsSL https://get.kinlab.dev/install | shThe installer downloads the latest release from GitHub, verifies its SHA-256 checksum
(and refuses to install an unverified or tampered download), places the kin and
kin-daemon binaries — plus the optional kin-vfs projection client where bundled —
into ~/.kin/bin, updates your shell profile (.zshrc / .bashrc), and then runs the
interactive setup wizard. Re-running the installer upgrades an existing install in place.
On Windows, use PowerShell:
irm https://get.kinlab.dev/install.ps1 | iexThe native Windows build is a limited, vector-free convenience binary with no filesystem projection. For the complete, vector-enabled Kin with working projection, install under WSL2 — see docs/windows-wsl2.md.
Configure the installer with environment variables:
KIN_VERSION: Pin a specific version to download (e.g.0.1.0). If omitted, the latest release is resolved automatically.KIN_DIR: Custom installation directory (defaults to~/.kin).KIN_NO_SETUP: Set to1to skip the interactive setup wizard after the binaries are downloaded.KIN_BASE_URL: Install from a mirror or local path instead of GitHub releases (offline/airgapped installs and CI smoke tests). Supported by both theshand PowerShell installers.
The Kin daemon is the canonical authority for graph truth. Commands that analyze the
graph in-process (kin merge, kin release, kin semver, kin rollback, kin git export)
read from the daemon and auto-start it as needed — no configuration required for normal use.
KIN_NO_DAEMON: Set to1to disable daemon auto-start. The CLI will only use an already-running daemon (orKIN_DAEMON_URL).KIN_DAEMON_URL: Point the CLI at an explicit daemon endpoint instead of the repo-local one.KIN_ALLOW_DAEMON_BOOTSTRAP_ADMIN: Offline/admin escape hatch. Set to1to let the above read-only commands fall back to reading the local.kinsnapshot directly when the daemon cannot be reached. Not needed for normal use, and never used for writes — all graph mutations still route through the daemon.
There is one recommended first-run path, and it's the same on macOS, Linux, and
Windows (via WSL2): install → run the guided kin setup wizard → build the graph → verify.
See docs/quickstart.md for the full end-to-end walkthrough.
The installer above already launches kin setup for you (run it again any time). It opens
with "What do you want Kin for?" and asks for your intent, then configures the
matching pieces:
kin setup- AI agents (default) — wires Kin's MCP server into every detected AI client (Claude Code, Cursor, Codex, Gemini, Windsurf), plus shell integration and daemon auto-start. The smallest path to value.
- Local-only — shell integration + daemon auto-start; no AI client config.
- Editor — local-only, plus how to install the
kin-editorVS Code extension. - Hosted / KinLab — local setup, plus a note that hosted connect is coming soon (not yet a first-run flow).
- Advanced / manual — choose shell, per-client MCP, and daemon options yourself.
Flags (global; kin setup --intent agent --no-interactive for scripts/CI):
--intent <local|agent|editor|hosted|advanced>: pick the first-run intent up front.--shell <zsh|bash|powershell>: target shell for profile updates.--auto-daemon: force daemon auto-start on (default on for every intent).--no-interactive: run with defaults / provided flags (default intent:agent).
Subcommands:
kin setup status [--json]: probe and show what's installed (the health checklist).kin setup doctor [--fix](or top-levelkin doctor [--fix]): run health checks and optionally apply safe repairs.
Build a semantic graph over your codebase:
kin initOptions:
[PATH]: Directory to initialize (defaults to the current directory).--force: Initialize even if a.git/directory is detected.--git-history <off|recent|full>: Git history import depth (default:recent).--no-lsp: Skip LSP enrichment for a faster, tree-sitter-only init.
kin init builds the graph instantly without embeddings. Run kin embed to add the
vector index that powers semantic search and kin locate:
kin embedEmbeddings are generated locally with nomic-embed-text-v1.5 (768 dimensions; override
via KIN_EMBED_MODEL_ID). kin status --json reports embedding coverage under its
enrichment block (embeddingsIndexed / embeddingsPending / embeddingsTotal).
Run the health checklist any time — it probes real filesystem, daemon, and agent state:
kin setup statusChecks cover the kin and kin-daemon binaries, VFS projection (macOS/Linux; n/a on
native Windows), shell integration, repository init, AI-client MCP config (the
agent-default profile), editor extension, KinLab connect (n/a — coming soon), and
semantic query readiness (STALE until you run kin embed). Failing checks print their
own fix: line; kin doctor --fix applies the safe repairs. See
docs/quickstart.md for the full
check table and what to do for each state.
- Status of the working copy:
kin status [--json]
- Commit changes semantically:
kin commit -m "commit message" - Show the change log:
kin log [-n <count>]
- Semantic diff:
kin diff [<base>] [<head>]
- Search entities (add
--semanticfor vector similarity over what is embedded):kin search "<pattern>" [--semantic] [--show-body] - Locate files relevant to an issue:
kin locate "<problem text>" [--explain] - Eject and restore files:
kin eject [--force]
Kin ships with a built-in MCP (Model Context Protocol) server that exposes semantic tools
to AI assistants (Claude, Cursor, Gemini, Codex, Windsurf, etc.). The AI agents intent
in kin setup wires this up for every detected client automatically — there is nothing
else to configure. The wizard writes a kin server entry running kin mcp start --global
with KIN_MCP_TOOL_PROFILE=agent-default (the small curated tool surface).
kin mcp start runs as a stdio server that the MCP client launches as a subprocess; you
normally do not run it by hand. To wire up a client manually, use the npm wrapper
(@kinlab/kin-mcp), or see the exact config and config-file locations, read the
Advanced configuration section of the
quickstart. For the full tool surface, see docs/mcp-tools.md.
To understand the philosophy behind Kin, see the thesis document.