Sha256: 8d6b1b69766ed6732665d728618c2e515078d094bf5993b865d1e4084cf66462

Contents?: true

Size: 1.86 KB

Versions: 46

Compression:

Stored size: 1.86 KB

Contents

# frozen_string_literal: true

require "active_support/concern"
require "active_support/core_ext/module/attribute_accessors"
require "concurrent"
require "fiber"

module ActiveSupport
  module LoggerThreadSafeLevel # :nodoc:
    extend ActiveSupport::Concern

    Logger::Severity.constants.each do |severity|
      class_eval(<<-EOT, __FILE__, __LINE__ + 1)
        def #{severity.downcase}?                # def debug?
          Logger::#{severity} >= level           #   DEBUG >= level
        end                                      # end
      EOT
    end

    def local_level
      IsolatedExecutionState[:logger_thread_safe_level]
    end

    def local_level=(level)
      case level
      when Integer
      when Symbol
        level = Logger::Severity.const_get(level.to_s.upcase)
      when nil
      else
        raise ArgumentError, "Invalid log level: #{level.inspect}"
      end
      IsolatedExecutionState[:logger_thread_safe_level] = level
    end

    def level
      local_level || super
    end

    # Change the thread-local level for the duration of the given block.
    def log_at(level)
      old_local_level, self.local_level = local_level, level
      yield
    ensure
      self.local_level = old_local_level
    end

    # Redefined to check severity against #level, and thus the thread-local level, rather than +@level+.
    # FIXME: Remove when the minimum Ruby version supports overriding Logger#level.
    def add(severity, message = nil, progname = nil, &block) # :nodoc:
      severity ||= UNKNOWN
      progname ||= @progname

      return true if @logdev.nil? || severity < level

      if message.nil?
        if block_given?
          message  = yield
        else
          message  = progname
          progname = @progname
        end
      end

      @logdev.write \
        format_message(format_severity(severity), Time.now, progname, message)
    end
  end
end

Version data entries

46 entries across 43 versions & 9 rubygems

Version Path
activesupport-7.0.5.1 lib/active_support/logger_thread_safe_level.rb
scrapbook-0.3.1 vendor/ruby/2.7.0/gems/activesupport-7.0.3.1/lib/active_support/logger_thread_safe_level.rb
scrapbook-0.3.1 vendor/ruby/2.7.0/gems/activesupport-7.0.2.3/lib/active_support/logger_thread_safe_level.rb
rubypitaya-3.12.5 ./lib/rubypitaya/app-template/vendor/bundle/ruby/3.1.0/gems/activesupport-7.0.4/lib/active_support/logger_thread_safe_level.rb
fablicop-1.10.2 vendor/bundle/ruby/3.2.0/gems/activesupport-7.0.5/lib/active_support/logger_thread_safe_level.rb
activesupport-7.0.5 lib/active_support/logger_thread_safe_level.rb
fluent-plugin-google-cloud-logging-on-prem-0.1.0 vendor/ruby/3.1.0/gems/activesupport-7.0.4.3/lib/active_support/logger_thread_safe_level.rb
activesupport-7.0.4.3 lib/active_support/logger_thread_safe_level.rb
rubypitaya-3.12.4 ./lib/rubypitaya/app-template/vendor/bundle/ruby/3.1.0/gems/activesupport-7.0.4/lib/active_support/logger_thread_safe_level.rb
activesupport-7.0.4.2 lib/active_support/logger_thread_safe_level.rb
rubypitaya-3.12.3 ./lib/rubypitaya/app-template/vendor/bundle/ruby/3.1.0/gems/activesupport-7.0.4/lib/active_support/logger_thread_safe_level.rb
activesupport-7.0.4.1 lib/active_support/logger_thread_safe_level.rb
rubypitaya-3.12.2 ./lib/rubypitaya/app-template/vendor/bundle/ruby/3.1.0/gems/activesupport-7.0.4/lib/active_support/logger_thread_safe_level.rb
activesupport-7.0.4 lib/active_support/logger_thread_safe_level.rb
activesupport-7.0.3.1 lib/active_support/logger_thread_safe_level.rb
activesupport-7.0.3 lib/active_support/logger_thread_safe_level.rb
activesupport-7.0.2.4 lib/active_support/logger_thread_safe_level.rb
activesupport-7.0.2.3 lib/active_support/logger_thread_safe_level.rb
activesupport-7.0.2.2 lib/active_support/logger_thread_safe_level.rb
activesupport-7.0.2.1 lib/active_support/logger_thread_safe_level.rb