Module: ActiveSupport::TaggedLogging::Formatter

Defined in:
activesupport/lib/active_support/tagged_logging.rb

Overview

:nodoc:

Instance Method Summary collapse

Instance Method Details

#call(severity, timestamp, progname, msg) ⇒ Object

This method is invoked when a log event occurs.



33
34
35
# File 'activesupport/lib/active_support/tagged_logging.rb', line 33

def call(severity, timestamp, progname, msg)
  super(severity, timestamp, progname, tag_stack.format_message(msg))
end

#clear_tags!Object



52
53
54
# File 'activesupport/lib/active_support/tagged_logging.rb', line 52

def clear_tags!
  tag_stack.clear
end

#current_tagsObject



62
63
64
# File 'activesupport/lib/active_support/tagged_logging.rb', line 62

def current_tags
  tag_stack.tags
end

#pop_tags(count = 1) ⇒ Object



48
49
50
# File 'activesupport/lib/active_support/tagged_logging.rb', line 48

def pop_tags(count = 1)
  tag_stack.pop_tags(count)
end

#push_tags(*tags) ⇒ Object



44
45
46
# File 'activesupport/lib/active_support/tagged_logging.rb', line 44

def push_tags(*tags)
  tag_stack.push_tags(tags)
end

#tag_stackObject



56
57
58
59
60
# File 'activesupport/lib/active_support/tagged_logging.rb', line 56

def tag_stack
  # We use our object ID here to avoid conflicting with other instances
  @thread_key ||= "activesupport_tagged_logging_tags:#{object_id}"
  IsolatedExecutionState[@thread_key] ||= TagStack.new
end

#tagged(*tags) ⇒ Object



37
38
39
40
41
42
# File 'activesupport/lib/active_support/tagged_logging.rb', line 37

def tagged(*tags)
  pushed_count = tag_stack.push_tags(tags).size
  yield self
ensure
  pop_tags(pushed_count)
end

#tags_textObject



66
67
68
# File 'activesupport/lib/active_support/tagged_logging.rb', line 66

def tags_text
  tag_stack.format_message("")
end