Sha256: e97abc3e88bc7b2e1d66ce83deed9ef61358a5720ff3448dc977fbcbeaaba67d

Contents?: true

Size: 1.04 KB

Versions: 23

Compression:

Stored size: 1.04 KB

Contents

# frozen_string_literal: true

require "active_support/concern"
require "logger"

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

    def local_level
      IsolatedExecutionState[local_level_key]
    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
      if level.nil?
        IsolatedExecutionState.delete(local_level_key)
      else
        IsolatedExecutionState[local_level_key] = level
      end
    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

    private
      def local_level_key
        @local_level_key ||= :"logger_thread_safe_level_#{object_id}"
      end
  end
end

Version data entries

23 entries across 23 versions & 3 rubygems

Version Path
activesupport-8.0.2 lib/active_support/logger_thread_safe_level.rb
tailscale_middleware-0.0.3 vendor/cache/ruby/3.4.0/gems/activesupport-8.0.1/lib/active_support/logger_thread_safe_level.rb
activesupport-8.0.1 lib/active_support/logger_thread_safe_level.rb
activesupport-8.0.0.1 lib/active_support/logger_thread_safe_level.rb
activesupport-7.2.2.1 lib/active_support/logger_thread_safe_level.rb
activesupport-8.0.0 lib/active_support/logger_thread_safe_level.rb
activesupport-7.2.2 lib/active_support/logger_thread_safe_level.rb
activesupport-8.0.0.rc2 lib/active_support/logger_thread_safe_level.rb
activesupport-7.2.1.2 lib/active_support/logger_thread_safe_level.rb
activesupport-8.0.0.rc1 lib/active_support/logger_thread_safe_level.rb
activesupport-7.2.1.1 lib/active_support/logger_thread_safe_level.rb
activesupport-8.0.0.beta1 lib/active_support/logger_thread_safe_level.rb
omg-activesupport-8.0.0.alpha9 lib/active_support/logger_thread_safe_level.rb
omg-activesupport-8.0.0.alpha8 lib/active_support/logger_thread_safe_level.rb
omg-activesupport-8.0.0.alpha7 lib/active_support/logger_thread_safe_level.rb
omg-activesupport-8.0.0.alpha4 lib/active_support/logger_thread_safe_level.rb
omg-activesupport-8.0.0.alpha3 lib/active_support/logger_thread_safe_level.rb
omg-activesupport-8.0.0.alpha2 lib/active_support/logger_thread_safe_level.rb
omg-activesupport-8.0.0.alpha1 lib/active_support/logger_thread_safe_level.rb
activesupport-7.2.1 lib/active_support/logger_thread_safe_level.rb