Class: Build::CompactFormatter
- Inherits:
-
Object
- Object
- Build::CompactFormatter
- Defined in:
- lib/build/logger.rb
Instance Method Summary collapse
- #call(severity, datetime, progname, message) ⇒ Object
- #chdir_string(options) ⇒ Object
- #format_command(arguments, buffer) ⇒ Object
- #format_exception(exception, buffer) ⇒ Object
-
#initialize(verbose: true) ⇒ CompactFormatter
constructor
A new instance of CompactFormatter.
- #time_offset_prefix ⇒ Object
Constructor Details
#initialize(verbose: true) ⇒ CompactFormatter
Returns a new instance of CompactFormatter.
26 27 28 29 |
# File 'lib/build/logger.rb', line 26 def initialize(verbose: true) @start = Time.now @verbose = verbose end |
Instance Method Details
#call(severity, datetime, progname, message) ⇒ Object
81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 |
# File 'lib/build/logger.rb', line 81 def call(severity, datetime, progname, ) buffer = [] prefix = "" if @verbose prefix = time_offset_prefix buffer << Rainbow(prefix).cyan + ": " prefix = " " * (prefix.size) + "| " end if progname == 'shell' and .kind_of? Array format_command(, buffer) elsif .kind_of? Exception format_exception(, buffer) else buffer << << "\n" end result = buffer.join # This fancy regex indents lines correctly depending on the prefix: result.gsub!(/\n(?!$)/, "\n#{prefix}") unless prefix.empty? return result end |
#chdir_string(options) ⇒ Object
43 44 45 46 47 48 49 |
# File 'lib/build/logger.rb', line 43 def chdir_string() if [:chdir] " in #{[:chdir]}" else "" end end |
#format_command(arguments, buffer) ⇒ Object
51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 |
# File 'lib/build/logger.rb', line 51 def format_command(arguments, buffer) arguments = arguments.dup environment = arguments.first.is_a?(Hash) ? arguments.shift : nil = arguments.last.is_a?(Hash) ? arguments.pop : nil arguments = arguments.flatten.collect(&:to_s) buffer << Rainbow(arguments.join(' ')).bright.blue if buffer << chdir_string() end buffer << "\n" # if environment # environment.each do |key,value| # buffer << "\texport #{key}=#{value.dump}\n" # end # end end |
#format_exception(exception, buffer) ⇒ Object
74 75 76 77 78 79 |
# File 'lib/build/logger.rb', line 74 def format_exception(exception, buffer) buffer << Rainbow("#{exception.class}: #{exception}").bright.red << "\n" exception.backtrace.each do |line| buffer << "\t" << Rainbow(line).red << "\n" end end |
#time_offset_prefix ⇒ Object
31 32 33 34 35 36 37 38 39 40 41 |
# File 'lib/build/logger.rb', line 31 def time_offset_prefix offset = Time.now - @start minutes = (offset/60).floor seconds = (offset - (minutes*60)) if minutes > 0 "#{minutes}m#{seconds.floor}s" else "#{seconds.round(2)}s" end.rjust(6) end |