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