2 * (C) Copyright 2007 John J. Foerch
3 * (C) Copyright 2007-2008 Jeremy Maitin-Shepard
5 * Use, modification, and distribution are subject to the terms specified in the
9 var MAX_DUMP_DEPTH = 1;
10 function dump_obj_r(obj, name, indent, depth) {
11 if (depth > MAX_DUMP_DEPTH) {
12 return indent + name + ": <Maximum Depth Reached>\n";
14 if (typeof obj == "object") {
16 var output = indent + name + "\n";
23 child = "<Unable to Evaluate>";
25 if (typeof child == "object") {
26 output += dump_obj(child, item, indent, depth + 1);
28 output += indent + item + ": " + child + "\n";
37 function dump_obj (obj, name) {
38 if (typeof obj == "object") {
40 var output = name + "\n";
46 child = "<Unable to Evaluate>";
48 output += item + ": " + child + "\n";
57 * This simple facility can be used to execute arbitrary expression in the context of some point that you'd like to debug.
58 * At that point, simply set some global variable to the result of: eval(DEBUG_HERE);
59 * For example: conkeror.my_debug_ref = eval(DEBUG_HERE);
60 * Then if you call: conkeror.my_debug_ref("some expression"), the specified expression is evaluated in the context
61 * at which eval(DEBUG_HERE) was called.
63 * Note that the unusual identifier __DEBUG_HERE is simply used to
64 * avoid clobbering any identifiers that you might want to examine in
67 const DEBUG_HERE = "function (__DEBUG_HERE) { return eval(__DEBUG_HERE); }";