module Ameba::AST::Util
Overview
Utility module for Ameba's rules.
Direct including types
- Ameba::AST::Branchable
- Ameba::AST::FlowExpression
- Ameba::AST::FlowExpressionVisitor
- Ameba::Rule::Lint::AmbiguousAssignment
- Ameba::Rule::Lint::ComparisonToBoolean
- Ameba::Rule::Lint::EmptyExpression
- Ameba::Rule::Lint::EmptyLoop
- Ameba::Rule::Lint::LiteralInCondition
- Ameba::Rule::Lint::LiteralInInterpolation
- Ameba::Rule::Lint::RedundantStringCoercion
- Ameba::Rule::Lint::UnreachableCode
- Ameba::Rule::Metrics::CyclomaticComplexity
- Ameba::Rule::Performance::AnyInsteadOfEmpty
- Ameba::Rule::Performance::ChainedCallWithNoBang
- Ameba::Rule::Style::MethodNames
- Ameba::Rule::Style::RedundantBegin
- Ameba::Rule::Style::RedundantNext
- Ameba::Rule::Style::RedundantReturn
- Ameba::Rule::Style::VerboseBlock
Defined in:
ameba/ast/util.crInstance Method Summary
-
#abort?(node)
Returns true if node represents
abort
method call. -
#control_exp_code(node : Crystal::ControlExpression, code_lines)
Returns the exp code of a control expression.
-
#exit?(node)
Returns true if node represents
exit
method call. -
#flow_command?(node, in_loop)
Returns true if node is a flow command, false - otherwise.
-
#flow_expression?(node, in_loop = false)
Returns true if node is a flow expression, false if not.
-
#literal?(node)
Returns true if current
node
is a literal, false otherwise. -
#loop?(node)
Returns true if node represents a loop.
-
#name_end_location(node)
Returns
nil
if node does not contain a name. -
#name_location(node)
Returns
nil
if node does not contain a name. -
#name_size(node)
Returns zero if node does not contain a name.
-
#node_source(node, code_lines)
Returns a source code for the current node.
-
#raise?(node)
Returns true if node represents
raise
method call. -
#source_between(loc, end_loc, code_lines) : String?
Returns the source code from loc to end_loc (inclusive).
Instance Method Detail
Returns the exp code of a control expression. Wraps implicit tuple literal with curly brackets (e.g. multi-return).
Returns true if node is a flow command, false - otherwise. Node represents a flow command if it is a control expression, or special call node that interrupts execution (i.e. raise, exit, abort).
Returns true if node is a flow expression, false if not. Node represents a flow expression if it is full-filled by a flow command.
For example, this node is a flow expression, because each branch contains
a flow command return
:
if a > 0
return :positive
elsif a < 0
return :negative
else
return :zero
end
This node is a not a flow expression:
if a > 0
return :positive
end
That's because not all branches return(i.e. else
is missing).
Returns nil
if node does not contain a name.
NOTE Use this instead of Crystal::Call#name_end_location
to avoid an
off-by-one error.
Returns a source code for the current node.
This method uses node.location
and node.end_location
to determine and cut a piece of source of the node.
Returns the source code from loc to end_loc (inclusive).