Sha256: 9df2e5ed775c5db0adf1e2c1ca9e141e17852fe9e3502fc073faf540f5beb024

Contents?: true

Size: 1.69 KB

Versions: 11

Compression:

Stored size: 1.69 KB

Contents

module Rackamole::Store
  class Log
            
    # Stores mole information to a log file or dump it to the console. All
    # available mole info will dumped to the logger.
    #
    # === Params:
    # file_name :: Specifies a file to send the logs to. By default mole info
    # will be sent out to stdout.
    def initialize( file_name=$stdout )
      @logger = Rackamole::Logger.new( :log_file => file_name )
    end
    
    # Dump mole info to logger
    #
    # === Params:
    # attrs :: The available moled information for a given feature
    def mole( attrs )
      return if attrs.empty?
              
      display_head( attrs )
      display_commons( attrs )          
    rescue => mole_boom
      log.error "MOLE STORE CRAPPED OUT -- #{mole_boom}"
      log.error mole_boom.backtrace.join( "\n   " )        
    end
       
    # =======================================================================
    private

      # dump moled info to log
      def display_commons( args )
        args.each do |k,v|
          display_info( k.to_s.capitalize, v.inspect )
        end
      end
      
      # retrieves logger instance
      def log
        @logger
      end
      
      # Console layout spacer
      def spacer() 20; end

      # Display mole type
      def display_head( args )
        log.info "-"*100
        log.info case args[:type]
          when Rackamole.feature 
            "FEATURE m()le"
          when Rackamole.fault
            "FAULT m()le"
          when Rackamole.perf
            "PERFORMANCE m()le"
        end
      end
      
      # Output formating...         
      def display_info( key, value )
        log.info "%-#{spacer}s : %s" % [key, value]
      end        
  end
end

Version data entries

11 entries across 11 versions & 1 rubygems

Version Path
rackamole-0.3.5 lib/rackamole/store/log.rb
rackamole-0.3.4 lib/rackamole/store/log.rb
rackamole-0.3.3 lib/rackamole/store/log.rb
rackamole-0.3.2 lib/rackamole/store/log.rb
rackamole-0.3.1 lib/rackamole/store/log.rb
rackamole-0.3.0 lib/rackamole/store/log.rb
rackamole-0.2.9 lib/rackamole/store/log.rb
rackamole-0.2.8 lib/rackamole/store/log.rb
rackamole-0.2.7 lib/rackamole/store/log.rb
rackamole-0.2.6 lib/rackamole/store/log.rb
rackamole-0.2.5 lib/rackamole/store/log.rb