Class: TreeHaver::Backends::Prism::Node Private

Inherits:
TreeHaver::Base::Node show all
Defined in:
lib/tree_haver/backends/prism.rb

Overview

This class is part of a private API. You should avoid using this class if possible, as it may be removed or be changed in the future.

Prism node wrapper

Wraps Prism::Node objects to provide tree-sitter-compatible node API.

Prism nodes provide:

  • type: class name without “Node” suffix (e.g., ProgramNode → “program”)
  • location: ::Prism::Location with start/end offsets and line/column
  • child_nodes: array of child nodes
  • Various node-specific accessors

Instance Attribute Summary

Attributes inherited from TreeHaver::Base::Node

#inner_node, #lines, #source

Instance Method Summary collapse

Methods inherited from TreeHaver::Base::Node

#<=>, #==, #child, #child_count, #each, #end_line, #first_child, #inspect, #last_child, #named?, #next_sibling, #parent, #prev_sibling, #source_position, #start_line

Constructor Details

#initialize(node, source) ⇒ Node

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Returns a new instance of Node.



297
298
299
# File 'lib/tree_haver/backends/prism.rb', line 297

def initialize(node, source)
  super(node, source: source)
end

Dynamic Method Handling

This class handles dynamic methods through the method_missing method

#method_missing(method_name, *args, **kwargs, &block) ⇒ Object

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Delegate unknown methods to the underlying Prism node

This provides passthrough access for Prism-specific node methods
like receiver, message, arguments, etc.

Parameters:

  • method_name (Symbol)

    method to call

  • args (Array)

    arguments to pass

  • kwargs (Hash)

    keyword arguments

  • block (Proc)

    block to pass

Returns:

  • (Object)

    result from the underlying node



455
456
457
458
459
460
461
# File 'lib/tree_haver/backends/prism.rb', line 455

def method_missing(method_name, *args, **kwargs, &block)
  if inner_node&.respond_to?(method_name)
    inner_node.public_send(method_name, *args, **kwargs, &block)
  else
    super
  end
end

Instance Method Details

#child_by_field_name(name) ⇒ Node? Also known as: field

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Get a child by field name (Prism node accessor)

Prism nodes have specific accessors for their children.

Parameters:

  • name (String, Symbol)

    field/accessor name

Returns:

  • (Node, nil)

    wrapped child node



415
416
417
418
419
420
421
422
423
424
# File 'lib/tree_haver/backends/prism.rb', line 415

def child_by_field_name(name)
  return if inner_node.nil?
  return unless inner_node.respond_to?(name)

  result = inner_node.public_send(name)
  return if result.nil?

  # Wrap if it's a node
  result.is_a?(::Prism::Node) ? Node.new(result, source) : nil
end

#childrenArray<Node>

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Get all child nodes

Returns:

  • (Array<Node>)

    array of wrapped child nodes



364
365
366
367
368
369
# File 'lib/tree_haver/backends/prism.rb', line 364

def children
  return [] if inner_node.nil?
  return [] unless inner_node.respond_to?(:child_nodes)

  inner_node.child_nodes.compact.map { |n| Node.new(n, source) }
end

#end_byteInteger

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Get byte offset where the node ends

Returns:

  • (Integer)


333
334
335
336
337
# File 'lib/tree_haver/backends/prism.rb', line 333

def end_byte
  return 0 if inner_node.nil? || !inner_node.respond_to?(:location)
  loc = inner_node.location
  loc&.end_offset || 0
end

#end_pointHash{Symbol => Integer}

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Get the end position as row/column (0-based)

Returns:

  • (Hash{Symbol => Integer})


353
354
355
356
357
358
359
# File 'lib/tree_haver/backends/prism.rb', line 353

def end_point
  return {row: 0, column: 0} if inner_node.nil? || !inner_node.respond_to?(:location)
  loc = inner_node.location
  return {row: 0, column: 0} unless loc

  {row: (loc.end_line - 1), column: loc.end_column}
end

#has_error?Boolean

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Check if this node has errors

Returns:

  • (Boolean)


390
391
392
393
394
395
396
397
398
399
# File 'lib/tree_haver/backends/prism.rb', line 390

def has_error?
  return false if inner_node.nil?

  # Check if this is an error node type
  return true if type.include?("missing") || type.include?("error")

  # Check children recursively (Prism error nodes are usually children)
  return false unless inner_node.respond_to?(:child_nodes)
  inner_node.child_nodes.compact.any? { |n| n.class.name.to_s.include?("Missing") }
end

#kindString

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Alias for type (API compatibility)

Returns:

  • (String)

    node type



317
318
319
# File 'lib/tree_haver/backends/prism.rb', line 317

def kind
  type
end

#missing?Boolean

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Check if this node is a “missing” node (error recovery)

Returns:

  • (Boolean)


404
405
406
407
# File 'lib/tree_haver/backends/prism.rb', line 404

def missing?
  return false if inner_node.nil?
  type.include?("missing")
end

#respond_to_missing?(method_name, include_private = false) ⇒ Boolean

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Check if node responds to a method (includes delegation to inner_node)

Parameters:

  • method_name (Symbol)

    method to check

  • include_private (Boolean) (defaults to: false)

    include private methods

Returns:

  • (Boolean)


440
441
442
443
# File 'lib/tree_haver/backends/prism.rb', line 440

def respond_to_missing?(method_name, include_private = false)
  return false if inner_node.nil?
  inner_node.respond_to?(method_name, include_private) || super
end

#start_byteInteger

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Get byte offset where the node starts

Returns:

  • (Integer)


324
325
326
327
328
# File 'lib/tree_haver/backends/prism.rb', line 324

def start_byte
  return 0 if inner_node.nil? || !inner_node.respond_to?(:location)
  loc = inner_node.location
  loc&.start_offset || 0
end

#start_pointHash{Symbol => Integer}

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Get the start position as row/column (0-based)

Returns:

  • (Hash{Symbol => Integer})


342
343
344
345
346
347
348
# File 'lib/tree_haver/backends/prism.rb', line 342

def start_point
  return {row: 0, column: 0} if inner_node.nil? || !inner_node.respond_to?(:location)
  loc = inner_node.location
  return {row: 0, column: 0} unless loc

  {row: (loc.start_line - 1), column: loc.start_column}
end

#textString Also known as: slice

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Get the text content of this node

Returns:

  • (String)


374
375
376
377
378
379
380
381
382
# File 'lib/tree_haver/backends/prism.rb', line 374

def text
  return "" if inner_node.nil?

  if inner_node.respond_to?(:slice)
    inner_node.slice
  else
    super
  end
end

#to_sString

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

String representation

Returns:

  • (String)


431
432
433
# File 'lib/tree_haver/backends/prism.rb', line 431

def to_s
  text
end

#typeString

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Get node type from Prism class name

Converts PrismClassName to tree-sitter-style type string.
Example: CallNode → “call_node”, ProgramNode → “program_node”

Returns:

  • (String)

    node type in snake_case



307
308
309
310
311
312
313
# File 'lib/tree_haver/backends/prism.rb', line 307

def type
  return "nil" if inner_node.nil?

  # Convert class name to snake_case type
  class_name = inner_node.class.name.split("::").last
  class_name.gsub(/([A-Z])/, '_\1').downcase.sub(/^_/, "")
end