Sha256: 86ba5436ad20490df677c82743059a9299903410031123863b5556033a73667b

Contents?: true

Size: 924 Bytes

Versions: 19

Compression:

Stored size: 924 Bytes

Contents

require 'logger'

module RubyApp
  require 'ruby_app/application'
  require 'ruby_app/mixins/delegate_mixin'

  class Log < ::Logger
    extend RubyApp::Mixins::DelegateMixin

    def exception(exception)
      self.error('-' * 80)
      self.error("exception=#{exception.class.inspect} #{exception.message}")
      self.error('-' * 80)
      exception.backtrace.each do |line|
        self.error(line)
      end
      self.error('-' * 80)
    end

    def self.get
      @@_log
    end

    def self.open!
      path = RubyApp::Application.options.log_path
      directory = File.dirname(path)
      Dir.mkdir(directory) unless File.exists?(directory)
      @@_log = RubyApp::Log.new(path)
      @@_log.debug("#{self}##{__method__} path=#{path.inspect}")
    end

    def self.close!
      @@_log.close if @@_log
      @@_log = nil
    end

    private

      def initialize(path)
        super(path)
      end

  end

end

Version data entries

19 entries across 19 versions & 1 rubygems

Version Path
RubyApp-0.0.51 lib/ruby_app/log.rb
RubyApp-0.0.50 lib/ruby_app/log.rb
RubyApp-0.0.49 lib/ruby_app/log.rb
RubyApp-0.0.48 lib/ruby_app/log.rb
RubyApp-0.0.47 lib/ruby_app/log.rb
RubyApp-0.0.46 lib/ruby_app/log.rb
RubyApp-0.0.45 lib/ruby_app/log.rb
RubyApp-0.0.44 lib/ruby_app/log.rb
RubyApp-0.0.43 lib/ruby_app/log.rb
RubyApp-0.0.42 lib/ruby_app/log.rb
RubyApp-0.0.41 lib/ruby_app/log.rb
RubyApp-0.0.30 lib/ruby_app/log.rb
RubyApp-0.0.29 lib/ruby_app/log.rb
RubyApp-0.0.28 lib/ruby_app/log.rb
RubyApp-0.0.27 lib/ruby_app/log.rb
RubyApp-0.0.26 lib/ruby_app/log.rb
RubyApp-0.0.25 lib/ruby_app/log.rb
RubyApp-0.0.24 lib/ruby_app/log.rb
RubyApp-0.0.23 lib/ruby_app/log.rb