Sha256: 051ee7437717db04759ec7b7d2d866d61e31eb917bc1bf96d554b061b4a06f2d
Contents?: true
Size: 1.85 KB
Versions: 5
Compression:
Stored size: 1.85 KB
Contents
# $Id: file.rb 77 2007-12-30 02:21:33Z tim_pease $ 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
5 entries across 5 versions & 1 rubygems