1
0
mirror of https://github.com/gryf/pentadactyl-pm.git synced 2025-12-22 15:48:00 +01:00

add :!! support and don't show error on :!non-existing-command (as the non-existing-command can't be known if it really does not exist)

This commit is contained in:
Martin Stubenschrott
2007-10-09 15:49:18 +00:00
parent 35f1205176
commit 46df40ef03
2 changed files with 32 additions and 17 deletions

View File

@@ -129,6 +129,7 @@ function Commands() //{{{
/////////////////////////////////////////////////////////////////////////////{{{
var ex_commands = [];
var last_run_command = ""; // updated whenever the users runs a command with :!
function addDefaultCommand(command)
{
@@ -177,7 +178,6 @@ function Commands() //{{{
return null;
}
// FIXME: doesn't really belong here...
// return [null, null, null, null, heredoc_tag || false];
// [count, cmd, special, args] = match;
@@ -1764,19 +1764,25 @@ function Commands() //{{{
addDefaultCommand(new Command(["!", "run"],
function(args, special)
{
// TODO: if special, run the last command
// :!! needs to be treated specially as the command parser sets the special flag but removes the ! from args
if (special)
args = "!" + (args || "");
// TODO: better escaping of ! to also substitute \\! correctly
args = args.replace(/(^|[^\\])!/g, "$1" + last_run_command);
last_run_command = args;
var output = vimperator.system(args)
if (typeof output === "string")
if (output)
vimperator.echo(vimperator.util.escapeHTML(output));
else
// FIXME: why are we accepting only a string return value from v.system()? -- djk
vimperator.echoerr("Invalid system command: " + args);
},
{
usage: ["!{command}"],
usage: ["!{cmd}"],
short_help: "Run a command",
help: "Runs {command} through system() and displays its output. " +
"Input redirection (< foo) not done, do not run commands which require stdin or it will hang Firefox!"
help: "Runs <code class=\"argument\">{cmd}</code> through system() and displays its output. " +
"Any '!' in <code class=\"argument\">{cmd}</code> is replaced with the previous external command. " +
"But not when there is a backslash before the '!', then that backslash is removed.<br/>" +
"Input redirection (< foo) not done, also do not run commands which require stdin or it will hang Firefox!"
}
));
//}}}

View File

@@ -543,10 +543,15 @@ const vimperator = (function() //{{{
run: function(program, args, blocking)
{
var file = Cc["@mozilla.org/file/local;1"].createInstance(Ci.nsILocalFile);
const WINDOWS = navigator.platform == "Win32";
var file = Components.classes["@mozilla.org/file/local;1"].
createInstance(Components.interfaces.nsILocalFile);
if (!args)
args = [];
if (typeof(blocking) != "boolean")
blocking = false;
try
{
file.initWithPath(program);
@@ -566,14 +571,14 @@ const vimperator = (function() //{{{
catch (e) { }
}
}
if (!file.exists())
{
vimperator.echoerr("command not found: " + program);
return -1;
}
var process = Components.classes["@mozilla.org/process/util;1"].
createInstance(Components.interfaces.nsIProcess);
var process = Cc["@mozilla.org/process/util;1"].createInstance(Ci.nsIProcess);
process.init(file);
var ec = process.run(blocking, args, args.length);
@@ -582,7 +587,6 @@ const vimperator = (function() //{{{
// when https://bugzilla.mozilla.org/show_bug.cgi?id=68702 is fixed
// is fixed, should use that instead of a tmpfile
// TODO: pass "input" as stdin
// TODO: add shell/shellcmdflag options to replace "sh" and "-c"
system: function (str, input)
{
@@ -607,14 +611,15 @@ const vimperator = (function() //{{{
command += " < \"" + filein.path.replace('"', '\\"') + "\"";
}
var res;
if (WINDOWS)
this.run("cmd.exe", ["/C", command], true);
res = this.run("cmd.exe", ["/C", command], true);
else
this.run("sh", ["-c", command], true);
res = this.run("sh", ["-c", command], true);
var fd = vimperator.fopen(fileout, "<");
if (!fd)
return null;
return "";
var s = fd.read();
fd.close();
@@ -622,6 +627,10 @@ const vimperator = (function() //{{{
if (filein)
filein.remove(false);
// if there is only one \n at the end, chop it off
if (s && s.indexOf("\n") == s.length-1)
s = s.substr(0, s.length-1);
return s;
},