Class: Solargraph::Source::Chain

Inherits:
Object
  • Object
show all
Defined in:
lib/solargraph/source/chain.rb,
lib/solargraph/source/chain/or.rb,
lib/solargraph/source/chain/call.rb,
lib/solargraph/source/chain/hash.rb,
lib/solargraph/source/chain/head.rb,
lib/solargraph/source/chain/link.rb,
lib/solargraph/source/chain/q_call.rb,
lib/solargraph/source/chain/literal.rb,
lib/solargraph/source/chain/z_super.rb,
lib/solargraph/source/chain/constant.rb,
lib/solargraph/source/chain/variable.rb,
lib/solargraph/source/chain/block_variable.rb,
lib/solargraph/source/chain/class_variable.rb,
lib/solargraph/source/chain/global_variable.rb,
lib/solargraph/source/chain/instance_variable.rb

Overview

A chain of constants, variables, and method calls for inferring types of values.

Defined Under Namespace

Classes: BlockVariable, Call, ClassVariable, Constant, GlobalVariable, Hash, Head, InstanceVariable, Link, Literal, Or, QCall, Variable, ZSuper

Constant Summary collapse

UNDEFINED_CALL =
Chain::Call.new('<undefined>')
UNDEFINED_CONSTANT =
Chain::Constant.new('<undefined>')
@@inference_stack =
[]
@@inference_depth =
0

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(links, node = nil, splat = false) ⇒ Chain

Returns a new instance of Chain.

Parameters:



39
40
41
42
43
44
45
46
47
48
49
50
# File 'lib/solargraph/source/chain.rb', line 39

def initialize links, node = nil, splat = false
  @links = links.clone
  @links.push UNDEFINED_CALL if @links.empty?
  head = true
  @links.map! do |link|
    result = (head ? link.clone_head : link.clone_body)
    head = false
    result
  end
  @node = node
  @splat = splat
end

Instance Attribute Details



34
35
36
# File 'lib/solargraph/source/chain.rb', line 34

def links
  @links
end

#nodeObject (readonly)

Returns the value of attribute node.



36
37
38
# File 'lib/solargraph/source/chain.rb', line 36

def node
  @node
end

Instance Method Details

#baseChain

Returns:



53
54
55
# File 'lib/solargraph/source/chain.rb', line 53

def base
  @base ||= Chain.new(links[0..-2])
end

#constant?Boolean

Returns:

  • (Boolean)


98
99
100
# File 'lib/solargraph/source/chain.rb', line 98

def constant?
  links.last.is_a?(Chain::Constant)
end

#define(api_map, name_pin, locals) ⇒ Array<Pin::Base>

Parameters:

Returns:



61
62
63
64
65
66
67
68
69
70
71
72
# File 'lib/solargraph/source/chain.rb', line 61

def define api_map, name_pin, locals
  return [] if undefined?
  working_pin = name_pin
  links[0..-2].each do |link|
    pins = link.resolve(api_map, working_pin, locals)
    type = infer_first_defined(pins, working_pin, api_map)
    return [] if type.undefined?
    working_pin = Pin::ProxyType.anonymous(type)
  end
  links.last.last_context = working_pin
  links.last.resolve(api_map, working_pin, locals)
end

#defined?Boolean

Returns:

  • (Boolean)


93
94
95
# File 'lib/solargraph/source/chain.rb', line 93

def defined?
  !undefined?
end

#infer(api_map, name_pin, locals) ⇒ ComplexType

Parameters:

Returns:



78
79
80
81
82
# File 'lib/solargraph/source/chain.rb', line 78

def infer api_map, name_pin, locals
  pins = define(api_map, name_pin, locals)
  type = infer_first_defined(pins, links.last.last_context, api_map)
  maybe_nil(type)
end

#literal?Boolean

Returns:

  • (Boolean)


85
86
87
# File 'lib/solargraph/source/chain.rb', line 85

def literal?
  links.last.is_a?(Chain::Literal)
end

#nullable?Boolean

Returns:

  • (Boolean)


106
107
108
# File 'lib/solargraph/source/chain.rb', line 106

def nullable?
  links.any?(&:nullable?)
end

#splat?Boolean

Returns:

  • (Boolean)


102
103
104
# File 'lib/solargraph/source/chain.rb', line 102

def splat?
  @splat
end

#undefined?Boolean

Returns:

  • (Boolean)


89
90
91
# File 'lib/solargraph/source/chain.rb', line 89

def undefined?
  links.any?(&:undefined?)
end