blob: 787dc9aedcf1530a0d788fac4f01593a4b3af4e5 [file] [log] [blame]
/*
Copyright (c) 2004-2006, The Dojo Foundation
All Rights Reserved.
Licensed under the Academic Free License version 2.1 or above OR the
modified BSD license. For more information on Dojo licensing, see:
http://dojotoolkit.org/community/licensing.shtml
*/
dojo.provide("dojo.debug");
dojo.debug = function () {
if (!djConfig.isDebug) {
return;
}
var args = arguments;
if (dj_undef("println", dojo.hostenv)) {
dojo.raise("dojo.debug not available (yet?)");
}
var isJUM = dj_global["jum"] && !dj_global["jum"].isBrowser;
var s = [(isJUM ? "" : "DEBUG: ")];
for (var i = 0; i < args.length; ++i) {
if (!false && args[i] && args[i] instanceof Error) {
var msg = "[" + args[i].name + ": " + dojo.errorToString(args[i]) + (args[i].fileName ? ", file: " + args[i].fileName : "") + (args[i].lineNumber ? ", line: " + args[i].lineNumber : "") + "]";
} else {
try {
var msg = String(args[i]);
}
catch (e) {
if (dojo.render.html.ie) {
var msg = "[ActiveXObject]";
} else {
var msg = "[unknown]";
}
}
}
s.push(msg);
}
dojo.hostenv.println(s.join(" "));
};
dojo.debugShallow = function (obj) {
if (!djConfig.isDebug) {
return;
}
dojo.debug("------------------------------------------------------------");
dojo.debug("Object: " + obj);
var props = [];
for (var prop in obj) {
try {
props.push(prop + ": " + obj[prop]);
}
catch (E) {
props.push(prop + ": ERROR - " + E.message);
}
}
props.sort();
for (var i = 0; i < props.length; i++) {
dojo.debug(props[i]);
}
dojo.debug("------------------------------------------------------------");
};
dojo.debugDeep = function (obj) {
if (!djConfig.isDebug) {
return;
}
if (!dojo.uri || !dojo.uri.dojoUri) {
return dojo.debug("You'll need to load dojo.uri.* for deep debugging - sorry!");
}
if (!window.open) {
return dojo.debug("Deep debugging is only supported in host environments with window.open");
}
var idx = dojo.debugDeep.debugVars.length;
dojo.debugDeep.debugVars.push(obj);
var url = (djConfig["dojoDebugDeepHtmlUrl"] || new dojo.uri.Uri(location, dojo.uri.moduleUri("dojo.debug", "deep.html")).toString()) + "?var=" + idx;
var win = window.open(url, "_blank", "width=600, height=400, resizable=yes, scrollbars=yes, status=yes");
try {
win.debugVar = obj;
}
catch (e) {
}
};
dojo.debugDeep.debugVars = [];