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 @@
+