Class: DaemonKit::ErrorHandlers::Hoptoad::Backtrace

Inherits:
Object
  • Object
show all
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

Class Method Summary collapse

Instance Method Summary collapse

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

#linesObject

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

#inspectObject



88
89
90
# File 'lib/daemon_kit/error_handlers/hoptoad.rb', line 88

def inspect
  "<Backtrace: " + lines.collect { |line| line.inspect }.join(", ") + ">"
end