Sha256: 32c0a5a741e9b77d1781a78565f425c58811763fad6857517faa90f27ee1adc3

Contents?: true

Size: 1.47 KB

Versions: 4

Compression:

Stored size: 1.47 KB

Contents

# $Id: file.rb 46 2007-10-31 14:39:01Z tim_pease $

require 'logging/appenders/io'

module Logging::Appenders

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

    # 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.delete(:filename) || opts.delete('filename') || name
      raise ArgumentError, 'no filename was given' if @fn.nil?

      mode = opts.delete(:truncate) || opts.delete('truncate')
      mode = mode ? 'w' : 'a'

      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

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

  end  # class FileAppender
end  # module Logging::Appenders

# EOF

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
logging-0.5.2 lib/logging/appenders/file.rb
logging-0.5.1 lib/logging/appenders/file.rb
logging-0.5.0 lib/logging/appenders/file.rb
logging-0.5.3 lib/logging/appenders/file.rb