diff options
author | Kornelius Kalnbach <murphy@rubychan.de> | 2016-02-13 00:21:25 +0100 |
---|---|---|
committer | Kornelius Kalnbach <murphy@rubychan.de> | 2016-02-13 00:25:15 +0100 |
commit | 61a9d9689be7720a8345b7ff35f08041134cc15e (patch) | |
tree | fbb8fe4950f4ef40b824fbb191bdb9a052507ba3 /lib/coderay | |
parent | e6d46f903a1478411696d1ed249e772096e64237 (diff) | |
download | coderay-61a9d9689be7720a8345b7ff35f08041134cc15e.tar.gz |
scanner tweaks
Diffstat (limited to 'lib/coderay')
-rw-r--r-- | lib/coderay/rule_based_scanner.rb | 10 | ||||
-rw-r--r-- | lib/coderay/scanners/c2.rb | 2 | ||||
-rw-r--r-- | lib/coderay/scanners/css2.rb | 5 | ||||
-rw-r--r-- | lib/coderay/scanners/java_script5.rb | 4 |
4 files changed, 12 insertions, 9 deletions
diff --git a/lib/coderay/rule_based_scanner.rb b/lib/coderay/rule_based_scanner.rb index ac6a623..9239cf6 100644 --- a/lib/coderay/rule_based_scanner.rb +++ b/lib/coderay/rule_based_scanner.rb @@ -219,18 +219,20 @@ module CodeRay protected - def make_callback block + def callbacks @callbacks ||= {} - + end + + def make_callback block base_name = "__callback_line_#{block.source_location.last}" name = base_name counter = 'a' - while @callbacks.key?(name) + while callbacks.key?(name) name = "#{base_name}_#{counter}" counter.succ! end - @callbacks[name] = define_method(name, &block) + callbacks[name] = define_method(name, &block) arguments = block.parameters.map(&:last) diff --git a/lib/coderay/scanners/c2.rb b/lib/coderay/scanners/c2.rb index d21e032..a5d4d09 100644 --- a/lib/coderay/scanners/c2.rb +++ b/lib/coderay/scanners/c2.rb @@ -118,7 +118,7 @@ module Scanners if ENV['PUTS'] puts scan_tokens_code - puts "callbacks: #{@callbacks.size}" + puts "callbacks: #{callbacks.size}" end class_eval scan_tokens_code, __FILE__, def_line end diff --git a/lib/coderay/scanners/css2.rb b/lib/coderay/scanners/css2.rb index 93b890a..edb9ca3 100644 --- a/lib/coderay/scanners/css2.rb +++ b/lib/coderay/scanners/css2.rb @@ -88,6 +88,7 @@ module Scanners states = Array(options[:state] || @state).dup value_expected = @value_expected block = @block + state = states.last until eos? @@ -112,8 +113,8 @@ module Scanners RUBY if ENV['PUTS'] - puts scan_tokens_code - puts "callbacks: #{@callbacks.size}" + puts CodeRay.scan(scan_tokens_code, :ruby).terminal + puts "callbacks: #{callbacks.size}" end class_eval scan_tokens_code, __FILE__, def_line diff --git a/lib/coderay/scanners/java_script5.rb b/lib/coderay/scanners/java_script5.rb index e337cc5..ae68cef 100644 --- a/lib/coderay/scanners/java_script5.rb +++ b/lib/coderay/scanners/java_script5.rb @@ -174,8 +174,8 @@ module Scanners RUBY if ENV['PUTS'] - puts scan_tokens_code - puts "callbacks: #{@callbacks.size}" + puts CodeRay.scan(scan_tokens_code, :ruby).terminal + puts "callbacks: #{callbacks.size}" end class_eval scan_tokens_code, __FILE__, def_line |