shard-ameba/Ameba/AST/Scope.html

1974 lines
64 KiB
HTML
Raw Normal View History

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="generator" content="Crystal Docs 1.7.3">
<meta name="crystal_docs.project_version" content="master">
<meta name="crystal_docs.project_name" content="ameba">
<link href="../../css/style.css" rel="stylesheet" type="text/css" />
<script type="text/javascript" src="../../js/doc.js"></script>
<meta name="repository-name" content="ameba">
<title>Ameba::AST::Scope - ameba master</title>
<script type="text/javascript">
CrystalDocs.base_path = "../../";
</script>
</head>
<body>
<svg class="hidden">
<symbol id="octicon-link" viewBox="0 0 16 16">
<path fill-rule="evenodd" d="M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z"></path>
</symbol>
</svg>
<div class="sidebar">
<div class="sidebar-header">
<div class="search-box">
<input type="search" class="search-input" placeholder="Search..." spellcheck="false" aria-label="Search">
</div>
<div class="project-summary">
<h1 class="project-name">
<a href="../../index.html">
ameba
</a>
</h1>
<span class="project-version">
master
</span>
</div>
</div>
<div class="search-results hidden">
<ul class="search-list"></ul>
</div>
<div class="types-list">
<ul>
<li class="parent open current" data-id="ameba/Ameba" data-name="ameba">
<a href="../../Ameba.html">Ameba</a>
<ul>
<li class="parent open current" data-id="ameba/Ameba/AST" data-name="ameba::ast">
<a href="../../Ameba/AST.html">AST</a>
<ul>
<li class=" " data-id="ameba/Ameba/AST/Argument" data-name="ameba::ast::argument">
<a href="../../Ameba/AST/Argument.html">Argument</a>
</li>
<li class=" " data-id="ameba/Ameba/AST/Assignment" data-name="ameba::ast::assignment">
<a href="../../Ameba/AST/Assignment.html">Assignment</a>
</li>
<li class=" " data-id="ameba/Ameba/AST/BaseVisitor" data-name="ameba::ast::basevisitor">
<a href="../../Ameba/AST/BaseVisitor.html">BaseVisitor</a>
</li>
<li class=" " data-id="ameba/Ameba/AST/Branch" data-name="ameba::ast::branch">
<a href="../../Ameba/AST/Branch.html">Branch</a>
</li>
<li class=" " data-id="ameba/Ameba/AST/Branchable" data-name="ameba::ast::branchable">
<a href="../../Ameba/AST/Branchable.html">Branchable</a>
</li>
<li class=" " data-id="ameba/Ameba/AST/CountingVisitor" data-name="ameba::ast::countingvisitor">
<a href="../../Ameba/AST/CountingVisitor.html">CountingVisitor</a>
</li>
<li class=" " data-id="ameba/Ameba/AST/FlowExpression" data-name="ameba::ast::flowexpression">
<a href="../../Ameba/AST/FlowExpression.html">FlowExpression</a>
</li>
<li class=" " data-id="ameba/Ameba/AST/FlowExpressionVisitor" data-name="ameba::ast::flowexpressionvisitor">
<a href="../../Ameba/AST/FlowExpressionVisitor.html">FlowExpressionVisitor</a>
</li>
<li class=" " data-id="ameba/Ameba/AST/InstanceVariable" data-name="ameba::ast::instancevariable">
<a href="../../Ameba/AST/InstanceVariable.html">InstanceVariable</a>
</li>
<li class="parent " data-id="ameba/Ameba/AST/NodeVisitor" data-name="ameba::ast::nodevisitor">
<a href="../../Ameba/AST/NodeVisitor.html">NodeVisitor</a>
<ul>
<li class=" " data-id="ameba/Ameba/AST/NodeVisitor/Category" data-name="ameba::ast::nodevisitor::category">
<a href="../../Ameba/AST/NodeVisitor/Category.html">Category</a>
</li>
</ul>
</li>
<li class=" " data-id="ameba/Ameba/AST/RedundantControlExpressionVisitor" data-name="ameba::ast::redundantcontrolexpressionvisitor">
<a href="../../Ameba/AST/RedundantControlExpressionVisitor.html">RedundantControlExpressionVisitor</a>
</li>
<li class=" " data-id="ameba/Ameba/AST/Reference" data-name="ameba::ast::reference">
<a href="../../Ameba/AST/Reference.html">Reference</a>
</li>
<li class=" current" data-id="ameba/Ameba/AST/Scope" data-name="ameba::ast::scope">
<a href="../../Ameba/AST/Scope.html">Scope</a>
</li>
<li class=" " data-id="ameba/Ameba/AST/ScopeVisitor" data-name="ameba::ast::scopevisitor">
<a href="../../Ameba/AST/ScopeVisitor.html">ScopeVisitor</a>
</li>
<li class=" " data-id="ameba/Ameba/AST/TopLevelNodesVisitor" data-name="ameba::ast::toplevelnodesvisitor">
<a href="../../Ameba/AST/TopLevelNodesVisitor.html">TopLevelNodesVisitor</a>
</li>
<li class=" " data-id="ameba/Ameba/AST/TypeDecVariable" data-name="ameba::ast::typedecvariable">
<a href="../../Ameba/AST/TypeDecVariable.html">TypeDecVariable</a>
</li>
<li class=" " data-id="ameba/Ameba/AST/Util" data-name="ameba::ast::util">
<a href="../../Ameba/AST/Util.html">Util</a>
</li>
<li class=" " data-id="ameba/Ameba/AST/Variable" data-name="ameba::ast::variable">
<a href="../../Ameba/AST/Variable.html">Variable</a>
</li>
</ul>
</li>
<li class=" " data-id="ameba/Ameba/Config" data-name="ameba::config">
<a href="../../Ameba/Config.html">Config</a>
</li>
<li class="parent " data-id="ameba/Ameba/Ext" data-name="ameba::ext">
<a href="../../Ameba/Ext.html">Ext</a>
<ul>
<li class=" " data-id="ameba/Ameba/Ext/Location" data-name="ameba::ext::location">
<a href="../../Ameba/Ext/Location.html">Location</a>
</li>
</ul>
</li>
<li class="parent " data-id="ameba/Ameba/Formatter" data-name="ameba::formatter">
<a href="../../Ameba/Formatter.html">Formatter</a>
<ul>
<li class=" " data-id="ameba/Ameba/Formatter/BaseFormatter" data-name="ameba::formatter::baseformatter">
<a href="../../Ameba/Formatter/BaseFormatter.html">BaseFormatter</a>
</li>
<li class=" " data-id="ameba/Ameba/Formatter/DisabledFormatter" data-name="ameba::formatter::disabledformatter">
<a href="../../Ameba/Formatter/DisabledFormatter.html">DisabledFormatter</a>
</li>
<li class=" " data-id="ameba/Ameba/Formatter/DotFormatter" data-name="ameba::formatter::dotformatter">
<a href="../../Ameba/Formatter/DotFormatter.html">DotFormatter</a>
</li>
<li class=" " data-id="ameba/Ameba/Formatter/ExplainFormatter" data-name="ameba::formatter::explainformatter">
<a href="../../Ameba/Formatter/ExplainFormatter.html">ExplainFormatter</a>
</li>
<li class=" " data-id="ameba/Ameba/Formatter/FlycheckFormatter" data-name="ameba::formatter::flycheckformatter">
<a href="../../Ameba/Formatter/FlycheckFormatter.html">FlycheckFormatter</a>
</li>
<li class=" " data-id="ameba/Ameba/Formatter/JSONFormatter" data-name="ameba::formatter::jsonformatter">
<a href="../../Ameba/Formatter/JSONFormatter.html">JSONFormatter</a>
</li>
<li class=" " data-id="ameba/Ameba/Formatter/TODOFormatter" data-name="ameba::formatter::todoformatter">
<a href="../../Ameba/Formatter/TODOFormatter.html">TODOFormatter</a>
</li>
<li class=" " data-id="ameba/Ameba/Formatter/Util" data-name="ameba::formatter::util">
<a href="../../Ameba/Formatter/Util.html">Util</a>
</li>
</ul>
</li>
<li class=" " data-id="ameba/Ameba/GlobUtils" data-name="ameba::globutils">
<a href="../../Ameba/GlobUtils.html">GlobUtils</a>
</li>
<li class="parent " data-id="ameba/Ameba/InlineComments" data-name="ameba::inlinecomments">
<a href="../../Ameba/InlineComments.html">InlineComments</a>
<ul>
<li class=" " data-id="ameba/Ameba/InlineComments/Action" data-name="ameba::inlinecomments::action">
<a href="../../Ameba/InlineComments/Action.html">Action</a>
</li>
</ul>
</li>
<li class="parent " data-id="ameba/Ameba/Issue" data-name="ameba::issue">
<a href="../../Ameba/Issue.html">Issue</a>
<ul>
<li class=" " data-id="ameba/Ameba/Issue/Status" data-name="ameba::issue::status">
<a href="../../Ameba/Issue/Status.html">Status</a>
</li>
</ul>
</li>
<li class=" " data-id="ameba/Ameba/Reportable" data-name="ameba::reportable">
<a href="../../Ameba/Reportable.html">Reportable</a>
</li>
<li class="parent " data-id="ameba/Ameba/Rule" data-name="ameba::rule">
<a href="../../Ameba/Rule.html">Rule</a>
<ul>
<li class=" " data-id="ameba/Ameba/Rule/Base" data-name="ameba::rule::base">
<a href="../../Ameba/Rule/Base.html">Base</a>
</li>
<li class="parent " data-id="ameba/Ameba/Rule/Layout" data-name="ameba::rule::layout">
<a href="../../Ameba/Rule/Layout.html">Layout</a>
<ul>
<li class=" " data-id="ameba/Ameba/Rule/Layout/LineLength" data-name="ameba::rule::layout::linelength">
<a href="../../Ameba/Rule/Layout/LineLength.html">LineLength</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Layout/TrailingBlankLines" data-name="ameba::rule::layout::trailingblanklines">
<a href="../../Ameba/Rule/Layout/TrailingBlankLines.html">TrailingBlankLines</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Layout/TrailingWhitespace" data-name="ameba::rule::layout::trailingwhitespace">
<a href="../../Ameba/Rule/Layout/TrailingWhitespace.html">TrailingWhitespace</a>
</li>
</ul>
</li>
<li class="parent " data-id="ameba/Ameba/Rule/Lint" data-name="ameba::rule::lint">
<a href="../../Ameba/Rule/Lint.html">Lint</a>
<ul>
<li class=" " data-id="ameba/Ameba/Rule/Lint/AmbiguousAssignment" data-name="ameba::rule::lint::ambiguousassignment">
<a href="../../Ameba/Rule/Lint/AmbiguousAssignment.html">AmbiguousAssignment</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/BadDirective" data-name="ameba::rule::lint::baddirective">
<a href="../../Ameba/Rule/Lint/BadDirective.html">BadDirective</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/ComparisonToBoolean" data-name="ameba::rule::lint::comparisontoboolean">
<a href="../../Ameba/Rule/Lint/ComparisonToBoolean.html">ComparisonToBoolean</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/DebugCalls" data-name="ameba::rule::lint::debugcalls">
<a href="../../Ameba/Rule/Lint/DebugCalls.html">DebugCalls</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/DebuggerStatement" data-name="ameba::rule::lint::debuggerstatement">
<a href="../../Ameba/Rule/Lint/DebuggerStatement.html">DebuggerStatement</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/Documentation" data-name="ameba::rule::lint::documentation">
<a href="../../Ameba/Rule/Lint/Documentation.html">Documentation</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/DuplicatedRequire" data-name="ameba::rule::lint::duplicatedrequire">
<a href="../../Ameba/Rule/Lint/DuplicatedRequire.html">DuplicatedRequire</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/EmptyEnsure" data-name="ameba::rule::lint::emptyensure">
<a href="../../Ameba/Rule/Lint/EmptyEnsure.html">EmptyEnsure</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/EmptyExpression" data-name="ameba::rule::lint::emptyexpression">
<a href="../../Ameba/Rule/Lint/EmptyExpression.html">EmptyExpression</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/EmptyLoop" data-name="ameba::rule::lint::emptyloop">
<a href="../../Ameba/Rule/Lint/EmptyLoop.html">EmptyLoop</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/Formatting" data-name="ameba::rule::lint::formatting">
<a href="../../Ameba/Rule/Lint/Formatting.html">Formatting</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/HashDuplicatedKey" data-name="ameba::rule::lint::hashduplicatedkey">
<a href="../../Ameba/Rule/Lint/HashDuplicatedKey.html">HashDuplicatedKey</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/LiteralAssignmentsInExpressions" data-name="ameba::rule::lint::literalassignmentsinexpressions">
<a href="../../Ameba/Rule/Lint/LiteralAssignmentsInExpressions.html">LiteralAssignmentsInExpressions</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/LiteralInCondition" data-name="ameba::rule::lint::literalincondition">
<a href="../../Ameba/Rule/Lint/LiteralInCondition.html">LiteralInCondition</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/LiteralInInterpolation" data-name="ameba::rule::lint::literalininterpolation">
<a href="../../Ameba/Rule/Lint/LiteralInInterpolation.html">LiteralInInterpolation</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/LiteralsComparison" data-name="ameba::rule::lint::literalscomparison">
<a href="../../Ameba/Rule/Lint/LiteralsComparison.html">LiteralsComparison</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/MissingBlockArgument" data-name="ameba::rule::lint::missingblockargument">
<a href="../../Ameba/Rule/Lint/MissingBlockArgument.html">MissingBlockArgument</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/NotNil" data-name="ameba::rule::lint::notnil">
<a href="../../Ameba/Rule/Lint/NotNil.html">NotNil</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/NotNilAfterNoBang" data-name="ameba::rule::lint::notnilafternobang">
<a href="../../Ameba/Rule/Lint/NotNilAfterNoBang.html">NotNilAfterNoBang</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/PercentArrays" data-name="ameba::rule::lint::percentarrays">
<a href="../../Ameba/Rule/Lint/PercentArrays.html">PercentArrays</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/RandZero" data-name="ameba::rule::lint::randzero">
<a href="../../Ameba/Rule/Lint/RandZero.html">RandZero</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/RedundantStringCoercion" data-name="ameba::rule::lint::redundantstringcoercion">
<a href="../../Ameba/Rule/Lint/RedundantStringCoercion.html">RedundantStringCoercion</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/RedundantWithIndex" data-name="ameba::rule::lint::redundantwithindex">
<a href="../../Ameba/Rule/Lint/RedundantWithIndex.html">RedundantWithIndex</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/RedundantWithObject" data-name="ameba::rule::lint::redundantwithobject">
<a href="../../Ameba/Rule/Lint/RedundantWithObject.html">RedundantWithObject</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/ShadowedArgument" data-name="ameba::rule::lint::shadowedargument">
<a href="../../Ameba/Rule/Lint/ShadowedArgument.html">ShadowedArgument</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/ShadowedException" data-name="ameba::rule::lint::shadowedexception">
<a href="../../Ameba/Rule/Lint/ShadowedException.html">ShadowedException</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/ShadowingOuterLocalVar" data-name="ameba::rule::lint::shadowingouterlocalvar">
<a href="../../Ameba/Rule/Lint/ShadowingOuterLocalVar.html">ShadowingOuterLocalVar</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/SharedVarInFiber" data-name="ameba::rule::lint::sharedvarinfiber">
<a href="../../Ameba/Rule/Lint/SharedVarInFiber.html">SharedVarInFiber</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/SpecFocus" data-name="ameba::rule::lint::specfocus">
<a href="../../Ameba/Rule/Lint/SpecFocus.html">SpecFocus</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/Syntax" data-name="ameba::rule::lint::syntax">
<a href="../../Ameba/Rule/Lint/Syntax.html">Syntax</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/UnneededDisableDirective" data-name="ameba::rule::lint::unneededdisabledirective">
<a href="../../Ameba/Rule/Lint/UnneededDisableDirective.html">UnneededDisableDirective</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/UnreachableCode" data-name="ameba::rule::lint::unreachablecode">
<a href="../../Ameba/Rule/Lint/UnreachableCode.html">UnreachableCode</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/UnusedArgument" data-name="ameba::rule::lint::unusedargument">
<a href="../../Ameba/Rule/Lint/UnusedArgument.html">UnusedArgument</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/UnusedBlockArgument" data-name="ameba::rule::lint::unusedblockargument">
<a href="../../Ameba/Rule/Lint/UnusedBlockArgument.html">UnusedBlockArgument</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/UselessAssign" data-name="ameba::rule::lint::uselessassign">
<a href="../../Ameba/Rule/Lint/UselessAssign.html">UselessAssign</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Lint/UselessConditionInWhen" data-name="ameba::rule::lint::uselessconditioninwhen">
<a href="../../Ameba/Rule/Lint/UselessConditionInWhen.html">UselessConditionInWhen</a>
</li>
</ul>
</li>
<li class="parent " data-id="ameba/Ameba/Rule/Metrics" data-name="ameba::rule::metrics">
<a href="../../Ameba/Rule/Metrics.html">Metrics</a>
<ul>
<li class=" " data-id="ameba/Ameba/Rule/Metrics/CyclomaticComplexity" data-name="ameba::rule::metrics::cyclomaticcomplexity">
<a href="../../Ameba/Rule/Metrics/CyclomaticComplexity.html">CyclomaticComplexity</a>
</li>
</ul>
</li>
<li class="parent " data-id="ameba/Ameba/Rule/Performance" data-name="ameba::rule::performance">
<a href="../../Ameba/Rule/Performance.html">Performance</a>
<ul>
<li class=" " data-id="ameba/Ameba/Rule/Performance/AnyAfterFilter" data-name="ameba::rule::performance::anyafterfilter">
<a href="../../Ameba/Rule/Performance/AnyAfterFilter.html">AnyAfterFilter</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Performance/AnyInsteadOfEmpty" data-name="ameba::rule::performance::anyinsteadofempty">
<a href="../../Ameba/Rule/Performance/AnyInsteadOfEmpty.html">AnyInsteadOfEmpty</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Performance/Base" data-name="ameba::rule::performance::base">
<a href="../../Ameba/Rule/Performance/Base.html">Base</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Performance/ChainedCallWithNoBang" data-name="ameba::rule::performance::chainedcallwithnobang">
<a href="../../Ameba/Rule/Performance/ChainedCallWithNoBang.html">ChainedCallWithNoBang</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Performance/CompactAfterMap" data-name="ameba::rule::performance::compactaftermap">
<a href="../../Ameba/Rule/Performance/CompactAfterMap.html">CompactAfterMap</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Performance/ExcessiveAllocations" data-name="ameba::rule::performance::excessiveallocations">
<a href="../../Ameba/Rule/Performance/ExcessiveAllocations.html">ExcessiveAllocations</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Performance/FirstLastAfterFilter" data-name="ameba::rule::performance::firstlastafterfilter">
<a href="../../Ameba/Rule/Performance/FirstLastAfterFilter.html">FirstLastAfterFilter</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Performance/FlattenAfterMap" data-name="ameba::rule::performance::flattenaftermap">
<a href="../../Ameba/Rule/Performance/FlattenAfterMap.html">FlattenAfterMap</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Performance/MapInsteadOfBlock" data-name="ameba::rule::performance::mapinsteadofblock">
<a href="../../Ameba/Rule/Performance/MapInsteadOfBlock.html">MapInsteadOfBlock</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Performance/SizeAfterFilter" data-name="ameba::rule::performance::sizeafterfilter">
<a href="../../Ameba/Rule/Performance/SizeAfterFilter.html">SizeAfterFilter</a>
</li>
</ul>
</li>
<li class="parent " data-id="ameba/Ameba/Rule/Style" data-name="ameba::rule::style">
<a href="../../Ameba/Rule/Style.html">Style</a>
<ul>
<li class=" " data-id="ameba/Ameba/Rule/Style/ConstantNames" data-name="ameba::rule::style::constantnames">
<a href="../../Ameba/Rule/Style/ConstantNames.html">ConstantNames</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Style/GuardClause" data-name="ameba::rule::style::guardclause">
<a href="../../Ameba/Rule/Style/GuardClause.html">GuardClause</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Style/IsAFilter" data-name="ameba::rule::style::isafilter">
<a href="../../Ameba/Rule/Style/IsAFilter.html">IsAFilter</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Style/IsANil" data-name="ameba::rule::style::isanil">
<a href="../../Ameba/Rule/Style/IsANil.html">IsANil</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Style/LargeNumbers" data-name="ameba::rule::style::largenumbers">
<a href="../../Ameba/Rule/Style/LargeNumbers.html">LargeNumbers</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Style/MethodNames" data-name="ameba::rule::style::methodnames">
<a href="../../Ameba/Rule/Style/MethodNames.html">MethodNames</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Style/NegatedConditionsInUnless" data-name="ameba::rule::style::negatedconditionsinunless">
<a href="../../Ameba/Rule/Style/NegatedConditionsInUnless.html">NegatedConditionsInUnless</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Style/ParenthesesAroundCondition" data-name="ameba::rule::style::parenthesesaroundcondition">
<a href="../../Ameba/Rule/Style/ParenthesesAroundCondition.html">ParenthesesAroundCondition</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Style/PredicateName" data-name="ameba::rule::style::predicatename">
<a href="../../Ameba/Rule/Style/PredicateName.html">PredicateName</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Style/QueryBoolMethods" data-name="ameba::rule::style::queryboolmethods">
<a href="../../Ameba/Rule/Style/QueryBoolMethods.html">QueryBoolMethods</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Style/RedundantBegin" data-name="ameba::rule::style::redundantbegin">
<a href="../../Ameba/Rule/Style/RedundantBegin.html">RedundantBegin</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Style/RedundantNext" data-name="ameba::rule::style::redundantnext">
<a href="../../Ameba/Rule/Style/RedundantNext.html">RedundantNext</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Style/RedundantReturn" data-name="ameba::rule::style::redundantreturn">
<a href="../../Ameba/Rule/Style/RedundantReturn.html">RedundantReturn</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Style/TypeNames" data-name="ameba::rule::style::typenames">
<a href="../../Ameba/Rule/Style/TypeNames.html">TypeNames</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Style/UnlessElse" data-name="ameba::rule::style::unlesselse">
<a href="../../Ameba/Rule/Style/UnlessElse.html">UnlessElse</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Style/VariableNames" data-name="ameba::rule::style::variablenames">
<a href="../../Ameba/Rule/Style/VariableNames.html">VariableNames</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Style/VerboseBlock" data-name="ameba::rule::style::verboseblock">
<a href="../../Ameba/Rule/Style/VerboseBlock.html">VerboseBlock</a>
</li>
<li class=" " data-id="ameba/Ameba/Rule/Style/WhileTrue" data-name="ameba::rule::style::whiletrue">
<a href="../../Ameba/Rule/Style/WhileTrue.html">WhileTrue</a>
</li>
</ul>
</li>
</ul>
</li>
<li class="parent " data-id="ameba/Ameba/Runner" data-name="ameba::runner">
<a href="../../Ameba/Runner.html">Runner</a>
<ul>
<li class=" " data-id="ameba/Ameba/Runner/InfiniteCorrectionLoopError" data-name="ameba::runner::infinitecorrectionlooperror">
<a href="../../Ameba/Runner/InfiniteCorrectionLoopError.html">InfiniteCorrectionLoopError</a>
</li>
</ul>
</li>
<li class=" " data-id="ameba/Ameba/Severity" data-name="ameba::severity">
<a href="../../Ameba/Severity.html">Severity</a>
</li>
<li class=" " data-id="ameba/Ameba/SeverityYamlConverter" data-name="ameba::severityyamlconverter">
<a href="../../Ameba/SeverityYamlConverter.html">SeverityYamlConverter</a>
</li>
<li class="parent " data-id="ameba/Ameba/Source" data-name="ameba::source">
<a href="../../Ameba/Source.html">Source</a>
<ul>
<li class=" " data-id="ameba/Ameba/Source/Corrector" data-name="ameba::source::corrector">
<a href="../../Ameba/Source/Corrector.html">Corrector</a>
</li>
<li class=" " data-id="ameba/Ameba/Source/Rewriter" data-name="ameba::source::rewriter">
<a href="../../Ameba/Source/Rewriter.html">Rewriter</a>
</li>
</ul>
</li>
<li class="parent " data-id="ameba/Ameba/Spec" data-name="ameba::spec">
<a href="../../Ameba/Spec.html">Spec</a>
<ul>
<li class=" " data-id="ameba/Ameba/Spec/AnnotatedSource" data-name="ameba::spec::annotatedsource">
<a href="../../Ameba/Spec/AnnotatedSource.html">AnnotatedSource</a>
</li>
<li class=" " data-id="ameba/Ameba/Spec/BeValid" data-name="ameba::spec::bevalid">
<a href="../../Ameba/Spec/BeValid.html">BeValid</a>
</li>
<li class=" " data-id="ameba/Ameba/Spec/BeValidExpectation" data-name="ameba::spec::bevalidexpectation">
<a href="../../Ameba/Spec/BeValidExpectation.html">BeValidExpectation</a>
</li>
<li class=" " data-id="ameba/Ameba/Spec/ExpectIssue" data-name="ameba::spec::expectissue">
<a href="../../Ameba/Spec/ExpectIssue.html">ExpectIssue</a>
</li>
<li class=" " data-id="ameba/Ameba/Spec/Util" data-name="ameba::spec::util">
<a href="../../Ameba/Spec/Util.html">Util</a>
</li>
</ul>
</li>
<li class=" " data-id="ameba/Ameba/Tokenizer" data-name="ameba::tokenizer">
<a href="../../Ameba/Tokenizer.html">Tokenizer</a>
</li>
</ul>
</li>
</ul>
</div>
</div>
<div class="main-content">
<h1 class="type-name">
<span class="kind">class</span> Ameba::AST::Scope
</h1>
<ul class="superclass-hierarchy"><li class="superclass"><a href="../../Ameba/AST/Scope.html">Ameba::AST::Scope</a></li><li class="superclass">Reference</li><li class="superclass">Object</li></ul>
<h2>
<a id="overview" class="anchor" href="#overview">
<svg class="octicon-link" aria-hidden="true">
<use href="#octicon-link"/>
</svg>
</a>
Overview
</h2>
<p>Represents a context of the local variable visibility.
This is where the local variables belong to.</p>
<h2>
<a id="defined-in" class="anchor" href="#defined-in">
<svg class="octicon-link" aria-hidden="true">
<use href="#octicon-link"/>
</svg>
</a>
Defined in:
</h2>
<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L6" target="_blank">
ameba/ast/scope.cr
</a>
<br/>
<h2>
<a id="constructors" class="anchor" href="#constructors">
<svg class="octicon-link" aria-hidden="true">
<use href="#octicon-link"/>
</svg>
</a>
Constructors
</h2>
<ul class="list-summary">
<li class="entry-summary">
<a href="#new%28node%3ACrystal%3A%3AASTNode%2Couter_scope%3ANil%7CAmeba%3A%3AAST%3A%3AScope%3Dnil%29-class-method" class="signature"><strong>.new</strong>(node : Crystal::ASTNode, outer_scope : Nil | Ameba::AST::Scope = <span class="n">nil</span>)</a>
<div class="summary"><p>Creates a new scope.</p></div>
</li>
</ul>
<h2>
<a id="instance-method-summary" class="anchor" href="#instance-method-summary">
<svg class="octicon-link" aria-hidden="true">
<use href="#octicon-link"/>
</svg>
</a>
Instance Method Summary
</h2>
<ul class="list-summary">
<li class="entry-summary">
<a href="#%3D%3D%28other%3Aself%29-instance-method" class="signature"><strong>#==</strong>(other : <span class="k">self</span>)</a>
<div class="summary"><p>Returns <code>true</code> if this reference is the same as <em>other</em>.</p></div>
</li>
<li class="entry-summary">
<a href="#add_argument%28node%29-instance-method" class="signature"><strong>#add_argument</strong>(node)</a>
<div class="summary"><p>Creates a new argument in the current scope.</p></div>
</li>
<li class="entry-summary">
<a href="#add_ivariable%28node%29-instance-method" class="signature"><strong>#add_ivariable</strong>(node)</a>
<div class="summary"><p>Adds a new instance variable to the current scope.</p></div>
</li>
<li class="entry-summary">
<a href="#add_type_dec_variable%28node%29-instance-method" class="signature"><strong>#add_type_dec_variable</strong>(node)</a>
<div class="summary"><p>Adds a new type declaration variable to the current scope.</p></div>
</li>
<li class="entry-summary">
<a href="#add_variable%28node%29-instance-method" class="signature"><strong>#add_variable</strong>(node)</a>
<div class="summary"><p>Creates a new variable in the current scope.</p></div>
</li>
<li class="entry-summary">
<a href="#arg%3F%28var%29-instance-method" class="signature"><strong>#arg?</strong>(var)</a>
<div class="summary"><p>Returns <code>true</code> if var is an argument in current scope, <code>false</code> otherwise.</p></div>
</li>
<li class="entry-summary">
<a href="#arguments%3AArray%28Ameba%3A%3AAST%3A%3AArgument%29-instance-method" class="signature"><strong>#arguments</strong> : Array(Ameba::AST::Argument)</a>
<div class="summary"><p>Link to the arguments in current scope</p></div>
</li>
<li class="entry-summary">
<a href="#assign_variable%28name%2Cnode%29-instance-method" class="signature"><strong>#assign_variable</strong>(name, node)</a>
<div class="summary"><p>Creates a new assignment for the variable.</p></div>
</li>
<li class="entry-summary">
<a href="#assigns_ivar%3F%28name%29-instance-method" class="signature"><strong>#assigns_ivar?</strong>(name)</a>
<div class="summary"><p>Returns <code>true</code> if instance variable is assigned in this scope.</p></div>
</li>
<li class="entry-summary">
<a href="#assigns_type_dec%3F%28name%29-instance-method" class="signature"><strong>#assigns_type_dec?</strong>(name)</a>
<div class="summary"><p>Returns <code>true</code> if type declaration variable is assigned in this scope.</p></div>
</li>
<li class="entry-summary">
<a href="#block%3F-instance-method" class="signature"><strong>#block?</strong></a>
<div class="summary"><p>Returns <code>true</code> if current scope represents a block (or proc), <code>false</code> otherwise.</p></div>
</li>
<li class="entry-summary">
<a href="#def%3F-instance-method" class="signature"><strong>#def?</strong></a>
<div class="summary"><p>Returns <code>true</code> if current scope is a def, <code>false</code> otherwise.</p></div>
</li>
<li class="entry-summary">
<a href="#end_location%28%2Aargs%2C%2A%2Aoptions%29-instance-method" class="signature"><strong>#end_location</strong>(*args, **options)</a>
</li>
<li class="entry-summary">
<a href="#end_location%28%2Aargs%2C%2A%2Aoptions%2C%26%29-instance-method" class="signature"><strong>#end_location</strong>(*args, **options, &)</a>
</li>
<li class="entry-summary">
<a href="#eql%3F%28node%29-instance-method" class="signature"><strong>#eql?</strong>(node)</a>
<div class="summary"><p>Returns <code>true</code> if the <em>node</em> represents exactly the same Crystal node as <code>@node</code>.</p></div>
</li>
<li class="entry-summary">
<a href="#find_variable%28name%3AString%29-instance-method" class="signature"><strong>#find_variable</strong>(name : String)</a>
<div class="summary"><p>Returns variable by its name or <code>nil</code> if it does not exist.</p></div>
</li>
<li class="entry-summary">
<a href="#hash%28hasher%29-instance-method" class="signature"><strong>#hash</strong>(hasher)</a>
<div class="summary"><p>See <code>Object#hash(hasher)</code></p></div>
</li>
<li class="entry-summary">
<a href="#in_macro%3F-instance-method" class="signature"><strong>#in_macro?</strong></a>
<div class="summary"><p>Returns <code>true</code> if current scope sits inside a macro.</p></div>
</li>
<li class="entry-summary">
<a href="#inner_scopes%3AArray%28Ameba%3A%3AAST%3A%3AScope%29-instance-method" class="signature"><strong>#inner_scopes</strong> : Array(Ameba::AST::Scope)</a>
<div class="summary"><p>List of inner scopes</p></div>
</li>
<li class="entry-summary">
<a href="#ivariables%3AArray%28Ameba%3A%3AAST%3A%3AInstanceVariable%29-instance-method" class="signature"><strong>#ivariables</strong> : Array(Ameba::AST::InstanceVariable)</a>
<div class="summary"><p>Link to the instance variables used in current scope</p></div>
</li>
<li class="entry-summary">
<a href="#location%28%2Aargs%2C%2A%2Aoptions%29-instance-method" class="signature"><strong>#location</strong>(*args, **options)</a>
</li>
<li class="entry-summary">
<a href="#location%28%2Aargs%2C%2A%2Aoptions%2C%26%29-instance-method" class="signature"><strong>#location</strong>(*args, **options, &)</a>
</li>
<li class="entry-summary">
<a href="#node%3ACrystal%3A%3AASTNode-instance-method" class="signature"><strong>#node</strong> : Crystal::ASTNode</a>
<div class="summary"><p>The actual AST node that represents a current scope.</p></div>
</li>
<li class="entry-summary">
<a href="#outer_scope%3AScope%7CNil-instance-method" class="signature"><strong>#outer_scope</strong> : Scope | Nil</a>
<div class="summary"><p>Link to the outer scope</p></div>
</li>
<li class="entry-summary">
<a href="#references%3AArray%28Ameba%3A%3AAST%3A%3AReference%29-instance-method" class="signature"><strong>#references</strong> : Array(Ameba::AST::Reference)</a>
<div class="summary"><p>Link to all variable references in currency scope</p></div>
</li>
<li class="entry-summary">
<a href="#references%3F%28variable%3AVariable%2Ccheck_inner_scopes%3Dtrue%29-instance-method" class="signature"><strong>#references?</strong>(variable : Variable, check_inner_scopes = <span class="n">true</span>)</a>
<div class="summary"><p>Returns <code>true</code> if current scope (or any of inner scopes) references variable, <code>false</code> otherwise.</p></div>
</li>
<li class="entry-summary">
<a href="#spawn_block%3F-instance-method" class="signature"><strong>#spawn_block?</strong></a>
<div class="summary"><p>Returns <code>true</code> if current scope represents a spawn block, e.</p></div>
</li>
<li class="entry-summary">
<a href="#to_s%28%2Aargs%2C%2A%2Aoptions%29-instance-method" class="signature"><strong>#to_s</strong>(*args, **options)</a>
</li>
<li class="entry-summary">
<a href="#to_s%28%2Aargs%2C%2A%2Aoptions%2C%26%29-instance-method" class="signature"><strong>#to_s</strong>(*args, **options, &)</a>
</li>
<li class="entry-summary">
<a href="#top_level%3F-instance-method" class="signature"><strong>#top_level?</strong></a>
<div class="summary"><p>Returns <code>true</code> if this scope is a top level scope, <code>false</code> otherwise.</p></div>
</li>
<li class="entry-summary">
<a href="#type_dec_variables%3AArray%28Ameba%3A%3AAST%3A%3ATypeDecVariable%29-instance-method" class="signature"><strong>#type_dec_variables</strong> : Array(Ameba::AST::TypeDecVariable)</a>
<div class="summary"><p>Link to the type declaration variables used in current scope</p></div>
</li>
<li class="entry-summary">
<a href="#type_definition%3F-instance-method" class="signature"><strong>#type_definition?</strong></a>
<div class="summary"><p>Returns <code>true</code> if and only if current scope represents some type definition, for example a class.</p></div>
</li>
<li class="entry-summary">
<a href="#variables%3AArray%28Ameba%3A%3AAST%3A%3AVariable%29-instance-method" class="signature"><strong>#variables</strong> : Array(Ameba::AST::Variable)</a>
<div class="summary"><p>Link to local variables</p></div>
</li>
<li class="entry-summary">
<a href="#visibility-instance-method" class="signature"><strong>#visibility</strong></a>
<div class="summary"><p>Returns visibility of the current scope (could be inherited from the outer scope).</p></div>
</li>
<li class="entry-summary">
<a href="#visibility%3D%28visibility%3ACrystal%3A%3AVisibility%7CNil%29-instance-method" class="signature"><strong>#visibility=</strong>(visibility : Crystal::Visibility | Nil)</a>
<div class="summary"><p>Scope visibility level</p></div>
</li>
<li class="entry-summary">
<a href="#yields%3D%28yields%3ABool%29-instance-method" class="signature"><strong>#yields=</strong>(yields : Bool)</a>
<div class="summary"><p>Whether the scope yields.</p></div>
</li>
<li class="entry-summary">
<a href="#yields%3F%28check_inner_scopes%3Dtrue%29-instance-method" class="signature"><strong>#yields?</strong>(check_inner_scopes = <span class="n">true</span>)</a>
<div class="summary"><p>Returns <code>true</code> if current scope (or any of inner scopes) yields, <code>false</code> otherwise.</p></div>
</li>
</ul>
<div class="methods-inherited">
</div>
<h2>
<a id="constructor-detail" class="anchor" href="#constructor-detail">
<svg class="octicon-link" aria-hidden="true">
<use href="#octicon-link"/>
</svg>
</a>
Constructor Detail
</h2>
<div class="entry-detail" id="new(node:Crystal::ASTNode,outer_scope:Nil|Ameba::AST::Scope=nil)-class-method">
<div class="signature">
def self.<strong>new</strong>(node : Crystal::ASTNode, outer_scope : Nil | <a href="../../Ameba/AST/Scope.html">Ameba::AST::Scope</a> = <span class="n">nil</span>)
<a class="method-permalink" href="#new%28node%3ACrystal%3A%3AASTNode%2Couter_scope%3ANil%7CAmeba%3A%3AAST%3A%3AScope%3Dnil%29-class-method">#</a>
</div>
<div class="doc">
<p>Creates a new scope. Accepts the AST node and the outer scope.</p>
<pre><code class="language-crystal">scope <span class="o">=</span> <span class="t">Scope</span>.new(class_node, <span class="n">nil</span>)</code></pre>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L48" target="_blank">View source</a>]
</div>
</div>
<h2>
<a id="instance-method-detail" class="anchor" href="#instance-method-detail">
<svg class="octicon-link" aria-hidden="true">
<use href="#octicon-link"/>
</svg>
</a>
Instance Method Detail
</h2>
<div class="entry-detail" id="==(other:self)-instance-method">
<div class="signature">
def <strong>==</strong>(other : <span class="k">self</span>)
<a class="method-permalink" href="#%3D%3D%28other%3Aself%29-instance-method">#</a>
</div>
<div class="doc">
<div class="doc-inherited">
Description copied from class Reference
</div>
<p>Returns <code>true</code> if this reference is the same as <em>other</em>. Invokes <code>same?</code>.</p>
</div>
<br/>
<div>
</div>
</div>
<div class="entry-detail" id="add_argument(node)-instance-method">
<div class="signature">
def <strong>add_argument</strong>(node)
<a class="method-permalink" href="#add_argument%28node%29-instance-method">#</a>
</div>
<div class="doc">
<p>Creates a new argument in the current scope.</p>
<pre><code class="language-crystal">scope <span class="o">=</span> <span class="t">Scope</span>.new(class_node, <span class="n">nil</span>)
scope.add_argument(arg_node)</code></pre>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L68" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="add_ivariable(node)-instance-method">
<div class="signature">
def <strong>add_ivariable</strong>(node)
<a class="method-permalink" href="#add_ivariable%28node%29-instance-method">#</a>
</div>
<div class="doc">
<p>Adds a new instance variable to the current scope.</p>
<pre><code class="language-crystal">scope <span class="o">=</span> <span class="t">Scope</span>.new(class_node, <span class="n">nil</span>)
scope.add_ivariable(ivar_node)</code></pre>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L79" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="add_type_dec_variable(node)-instance-method">
<div class="signature">
def <strong>add_type_dec_variable</strong>(node)
<a class="method-permalink" href="#add_type_dec_variable%28node%29-instance-method">#</a>
</div>
<div class="doc">
<p>Adds a new type declaration variable to the current scope.</p>
<pre><code class="language-crystal">scope <span class="o">=</span> <span class="t">Scope</span>.new(class_node, <span class="n">nil</span>)
scope.add_type_dec_variable(node)</code></pre>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L89" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="add_variable(node)-instance-method">
<div class="signature">
def <strong>add_variable</strong>(node)
<a class="method-permalink" href="#add_variable%28node%29-instance-method">#</a>
</div>
<div class="doc">
<p>Creates a new variable in the current scope.</p>
<pre><code class="language-crystal">scope <span class="o">=</span> <span class="t">Scope</span>.new(class_node, <span class="n">nil</span>)
scope.add_variable(var_node)</code></pre>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L58" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="arg?(var)-instance-method">
<div class="signature">
def <strong>arg?</strong>(var)
<a class="method-permalink" href="#arg%3F%28var%29-instance-method">#</a>
</div>
<div class="doc">
<p>Returns <code>true</code> if var is an argument in current scope, <code>false</code> otherwise.</p>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L195" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="arguments:Array(Ameba::AST::Argument)-instance-method">
<div class="signature">
def <strong>arguments</strong> : Array(<a href="../../Ameba/AST/Argument.html">Ameba::AST::Argument</a>)
<a class="method-permalink" href="#arguments%3AArray%28Ameba%3A%3AAST%3A%3AArgument%29-instance-method">#</a>
</div>
<div class="doc">
<p>Link to the arguments in current scope</p>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L20" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="assign_variable(name,node)-instance-method">
<div class="signature">
def <strong>assign_variable</strong>(name, node)
<a class="method-permalink" href="#assign_variable%28name%2Cnode%29-instance-method">#</a>
</div>
<div class="doc">
<p>Creates a new assignment for the variable.</p>
<pre><code class="language-crystal">scope <span class="o">=</span> <span class="t">Scope</span>.new(class_node, <span class="n">nil</span>)
scope.assign_variable(var_name, assign_node)</code></pre>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L110" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="assigns_ivar?(name)-instance-method">
<div class="signature">
def <strong>assigns_ivar?</strong>(name)
<a class="method-permalink" href="#assigns_ivar%3F%28name%29-instance-method">#</a>
</div>
<div class="doc">
<p>Returns <code>true</code> if instance variable is assigned in this scope.</p>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L141" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="assigns_type_dec?(name)-instance-method">
<div class="signature">
def <strong>assigns_type_dec?</strong>(name)
<a class="method-permalink" href="#assigns_type_dec%3F%28name%29-instance-method">#</a>
</div>
<div class="doc">
<p>Returns <code>true</code> if type declaration variable is assigned in this scope.</p>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L147" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="block?-instance-method">
<div class="signature">
def <strong>block?</strong>
<a class="method-permalink" href="#block%3F-instance-method">#</a>
</div>
<div class="doc">
<p>Returns <code>true</code> if current scope represents a block (or proc),
<code>false</code> otherwise.</p>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L116" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="def?-instance-method">
<div class="signature">
def <strong>def?</strong>
<a class="method-permalink" href="#def%3F-instance-method">#</a>
</div>
<div class="doc">
<p>Returns <code>true</code> if current scope is a def, <code>false</code> otherwise.</p>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L185" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="end_location(*args,**options)-instance-method">
<div class="signature">
def <strong>end_location</strong>(*args, **options)
<a class="method-permalink" href="#end_location%28%2Aargs%2C%2A%2Aoptions%29-instance-method">#</a>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L39" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="end_location(*args,**options,&amp;)-instance-method">
<div class="signature">
def <strong>end_location</strong>(*args, **options, &)
<a class="method-permalink" href="#end_location%28%2Aargs%2C%2A%2Aoptions%2C%26%29-instance-method">#</a>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L39" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="eql?(node)-instance-method">
<div class="signature">
def <strong>eql?</strong>(node)
<a class="method-permalink" href="#eql%3F%28node%29-instance-method">#</a>
</div>
<div class="doc">
<p>Returns <code>true</code> if the <em>node</em> represents exactly
the same Crystal node as <code>@node</code>.</p>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L214" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="find_variable(name:String)-instance-method">
<div class="signature">
def <strong>find_variable</strong>(name : String)
<a class="method-permalink" href="#find_variable%28name%3AString%29-instance-method">#</a>
</div>
<div class="doc">
<p>Returns variable by its name or <code>nil</code> if it does not exist.</p>
<pre><code class="language-crystal">scope <span class="o">=</span> <span class="t">Scope</span>.new(class_node, <span class="n">nil</span>)
scope.find_variable(<span class="s">&quot;foo&quot;</span>)</code></pre>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L99" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="hash(hasher)-instance-method">
<div class="signature">
def <strong>hash</strong>(hasher)
<a class="method-permalink" href="#hash%28hasher%29-instance-method">#</a>
</div>
<div class="doc">
<div class="doc-inherited">
Description copied from class Reference
</div>
<p>See <code>Object#hash(hasher)</code></p>
</div>
<br/>
<div>
</div>
</div>
<div class="entry-detail" id="in_macro?-instance-method">
<div class="signature">
def <strong>in_macro?</strong>
<a class="method-permalink" href="#in_macro%3F-instance-method">#</a>
</div>
<div class="doc">
<p>Returns <code>true</code> if current scope sits inside a macro.</p>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L133" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="inner_scopes:Array(Ameba::AST::Scope)-instance-method">
<div class="signature">
def <strong>inner_scopes</strong> : Array(<a href="../../Ameba/AST/Scope.html">Ameba::AST::Scope</a>)
<a class="method-permalink" href="#inner_scopes%3AArray%28Ameba%3A%3AAST%3A%3AScope%29-instance-method">#</a>
</div>
<div class="doc">
<p>List of inner scopes</p>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L32" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="ivariables:Array(Ameba::AST::InstanceVariable)-instance-method">
<div class="signature">
def <strong>ivariables</strong> : Array(<a href="../../Ameba/AST/InstanceVariable.html">Ameba::AST::InstanceVariable</a>)
<a class="method-permalink" href="#ivariables%3AArray%28Ameba%3A%3AAST%3A%3AInstanceVariable%29-instance-method">#</a>
</div>
<div class="doc">
<p>Link to the instance variables used in current scope</p>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L23" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="location(*args,**options)-instance-method">
<div class="signature">
def <strong>location</strong>(*args, **options)
<a class="method-permalink" href="#location%28%2Aargs%2C%2A%2Aoptions%29-instance-method">#</a>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L38" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="location(*args,**options,&amp;)-instance-method">
<div class="signature">
def <strong>location</strong>(*args, **options, &)
<a class="method-permalink" href="#location%28%2Aargs%2C%2A%2Aoptions%2C%26%29-instance-method">#</a>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L38" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="node:Crystal::ASTNode-instance-method">
<div class="signature">
def <strong>node</strong> : Crystal::ASTNode
<a class="method-permalink" href="#node%3ACrystal%3A%3AASTNode-instance-method">#</a>
</div>
<div class="doc">
<p>The actual AST node that represents a current scope.</p>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L35" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="outer_scope:Scope|Nil-instance-method">
<div class="signature">
def <strong>outer_scope</strong> : <a href="../../Ameba/AST/Scope.html">Scope</a> | Nil
<a class="method-permalink" href="#outer_scope%3AScope%7CNil-instance-method">#</a>
</div>
<div class="doc">
<p>Link to the outer scope</p>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L29" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="references:Array(Ameba::AST::Reference)-instance-method">
<div class="signature">
def <strong>references</strong> : Array(<a href="../../Ameba/AST/Reference.html">Ameba::AST::Reference</a>)
<a class="method-permalink" href="#references%3AArray%28Ameba%3A%3AAST%3A%3AReference%29-instance-method">#</a>
</div>
<div class="doc">
<p>Link to all variable references in currency scope</p>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L17" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="references?(variable:Variable,check_inner_scopes=true)-instance-method">
<div class="signature">
def <strong>references?</strong>(variable : <a href="../../Ameba/AST/Variable.html">Variable</a>, check_inner_scopes = <span class="n">true</span>)
<a class="method-permalink" href="#references%3F%28variable%3AVariable%2Ccheck_inner_scopes%3Dtrue%29-instance-method">#</a>
</div>
<div class="doc">
<p>Returns <code>true</code> if current scope (or any of inner scopes) references variable,
<code>false</code> otherwise.</p>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L166" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="spawn_block?-instance-method">
<div class="signature">
def <strong>spawn_block?</strong>
<a class="method-permalink" href="#spawn_block%3F-instance-method">#</a>
</div>
<div class="doc">
<p>Returns <code>true</code> if current scope represents a spawn block, e. g.</p>
<pre><code class="language-crystal">spawn <span class="k">do</span>
<span class="c"># ...</span>
<span class="k">end</span></code></pre>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L128" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="to_s(*args,**options)-instance-method">
<div class="signature">
def <strong>to_s</strong>(*args, **options)
<a class="method-permalink" href="#to_s%28%2Aargs%2C%2A%2Aoptions%29-instance-method">#</a>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L37" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="to_s(*args,**options,&amp;)-instance-method">
<div class="signature">
def <strong>to_s</strong>(*args, **options, &)
<a class="method-permalink" href="#to_s%28%2Aargs%2C%2A%2Aoptions%2C%26%29-instance-method">#</a>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L37" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="top_level?-instance-method">
<div class="signature">
def <strong>top_level?</strong>
<a class="method-permalink" href="#top_level%3F-instance-method">#</a>
</div>
<div class="doc">
<p>Returns <code>true</code> if this scope is a top level scope, <code>false</code> otherwise.</p>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L190" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="type_dec_variables:Array(Ameba::AST::TypeDecVariable)-instance-method">
<div class="signature">
def <strong>type_dec_variables</strong> : Array(<a href="../../Ameba/AST/TypeDecVariable.html">Ameba::AST::TypeDecVariable</a>)
<a class="method-permalink" href="#type_dec_variables%3AArray%28Ameba%3A%3AAST%3A%3ATypeDecVariable%29-instance-method">#</a>
</div>
<div class="doc">
<p>Link to the type declaration variables used in current scope</p>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L26" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="type_definition?-instance-method">
<div class="signature">
def <strong>type_definition?</strong>
<a class="method-permalink" href="#type_definition%3F-instance-method">#</a>
</div>
<div class="doc">
<p>Returns <code>true</code> if and only if current scope represents some
type definition, for example a class.</p>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L154" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="variables:Array(Ameba::AST::Variable)-instance-method">
<div class="signature">
def <strong>variables</strong> : Array(<a href="../../Ameba/AST/Variable.html">Ameba::AST::Variable</a>)
<a class="method-permalink" href="#variables%3AArray%28Ameba%3A%3AAST%3A%3AVariable%29-instance-method">#</a>
</div>
<div class="doc">
<p>Link to local variables</p>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L14" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="visibility-instance-method">
<div class="signature">
def <strong>visibility</strong>
<a class="method-permalink" href="#visibility-instance-method">#</a>
</div>
<div class="doc">
<p>Returns visibility of the current scope (could be inherited from the outer scope).</p>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L180" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="visibility=(visibility:Crystal::Visibility|Nil)-instance-method">
<div class="signature">
def <strong>visibility=</strong>(visibility : Crystal::Visibility | Nil)
<a class="method-permalink" href="#visibility%3D%28visibility%3ACrystal%3A%3AVisibility%7CNil%29-instance-method">#</a>
</div>
<div class="doc">
<p>Scope visibility level</p>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L11" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="yields=(yields:Bool)-instance-method">
<div class="signature">
def <strong>yields=</strong>(yields : Bool)
<a class="method-permalink" href="#yields%3D%28yields%3ABool%29-instance-method">#</a>
</div>
<div class="doc">
<p>Whether the scope yields.</p>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L8" target="_blank">View source</a>]
</div>
</div>
<div class="entry-detail" id="yields?(check_inner_scopes=true)-instance-method">
<div class="signature">
def <strong>yields?</strong>(check_inner_scopes = <span class="n">true</span>)
<a class="method-permalink" href="#yields%3F%28check_inner_scopes%3Dtrue%29-instance-method">#</a>
</div>
<div class="doc">
<p>Returns <code>true</code> if current scope (or any of inner scopes) yields,
<code>false</code> otherwise.</p>
</div>
<br/>
<div>
[<a href="https://github.com/crystal-ameba/ameba/blob/5cff760/src/ameba/ast/scope.cr#L175" target="_blank">View source</a>]
</div>
</div>
</div>
</body>
</html>