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_r(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";
56 function get_interface_info(o) {
60 o.QueryInterface(Ci[x]);
64 o.QueryInterface(Ci.nsIInterfaceRequestor).getInterface(Ci[x]);
65 output += x + " (getInterface)\n";
74 * This simple facility can be used to execute arbitrary expression in the context of some point that you'd like to debug.
75 * At that point, simply set some global variable to the result of: eval(DEBUG_HERE);
76 * For example: conkeror.my_debug_ref = eval(DEBUG_HERE);
77 * Then if you call: conkeror.my_debug_ref("some expression"), the specified expression is evaluated in the context
78 * at which eval(DEBUG_HERE) was called.
80 * Note that the unusual identifier __DEBUG_HERE is simply used to
81 * avoid clobbering any identifiers that you might want to examine in
84 const DEBUG_HERE = "function (__DEBUG_HERE) { return eval(__DEBUG_HERE); }";