Exception: EBNF::LL1::Lexer::Error

Inherits:
StandardError
  • Object
show all
Defined in:
lib/ebnf/ll1/lexer.rb

Overview

Raised for errors during lexical analysis.

Examples:

Raising a lexer error

raise EBNF::LL1::Lexer::Error.new(
  "invalid token '%' on line 10",
  input: query, token: '%', lineno: 9)

See Also:

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(message, options = {}) ⇒ Error

Initializes a new lexer error instance.

Parameters:

  • message (String, #to_s)
  • options (Hash{Symbol => Object}) (defaults to: {})

Options Hash (options):

  • :input (String) — default: nil
  • :token (String) — default: nil
  • :lineno (Integer) — default: nil


517
518
519
520
521
522
# File 'lib/ebnf/ll1/lexer.rb', line 517

def initialize(message, options = {})
  @input  = options[:input]
  @token  = options[:token]
  @lineno = options[:lineno]
  super(message.to_s)
end

Instance Attribute Details

#inputString (readonly)

The input string associated with the error.

Returns:

  • (String)


495
496
497
# File 'lib/ebnf/ll1/lexer.rb', line 495

def input
  @input
end

#linenoInteger (readonly)

The line number where the error occurred.

Returns:

  • (Integer)


507
508
509
# File 'lib/ebnf/ll1/lexer.rb', line 507

def lineno
  @lineno
end

#tokenString (readonly)

The invalid token which triggered the error.

Returns:

  • (String)


501
502
503
# File 'lib/ebnf/ll1/lexer.rb', line 501

def token
  @token
end