diff options
author | murphy <murphy@rubychan.de> | 2010-05-18 06:26:06 +0000 |
---|---|---|
committer | murphy <murphy@rubychan.de> | 2010-05-18 06:26:06 +0000 |
commit | a2156b92bec0bb4e2ea7c02927ee6fbd423e82bf (patch) | |
tree | 070707d48722135c0cfe18b1ca6e4f2eb961738e /lib/coderay/scanners/raydebug.rb | |
parent | 591b2823d986bc877697e3bd485ffa9c9adff3ed (diff) | |
download | coderay-a2156b92bec0bb4e2ea7c02927ee6fbd423e82bf.tar.gz |
Diffstat (limited to 'lib/coderay/scanners/raydebug.rb')
-rw-r--r-- | lib/coderay/scanners/raydebug.rb | 67 |
1 files changed, 67 insertions, 0 deletions
diff --git a/lib/coderay/scanners/raydebug.rb b/lib/coderay/scanners/raydebug.rb new file mode 100644 index 0000000..d5839f9 --- /dev/null +++ b/lib/coderay/scanners/raydebug.rb @@ -0,0 +1,67 @@ +($:.unshift '../..'; require 'coderay') unless defined? CodeRay +module CodeRay +module Scanners + + # = Debug Scanner + # + # Parses the output of the Encoders::Debug encoder. + class Raydebug < Scanner + + register_for :raydebug + file_extension 'raydebug' + title 'CodeRay Token Dump' + + protected + + def scan_tokens encoder, options + + opened_tokens = [] + + until eos? + + if match = scan(/\s+/) + encoder.text_token match, :space + + elsif match = scan(/ (\w+) \( ( [^\)\\]* ( \\. [^\)\\]* )* ) /x) + kind = self[1] + encoder.text_token kind, :class + encoder.text_token '(', :operator + match = self[2] + encoder.text_token match, kind.to_sym + encoder.text_token match, :operator if match = scan(/\)/) + + elsif match = scan(/ (\w+) ([<\[]) /x) + kind = self[1] + case self[2] + when '<' + encoder.text_token kind, :class + when '[' + encoder.text_token kind, :class + else + raise 'CodeRay bug: This case should not be reached.' + end + kind = kind.to_sym + opened_tokens << kind + encoder.begin_group kind + encoder.text_token self[2], :operator + + elsif !opened_tokens.empty? && match = scan(/ [>\]] /x) + encoder.text_token match, :operator + encoder.end_group opened_tokens.pop + + else + encoder.text_token getch, :space + + end + + end + + encoder.end_group opened_tokens.pop until opened_tokens.empty? + + encoder + end + + end + +end +end |