Class: RBS::Environment::MultiEntry

Inherits:
Object
  • Object
show all
Defined in:
lib/rbs/environment.rb

Direct Known Subclasses

ClassEntry, ModuleEntry

Constant Summary collapse

D =
_ = Struct.new(:decl, :outer, keyword_init: true) do
  # @implements D[M]

  include ContextUtil

  def context
    @context ||= calculate_context(outer + [decl])
  end
end

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(name:) ⇒ MultiEntry

Returns a new instance of MultiEntry.

[View source]

43
44
45
46
# File 'lib/rbs/environment.rb', line 43

def initialize(name:)
  @name = name
  @decls = []
end

Instance Attribute Details

#declsObject (readonly)

Returns the value of attribute decls.


41
42
43
# File 'lib/rbs/environment.rb', line 41

def decls
  @decls
end

#nameObject (readonly)

Returns the value of attribute name.


40
41
42
# File 'lib/rbs/environment.rb', line 40

def name
  @name
end

Instance Method Details

#compatible_params?(ps1, ps2) ⇒ Boolean

Returns:

  • (Boolean)
[View source]

70
71
72
73
74
# File 'lib/rbs/environment.rb', line 70

def compatible_params?(ps1, ps2)
  if ps1.size == ps2.size
    ps1 == AST::TypeParam.rename(ps2, new_names: ps1.map(&:name))
  end
end

#insert(decl:, outer:) ⇒ Object

[View source]

48
49
50
51
# File 'lib/rbs/environment.rb', line 48

def insert(decl:, outer:)
  decls << D.new(decl: decl, outer: outer)
  @primary = nil
end

#primaryObject

[View source]

80
81
82
# File 'lib/rbs/environment.rb', line 80

def primary
  raise "Not implemented"
end

#type_paramsObject

[View source]

76
77
78
# File 'lib/rbs/environment.rb', line 76

def type_params
  primary.decl.type_params
end

#validate_type_paramsObject

[View source]

53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
# File 'lib/rbs/environment.rb', line 53

def validate_type_params
  unless decls.empty?
    hd_decl, *tl_decls = decls
    raise unless hd_decl

    hd_params = hd_decl.decl.type_params

    tl_decls.each do |tl_decl|
      tl_params = tl_decl.decl.type_params

      unless compatible_params?(hd_params, tl_params)
        raise GenericParameterMismatchError.new(name: name, decl: _ = tl_decl.decl)
      end
    end
  end
end