Index: third_party/android_platform/development/scripts/stack
|
diff --git a/third_party/android_platform/development/scripts/stack b/third_party/android_platform/development/scripts/stack
|
index 6bb8d0acb2f71f7ed6f5546243c20ca514a0eb8a..758c412cb7507ce0208a644f8f8c3a7c581b8b48 100755
|
--- a/third_party/android_platform/development/scripts/stack
|
+++ b/third_party/android_platform/development/scripts/stack
|
@@ -17,11 +17,14 @@
|
"""stack symbolizes native crash dumps."""
|
|
import getopt
|
+import glob
|
+import os
|
import sys
|
|
import stack_core
|
+import subprocess
|
import symbol
|
-
|
+import sys
|
|
def PrintUsage():
|
"""Print usage and exit with error."""
|
@@ -29,6 +32,26 @@ def PrintUsage():
|
print
|
print " usage: " + sys.argv[0] + " [options] [FILE]"
|
print
|
+ print " --symbols-dir=path"
|
+ print " the path to a symbols dir, such as =/tmp/out/target/product/dream/symbols"
|
+ print
|
+ print " --chrome-symbols-dir=path"
|
+ print " the path to a Chrome symbols dir (can be absolute or relative"
|
+ print " to src), such as =out/Debug/lib"
|
+ print " If not specified, will look for the newest lib in out/Debug or"
|
+ print " out/Release"
|
+ print
|
+ print " --symbols-zip=path"
|
+ print " the path to a symbols zip file, such as =dream-symbols-12345.zip"
|
+ print
|
+ print " --more-info"
|
+ print " --less-info"
|
+ print " Change the level of detail in the output."
|
+ print " --more-info is slower and more verbose, but more functions will"
|
+ print " be fully qualified with namespace/classname and have full"
|
+ print " argument information. Also, the 'stack data' section will be"
|
+ print " printed."
|
+ print
|
print " --arch=arm|x86"
|
print " the target architecture"
|
print
|
@@ -41,20 +64,78 @@ def PrintUsage():
|
# pylint: enable-msg=C6310
|
sys.exit(1)
|
|
+def UnzipSymbols(symbolfile, symdir=None):
|
+ """Unzips a file to DEFAULT_SYMROOT and returns the unzipped location.
|
+
|
+ Args:
|
+ symbolfile: The .zip file to unzip
|
+ symdir: Optional temporary directory to use for extraction
|
+
|
+ Returns:
|
+ A tuple containing (the directory into which the zip file was unzipped,
|
+ the path to the "symbols" directory in the unzipped file). To clean
|
+ up, the caller can delete the first element of the tuple.
|
+
|
+ Raises:
|
+ SymbolDownloadException: When the unzip fails.
|
+ """
|
+ if not symdir:
|
+ symdir = "%s/%s" % (DEFAULT_SYMROOT, hash(symbolfile))
|
+ if not os.path.exists(symdir):
|
+ os.makedirs(symdir)
|
+
|
+ print "extracting %s..." % symbolfile
|
+ saveddir = os.getcwd()
|
+ os.chdir(symdir)
|
+ try:
|
+ unzipcode = subprocess.call(["unzip", "-qq", "-o", symbolfile])
|
+ if unzipcode > 0:
|
+ os.remove(symbolfile)
|
+ raise SymbolDownloadException("failed to extract symbol files (%s)."
|
+ % symbolfile)
|
+ finally:
|
+ os.chdir(saveddir)
|
+
|
+ android_symbols = glob.glob("%s/out/target/product/*/symbols" % symdir)
|
+ if android_symbols:
|
+ return (symdir, android_symbols[0])
|
+ else:
|
+ # This is a zip of Chrome symbols, so symbol.CHROME_SYMBOLS_DIR needs to be
|
+ # updated to point here.
|
+ symbol.CHROME_SYMBOLS_DIR = symdir
|
+ return (symdir, symdir)
|
+
|
|
def main():
|
try:
|
options, arguments = getopt.getopt(sys.argv[1:], "",
|
- ["arch=",
|
+ ["more-info",
|
+ "less-info",
|
+ "chrome-symbols-dir=",
|
+ "symbols-dir=",
|
+ "symbols-zip=",
|
+ "arch=",
|
"help"])
|
except getopt.GetoptError, unused_error:
|
PrintUsage()
|
|
+ zip_arg = None
|
+ more_info = False
|
for option, value in options:
|
if option == "--help":
|
PrintUsage()
|
+ elif option == "--symbols-dir":
|
+ symbol.SYMBOLS_DIR = os.path.expanduser(value)
|
+ elif option == "--symbols-zip":
|
+ zip_arg = os.path.expanduser(value)
|
elif option == "--arch":
|
symbol.ARCH = value
|
+ elif option == "--chrome-symbols-dir":
|
+ symbol.CHROME_SYMBOLS_DIR = os.path.join(symbol.CHROME_SYMBOLS_DIR, value)
|
+ elif option == "--more-info":
|
+ more_info = True
|
+ elif option == "--less-info":
|
+ more_info = False
|
|
if len(arguments) > 1:
|
PrintUsage()
|
@@ -69,8 +150,19 @@ def main():
|
lines = f.readlines()
|
f.close()
|
|
- print "Reading symbols from", symbol.SYMBOLS_DIR
|
- stack_core.ConvertTrace(lines)
|
+ rootdir = None
|
+ if zip_arg:
|
+ rootdir, symbol.SYMBOLS_DIR = UnzipSymbols(zip_arg)
|
+
|
+ print "Reading Android symbols from", symbol.SYMBOLS_DIR
|
+ print "Reading Chrome symbols from", symbol.CHROME_SYMBOLS_DIR
|
+ stack_core.ConvertTrace(lines, more_info)
|
+
|
+ if rootdir:
|
+ # be a good citizen and clean up...os.rmdir and os.removedirs() don't work
|
+ cmd = "rm -rf \"%s\"" % rootdir
|
+ print "\ncleaning up (%s)" % cmd
|
+ os.system(cmd)
|
|
if __name__ == "__main__":
|
main()
|
|