pinescript

v2.56.1

Pine Script v6 patterns: syntax, performance, error diagnosis, backtesting, visualization. Use when working with PineScript, TradingView, indicators, strateg...

0· 160·0 current·0 all-time
byIlia Alshanetsky@iliaal
Security Scan
VirusTotalVirusTotal
Benign
View report →
OpenClawOpenClaw
Benign
high confidence
Purpose & Capability
Name/description (Pine Script v6 guidance) aligns with the SKILL.md content: syntax rules, performance tips, debugging, backtesting, visualization and publishing guidance. The skill does not request unrelated binaries, env vars, or credentials.
Instruction Scope
The instructions stay within the domain of Pine Script development. They do not direct the agent to read unrelated files, access system credentials, or transmit data to external endpoints. The only external action suggested is to 'search current docs via `search_docs`' which is a reasonable, limited helper for up-to-date syntax.
Install Mechanism
No install specification and no code files are present (instruction-only), so nothing is written to disk or fetched at install time.
Credentials
The skill declares no environment variables, credentials, or config paths. The SKILL.md does not reference any secret-bearing env vars or unrelated services.
Persistence & Privilege
Skill is not forced-always (always:false) and has no install effects. Autonomous invocation is allowed by platform default but the skill itself does not request persistent privileges or modify other skills.
Assessment
This skill is low-risk: it's an instruction-only style guide for Pine Script and doesn't ask for keys, installs, or file access. Two practical notes before installing: (1) The SKILL.md suggests using a 'search_docs' helper — verify what that helper actually searches (official TradingView docs vs. other sources) if the agent can call external tools. (2) Some guidance mentions using forward-looking indices for accuracy testing and debug labels; ensure you (or the agent) do not accidentally ship lookahead/debug code into production indicators. If you want extra assurance, request the skill author to document what 'search_docs' uses or to remove any ambiguous external-tool references.

Like a lobster shell, security has layers — review code before you run it.

latestvk97eh77y8c5awcphah4yjnh6tn853r7v
160downloads
0stars
6versions
Updated 19h ago
v2.56.1
MIT-0

Pine Script Development

Verify before implementing: For Pine Script version-specific syntax or new built-in functions, search current docs via search_docs before writing code. TradingView updates Pine Script frequently and training data may be stale.

Critical Syntax Rules

  • Ternary operators MUST stay on one line -- splitting across lines causes "end of line without line continuation" error. For complex ternaries, use intermediate variables:
    isBull = close > open
    barColor = isBull ? color.green : color.red
    
  • Continuation lines MUST be indented MORE than the starting line -- same indentation = error
  • NEVER use plot() inside local scopes (if/for/functions) -- use conditional value instead: plot(condition ? value : na)
  • barstate.isconfirmed -- use to prevent repainting on real-time bars

Platform Limits

500 bars history for request.security() | 500 plot calls | 64 drawing objects | 40 request.security() calls | 100KB compiled size

Performance

  • Tuple security calls -- one request.security() returning [close, high, low] instead of 3 separate calls
  • Pre-allocate arrays with array.new<type>(size) instead of push-and-resize
  • Short-circuit signals: build conditions incrementally, exit early when first condition fails
  • Cache repeated calculations in variables -- Pine recalculates every bar

Debugging

TradingView has no console or debugger. Use these patterns:

  • Label debugging: label.new(bar_index, high, str.tostring(myVar)) to inspect values
  • Table monitor: table.new() with barstate.islast for real-time variable dashboard
  • Debug mode toggle: wrap all debug code in if input.bool("Debug", false) -- remove before publishing
  • Repainting detector: track previousValue = value[1], flag when historical values change

Strategy & Backtesting

  • Use strategy.* functions: strategy.wintrades, strategy.losstrades, strategy.grossprofit
  • Drawdown tracking: maxEquity = math.max(strategy.equity, nz(maxEquity[1])), then dd = (maxEquity - strategy.equity) / maxEquity * 100
  • Sharpe: dailyReturn * 252 / (stdDev * math.sqrt(252))
  • Walk-forward validation -- optimize on period 1, test on period 2, re-optimize on period 2, test on period 3. If metrics degrade > 30%, parameters are overfit.
  • Indicator accuracy testing -- use forward-looking close[lookforward] to measure prediction accuracy, track true/false positive rates

Visualization

  • color.from_gradient() for trend strength coloring
  • Adaptive text sizing: size.small for intraday, size.normal for daily+
  • Dynamic table rows -- resize based on enabled features via input toggles
  • Professional color constants: define BULL_COLOR, BEAR_COLOR, NEUTRAL_COLOR once with transparency

Publishing

  • Documentation goes at TOP of .pine file as comments before indicator()/strategy()
  • Use @version, @description, @param tags
  • Multi-line tooltips: tooltip="Line 1" + "\n" + "Line 2"
  • TradingView House Rules: no financial advice, no performance guarantees, no external links, no obfuscated code, no donation requests

Common Coding Mistakes

  • Indicator stacking (RSI + Stochastics + CCI) -- all measure the same thing (momentum). Use indicators from different categories instead.
  • Overfitting parameters: if optimal values are oddly specific (RSI 23 instead of 20), the backtest is curve-fitted. Use round numbers and input() with sensible defaults.
  • Missing barstate.isconfirmed guard -- calculations on unconfirmed bars cause repainting. Always guard entry signals.
  • Hardcoded thresholds without input() -- makes the script untestable across instruments.

Workflow

  1. Write indicator/strategy in Pine Editor
  2. Test with bar replay and strategy tester on multiple timeframes
  3. Walk-forward validate before trusting backtest results (see Strategy & Backtesting above)
  4. Verify: run on 3+ symbols and 2+ timeframes

Verify

  • Indicator compiles without errors on TradingView
  • No repainting: barstate.isconfirmed guard present where needed
  • Walk-forward tested on 3+ symbols across different timeframes

Comments

Loading comments...