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 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 module_names
def module_names ast_node_children = children.select do |child| child.is_a?(Parser::AST::Node) end children_modules = ast_node_children.flat_map(&:module_names) if MODULE_TYPES.include?(type) module_names_with_children children_modules else children_modules end end
def module_names_with_children(children_modules)
def module_names_with_children(children_modules) if children_modules.empty? [module_name] else children_modules.map do |children_module| "#{module_name}::#{children_module}" end end end
def recursive_children(&block)
def recursive_children(&block) children.each do |child| next unless child.is_a?(Parser::AST::Node) yield child child.recursive_children(&block) end end