Sha256: 5bb22a1ce23ee881907c17151d275f7d2874d35b37ea74a3585b6cdc411dfd21

Contents?: true

Size: 1.8 KB

Versions: 21

Compression:

Stored size: 1.8 KB

Contents

module Logging::Appenders

  # This class provides an Appender that can write to a File.
  #
  class File < ::Logging::Appenders::IO

    # call-seq:
    #    File.assert_valid_logfile( filename )    => true
    #
    # Asserts that the given _filename_ can be used as a log file by ensuring
    # that if the file exists it is a regular file and it is writable. If
    # the file does not exist, then the directory is checked to see if it is
    # writable.
    #
    # An +ArgumentError+ is raised if any of these assertions fail.
    #
    def self.assert_valid_logfile( fn )
      if ::File.exist?(fn)
        if not ::File.file?(fn)
          raise ArgumentError, "#{fn} is not a regular file"
        elsif not ::File.writable?(fn)
          raise ArgumentError, "#{fn} is not writeable"
        end
      elsif not ::File.writable?(::File.dirname(fn))
        raise ArgumentError, "#{::File.dirname(fn)} is not writable"
      end
      true
    end

    # call-seq:
    #    File.new( name, :filename => 'file' )
    #    File.new( name, :filename => 'file', :truncate => true )
    #    File.new( name, :filename => 'file', :layout => layout )
    #
    # Creates a new File Appender that will use the given filename as the
    # logging destination. If the file does not already exist it will be
    # created. If the :truncate option is set to +true+ then the file will
    # be truncated before writing begins; otherwise, log messages will be
    # appened to the file.
    #
    def initialize( name, opts = {} )
      @fn = opts.getopt(:filename, name)
      raise ArgumentError, 'no filename was given' if @fn.nil?
      self.class.assert_valid_logfile(@fn)
      mode = opts.getopt(:truncate) ? 'w' : 'a'

      super(name, ::File.new(@fn, mode), opts)
    end

  end  # class FileAppender
end  # module Logging::Appenders

# EOF

Version data entries

21 entries across 21 versions & 4 rubygems

Version Path
TwP-logging-0.9.7 lib/logging/appenders/file.rb
TwP-logging-0.9.8.1 lib/logging/appenders/file.rb
TwP-logging-0.9.8.2 lib/logging/appenders/file.rb
TwP-logging-0.9.8 lib/logging/appenders/file.rb
TwP-logging-1.0.0 lib/logging/appenders/file.rb
TwP-logging-1.1.0 lib/logging/appenders/file.rb
ottobar-logging-0.9.5.1 lib/logging/appenders/file.rb
logging-0.9.6 lib/logging/appenders/file.rb
logging-0.9.4 lib/logging/appenders/file.rb
logging-0.9.3 lib/logging/appenders/file.rb
logging-0.9.1 lib/logging/appenders/file.rb
logging-0.9.2 lib/logging/appenders/file.rb
logging-0.9.7 lib/logging/appenders/file.rb
logging-0.9.0 lib/logging/appenders/file.rb
logging-0.9.5 lib/logging/appenders/file.rb
logging-1.1.0 lib/logging/appenders/file.rb
logging-0.9.8 lib/logging/appenders/file.rb
logging-1.0.0 lib/logging/appenders/file.rb
mack-0.8.2 lib/gems/logging-0.9.4/lib/logging/appenders/file.rb
mack-0.8.3.1 lib/gems/logging-0.9.4/lib/logging/appenders/file.rb