54 lines
1.5 KiB
CoffeeScript
Executable file
54 lines
1.5 KiB
CoffeeScript
Executable file
#!/usr/bin/env coffee
|
|
# Usage:
|
|
# Copy the crash log into pasteboard and then run
|
|
# pbpaste | ./script/translate-crash-log-addresses.coffee
|
|
|
|
atos = (addresses, callback) ->
|
|
path = require 'path'
|
|
exec = require('child_process').exec
|
|
|
|
exec 'atos -o vendor/brightray/vendor/download/libchromiumcontent/Release/libchromiumcontent.dylib -arch i386 '.concat(addresses...), (error, stdout, stderr) ->
|
|
throw error if error?
|
|
callback stdout.split('\n')
|
|
|
|
parse_stack_trace = (raw) ->
|
|
lines = {}
|
|
addresses = []
|
|
for line in raw
|
|
columns = line.split /\ +/
|
|
if columns[1] == 'libchromiumcontent.dylib' and /0x[a-f0-9]+/.test columns[3]
|
|
lines[columns[0]] = addresses.length
|
|
addresses.push '0x' + parseInt(columns[5]).toString(16) + ' '
|
|
|
|
atos addresses, (parsed) ->
|
|
for line in raw
|
|
columns = line.split /\ +/
|
|
frame = columns[0]
|
|
if lines[frame]?
|
|
console.log frame, parsed[lines[frame]]
|
|
else
|
|
console.log line
|
|
|
|
parse_log_file = (content) ->
|
|
state = 'start'
|
|
stack_trace = []
|
|
lines = content.split /\r?\n/
|
|
|
|
for line in lines
|
|
if state == 'start'
|
|
if /Thread \d+ Crashed::/.test line
|
|
console.log line
|
|
state = 'parse'
|
|
else if state == 'parse'
|
|
break if line == ''
|
|
stack_trace.push line
|
|
|
|
parse_stack_trace stack_trace
|
|
|
|
input = ''
|
|
process.stdin.resume()
|
|
process.stdin.setEncoding 'utf8'
|
|
process.stdin.on 'data', (chunk) ->
|
|
input += chunk
|
|
process.stdin.on 'end', ->
|
|
parse_log_file input
|