类 RubyVM::AbstractSyntaxTree::Node

RubyVM::AbstractSyntaxTree::Node 的实例由 RubyVM::AbstractSyntaxTree 中的解析方法创建。

这个类是 MRI 特定的。

公共实例方法

all_tokens → 数组 点击以切换源代码

返回输入脚本的所有标记,与接收器节点无关。如果在调用解析方法时未启用 keep_tokens,则返回 nil

root = RubyVM::AbstractSyntaxTree.parse("x = 1 + 2", keep_tokens: true)
root.all_tokens # => [[0, :tIDENTIFIER, "x", [1, 0, 1, 1]], [1, :tSP, " ", [1, 1, 1, 2]], ...]
root.children[-1].all_tokens # => [[0, :tIDENTIFIER, "x", [1, 0, 1, 1]], [1, :tSP, " ", [1, 1, 1, 2]], ...]
# File ruby_3_4_1/ast.rb, line 205
def all_tokens
  Primitive.ast_node_all_tokens
end
children → 数组 点击以切换源代码

返回此节点下的 AST 节点。每种节点都有不同的子节点,具体取决于它是哪种节点。

返回的数组可能包含其他节点或 nil

# File ruby_3_4_1/ast.rb, line 216
def children
  Primitive.ast_node_children
end
first_column → 整数 点击以切换源代码

此 AST 的文本在源代码中开始的列号。

# File ruby_3_4_1/ast.rb, line 148
def first_column
  Primitive.ast_node_first_column
end
first_lineno → 整数 点击以切换源代码

此 AST 的文本在源代码中开始的行号。

# File ruby_3_4_1/ast.rb, line 140
def first_lineno
  Primitive.ast_node_first_lineno
end
inspect → 字符串 点击以切换源代码

返回关于此节点的调试信息,以字符串形式表示。

# File ruby_3_4_1/ast.rb, line 224
def inspect
  Primitive.ast_node_inspect
end
last_column → 整数 点击以切换源代码

此 AST 的文本在源代码中结束的列号。

# File ruby_3_4_1/ast.rb, line 164
def last_column
  Primitive.ast_node_last_column
end
last_lineno → 整数 点击以切换源代码

此 AST 的文本在源代码中结束的行号。

# File ruby_3_4_1/ast.rb, line 156
def last_lineno
  Primitive.ast_node_last_lineno
end
locations → 数组 点击以切换源代码

返回与 AST 节点关联的位置对象。返回的数组包含 RubyVM::AbstractSyntaxTree::Location

# File ruby_3_4_1/ast.rb, line 280
def locations
  Primitive.ast_node_locations
end
node_id → 整数 点击以切换源代码

返回内部 node_id 编号。请注意,这是用于 ruby 内部使用、调试和研究的 API。请勿将其用于任何其他目的。兼容性无法保证。

# File ruby_3_4_1/ast.rb, line 235
def node_id
  Primitive.ast_node_node_id
end
script_lines → 数组 点击以切换源代码

将原始源代码作为行数组返回。

请注意,这是用于 ruby 内部使用、调试和研究的 API。请勿将其用于任何其他目的。兼容性无法保证。

# File ruby_3_4_1/ast.rb, line 247
def script_lines
  Primitive.ast_node_script_lines
end
source → 字符串 点击以切换源代码

返回与此 AST 相对应的代码片段。

请注意,这是用于 ruby 内部使用、调试和研究的 API。请勿将其用于任何其他目的。兼容性无法保证。

另请注意,此 API 可能会返回不完整的代码片段,该代码片段无法解析;例如,表达式后面的 here 文档可能会被删除。

# File ruby_3_4_1/ast.rb, line 263
def source
  lines = script_lines
  if lines
    lines = lines[first_lineno - 1 .. last_lineno - 1]
    lines[-1] = lines[-1].byteslice(0...last_column)
    lines[0] = lines[0].byteslice(first_column..-1)
    lines.join
  else
    nil
  end
end
tokens → 数组 点击以切换源代码

返回与节点位置对应的标记。如果在调用解析方法时未启用 keep_tokens,则返回 nil

root = RubyVM::AbstractSyntaxTree.parse("x = 1 + 2", keep_tokens: true)
root.tokens # => [[0, :tIDENTIFIER, "x", [1, 0, 1, 1]], [1, :tSP, " ", [1, 1, 1, 2]], ...]
root.tokens.map{_1[2]}.join # => "x = 1 + 2"

标记是一个数组,包含:

# File ruby_3_4_1/ast.rb, line 184
def tokens
  return nil unless all_tokens

  all_tokens.each_with_object([]) do |token, a|
    loc = token.last
    if ([first_lineno, first_column] <=> [loc[0], loc[1]]) <= 0 &&
       ([last_lineno, last_column]   <=> [loc[2], loc[3]]) >= 0
       a << token
    end
  end
end
type → 符号 点击以切换源代码

以符号形式返回此节点的类型。

root = RubyVM::AbstractSyntaxTree.parse("x = 1 + 2")
root.type # => :SCOPE
lasgn = root.children[2]
lasgn.type # => :LASGN
call = lasgn.children[1]
call.type # => :OPCALL
# File ruby_3_4_1/ast.rb, line 132
def type
  Primitive.ast_node_type
end