Class: Prism::MagicComment

Inherits:
Object
  • Object
show all
Defined in:
lib/prism/parse_result.rb,
ext/prism/extension.c

Overview

This represents a magic comment that was encountered during parsing.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(key_loc, value_loc) ⇒ MagicComment

Create a new magic comment object with the given key and value locations.



565
566
567
568
# File 'lib/prism/parse_result.rb', line 565

def initialize(key_loc, value_loc)
  @key_loc = key_loc
  @value_loc = value_loc
end

Instance Attribute Details

#key_locObject (readonly)

A Location object representing the location of the key in the source.



559
560
561
# File 'lib/prism/parse_result.rb', line 559

def key_loc
  @key_loc
end

#value_locObject (readonly)

A Location object representing the location of the value in the source.



562
563
564
# File 'lib/prism/parse_result.rb', line 562

def value_loc
  @value_loc
end

Instance Method Details

#deconstruct_keys(keys) ⇒ Object

Implement the hash pattern matching interface for MagicComment.



581
582
583
# File 'lib/prism/parse_result.rb', line 581

def deconstruct_keys(keys)
  { key_loc: key_loc, value_loc: value_loc }
end

#inspectObject

Returns a string representation of this magic comment.



586
587
588
# File 'lib/prism/parse_result.rb', line 586

def inspect
  "#<Prism::MagicComment @key=#{key.inspect} @value=#{value.inspect}>"
end

#keyObject

Returns the key of the magic comment by slicing it from the source code.



571
572
573
# File 'lib/prism/parse_result.rb', line 571

def key
  key_loc.slice
end

#valueObject

Returns the value of the magic comment by slicing it from the source code.



576
577
578
# File 'lib/prism/parse_result.rb', line 576

def value
  value_loc.slice
end