class Ameba::AST::FlowExpression

Overview

Represents a flow expression in Crystal code. For example,

def foobar
  a = 3
  return 42 # => flow expression
  a + 1
end

Flow expression contains an actual node of a control expression and a parent node, which allows easily search through the related statement (i.e. find unreachable code)

Included Modules

Defined in:

Constructors

Instance Method Summary

Instance methods inherited from module Ameba::AST::Util

abort?(node) abort?, exit?(node) exit?, flow_command?(node, in_loop) flow_command?, flow_expression?(node, in_loop = false) flow_expression?, literal?(node) literal?, loop?(node) loop?, node_source(node, code_lines) node_source, raise?(node) raise?

Constructor Detail

def self.new(node, in_loop) #

Creates a new flow expression.

FlowExpression.new(node, parent_node)

Instance Method Detail

def end_location(*args, **options) #

def end_location(*args, **options, &) #

def in_loop? : Bool #

Is true only if some of the nodes parents is a loop.


def location(*args, **options) #

def location(*args, **options, &) #

def node : Crystal::ASTNode #

The actual node of the flow expression.


def to_s(*args, **options) #

def to_s(*args, **options, &) #

def unreachable_nodes #

Returns nodes which can't be reached because of a flow command inside. For example:

def foobar
  a = 1
  return 42

  a + 2 # => unreachable assign node
end