aboutsummaryrefslogtreecommitdiffstats
path: root/activesupport/lib/active_support/logger_silence.rb
diff options
context:
space:
mode:
authorDavid Heinemeier Hansson <david@loudthinking.com>2012-12-21 19:35:10 +0100
committerDavid Heinemeier Hansson <david@loudthinking.com>2012-12-21 19:35:10 +0100
commit95f5f8167ff86550d7fa9f5f7419cc9b38ef9704 (patch)
treed30a605ded5ac89a5c95e9e382eaa1cabf52507e /activesupport/lib/active_support/logger_silence.rb
parentd00f568a83a5159ed93618b1081bd17858536d1c (diff)
downloadrails-95f5f8167ff86550d7fa9f5f7419cc9b38ef9704.tar.gz
rails-95f5f8167ff86550d7fa9f5f7419cc9b38ef9704.tar.bz2
rails-95f5f8167ff86550d7fa9f5f7419cc9b38ef9704.zip
Revert "Make sure that ActiveSupport::Logger includes the Logger extensions from core_ext/logger" (some confusion over deprecation)
This reverts commit d00f568a83a5159ed93618b1081bd17858536d1c.
Diffstat (limited to 'activesupport/lib/active_support/logger_silence.rb')
-rw-r--r--activesupport/lib/active_support/logger_silence.rb24
1 files changed, 24 insertions, 0 deletions
diff --git a/activesupport/lib/active_support/logger_silence.rb b/activesupport/lib/active_support/logger_silence.rb
new file mode 100644
index 0000000000..a8efdef944
--- /dev/null
+++ b/activesupport/lib/active_support/logger_silence.rb
@@ -0,0 +1,24 @@
+require 'active_support/concern'
+
+module LoggerSilence
+ extend ActiveSupport::Concern
+
+ included do
+ cattr_accessor :silencer
+ self.silencer = true
+ end
+
+ # Silences the logger for the duration of the block.
+ def silence(temporary_level = Logger::ERROR)
+ if silencer
+ begin
+ old_logger_level, self.level = level, temporary_level
+ yield self
+ ensure
+ self.level = old_logger_level
+ end
+ else
+ yield self
+ end
+ end
+end \ No newline at end of file