Class: AwesomePrint::Formatter
Constant Summary collapse
- CORE =
[ :array, :hash, :class, :file, :dir, :bigdecimal, :rational, :struct, :method, :unboundmethod ]
- DEFAULT_LIMIT_SIZE =
7
Instance Method Summary collapse
-
#cast(object, type) ⇒ Object
Hook this when adding custom formatters.
-
#colorize(s, type) ⇒ Object
Pick the color and apply it to the given string as necessary.
-
#format(object, type = nil) ⇒ Object
Main entry point to format an object.
-
#initialize(inspector) ⇒ Formatter
constructor
A new instance of Formatter.
Constructor Details
#initialize(inspector) ⇒ Formatter
Returns a new instance of Formatter.
15 16 17 18 19 |
# File 'lib/awesome_print/formatter.rb', line 15 def initialize(inspector) @inspector = inspector @options = inspector. @indentation = @options[:indent].abs end |
Instance Method Details
#cast(object, type) ⇒ Object
Hook this when adding custom formatters. Check out lib/awesome_print/ext directory for custom formatters that ship with awesome_print.
36 37 38 |
# File 'lib/awesome_print/formatter.rb', line 36 def cast(object, type) CORE.grep(type)[0] || :self end |
#colorize(s, type) ⇒ Object
Pick the color and apply it to the given string as necessary.
42 43 44 45 46 47 48 49 |
# File 'lib/awesome_print/formatter.rb', line 42 def colorize(s, type) s = CGI.escapeHTML(s) if @options[:html] if @options[:plain] || !@options[:color][type] || !@inspector.colorize? s else s.send(@options[:color][type], @options[:html]) end end |
#format(object, type = nil) ⇒ Object
Main entry point to format an object.
23 24 25 26 27 28 29 30 31 |
# File 'lib/awesome_print/formatter.rb', line 23 def format(object, type = nil) core_class = cast(object, type) awesome = if core_class != :self send(:"awesome_#{core_class}", object) # Core formatters. else awesome_self(object, type) # Catch all that falls back to object.inspect. end @options[:html] ? "<pre>#{awesome}</pre>" : awesome end |