Class: Solargraph::Parser::ParserGem::NodeProcessors::SclassNode

Inherits:
NodeProcessor::Base show all
Defined in:
lib/solargraph/parser/parser_gem/node_processors/sclass_node.rb

Instance Attribute Summary

Attributes inherited from NodeProcessor::Base

#locals, #node, #pins, #region

Instance Method Summary collapse

Methods inherited from NodeProcessor::Base

#initialize

Constructor Details

This class inherits a constructor from Solargraph::Parser::NodeProcessor::Base

Instance Method Details

#processObject



8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
# File 'lib/solargraph/parser/parser_gem/node_processors/sclass_node.rb', line 8

def process
  sclass = node.children[0]
  # @todo Changing Parser::AST::Node to AST::Node below will

  #   cause type errors at strong level because the combined

  #   pin for AST::Node#children has return type

  #   "Array<AST::Node>, Array".  YARD annotations in AST

  #   provided the Array, RBS for Array<AST::Node>.  We

  #   should probably have a rule to combine "A, A<T>""

  #   types to "A<T>" if the "A" comes from YARD, with the

  #   rationale that folks tend to be less formal with types in

  #   YARD.

  if sclass.is_a?(::Parser::AST::Node) && sclass.type == :self
    closure = region.closure
  elsif sclass.is_a?(::Parser::AST::Node) && sclass.type == :casgn
    names = [region.closure.namespace, region.closure.name]
    if sclass.children[0].nil? && names.last != sclass.children[1].to_s
      names << sclass.children[1].to_s
    else
      names.concat [NodeMethods.unpack_name(sclass.children[0]), sclass.children[1].to_s]
    end
    name = names.reject(&:empty?).join('::')
    closure = Solargraph::Pin::Namespace.new(name: name, location: region.closure.location, source: :parser)
  elsif sclass.is_a?(::Parser::AST::Node) && sclass.type == :const
    names = [region.closure.namespace, region.closure.name]
    also = NodeMethods.unpack_name(sclass)
    if also != region.closure.name
      names << also
    end
    name = names.reject(&:empty?).join('::')
    closure = Solargraph::Pin::Namespace.new(name: name, location: region.closure.location, source: :parser)
  else
    return
  end
  pins.push Solargraph::Pin::Singleton.new(
    location: get_node_location(node),
    closure: closure,
    source: :parser,
  )
  process_children region.update(visibility: :public, scope: :class, closure: pins.last)
end