Skip to main content

MCP server providing Pine Script v6 documentation for AI assistants

Project description

pinescript-mcp

MCP server providing Pine Script v6 documentation for AI assistants (Claude, etc.).

Enables AI to:

  • Look up Pine Script functions and validate syntax
  • Access official documentation for indicators, strategies, and visuals
  • Understand Pine Script concepts (execution model, repainting, etc.)
  • Generate correct v6 code with proper function references

Usage with Claude Code

Add to .mcp.json in your project (recommended):

{
  "mcpServers": {
    "pinescript-docs": {
      "type": "stdio",
      "command": "uvx",
      "args": ["pinescript-mcp"]
    }
  }
}

Usage with Claude Desktop

Add to ~/.config/claude/claude_desktop_config.json:

{
  "mcpServers": {
    "pinescript-docs": {
      "command": "uvx",
      "args": ["pinescript-mcp"]
    }
  }
}

Usage with Google Antigravity

Add to ~/.gemini/antigravity/mcp_config.json:

{
  "mcpServers": {
    "pinescript-docs": {
      "command": "uvx",
      "args": ["pinescript-mcp"]
    }
  }
}

Or use the public HTTP server (no install):

{
  "mcpServers": {
    "pinescript-docs": {
      "serverUrl": "https://pinescript-mcp.fly.dev/mcp"
    }
  }
}

Version Pinning

Documentation is bundled in the package - each version contains a frozen snapshot. For reproducible agent behavior, pin to a specific version:

{
  "mcpServers": {
    "pinescript-docs": {
      "command": "uvx",
      "args": ["pinescript-mcp==0.6.7"]
    }
  }
}

Without pinning, uvx pinescript-mcp gets the latest version.

Alternative: pip install

If you prefer pip over uvx:

pip install pinescript-mcp==0.6.7

Note: "command": "pinescript-mcp" only works if the install location is in your PATH. The uvx method above is more reliable as it handles environments automatically.

Public Server (No Install Required)

Connect directly to the hosted server - no Python or uvx needed:

{
  "mcpServers": {
    "pinescript-docs": {
      "type": "http",
      "url": "https://pinescript-mcp.fly.dev/mcp/"
    }
  }
}

Available Tools (10)

Tool Description
get_manifest() Start here for natural language questions — routing guide
resolve_topic(query) Fast lookup for exact API terms (ta.rsi, repainting)
search_docs(query) Grep for exact strings across all docs
list_docs() List all documentation files with descriptions
list_sections(path) List ## headers in a doc file (for navigating large files)
get_doc(path) Read a specific documentation file
get_section(path, header) Read a specific section by header
get_functions(namespace) List valid functions (ta, strategy, etc.)
validate_function(name) Check if a function exists in Pine v6
lint_script(script) Lint Pine Script (17 rules, free, no API cost)

Available Prompts

Prompt Description
debug_error(error, code) Analyze a Pine Script compilation error
convert_v5_to_v6(code) Convert Pine Script v5 code to v6 syntax
explain_function(name) Explain a Pine Script function in detail

Example Queries

  • "How do I create a trailing stop in Pine Script?"
  • "What's the difference between var and varip?"
  • "Is ta.supertrend a valid function?"
  • "How do I avoid repainting with request.security?"

Documentation Coverage

The server bundles comprehensive Pine Script v6 documentation:

  • Concepts: Execution model, timeframes, colors, methods, objects, common errors
  • Reference: Types, variables, constants, keywords, operators, annotations
  • Functions: Technical analysis (ta.*), strategies, requests, drawings, collections
  • Visuals: Plots, fills, shapes, tables, lines, boxes, backgrounds
  • Writing Scripts: Style guide, debugging, optimization, limitations

Why Use This?

AI models often hallucinate Pine Script functions or use deprecated v5 syntax. This MCP server grounds the AI in actual v6 documentation, preventing:

  • Made-up function names (e.g., ta.hull doesn't exist, use ta.hma)
  • Deprecated syntax from v4/v5
  • Incorrect parameter orders
  • Missing required arguments

Lint Rules (17 total)

The lint_script tool checks for common Pine Script issues without using AI:

Rule Type Description
S000 Warning AST parser failed (graceful fallback)
S001 Error Real syntax errors (via pynescript AST parser)
E001 Error input.enum() with const string constants
E003 Error Return type keyword on function declaration
E005 Error study() → use indicator()
E006 Error security() → use request.security()
E007 Error alertcondition() in strategy scripts
E009 Error format.currency doesn't exist
E010 Error Direct na comparison (use na() function)
E012 Error Unknown/hallucinated function
E013 Error input.enum() with options array
E014 Error strategy() missing title parameter
E015 Error Mismatched string quotes
W001 Warning Missing //@version=6
W003 Warning lookahead_on without justification
W004 Warning High max_bars_back value
W005 Warning Potentially unused variable

Performance

The HTTP server (Fly.io) uses response caching with 1-hour TTL for documentation lookups, making repeated queries very fast.

Development

# Clone and install locally
git clone https://gitlab.com/articat1066/pinescript-v6-mcp
cd pinescript-mcp
pip install -e .

# Run the server
pinescript-mcp

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

pinescript_mcp-0.6.7.tar.gz (326.5 kB view details)

Uploaded Source

Built Distribution

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

pinescript_mcp-0.6.7-py3-none-any.whl (354.2 kB view details)

Uploaded Python 3

File details

Details for the file pinescript_mcp-0.6.7.tar.gz.

File metadata

  • Download URL: pinescript_mcp-0.6.7.tar.gz
  • Upload date:
  • Size: 326.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.9

File hashes

Hashes for pinescript_mcp-0.6.7.tar.gz
Algorithm Hash digest
SHA256 e122593c63a74e572d8a6fca42caf4a55960f4e6a2c8057412c59a5bfcdf1672
MD5 a1eeb93ce66775b41152aff6733bffd0
BLAKE2b-256 4bc141c7642ae51c0bb0a533fd5b18c0c8a58fdf909772a5e5d6569a20463905

See more details on using hashes here.

File details

Details for the file pinescript_mcp-0.6.7-py3-none-any.whl.

File metadata

  • Download URL: pinescript_mcp-0.6.7-py3-none-any.whl
  • Upload date:
  • Size: 354.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.9

File hashes

Hashes for pinescript_mcp-0.6.7-py3-none-any.whl
Algorithm Hash digest
SHA256 742bf17e26f0245b7e44aadffdb6dc384a4e01a3a7d788cc8d273ab46bd68a8f
MD5 2010330b31b5352d8c31603b2af949ed
BLAKE2b-256 9c748d5f9eb97eaf33cce4c3e0db2d8208abe24c3f215c28698b6c5cc303c6f9

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