Sha256: 03f24d7b3dbd02947203c76c8a42f4b3c57e7a5b7ed06118f3f84f5b8a0acfc8

Contents?: true

Size: 1.39 KB

Versions: 5

Compression:

Stored size: 1.39 KB

Contents

require 'logger'
require 'singleton'

module Rezept
  class TermColor
    class << self

      def green(msg)
        colorize 32, msg
      end

      def yellow(msg)
        colorize 33, msg
      end

      def red(msg)
        colorize 31, msg
      end

      def colorize(num, msg)
        "\e[#{num}m#{msg}\e[0m"
      end

    end
  end

  class Logger < Logger
    include Singleton

    def initialize
      super(STDERR)

      self.formatter = proc do |severity, datetime, progname, msg|
        "#{msg}\n"
      end

      self.level = Logger::INFO
    end

    def debug(progname = nil, method_name = nil, msg)
      super(progname) { { method_name: method_name, message: msg } }
    end

    def info(msg)
      super { Rezept::TermColor.green(msg) }
    end

    def warn(msg)
      super { Rezept::TermColor.yellow(msg) }
    end

    def fatal(msg)
      super { Rezept::TermColor.red(msg) }
    end

    def error(msg)
      super { Rezept::TermColor.red(msg) }
    end

    module Helper

      def log(level, message)
        logger = Rezept::Logger.instance
        logger.send(level, message)
      end

      def info(msg)
        log(:info, msg)
      end

      def warn(msg)
        log(:warn, msg)
      end

      def fatal(msg)
        log(:error, msg)
      end

      def debug(msg)
        log(:debug, msg)
      end

      module_function :log, :info, :warn, :fatal, :debug
    end
  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
rezept-0.4.0 lib/rezept/logger.rb
rezept-0.3.1 lib/rezept/logger.rb
rezept-0.3.0 lib/rezept/logger.rb
rezept-0.2.0 lib/rezept/logger.rb
rezept-0.1.0 lib/rezept/logger.rb