2016-01-31 18:16:13 +01:00
|
|
|
# vim: ts=8 sts=2 sw=2 tw=99 et ft=python:
|
|
|
|
import sys
|
|
|
|
import subprocess
|
|
|
|
import os
|
|
|
|
try:
|
|
|
|
import urllib.request as urllib
|
|
|
|
except ImportError:
|
|
|
|
import urllib2 as urllib
|
|
|
|
|
|
|
|
if len(sys.argv) < 3:
|
|
|
|
sys.stderr.write('Usage: <symbol-file> <dump-syms-cmd> <args...>\n')
|
|
|
|
sys.exit(1)
|
|
|
|
|
|
|
|
SYMBOL_SERVER = os.environ['BREAKPAD_SYMBOL_SERVER']
|
|
|
|
symbol_file = sys.argv[1]
|
|
|
|
cmd_argv = sys.argv[2:]
|
|
|
|
|
|
|
|
sys.stdout.write(' '.join(cmd_argv))
|
|
|
|
sys.stdout.write('\n')
|
|
|
|
|
|
|
|
p = subprocess.Popen(
|
|
|
|
args = cmd_argv,
|
|
|
|
stdout = subprocess.PIPE,
|
|
|
|
stderr = subprocess.PIPE,
|
|
|
|
shell = False
|
|
|
|
)
|
|
|
|
stdout, stderr = p.communicate()
|
|
|
|
out = stdout.decode('utf8')
|
|
|
|
err = stdout.decode('utf8')
|
|
|
|
|
|
|
|
with open(symbol_file, 'w') as fp:
|
2016-01-31 18:41:49 +01:00
|
|
|
fp.write(out)
|
|
|
|
fp.write(err)
|
|
|
|
|
|
|
|
lines = out.splitlines()
|
|
|
|
|
|
|
|
paths = set()
|
|
|
|
roots = {}
|
|
|
|
|
|
|
|
# Lets not even talk about this.
|
|
|
|
def fixWindowsPath(path):
|
|
|
|
import ctypes
|
|
|
|
GetShortPathName = ctypes.windll.kernel32.GetShortPathNameW
|
|
|
|
shortp = ctypes.create_unicode_buffer(260)
|
|
|
|
rv = GetShortPathName(path.capitalize(), shortp, 260)
|
|
|
|
if rv == 0 or rv > 260:
|
|
|
|
return path
|
|
|
|
GetLongPathName = ctypes.windll.kernel32.GetLongPathNameW
|
|
|
|
longp = ctypes.create_unicode_buffer(260)
|
|
|
|
rv = GetLongPathName(shortp, longp, 260)
|
|
|
|
if rv == 0 or rv > 260:
|
|
|
|
return path
|
|
|
|
return longp.value
|
|
|
|
|
|
|
|
for i, line in enumerate(lines):
|
|
|
|
line = line.strip().split(None, 2)
|
|
|
|
|
|
|
|
if line[0] != 'FILE':
|
|
|
|
continue
|
|
|
|
|
|
|
|
path = line[2]
|
|
|
|
|
|
|
|
if os.name == 'nt' and os.path.exists(path):
|
|
|
|
path = fixWindowsPath(path)
|
|
|
|
line = ' '.join(['FILE', line[1], path])
|
|
|
|
lines[i] = line
|
|
|
|
|
|
|
|
path = os.path.dirname(path)
|
|
|
|
if path in paths:
|
|
|
|
continue
|
|
|
|
|
|
|
|
paths.add(path)
|
|
|
|
|
|
|
|
root = None
|
|
|
|
url = None
|
|
|
|
rev = None
|
|
|
|
|
|
|
|
with open(os.devnull, 'w') as devnull:
|
|
|
|
def runCommand(argv):
|
|
|
|
proc = subprocess.Popen(argv, stdout=subprocess.PIPE, stderr=devnull, cwd=path, universal_newlines=True)
|
|
|
|
procout, procerr = proc.communicate()
|
|
|
|
if proc.returncode:
|
|
|
|
raise RuntimeError('Failed to execute \'' + ' '.join(argv) + '\' = ' + str(proc.returncode))
|
|
|
|
return procout.strip()
|
|
|
|
|
|
|
|
try:
|
|
|
|
root = runCommand(['git', 'rev-parse', '--show-toplevel'])
|
|
|
|
root = os.path.normpath(root)
|
|
|
|
|
|
|
|
if root in roots:
|
|
|
|
continue
|
|
|
|
|
|
|
|
url = runCommand(['git', 'ls-remote', '--get-url', 'origin'])
|
|
|
|
rev = runCommand(['git', 'log', '--pretty=format:%H', '-n', '1'])
|
|
|
|
except (OSError, RuntimeError) as e:
|
|
|
|
#sys.stderr.write(str(e) + '\n')
|
|
|
|
continue
|
|
|
|
|
|
|
|
roots[root] = (url, rev)
|
|
|
|
|
|
|
|
index = 1
|
|
|
|
while lines[index].split(None, 1)[0] == 'INFO':
|
|
|
|
index += 1;
|
|
|
|
|
|
|
|
for root, info in roots.items():
|
|
|
|
lines.insert(index, 'INFO REPO ' + ' '.join([info[1], info[0], root]))
|
|
|
|
index += 1;
|
|
|
|
|
|
|
|
out = os.linesep.join(lines).encode('utf8')
|
2016-01-31 18:16:13 +01:00
|
|
|
|
|
|
|
request = urllib.Request(SYMBOL_SERVER, out)
|
|
|
|
request.add_header('Content-Type', 'text/plain')
|
2016-01-31 18:41:49 +01:00
|
|
|
server_response = urllib.urlopen(request).read().decode('utf8').strip()
|
2016-01-31 18:16:13 +01:00
|
|
|
print(server_response)
|