class IDL::AST::Connector

def add_interfaces(intfs)

def add_interfaces(intfs)
  raise "interface support not allowed for #{typename} #{scoped_lm_name}" if intfs && !intfs.empty?
end

def attributes(include_bases = false, traversed = nil)

def attributes(include_bases = false, traversed = nil)
  atts = @children.inject([]) do |lst, c|
    if IDL::AST::Port === c
      lst.concat(c.attributes)
    else
      lst << c
    end
    lst
  end
  atts.concat(base_attributes(traversed || [])) if include_bases
  atts
end

def base_ports(traversed)

recursively collect ports from bases
def base_ports(traversed)
  traversed.push self
  ports = []
  if (base = @resolved_base)
    base = base.idltype.resolved_type.node if base.is_a?(IDL::AST::Typedef)
    ports = base.ports(true, traversed) unless traversed.include?(base)
  end
  ports
end

def initialize(_name, _enclosure, params)

def initialize(_name, _enclosure, params)
  @idltype = IDL::Type::Component.new(self)
  super(_name, _enclosure, params)
end

def instantiate(instantiation_context, _enclosure)

def instantiate(instantiation_context, _enclosure)
  # instantiate concrete connector def and validate
  super(instantiation_context, _enclosure, {})
end

def is_defined?

def is_defined?
  true
end

def is_forward?

def is_forward?
  false
end

def marshal_dump

def marshal_dump
  super()
end

def marshal_load(vars)

def marshal_load(vars)
  super(vars)
end

def ports(include_bases = false, traversed = nil)

def ports(include_bases = false, traversed = nil)
  ports = @children.inject([]) do |lst, c|
    lst.concat(c.ports) if IDL::AST::Port === c
    lst
  end
  ports.concat(base_ports(traversed || [])) if include_bases
  ports
end

def set_base(parent)

def set_base(parent)
  unless parent.is_a?(IDL::Type::ScopedName) && parent.is_node?(IDL::AST::TemplateParam)
    unless (parent.is_a?(IDL::Type::NodeType) && parent.is_node?(self.class))
      raise "invalid inheritance identifier for #{typename} #{scoped_lm_name}: #{parent.typename}"
    end
    @resolved_base = parent.resolved_type.node
    if @resolved_base.has_base?(self)
      raise "circular inheritance detected for #{typename} #{scoped_lm_name}: #{parent.node.scoped_lm_name} is descendant"
    end
  end
  @base = parent.node
end