From shannon
Interact with Neovim via RPC to annotate code, navigate files, and do walkthroughs
How this skill is triggered — by the user, by Claude, or both
Slash command
/shannon:neovimThis skill is limited to the following tools:
The summary Claude sees in its skill listing — used to decide when to auto-load this skill
When a prompt arrives from Shannon (indicated by a footer like `(Shannon prompt via Neovim server <addr>)`), you have the ability to interact with the user's Neovim session via RPC.
When a prompt arrives from Shannon (indicated by a footer like (Shannon prompt via Neovim server <addr>)), you have the ability to interact with the user's Neovim session via RPC.
There are two ways to obtain the Neovim server address:
From a Shannon prompt — Shannon prompts include a footer of the form:
(Shannon prompt via Neovim server /path/to/socket)
Extract the server address from this footer.
Auto-discovery — if no Shannon prompt has been received yet, run the discovery script. Below, $SKILL_DIR is the absolute path to the directory containing this SKILL.md file; expand it to its absolute value before running, since the current working directory is not guaranteed to be the skill directory.
$SKILL_DIR/scripts/shannon-find-nvim.sh
This finds the Neovim instance running in a sibling tmux pane and prints its server socket path. It exits non-zero if no Neovim is found.
Use nvim --server <addr> --remote-expr '<expr>' to execute Vimscript or Lua in the user's Neovim. For Lua, wrap with luaeval("...").
The Shannon plugin exposes private helper functions as individual modules for use by this skill. Each returns a single function. Prefer these over raw Neovim API calls.
Open a file (with optional 1-indexed line number):
nvim --server <addr> --remote-expr 'luaeval("require(\"wincent.shannon.private.open\")(\"path/to/file\")")'
nvim --server <addr> --remote-expr 'luaeval("require(\"wincent.shannon.private.open\")(\"path/to/file\", 42)")'
Jump to a line (1-indexed) in the current buffer:
nvim --server <addr> --remote-expr 'luaeval("require(\"wincent.shannon.private.jump\")(42)")'
Add virtual text annotation below a line (1-indexed):
nvim --server <addr> --remote-expr 'luaeval("require(\"wincent.shannon.private.annotate\")(42, \"text here\", \"DiagnosticInfo\")")'
The third argument is a highlight group. Use these to convey meaning:
DiagnosticInfo — informational annotations (blue)DiagnosticWarn — warnings (yellow)DiagnosticError — errors/issues (red)DiagnosticHint — hints/suggestions (green)If omitted, defaults to DiagnosticInfo.
Clear all Shannon annotations in current buffer:
nvim --server <addr> --remote-expr 'luaeval("vim.cmd.ShannonClearMarks()")'
Show a message in Neovim's command area:
nvim --server <addr> --remote-expr 'luaeval("vim.api.nvim_echo({{\"message\", \"WarningMsg\"}}, true, {})")'
Use RPC when:
The Shannon plugin provides the following commands, which can be invoked via RPC:
:ShannonNextMark — jump to the next Shannon extmark in the current buffer (wraps around).:ShannonPreviousMark — jump to the previous Shannon extmark (wraps around).:ShannonClearMarks — clear all Shannon extmarks in the current buffer.After adding annotations, tell the user they can navigate between marks with :ShannonNextMark / :ShannonPreviousMark (or their configured mappings). When you are done with an annotation session and the user has finished reviewing, clear the marks via RPC:
nvim --server <addr> --remote-expr 'luaeval("vim.cmd.ShannonClearMarks()")'
private.open first.--remote-expr call is synchronous and blocks until Neovim processes it.Creates, edits, and optimizes skills for Claude Code, including drafting, evaluating with test prompts, iterating on performance, and improving skill descriptions for better triggering accuracy.
npx claudepluginhub wincent/wincent-agent-plugins --plugin shannon