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:
@@ -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!"
|
||||
}
|
||||
));
|
||||
//}}}
|
||||
|
||||
@@ -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;
|
||||
},
|
||||
|
||||
|
||||
Reference in New Issue
Block a user