class Parser::AST::Node

def count_nodes_of_type(*types)

def count_nodes_of_type(*types)
  count = 0
  recursive_children do |child|
    count += 1 if types.include?(child.type)
  end
  count
end

def get_module_names

def get_module_names
  children_modules = children
    .select { |child| child.is_a?(Parser::AST::Node) }
    .flat_map(&:get_module_names)
  if MODULE_TYPES.include?(type)
    if children_modules.empty?
      [module_name]
    else
      children_modules.map do |children_module|
        "#{module_name}::#{children_module}"
      end
    end
  else
    children_modules
  end
end

def module_name

def module_name
  name_segments = []
  current_node = children[0]
  while current_node
    name_segments.unshift(current_node.children[1])
    current_node = current_node.children[0]
  end
  name_segments.join("::")
end

def recursive_children

def recursive_children
  children.each do |child|
    next unless child.is_a?(Parser::AST::Node)
    yield child
    child.recursive_children { |grand_child| yield grand_child }
  end
end