From 4405d993c983a9735c68d4be596e00e1b3b4d9b9 Mon Sep 17 00:00:00 2001 From: Dan Winship Date: Wed, 20 Jul 2011 13:45:31 -0400 Subject: [PATCH] main: add logStackTrace(), for debugging Add Main.logStackTrace(), to print a (javascript) stack trace, which is often useful when debugging. https://bugzilla.gnome.org/show_bug.cgi?id=654987 --- js/ui/main.js | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/js/ui/main.js b/js/ui/main.js index 6cb58fd41..47f6af2cd 100644 --- a/js/ui/main.js +++ b/js/ui/main.js @@ -486,6 +486,18 @@ function _getAndClearErrorStack() { return errors; } +function logStackTrace(msg) { + try { + throw new Error(); + } catch (e) { + // e.stack must have at least two lines, with the first being + // logStackTrace() (which we strip off), and the second being + // our caller. + let trace = e.stack.substr(e.stack.indexOf('\n') + 1); + log(msg ? (msg + '\n' + trace) : trace); + } +} + function isWindowActorDisplayedOnWorkspace(win, workspaceIndex) { return win.get_workspace() == workspaceIndex || (win.get_meta_window() && win.get_meta_window().is_on_all_workspaces());