class IDL::AST::TemplateModuleReference

def initialize(_name, _enclosure, _params)

def initialize(_name, _enclosure, _params)
  super(_name, _enclosure)
  unless _params[:tpl_type].is_a?(IDL::Type::ScopedName) && _params[:tpl_type].is_node?(IDL::AST::TemplateModule)
    raise "templated module reference type required for #{typename} #{scoped_lm_name}: got #{_params[:tpl_type].typename}"
  end
  @template = _params[:tpl_type].resolved_type.node
  _params[:tpl_params].each do |p|
    unless (p.is_a?(IDL::Type::ScopedName) || p.is_a?(IDL::Expression::ScopedName)) && p.is_node?(IDL::AST::TemplateParam)
      raise "invalid template module parameter for template module reference #{typename} #{scoped_lm_name}: #{p.typename}"
    end
  end
  @params = _params[:tpl_params].collect { |p| p.resolved_node }
end

def instantiate(instantiation_context, _enclosure)

def instantiate(instantiation_context, _enclosure)
  inst_params = @params.collect do |tp|
    # concrete objects are either Expression or Type
    tp.concrete
  end
  mod_inst = IDL::AST::Module.new(self.name, _enclosure, { template: @template, template_params: inst_params })
  @template.instantiate(mod_inst, instantiation_context)
  mod_inst
end

def marshal_dump

def marshal_dump
  super() << @template << @params
end

def marshal_load(vars)

def marshal_load(vars)
  @params = vars.pop
  @template = vars.pop
  super(vars)
end

def resolve(_name)

def resolve(_name)
  @template.resolve(_name)
end