Skip to main content

A package manager for agent skills

Project description

napoln

A package manager for agent skills. Install from any git repo, upgrade without losing your customizations, and manage skills across every agent you use.

"I don't even have any good skills. You know, like nunchuck skills, bow hunting skills, computer hacking skills."

  • Multi-agent. One command places skills into Claude Code, Gemini CLI, pi, Codex, and Cursor.
  • Versioned upgrades. Three-way merge on upgrade preserves your local customizations.
  • Decentralized. Any git repo is a valid source. No registry required.
  • Content-addressed. Every stored version has a deterministic SHA-256 hash.
  • Zero-copy placement. Reflink (copy-on-write) on APFS and btrfs. Full copy fallback elsewhere.
  • Self-describing. A bundled skill teaches your agents how to use napoln.

napoln demo

Install

Requires Python 3.11+. napoln is published on PyPI.

Run without installing:

uvx napoln add owner/repo

Or install globally:

uv tool install napoln    # recommended
pipx install napoln       # alternative
pip install napoln        # plain pip

First Run

On first run, napoln installs its bundled management skill so your agents know how to use it. After that, your agents can find and install new capabilities without prompting you for CLI commands.

Agents prefer uvx napoln so they never hit PATH issues. The bundled skill is automatically installed alongside your first skill, so it works out of the box.

Quick Start

napoln add owner/repo --all

napoln clones the repo, discovers all skills, and places them in every detected agent's skill directory:

✓ Placed 'code-review' in ~/.claude/skills/code-review (clone)
✓ Placed 'code-review' in ~/.agents/skills/code-review (clone)
✓ Placed 'code-review' in ~/.cursor/skills/code-review (clone)
✓ Added 'code-review' v1.2.0

Install a specific skill, pin a version, or use a local path:

napoln add owner/repo --skill code-review   # specific skill by name
napoln add owner/repo@v1.2.0               # pinned to a tag
napoln add ./my-local-skill                 # local directory

Multi-skill repos show an interactive picker when no --skill or --all flag is given:

napoln add owner/repo
# ? Select skills to install:
# ❯ ◯ code-review  Review pull requests for quality and correctness
#   ◯ testing       Generate and improve test coverage
#   ◯ rust          Rust-specific development patterns

Customize a skill, then upgrade without losing your changes:

napoln upgrade code-review
# ✓ Merged 'code-review' at ~/.claude/skills/code-review (2 files updated)

Remove one or more skills at once:

napoln remove design-audit design-frontend design-preflight

Remove all skills from a specific repository:

napoln remove --from-source raiderrobert/flow

Combine explicit names with --from-source filter:

napoln remove --from-source raiderrobert/flow design-audit

Commands

napoln add <source>           Install skills from a git repo or local path
napoln remove <name>...       Remove one or more skills
napoln remove --from-source  Remove all skills from a specific repository
napoln upgrade [<name>]       Upgrade one or all skills
napoln list                   Show installed skills and where they are placed
napoln install                Restore skill placements from manifests
napoln init [<name>]          Scaffold a new SKILL.md
napoln config                 View configuration and run housekeeping

All mutating commands support --dry-run. Use -p for project scope on any command.

Supported Agents

Agent Global Path Project Path
Claude Code ~/.claude/skills/ .claude/skills/
Gemini CLI ~/.agents/skills/ .agents/skills/
pi ~/.agents/skills/ .agents/skills/
Codex ~/.agents/skills/ .agents/skills/
Cursor ~/.cursor/skills/ .agents/skills/

Gemini CLI, pi, and Codex share ~/.agents/skills/ — one placement serves all three.

One SKILL.md for every agent

A skill is a single SKILL.md file. Every supported agent reads the same file; napoln does not fork or transform it per agent. Agent-specific frontmatter fields are optional, and each agent ignores the fields it does not understand. Skill authors should keep one canonical SKILL.md per skill rather than maintaining per-agent variants.

Team Workflow

Install with --project and commit the manifest:

napoln add owner/repo --skill code-review --project
# Creates .napoln/manifest.toml  (commit this)
# Places into .claude/skills/    (gitignore these)

Teammates clone and run:

napoln install
# ✓ Synced 3 project skills (3 restored)

napoln install syncs both global and project manifests automatically.

Documentation

License

MIT

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

napoln-0.2.9.tar.gz (527.5 kB view details)

Uploaded Source

Built Distribution

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

napoln-0.2.9-py3-none-any.whl (46.1 kB view details)

Uploaded Python 3

File details

Details for the file napoln-0.2.9.tar.gz.

File metadata

  • Download URL: napoln-0.2.9.tar.gz
  • Upload date:
  • Size: 527.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","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 napoln-0.2.9.tar.gz
Algorithm Hash digest
SHA256 2fd8f383235f4f64f0c31dde975afb3a219886e9cbfcc633f6a17021a856bfdf
MD5 3353935452890affdb340cc5bb051233
BLAKE2b-256 a4b36ae06a649a3395f27be3070a7411eb3df9104c5a6703fecf782c7aaa1f1f

See more details on using hashes here.

File details

Details for the file napoln-0.2.9-py3-none-any.whl.

File metadata

  • Download URL: napoln-0.2.9-py3-none-any.whl
  • Upload date:
  • Size: 46.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","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 napoln-0.2.9-py3-none-any.whl
Algorithm Hash digest
SHA256 00225da6f38aaf4f2731d3cf7bb3ae639b121b1f6722a395a8470e9ea34258a5
MD5 6dfdd9331a0f19fd2f8e406f6925bcbe
BLAKE2b-256 e1d102180fcb97f57ac7c8b3b1de116d93b1dcd212c40b245019cbb83895d2ec

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