Module: ActiveSupport::LoggerThreadSafeLevel
- Extended by:
- Concern
- Defined in:
- activesupport/lib/active_support/logger_thread_safe_level.rb
Overview
Instance Method Summary
collapse
Methods included from Concern
append_features, class_methods, extended, included
Instance Method Details
#add(severity, message = nil, progname = nil, &block) ⇒ Object
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.
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
|
# File 'activesupport/lib/active_support/logger_thread_safe_level.rb', line 66
def add(severity, message = nil, progname = nil, &block) 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
|
#after_initialize ⇒ Object
24
25
26
27
28
29
|
# File 'activesupport/lib/active_support/logger_thread_safe_level.rb', line 24
def after_initialize
ActiveSupport::Deprecation.warn(
"Logger don't need to call #after_initialize directly anymore. It will be deprecated without replacement in " \
"Rails 6.1."
)
end
|
52
53
54
|
# File 'activesupport/lib/active_support/logger_thread_safe_level.rb', line 52
def level
local_level || super
end
|
#local_level ⇒ Object
35
36
37
|
# File 'activesupport/lib/active_support/logger_thread_safe_level.rb', line 35
def local_level
self.class.local_levels[local_log_id]
end
|
#local_level=(level) ⇒ Object
39
40
41
42
43
44
45
46
47
48
49
50
|
# File 'activesupport/lib/active_support/logger_thread_safe_level.rb', line 39
def local_level=(level)
case level
when Integer
self.class.local_levels[local_log_id] = level
when Symbol
self.class.local_levels[local_log_id] = Logger::Severity.const_get(level.to_s.upcase)
when nil
self.class.local_levels.delete(local_log_id)
else
raise ArgumentError, "Invalid log level: #{level.inspect}"
end
end
|
#local_log_id ⇒ Object
31
32
33
|
# File 'activesupport/lib/active_support/logger_thread_safe_level.rb', line 31
def local_log_id
Fiber.current.__id__
end
|
#log_at(level) ⇒ Object
Change the thread-local level for the duration of the given block.
57
58
59
60
61
62
|
# File 'activesupport/lib/active_support/logger_thread_safe_level.rb', line 57
def log_at(level)
old_local_level, self.local_level = local_level, level
yield
ensure
self.local_level = old_local_level
end
|