Class: DaemonKit::ErrorHandlers::Hoptoad::Backtrace
- Defined in:
- lib/daemon_kit/error_handlers/hoptoad.rb
Overview
Front end to parsing the backtrace for each notice (Graciously borrowed from github.com/thoughtbot/hoptoad_notifier)
Defined Under Namespace
Classes: Line
Instance Attribute Summary collapse
-
#lines ⇒ Object
readonly
holder for an Array of Backtrace::Line instances.
Class Method Summary collapse
Instance Method Summary collapse
- #==(other) ⇒ Object
-
#initialize(lines) ⇒ Backtrace
constructor
A new instance of Backtrace.
- #inspect ⇒ Object
Constructor Details
#initialize(lines) ⇒ Backtrace
Returns a new instance of Backtrace.
84 85 86 |
# File 'lib/daemon_kit/error_handlers/hoptoad.rb', line 84 def initialize(lines) self.lines = lines end |
Instance Attribute Details
#lines ⇒ Object
holder for an Array of Backtrace::Line instances
65 66 67 |
# File 'lib/daemon_kit/error_handlers/hoptoad.rb', line 65 def lines @lines end |
Class Method Details
.parse(ruby_backtrace, opts = {}) ⇒ Object
67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 |
# File 'lib/daemon_kit/error_handlers/hoptoad.rb', line 67 def self.parse(ruby_backtrace, opts = {}) ruby_lines = split_multiline_backtrace(ruby_backtrace) filters = opts[:filters] || [] filtered_lines = ruby_lines.to_a.map do |line| filters.inject(line) do |line, proc| proc.call(line) end end.compact lines = filtered_lines.collect do |unparsed_line| Line.parse(unparsed_line) end instance = new(lines) end |
Instance Method Details
#==(other) ⇒ Object
92 93 94 95 96 97 98 |
# File 'lib/daemon_kit/error_handlers/hoptoad.rb', line 92 def ==(other) if other.respond_to?(:lines) lines == other.lines else false end end |
#inspect ⇒ Object
88 89 90 |
# File 'lib/daemon_kit/error_handlers/hoptoad.rb', line 88 def inspect "<Backtrace: " + lines.collect { |line| line.inspect }.join(", ") + ">" end |