diff --git a/Inquirer.js b/Inquirer.js index 29c109e..7f2ffd3 100644 --- a/Inquirer.js +++ b/Inquirer.js @@ -25,15 +25,10 @@ var icon = "", bugico = ""; - // Locals - - var formerOnError; - var inq = this; - var inqapp; + var inq = this, inqapp; // Tools - function objectResume(obj) { var r, k, v; if (obj === null) @@ -86,7 +81,6 @@ } // Methods - function getApp() { if (!inqapp) inqapp = merger.app("inquirer", { @@ -240,14 +234,12 @@ d.style.paddingBottom = "3px"; break; case 'o': - window.console.info(object); d.appendChild(objectResumeLink(object)); d.style.borderBottom = "1px solid #EEE"; head.appendChild(document.createTextNode("<")); head.style.color = "#DDD"; break; case 'e': - window.console.error(object); d.innerText = object; head.appendChild(document.createTextNode("!")); head.style.color = "#F88"; @@ -270,10 +262,20 @@ try { obj = eval('(' + code + ')'); } catch (err) { - this.log('e', err); + window.console.error(err); return; } - this.log('o', obj); + window.console.log(obj); + }, + write: function () { + var k; + for (k in arguments) + this.log('o', arguments[k]); + }, + writeError: function () { + var k; + for (k in arguments) + this.log('e', arguments[k]); }, setError: function (message, data) { this.content.Lerror.setText(message); @@ -307,9 +309,9 @@ getApp().windows.Wmain.close(); } - function hook() { - // On error code controller - formerOnError = window.onerror; + // On error hook + function hookOnError() { + var formerOnError = window.onerror; window.onerror = function (message, source, lineno, colno, err) { error.bind(inq)(message, { "source": source, @@ -317,24 +319,54 @@ "error": err, "raw": arguments }); - formerOnError; + if (formerOnError) + formerOnError.apply(window, arguments); } - // Konami code controller - var ckc = (function (callback) { - var kc = [38, 38, 40, 40, 37, 39, 37, 39, 66, 65]; // Konami code - var kcindex = 0; - return function (e) { - if (e.keyCode == kc[kcindex]) - kcindex++; - else - kcindex = 0; - if (kcindex == kc.length) - callback(); - } - })(function () { - this.show(); - }.bind(this)); - document.addEventListener("keydown", ckc, false); + } + + // Konami code hook + function hookKonamiCode() { + var kc = [38, 38, 40, 40, 37, 39, 37, 39, 66, 65], kcindex = 0 // Konami code + document.addEventListener("keydown", function (e) { + if (e.keyCode == kc[kcindex]) + kcindex++; + else + kcindex = 0; + if (kcindex == kc.length) + inquirer.show(); + }, false); + } + + // Console hook + function hookConsole() { + var wcon = getApp().windows.Wconsole; + if (!window.console) + window.console = {}; + function consoleOverride(method, funct) { + var old = window.console[method]; + window.console[method] = function () { + funct.apply(this, arguments); + if (old) + old.apply(this, arguments); + }; + window.console[method].old = old; + } + consoleOverride("log", function () { + wcon.write.apply(wcon, arguments); + }) + consoleOverride("debug", function () { + wcon.write.apply(wcon, arguments); + }) + consoleOverride("error", function () { + wcon.writeError.apply(wcon, arguments); + }) + } + + // Install hooks + function hook() { + hookOnError(); + hookKonamiCode(); + hookConsole(); } function error(message, data) { @@ -350,14 +382,15 @@ } function console() { - + getApp().showConsole(); + show(); } function log() { - + getApp().windows.Wconsole.write.apply(getApp().windows.Wconsole, arguments); } - // Publish + // Publish this.merge({ autoShow: true, // Open Inquirer environment when a new unhandled error happen show: show, // Enters environment diff --git a/WebInquirer.html b/WebInquirer.html index 36d6d31..d617a0d 100644 --- a/WebInquirer.html +++ b/WebInquirer.html @@ -46,6 +46,7 @@


+