From 3464d59cb739fcd3ff7214e80d94cd8972304bc1 Mon Sep 17 00:00:00 2001 From: stereobooster Date: Mon, 20 Jun 2011 05:26:44 -0700 Subject: [PATCH] more color support for UI --- lib/guard/ui.rb | 36 +++++++++++++++++++++++++++++++++--- 1 file changed, 33 insertions(+), 3 deletions(-) diff --git a/lib/guard/ui.rb b/lib/guard/ui.rb index d9b9991..7d20871 100644 --- a/lib/guard/ui.rb +++ b/lib/guard/ui.rb @@ -1,5 +1,24 @@ module Guard module UI + + ANSI_ESCAPE_BLACK = "30" + ANSI_ESCAPE_RED = "31" + ANSI_ESCAPE_GREEN = "32" + ANSI_ESCAPE_YELLOW = "33" + ANSI_ESCAPE_BLUE = "34" + ANSI_ESCAPE_MAGENTA = "35" + ANSI_ESCAPE_CYAN = "36" + ANSI_ESCAPE_WHITE = "37" + + ANSI_ESCAPE_BGBLACK = "40" + ANSI_ESCAPE_BGRED = "41" + ANSI_ESCAPE_BGGREEN = "42" + ANSI_ESCAPE_BGYELLOW = "43" + ANSI_ESCAPE_BGBLUE = "44" + ANSI_ESCAPE_BGMAGENTA = "45" + ANSI_ESCAPE_BGCYAN = "46" + ANSI_ESCAPE_BGWHITE = "47" + class << self color_enabled = nil @@ -7,14 +26,14 @@ module Guard def info(message, options = {}) unless ENV["GUARD_ENV"] == "test" reset_line if options[:reset] - puts reset_color(message) if message != '' + puts color(message) if message != '' end end def error(message, options = {}) unless ENV["GUARD_ENV"] == "test" reset_line if options[:reset] - puts "#{color('ERROR:', ';31')} #{message}" + puts color('ERROR:', :red) + message end end @@ -35,11 +54,22 @@ module Guard private + # @deprecated def reset_color(text) color(text, "") end - def color(text, color_code) + def color(text, *color_options) + color_code = "" + color_options.each do |color_option| + color_option = color_option.to_s + if color_option != "" + if !(color_option =~ /\d+/) + color_option = const_get("ANSI_ESCAPE_#{color_option.upcase}") + end + color_code += ";" + color_option + end + end color_enabled? ? "\e[0#{color_code}m#{text}\e[0m" : text end