mirror of
https://github.com/gryf/pentadactyl-pm.git
synced 2026-04-11 00:33:32 +02:00
Much more advanced :echo[err] methods which can print objects/etc. through eval()
This commit is contained in:
@@ -483,15 +483,53 @@ function Commands() //{{{
|
|||||||
"Here, downloads can be paused, canceled and resumed."
|
"Here, downloads can be paused, canceled and resumed."
|
||||||
}
|
}
|
||||||
));
|
));
|
||||||
addDefaultCommand(new Command(["ec[ho]"],
|
|
||||||
function(args) { vimperator.echo(args); } ,
|
function argToString(arg, color)
|
||||||
|
{
|
||||||
|
try
|
||||||
{
|
{
|
||||||
|
// TODO: move to vimperator.eval()?
|
||||||
|
arg = eval(arg);
|
||||||
|
}
|
||||||
|
catch (e)
|
||||||
|
{
|
||||||
|
vimperator.echoerr(e.toString());
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (typeof arg === "object")
|
||||||
|
arg = vimperator.objectToString(arg, color);
|
||||||
|
else if (typeof arg === "function")
|
||||||
|
arg = arg.toString().replace(/</g, "<").replace(/>/, ">");
|
||||||
|
else if (typeof arg === "number" || typeof arg === "boolean")
|
||||||
|
arg = "" + arg;
|
||||||
|
else if (typeof arg === "undefined")
|
||||||
|
arg = "undefined";
|
||||||
|
|
||||||
|
return arg;
|
||||||
|
}
|
||||||
|
addDefaultCommand(new Command(["ec[ho]"],
|
||||||
|
function(args)
|
||||||
|
{
|
||||||
|
var res = argToString(args, true);
|
||||||
|
if (res != null)
|
||||||
|
vimperator.echo(res);
|
||||||
|
},
|
||||||
|
{
|
||||||
|
usage: ["ec[ho] {arg}"],
|
||||||
short_help: "Display a string at the bottom of the window",
|
short_help: "Display a string at the bottom of the window",
|
||||||
help: "Echo all arguments of this command. Useful for showing informational messages.<br/>Multiple lines can be separated by \\n."
|
help: "Useful for showing informational messages.Multiple lines can be separated by \\n.<br/>" +
|
||||||
|
"<code class=\"argument\"}{arg}</code> can either be a quoted string, or any expression which can be fed to eval() like 4+5. " +
|
||||||
|
"You can also view the source code of objects and functions if the return value of <code class=\"argument\">{arg}</code> is an object or function."
|
||||||
}
|
}
|
||||||
));
|
));
|
||||||
addDefaultCommand(new Command(["echoe[rr]"],
|
addDefaultCommand(new Command(["echoe[rr]"],
|
||||||
function(args) { vimperator.echoerr(args); } ,
|
function(args)
|
||||||
|
{
|
||||||
|
var res = argToString(args, false);
|
||||||
|
if (res != null)
|
||||||
|
vimperator.echoerr(res);
|
||||||
|
},
|
||||||
{
|
{
|
||||||
short_help: "Display an error string at the bottom of the window",
|
short_help: "Display an error string at the bottom of the window",
|
||||||
help: "Echo all arguments of this command highlighted in red. Useful for showing important messages."
|
help: "Echo all arguments of this command highlighted in red. Useful for showing important messages."
|
||||||
@@ -1565,7 +1603,7 @@ function Commands() //{{{
|
|||||||
// TODO: if special, run the last command
|
// TODO: if special, run the last command
|
||||||
var output = vimperator.system(args)
|
var output = vimperator.system(args)
|
||||||
if (typeof output === "string")
|
if (typeof output === "string")
|
||||||
vimperator.echo("<pre>" + output + "</pre>");
|
vimperator.echo(output);
|
||||||
else
|
else
|
||||||
vimperator.echoerr("Invalid system command: " + args);
|
vimperator.echoerr("Invalid system command: " + args);
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -185,9 +185,7 @@ function CommandLine() //{{{
|
|||||||
|
|
||||||
multiline_input_widget.collapsed = true;
|
multiline_input_widget.collapsed = true;
|
||||||
|
|
||||||
var output = str.replace(/\n|\\n/g, "<br/>");
|
var output = "<pre>" + str + "</pre>";
|
||||||
//output = ":" + command_widget.value + "<br/>" + output;
|
|
||||||
output += "<br/>"
|
|
||||||
output += '<span id="end-prompt" style="color: green; background-color: white;">Press ENTER or type command to continue</span>';
|
output += '<span id="end-prompt" style="color: green; background-color: white;">Press ENTER or type command to continue</span>';
|
||||||
output += '<span id="more-prompt" style="display: none; position: fixed; top: auto; bottom: 0; left: 0; right: 0; color: green; background-color: white;">';
|
output += '<span id="more-prompt" style="display: none; position: fixed; top: auto; bottom: 0; left: 0; right: 0; color: green; background-color: white;">';
|
||||||
output += "-- More --";
|
output += "-- More --";
|
||||||
@@ -289,7 +287,7 @@ function CommandLine() //{{{
|
|||||||
str = "";
|
str = "";
|
||||||
|
|
||||||
setNormalStyle();
|
setNormalStyle();
|
||||||
if (flags || str.indexOf("\n") > -1 || str.indexOf("\\n") > -1 || str.indexOf("<br>") > -1 || str.indexOf("<br/>") > -1)
|
if (flags || str.indexOf("\n") > -1 || str.indexOf("<br>") > -1 || str.indexOf("<br/>") > -1)
|
||||||
{
|
{
|
||||||
setMultiline(str);
|
setMultiline(str);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -346,39 +346,89 @@ const vimperator = (function() //{{{
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
// logs a message to the javascript error console
|
// if color = true it uses HTML markup to color certain items
|
||||||
log: function(msg, level)
|
objectToString: function(object, color)
|
||||||
{
|
{
|
||||||
// if (Options.getPref("verbose") >= level) // FIXME: hangs vimperator, probably timing issue --mst
|
if (object === null)
|
||||||
console_service.logStringMessage('vimperator: ' + msg);
|
return "null";
|
||||||
},
|
if (typeof object != "object")
|
||||||
|
|
||||||
// log an object to the javascript error console and print all
|
|
||||||
// properties of the object
|
|
||||||
logObject: function(object, level)
|
|
||||||
{
|
|
||||||
if (typeof object != 'object')
|
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
var string = object + '::\n';
|
var string = "";
|
||||||
|
var obj = "";
|
||||||
|
try { // for window.JSON
|
||||||
|
obj = object.toString();
|
||||||
|
} catch (e) {
|
||||||
|
obj = "<Object>";
|
||||||
|
}
|
||||||
|
|
||||||
|
if (color)
|
||||||
|
string += "<span style=\"color: magenta; font-weight: bold;\">" + obj + "</span>::\n";
|
||||||
|
else
|
||||||
|
string += obj + "::\n";
|
||||||
|
|
||||||
for (var i in object)
|
for (var i in object)
|
||||||
{
|
{
|
||||||
var value;
|
var value;
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
var value = object[i];
|
if (i == "JSON") // without this ugly hack, ":echo window" does not work
|
||||||
|
value = "[object JSON]";
|
||||||
|
else
|
||||||
|
value = object[i];
|
||||||
}
|
}
|
||||||
catch (e)
|
catch (e)
|
||||||
{
|
{
|
||||||
value = "";
|
value = "";
|
||||||
}
|
}
|
||||||
|
|
||||||
string += i + ": " + value + "\n";
|
if (color)
|
||||||
|
{
|
||||||
|
// syntax highlighting for special items
|
||||||
|
if (typeof value === "number")
|
||||||
|
value = "<span style=\"color: red;\">" + value + "</span>";
|
||||||
|
else if (typeof value === "string")
|
||||||
|
{
|
||||||
|
value = value.replace(/\n/, "\\n").replace(/</, "<");
|
||||||
|
value = "<span style=\"color: green;\">\"" + value + "\"</span>";
|
||||||
|
}
|
||||||
|
else if (typeof value === "boolean")
|
||||||
|
value = "<span style=\"color: blue;\">" + value + "</span>";
|
||||||
|
else if (value == null || value == "undefined")
|
||||||
|
value = "<span style=\"color: blue;\">" + value + "</span>";
|
||||||
|
else if (typeof value === "object" || typeof value === "function")
|
||||||
|
{
|
||||||
|
// for java packages value.toString() would crash so badly
|
||||||
|
// that we cannot even try/catch it
|
||||||
|
if (/^\[JavaPackage.*\]$/.test(value))
|
||||||
|
value = "[JavaPackage]";
|
||||||
|
else
|
||||||
|
{
|
||||||
|
var str = value.toString();
|
||||||
|
if (typeof str == "string") // can be "undefined"
|
||||||
|
value = str.replace(/</g, "<").replace(/>/g, ">");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
string += "<span style=\"font-weight: bold;\">" + i + "</span>: " + value + "\n";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
string += i + ": " + value + "\n";
|
||||||
}
|
}
|
||||||
vimperator.log(string, level);
|
|
||||||
return string;
|
return string;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
// logs a message to the javascript error console
|
||||||
|
// if msg is an object, it is beautified
|
||||||
|
log: function(msg, level)
|
||||||
|
{
|
||||||
|
//if (Options.getPref("verbose") >= level) // FIXME: hangs vimperator, probably timing issue --mst
|
||||||
|
if (typeof msg == "object")
|
||||||
|
msg = this.objectToString(msg, false);
|
||||||
|
|
||||||
|
console_service.logStringMessage('vimperator: ' + msg);
|
||||||
|
},
|
||||||
|
|
||||||
// open one or more URLs
|
// open one or more URLs
|
||||||
//
|
//
|
||||||
// @param urls: either a string or an array of urls
|
// @param urls: either a string or an array of urls
|
||||||
|
|||||||
Reference in New Issue
Block a user