diff options
| author | murphy <murphy@rubychan.de> | 2006-03-16 18:35:43 +0000 | 
|---|---|---|
| committer | murphy <murphy@rubychan.de> | 2006-03-16 18:35:43 +0000 | 
| commit | ace3fcea2ffccb6d88f155cd884eb05d2b2cb067 (patch) | |
| tree | d98ec478acdcb6c5516cf47c4a9141ce95991fd3 /lib/coderay/encoders/html.rb | |
| parent | c9b79010179d695fa16e1dd2f51818fa5c929548 (diff) | |
| download | coderay-ace3fcea2ffccb6d88f155cd884eb05d2b2cb067.tar.gz | |
HTML Encoder: hints fixed and improved. Still in progress.
Documentation cleanups.
Diffstat (limited to 'lib/coderay/encoders/html.rb')
| -rw-r--r-- | lib/coderay/encoders/html.rb | 13 | 
1 files changed, 9 insertions, 4 deletions
| diff --git a/lib/coderay/encoders/html.rb b/lib/coderay/encoders/html.rb index 65a7874..02a718b 100644 --- a/lib/coderay/encoders/html.rb +++ b/lib/coderay/encoders/html.rb @@ -109,7 +109,7 @@ module Encoders  		# \x9 (\t) and \xA (\n) not included
  		HTML_ESCAPE_PATTERN = /[\t&"><\xB-\x1f\x7f-\xff\0-\x8]/
 -		TOKEN_KIND_TO_INFO = Hash.new do |h, kind|
 +		TOKEN_KIND_TO_INFO = Hash.new { |h, kind|
  			h[kind] =
  				case kind
  				when :pre_constant
 @@ -117,8 +117,11 @@ module Encoders  				else
  					kind.to_s.gsub(/_/, ' ').gsub(/\b\w/) { $&.capitalize }
  				end
 -		end
 +		}
 +		# Generate a hint about the given +classes+ in a +hint+ style.
 +		# 
 +		# +hint+ may be :info, :info_long or :debug.
  		def self.token_path_to_hint hint, classes
  			return '' unless hint
  			title =
 @@ -126,7 +129,7 @@ module Encoders  				when :info
  					TOKEN_KIND_TO_INFO[classes.first]
  				when :info_long
 -					classes.map { |kind| TOKEN_KIND_TO_INFO[kind] }.join('/')
 +					classes.reverse.map { |kind| TOKEN_KIND_TO_INFO[kind] }.join('/')
  				when :debug
  					classes.inspect
  				end
 @@ -145,7 +148,7 @@ module Encoders  			@css = CSS.new options[:style]
  			hint = options[:hint]
 -			if hint and not [:debug, :info].include? hint
 +			if hint and not [:debug, :info, :info_long].include? hint
  				raise ArgumentError, "Unknown value %p for :hint; expected :info, :debug, false or nil." % hint
  			end
 @@ -179,7 +182,9 @@ module Encoders  					if classes.first == :NO_HIGHLIGHT and not hint
  						h[k] = false
  					else
 +						styles.shift if [:delimiter, :modifier, :content, :escape].include? styles.first
  						title = HTML.token_path_to_hint hint, styles
 +						classes.delete 'il'
  						style = @css[*classes]
  						h[k] =
  							if style
 | 
