pinescript
v2.56.1Pine Script v6 patterns: syntax, performance, error diagnosis, backtesting, visualization. Use when working with PineScript, TradingView, indicators, strateg...
Security Scan
OpenClaw
Benign
high confidencePurpose & 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.
latest
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()withbarstate.islastfor 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])), thendd = (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.smallfor intraday,size.normalfor 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,@paramtags - 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.isconfirmedguard -- calculations on unconfirmed bars cause repainting. Always guard entry signals. - Hardcoded thresholds without
input()-- makes the script untestable across instruments.
Workflow
- Write indicator/strategy in Pine Editor
- Test with bar replay and strategy tester on multiple timeframes
- Walk-forward validate before trusting backtest results (see Strategy & Backtesting above)
- Verify: run on 3+ symbols and 2+ timeframes
Verify
- Indicator compiles without errors on TradingView
- No repainting:
barstate.isconfirmedguard present where needed - Walk-forward tested on 3+ symbols across different timeframes
Comments
Loading comments...
