Index: src/processor/minidump_stackwalk.cc |
diff --git a/src/processor/minidump_stackwalk.cc b/src/processor/minidump_stackwalk.cc |
index 8f83969fef1be48e0cdcf44273515694712fe95c..b01d92f488faecefa7d1679f0996b16f77ee4002 100644 |
--- a/src/processor/minidump_stackwalk.cc |
+++ b/src/processor/minidump_stackwalk.cc |
@@ -71,7 +71,8 @@ using google_breakpad::scoped_ptr; |
bool PrintMinidumpProcess(const string &minidump_file, |
const std::vector<string> &symbol_paths, |
bool machine_readable, |
- bool output_stack_contents) { |
+ bool output_stack_contents, |
+ bool output_modules_only) { |
scoped_ptr<SimpleSymbolSupplier> symbol_supplier; |
if (!symbol_paths.empty()) { |
// TODO(mmentovai): check existence of symbol_path if specified? |
@@ -94,7 +95,10 @@ bool PrintMinidumpProcess(const string &minidump_file, |
return false; |
} |
- if (machine_readable) { |
+ if (output_modules_only) { |
+ PrintProcessModules(process_state); |
+ } |
+ else if (machine_readable) { |
Lei Zhang
2016/01/29 20:27:37
nit: merge with prev line
David Yen
2016/01/29 20:36:26
Done.
|
PrintProcessStateMachineReadable(process_state); |
} else { |
PrintProcessState(process_state, output_stack_contents, &resolver); |
@@ -106,7 +110,8 @@ bool PrintMinidumpProcess(const string &minidump_file, |
void usage(const char *program_name) { |
fprintf(stderr, "usage: %s [-m|-s] <minidump-file> [symbol-path ...]\n" |
Lei Zhang
2016/01/29 20:27:37
Update this to mention -b
David Yen
2016/01/29 20:36:26
Done.
|
" -m : Output in machine-readable format\n" |
- " -s : Output stack contents\n", |
+ " -s : Output stack contents\n" |
+ " -b : Output contained binary modules\n", |
program_name); |
} |
@@ -123,6 +128,7 @@ int main(int argc, char **argv) { |
const char *minidump_file; |
bool machine_readable = false; |
bool output_stack_contents = false; |
+ bool output_modules_only = false; |
int symbol_path_arg; |
if (strcmp(argv[1], "-m") == 0) { |
@@ -143,7 +149,16 @@ int main(int argc, char **argv) { |
output_stack_contents = true; |
minidump_file = argv[2]; |
symbol_path_arg = 3; |
- } else { |
+ } if (strcmp(argv[1], "-b") == 0) { |
Lei Zhang
2016/01/29 20:27:37
else if?
David Yen
2016/01/29 20:36:26
Done. I think this is what was breaking the other
|
+ if (argc < 3) { |
+ usage(argv[0]); |
+ return 1; |
+ } |
+ |
+ output_modules_only = true; |
+ minidump_file = argv[2]; |
+ symbol_path_arg = 3; |
+ }else { |
minidump_file = argv[1]; |
symbol_path_arg = 2; |
} |
@@ -158,5 +173,6 @@ int main(int argc, char **argv) { |
return PrintMinidumpProcess(minidump_file, |
symbol_paths, |
machine_readable, |
- output_stack_contents) ? 0 : 1; |
+ output_stack_contents, |
+ output_modules_only) ? 0 : 1; |
} |