Sha256: 0ce60291087f6aa49c214cad9fa0054f69044438e163fbcc26f58c18c3054b69

Contents?: true

Size: 733 Bytes

Versions: 1

Compression:

Stored size: 733 Bytes

Contents

require "logger"

module Smartcloud
	module Logger
	  def logger
	    @logger ||= Smartcloud::Logger.logger_for(self.class.name)
	  end

	  # Use a hash class-ivar to cache a unique Logger per class:
	  @loggers = {}

	  def self.included(base)
		class << base
			def logger
			  @logger ||= Smartcloud::Logger.logger_for(self.name)
			end
		end
	  end

	  class << self
	    def logger_for(classname)
	      @loggers[classname] ||= configure_logger_for(classname)
	    end

	    def configure_logger_for(classname)
		  $stdout.sync = true
	      logger = ::Logger.new($stdout)
		  logger.level = ::Logger.const_get("#{Smartcloud.config.logger_level}".upcase)
	      logger.progname = classname
	      logger
	    end
	  end
	end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
smartcloud-0.0.168 lib/smartcloud/logger.rb