Sha256: 6ff63df7db337cbcb0f0d690daa13ee56184d54632fe93543f15958b6ce45382

Contents?: true

Size: 1.88 KB

Versions: 19

Compression:

Stored size: 1.88 KB

Contents

module Lumberjack
  class Device
    # This is a log device that appends entries to a file and rolls the file when it reaches a specified
    # size threshold. When a file is rolled, it will have an number extension appended to the file name.
    # For example, if the log file is named production.log, the first time it is rolled it will be renamed
    # production.log.1, then production.log.2, etc.
    class SizeRollingLogFile < RollingLogFile
      attr_reader :max_size
      
      # Create an new log device to the specified file. The maximum size of the log file is specified with
      # the <tt>:max_size</tt> option. The unit can also be specified: "32K", "100M", "2G" are all valid.
      def initialize(path, options = {})
        @max_size = options[:max_size]
        if @max_size.is_a?(String)
          if @max_size.match(/^(\d+(\.\d+)?)([KMG])?$/i)
            @max_size = $~[1].to_f
            units = $~[3].to_s.upcase
            case units
            when "K"
              @max_size *= 1024
            when "M"
              @max_size *= 1024 ** 2
            when "G"
              @max_size *= 1024 ** 3
            end
            @max_size = @max_size.round
          else
            raise ArgumentError.new("illegal value for :max_size (#{@max_size})")
          end
        end
        
        super
      end

      def archive_file_suffix
        next_archive_number.to_s
      end

      def roll_file?
        stream.stat.size > @max_size
      rescue SystemCallError => e
        false
      end
      
      protected
      
      # Calculate the next archive file name extension.
      def next_archive_number # :nodoc:
        max = 0
        Dir.glob("#{path}.*").each do |filename|
          if filename.match(/\.\d+$/)
            suffix = filename.split('.').last.to_i
            max = suffix if suffix > max
          end
        end
        max + 1
      end
    end
  end
end

Version data entries

19 entries across 17 versions & 6 rubygems

Version Path
honeybadger-2.4.0 vendor/gems/ruby/1.9.1/gems/lumberjack-1.0.9/lib/lumberjack/device/size_rolling_log_file.rb
honeybadger-2.4.0 vendor/gems/ruby/2.2.0/gems/lumberjack-1.0.9/lib/lumberjack/device/size_rolling_log_file.rb
honeybadger-2.4.0 vendor/gems/ruby/2.1.0/gems/lumberjack-1.0.9/lib/lumberjack/device/size_rolling_log_file.rb
mastermind_adeybee-0.1.4 vendor/bundle/ruby/2.2.0/gems/lumberjack-1.0.9/lib/lumberjack/device/size_rolling_log_file.rb
mastermind_adeybee-0.1.3 vendor/bundle/ruby/2.2.0/gems/lumberjack-1.0.9/lib/lumberjack/device/size_rolling_log_file.rb
mastermind_adeybee-0.1.2 vendor/bundle/ruby/2.2.0/gems/lumberjack-1.0.9/lib/lumberjack/device/size_rolling_log_file.rb
mastermind_adeybee-0.1.1 vendor/bundle/ruby/2.2.0/gems/lumberjack-1.0.9/lib/lumberjack/device/size_rolling_log_file.rb
geminfo-0.1.0 path/gems/lumberjack-1.0.9/lib/lumberjack/device/size_rolling_log_file.rb
lumberjack-1.0.9 lib/lumberjack/device/size_rolling_log_file.rb
lumberjack-1.0.8 lib/lumberjack/device/size_rolling_log_file.rb
lumberjack-1.0.7 lib/lumberjack/device/size_rolling_log_file.rb
lumberjack-1.0.6 lib/lumberjack/device/size_rolling_log_file.rb
lumberjack-1.0.5 lib/lumberjack/device/size_rolling_log_file.rb
lumberjack_aziz_light-1.0.5 lib/lumberjack/device/size_rolling_log_file.rb
lumberjack-1.0.4 lib/lumberjack/device/size_rolling_log_file.rb
sidekiq-statsd-0.1.1 vendor/ruby/1.9.1/gems/lumberjack-1.0.3/lib/lumberjack/device/size_rolling_log_file.rb
sidekiq-statsd-0.1.0 vendor/ruby/1.9.1/gems/lumberjack-1.0.3/lib/lumberjack/device/size_rolling_log_file.rb
lumberjack-1.0.3 lib/lumberjack/device/size_rolling_log_file.rb
lumberjack-1.0.2 lib/lumberjack/device/size_rolling_log_file.rb