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.



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

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.



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

def key_loc
  @key_loc
end

#value_locObject (readonly)

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



579
580
581
# File 'lib/prism/parse_result.rb', line 579

def value_loc
  @value_loc
end

Instance Method Details

#deconstruct_keys(keys) ⇒ Object

Implement the hash pattern matching interface for MagicComment.



598
599
600
# File 'lib/prism/parse_result.rb', line 598

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

#inspectObject

Returns a string representation of this magic comment.



603
604
605
# File 'lib/prism/parse_result.rb', line 603

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.



588
589
590
# File 'lib/prism/parse_result.rb', line 588

def key
  key_loc.slice
end

#valueObject

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



593
594
595
# File 'lib/prism/parse_result.rb', line 593

def value
  value_loc.slice
end