Class Logger::Application
In: lib/logger.rb
Parent: Object

Description

Application — Add logging support to your application.

Usage

  1. Define your application class as a sub-class of this class.
  2. Override ‘run’ method in your class to do many things.
  3. Instantiate it and invoke ‘start’.

Example

  class FooApp < Application
    def initialize(foo_app, application_specific, arguments)
      super('FooApp') # Name of the application.
    end

    def run
      ...
      log(WARN, 'warning', 'my_method1')
      ...
      @log.error('my_method2') { 'Error!' }
      ...
    end
  end

  status = FooApp.new(....).start

Methods

level=   log   log=   new   run   set_log   start  

Included Modules

Logger::Severity

Attributes

appname  [R] 
logdev  [R] 

Public Class methods

Synopsis

  Application.new(appname = '')

Args

appname:Name of the application.

Description

Create an instance. Log device is STDERR by default. This can be changed with set_log.

[Source]

     # File lib/logger.rb, line 645
645:     def initialize(appname = nil)
646:       @appname = appname
647:       @log = Logger.new(STDERR)
648:       @log.progname = @appname
649:       @level = @log.level
650:     end

Public Instance methods

Set the logging threshold, just like Logger#level=.

[Source]

     # File lib/logger.rb, line 685
685:     def level=(level)
686:       @level = level
687:       @log.level = @level
688:     end

See Logger#add. This application‘s appname is used.

[Source]

     # File lib/logger.rb, line 693
693:     def log(severity, message = nil, &block)
694:       @log.add(severity, message, @appname, &block) if @log
695:     end

[Source]

     # File lib/logger.rb, line 678
678:     def log=(logdev)
679:       set_log(logdev)
680:     end

Sets the log device for this application. See the class Logger for an explanation of the arguments.

[Source]

     # File lib/logger.rb, line 672
672:     def set_log(logdev, shift_age = 0, shift_size = 1024000)
673:       @log = Logger.new(logdev, shift_age, shift_size)
674:       @log.progname = @appname
675:       @log.level = @level
676:     end

Start the application. Return the status code.

[Source]

     # File lib/logger.rb, line 655
655:     def start
656:       status = -1
657:       begin
658:         log(INFO, "Start of #{ @appname }.")
659:         status = run
660:       rescue
661:         log(FATAL, "Detected an exception. Stopping ... #{$!} (#{$!.class})\n" << $@.join("\n"))
662:       ensure
663:         log(INFO, "End of #{ @appname }. (status: #{ status.to_s })")
664:       end
665:       status
666:     end

Private Instance methods

[Source]

     # File lib/logger.rb, line 699
699:     def run
700:       raise RuntimeError.new('Method run must be defined in the derived class.')
701:     end

[Validate]