diff options
author | Kornelius Kalnbach <murphy@rubychan.de> | 2011-09-19 01:47:08 +0200 |
---|---|---|
committer | Kornelius Kalnbach <murphy@rubychan.de> | 2011-09-19 01:47:08 +0200 |
commit | 2f97912d6372b3edde924f83ed283b97f6472273 (patch) | |
tree | de7cb89c4f44e03f280ef831295a33339e4d31e8 /lib/coderay/tokens_proxy.rb | |
parent | 14b4728342af152f865f29e67d583c733e912756 (diff) | |
download | coderay-2f97912d6372b3edde924f83ed283b97f6472273.tar.gz |
TokensProxy: wrap up
Diffstat (limited to 'lib/coderay/tokens_proxy.rb')
-rw-r--r-- | lib/coderay/tokens_proxy.rb | 14 |
1 files changed, 12 insertions, 2 deletions
diff --git a/lib/coderay/tokens_proxy.rb b/lib/coderay/tokens_proxy.rb index 598ad2e..b333e57 100644 --- a/lib/coderay/tokens_proxy.rb +++ b/lib/coderay/tokens_proxy.rb @@ -1,13 +1,15 @@ module CodeRay - class TokensProxy < Struct.new :code, :lang, :options, :block + class TokensProxy < Struct.new :input, :lang, :options, :block def method_missing method, *args, &blk + encode method, *args + rescue PluginHost::PluginNotFound tokens.send(method, *args, &blk) end def tokens - @tokens ||= scanner.tokenize(code) + @tokens ||= scanner.tokenize(input) end def each *args, &blk @@ -22,6 +24,14 @@ module CodeRay @scanner ||= CodeRay.scanner(lang, options, &block) end + def encode encoder, options = {} + if encoder.respond_to? :to_sym + CodeRay.encode(input, lang, encoder, options) + else + encoder.encode_tokens tokens, options + end + end + end end |