Scrivener MCP

Подключайте проекты Scrivener 3 к Claude, ChatGPT и другим ИИ-ассистентам. 60+ инструментов для управления рукописями, анализа текста, семантического поиска, памяти персонажей/сюжета и улучшения контента.

Документация

Scrivener MCP Logo

Scrivener MCP

Connect your Scrivener projects to Claude, ChatGPT, and other AI assistants

npm version npm downloads build license node version issues stars MseeP verified scrivener-mcp MCP server score

Install · What You Can Do · All Tools · Guides · Contributing


Scrivener MCP lets your AI assistant open, read, edit, analyze, and search your Scrivener projects directly. No copy-pasting. No exporting. Just open your novel and start working.

You: Open my novel and analyze the pacing in Chapter 12.

Claude: Opens your .scriv project, reads Chapter 12, runs pacing analysis. The first half moves well with short, tense paragraphs. The middle section slows considerably -- the three-page internal monologue starting at paragraph 14 stalls the momentum you built in the confrontation scene. Consider cutting it to a single paragraph and moving the backstory to Chapter 8 where Elena is first introduced.

Works with Claude Desktop, Claude Code, VS Code (Copilot/Continue), Cursor, and any MCP-compatible client. Scrivener 3 on macOS, Windows, and Linux.

Install

Pick the method that works for you. All of them auto-configure Claude Desktop on install.

npm (recommended)

npm install -g scrivener-mcp

Restart Claude Desktop. Done.

Smithery

npx -y @smithery/cli install scrivener-mcp --client claude

npx (no install)

Use directly without installing globally:

npx scrivener-mcp

Or add to your Claude Desktop config manually:

{
  "mcpServers": {
    "scrivener": {
      "command": "npx",
      "args": ["scrivener-mcp"]
    }
  }
}

GitHub

Install directly from the repo (latest main):

npm install -g writerslogic/scrivener-mcp

Or a specific release:

npm install -g writerslogic/scrivener-mcp#v0.5.1

Homebrew (macOS)

brew install writerslogic/tap/scrivener-mcp

Docker

docker build -t scrivener-mcp https://github.com/writerslogic/scrivener-mcp.git
docker run -i --rm -v /path/to/your/projects:/projects scrivener-mcp
Setup for other MCP clients

Run the interactive setup to auto-detect and configure your client:

npx scrivener-setup

This detects Claude Desktop, Claude Code, and Cursor, and writes the config for you.

For other MCP clients, point them at npx scrivener-mcp as a stdio server.

Optional: AI-powered features

Core features (document management, analysis, search) work without any API key. For AI-powered enhancements, the server automatically discovers your OpenAI key from common locations:

  • OPENAI_API_KEY environment variable
  • ~/.env, ~/.scrivener-mcp/.env, ~/.openai/key
  • macOS Keychain (service name openai-api-key)

To store your key in the macOS Keychain:

security add-generic-password -s openai-api-key -a openai -w sk-your-key-here

Or export it manually:

export OPENAI_API_KEY="sk-..."

This enables: content enhancement, semantic search, multi-agent analysis, character consistency checking, and intelligent compilation.

What You Can Do

Manage Your Manuscript

Open any Scrivener project and work with it naturally. Read chapters, create new scenes, reorganize the binder, update synopses -- all through conversation.

You: Create a new scene called "The Reveal" after Chapter 5, and move the old epilogue to the trash.

Analyze Your Writing

Get detailed feedback on readability, pacing, style, dialogue quality, and emotional arc. Not generic advice -- analysis grounded in your actual prose.

You: Analyze Chapter 3. Is the pacing too slow?

Claude: Readability is good (Flesch-Kincaid grade 8.2), but pacing flags:

  • 4 consecutive paragraphs of internal monologue (lines 45-78) with no action or dialogue
  • The scene is 3,200 words with only 2 scene breaks -- your other chapters average 4
  • Filter word density is 2x your manuscript average ("felt", "seemed", "noticed") Specific suggestions: ...

Enhance Your Prose

Apply targeted improvements: eliminate filter words, strengthen verbs, vary sentence structure, add sensory details, convert telling to showing, tighten dialogue, adjust pacing.

You: Eliminate the filter words in Chapter 7 and strengthen the verbs.

Track Characters and Plot

Store character profiles, plot threads, and style guides that persist with your project. The AI remembers your characters across sessions.

You: Save a character profile for Marcus: retired detective, cynical but fair, walks with a limp from an old injury, speaks in clipped sentences.

Later...

You: Check if Marcus is consistent across all chapters.

Claude: Found an inconsistency: Marcus walks "briskly" in Chapter 9 (line 34), but his limp is referenced in Chapters 2, 5, and 11. Also, his dialogue in Chapter 4 uses long flowing sentences, which contradicts the "clipped sentences" note in his profile.

Search by Meaning

Find passages by what they're about, not just keyword matching. "Find scenes where the protagonist feels isolated" works even if the word "isolated" never appears. Powered by the Holographic Memory System -- works offline, no API key needed.

You: Find all scenes where Elena and Marcus are alone together.

Track Relationships

Store and query relationships between characters, locations, themes, and plot threads. No Neo4j required -- relationships live in the semantic memory engine and persist with your project.

You: Who is connected to Marcus? What plot threads involve the lighthouse?

Compile and Export

Combine chapters into a single manuscript with configurable formatting, separators, and structure preservation.

All Tools

45 tools organized by workflow. To keep token usage low, tools load progressively -- project tools at startup, document and search tools when you open a project, and the rest on demand (your AI client activates them automatically). Set SCRIVENER_MCP_EAGER_TOOLS=1 to load everything at once.

Project -- open, browse, manage
ToolWhat it does
open_projectOpen a .scriv project (accepts .scriv folders or .scrivx files) and make it active
discover_projectsScan common locations for Scrivener projects when you don't know the path
get_structureBrowse the binder hierarchy (folders, documents, word counts)
refresh_projectReload from disk after external edits
close_projectClose the active project and flush pending changes
Documents -- read, write, create, organize
ToolWhat it does
get_document_infoMetadata for one document (title, type, word count, synopsis, label, status)
read_documentRead content; format: "formatted" for rich text, offset/limit to page long docs
write_documentReplace a document's content (atomic, with pre-write backup)
create_documentCreate a new text document or folder
update_documentChange title and/or metadata (synopsis, notes, label, status, custom fields)
move_documentReorganize within the binder
delete_documentMove to trash (reversible)
Search -- find content, passages, and mentions
ToolWhat it does
searchKeyword/full-text search; field: "title" for titles, scope: "trash" for trash
semantic_searchFind passages by meaning using embeddings, with similarity scores
find_mentionsLocate every occurrence of a specific name or term, with context
list_trashList trashed documents
restore_documentRestore a document from trash
read_annotationsRead a document's comments and footnotes
Analysis -- quality, consistency, structure
ToolWhat it does
analyze_documentAI writing analysis; focus with aspects (structure, style, pacing, themes...)
check_consistencyProject-wide continuity check; scope for plot, characters, or timeline
analyze_writing_styleStyle-focused analysis
check_plot_consistencyPlot-thread consistency check
check_character_continuityDetect contradictions in how a character is portrayed
analyze_narrativeNarrative structure and arc analysis
track_motifsTrace recurring motifs, themes, and symbols
suggest_improvementsAI-generated improvement suggestions
enhance_contentSuggest a specific improvement to a document
generate_contentGenerate new prose from a prompt and context

Enhancement types: eliminate-filter-words, strengthen-verbs, vary-sentences, add-sensory-details, show-dont-tell, improve-flow, enhance-descriptions, strengthen-dialogue, fix-pacing, expand, condense, rewrite

Compile & Export -- assemble and ship the manuscript
ToolWhat it does
compile_documentsCombine documents with formatting; mode: "intelligent" for AI-optimized output
export_projectWrite the manuscript to disk in a target format
get_statisticsProject-level word/document/character counts
generate_marketing_materialsDraft synopsis, query letter, pitch, and related materials
Memory -- persistent project knowledge
ToolWhat it does
rememberStore information that persists across sessions with the project
recallRetrieve previously stored memory
get_memory_statsMetrics about the project's memory subsystem

Memory is stored within each .scriv project and travels with it.

Relationships -- entity connections and story graph
ToolWhat it does
add_relationshipStore a relationship between characters, locations, themes, or plot threads
find_relationshipsQuery entities related to a given character/theme/location
discover_connectionsFind co-occurring entities across the manuscript
character_networkThe character relationship network

Works without Neo4j -- relationships live in the Holographic Memory System and are available immediately. Neo4j adds advanced graph analysis when connected.

Background Jobs -- long-running analysis
ToolWhat it does
queue_document_analysisEnqueue an async analysis of one document; returns a job id
queue_project_analysisEnqueue an async analysis of the whole project
get_job_statusPoll progress/results for a queued job
cancel_jobCancel a queued or running job
Discovery -- explore capabilities
ToolWhat it does
list_skillsList the available tool groups and their tools
use_skillActivate a tool group (most are pre-activated by default)

Guides

Requirements

  • Node.js 18+
  • Scrivener 3 project files (.scriv)
  • macOS, Windows, or Linux
  • Optional: OpenAI API key for AI-powered features
  • Optional: Neo4j for character relationship graphs

Development

git clone https://github.com/writerslogic/scrivener-mcp.git
cd scrivener-mcp
npm install
npm run dev          # Development mode with hot reload
npm run build        # Compile TypeScript
npm test             # Run tests
npm run typecheck    # Type checking only

Why This One?

Several Scrivener MCP servers exist. Here's how they compare:

Featurescrivener-mcpjiayunzaphodsdadothers
Document read/write60+ tools29 toolsread-onlybasic
RTF / rich text supportyesnonono
Writing analysisreadability, pacing, style, emotionbasic metricsnono
Content enhancement12 types (filter words, verbs, show-don't-tell…)nonono
Semantic search (offline)vector + analogies + dream modenonono
Character consistency checkyesnonono
Character / plot memorypersistent profiles, plot threads, style guidenonono
Relationship graphsHMS triplets + optional Neo4jnonono
Multi-agent analysisroundtable critique with specialised agentsnonono
Story structure analysisyes (requires Neo4j)nonono
Token optimisationprogressive skill loading, compact JSONnonono
Batch document operationsyespartialnono
Export / compilationyes — multiple formatsbasicnono
Windows supportfull path handling + .scrivx discoverypartialnono
Install methodnpm · Homebrew · Docker · Smitherymanual clonemanual clonevaries
Published to npmyes (npm i -g scrivener-mcp)nonono
LicenseAGPL-3.0 / commercial dual-licenseMITvaries
Active developmentweeklystaleoccasionalstale
Community⭐ 30 · 13 forks · 29 issues⭐ ?⭐ 4minimal

Contributing

We welcome contributions of all sizes. Check the issue tracker for good first issue labels, or see the contributing guide for development setup.

Areas where help is especially welcome:

  • Test coverage (#18)
  • Windows testing and path handling
  • Scrivener 2 compatibility testing
  • Documentation improvements (#25)

License

AGPL-3.0 © WritersLogic, Inc.

Free for personal use and open-source projects. Commercial license available for proprietary integration. See COMMERCIAL_LICENSE.md for details.

scrivener-mcp MCP server

GitHub · npm · Issues · Changelog