Sha256: 1402b4a740467cd6078b9a787fc05e3d65706d05ca03b0fbbae8719d2da5581e
Contents?: true
Size: 1.27 KB
Versions: 25
Compression:
Stored size: 1.27 KB
Contents
module Parser module Lexer::Explanation def self.included(klass) klass.class_exec do alias_method :state_before_explanation=, :state= alias_method :advance_before_explanation, :advance remove_method :state=, :advance end end # Like #advance, but also pretty-print the token and its position # in the stream to `stdout`. def advance type, (val, range) = advance_before_explanation puts decorate(range, "\e[0;32m#{type} #{val.inspect}\e[0m", "#{state.to_s.ljust(12)} #{@cond} #{@cmdarg}\e[0m") [ type, [val, range] ] end def state=(new_state) puts " \e[1;33m>>> STATE SET <<<\e[0m " + "#{new_state.to_s.ljust(12)} #{@cond} #{@cmdarg}".rjust(66) self.state_before_explanation = new_state end private def decorate(range, token, info) from, to = range.begin.column, range.end.column line = range.source_line + ' ' line[from...to] = "\e[4m#{line[from...to]}\e[0m" tail_len = to - from - 1 tail = '~' * (tail_len >= 0 ? tail_len : 0) decoration = "#{" " * from}\e[1;31m^#{tail}\e[0m #{token} ". ljust(70) + info [ line, decoration ] end end end
Version data entries
25 entries across 25 versions & 2 rubygems