mirror of
https://github.com/jarun/nnn.git
synced 2024-11-24 20:01:27 +00:00
Quote argument with sh -c
This commit is contained in:
parent
b811997120
commit
6dc151e05d
|
@ -136,7 +136,7 @@ Stripped binary (or script) size and memory usage of `nnn` and some other simila
|
||||||
<b> 1M</b> 50496 <b>15328</b> 4076 S 0.2 vifm
|
<b> 1M</b> 50496 <b>15328</b> 4076 S 0.2 vifm
|
||||||
<b> 1M</b> 72152 <b>12468</b> 7336 S 0.2 mc
|
<b> 1M</b> 72152 <b>12468</b> 7336 S 0.2 mc
|
||||||
<b> 70K</b> 16068 <b> 4620</b> 2408 S 0.1 ncdu
|
<b> 70K</b> 16068 <b> 4620</b> 2408 S 0.1 ncdu
|
||||||
<b> 52K</b> 15712 <b> 4368</b> 2512 S 0.1 nnn -S
|
<b> 55K</b> 15712 <b> 4368</b> 2512 S 0.1 nnn -S
|
||||||
</pre>
|
</pre>
|
||||||
|
|
||||||
Intrigued? Find out [HOW](https://github.com/jarun/nnn/wiki/performance-factors).
|
Intrigued? Find out [HOW](https://github.com/jarun/nnn/wiki/performance-factors).
|
||||||
|
|
59
src/nnn.c
59
src/nnn.c
|
@ -385,6 +385,7 @@ static char * const utils[] = {
|
||||||
#define STR_INVBM_KEY 3
|
#define STR_INVBM_KEY 3
|
||||||
#define STR_COPY_ID 4
|
#define STR_COPY_ID 4
|
||||||
#define STR_DATE_ID 5
|
#define STR_DATE_ID 5
|
||||||
|
#define STR_UNSAFE 6
|
||||||
|
|
||||||
static const char messages[][16] = {
|
static const char messages[][16] = {
|
||||||
"nftw failed",
|
"nftw failed",
|
||||||
|
@ -393,6 +394,7 @@ static const char messages[][16] = {
|
||||||
"invalid key",
|
"invalid key",
|
||||||
"copy not set",
|
"copy not set",
|
||||||
"%F %T %z",
|
"%F %T %z",
|
||||||
|
"unsafe cmd",
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Forward declarations */
|
/* Forward declarations */
|
||||||
|
@ -879,6 +881,49 @@ static void spawn(const char *file, const char *arg1, const char *arg2, const ch
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Quotes argument and spawns a shell command
|
||||||
|
* Uses g_buf
|
||||||
|
*/
|
||||||
|
static bool quote_run_sh_cmd(const char *cmd, const char *arg, const char *path)
|
||||||
|
{
|
||||||
|
const char *ptr;
|
||||||
|
size_t r;
|
||||||
|
|
||||||
|
if (!cmd)
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
r = xstrlcpy(g_buf, cmd, CMD_LEN_MAX);
|
||||||
|
|
||||||
|
if (arg) {
|
||||||
|
if (r >= CMD_LEN_MAX - 4) { /* space for at least 4 chars - space'c' */
|
||||||
|
printmsg(messages[6]);
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (ptr = arg; *ptr; ++ptr)
|
||||||
|
if (*ptr == '\'') {
|
||||||
|
printmsg(messages[6]);
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
g_buf[r - 1] = ' ';
|
||||||
|
g_buf[r] = '\'';
|
||||||
|
r += xstrlcpy(g_buf + r + 1, arg, CMD_LEN_MAX - 1 - r);
|
||||||
|
if (r >= CMD_LEN_MAX - 1) {
|
||||||
|
printmsg(messages[6]);
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
g_buf[r] = '\'';
|
||||||
|
g_buf[r + 1] = '\0';
|
||||||
|
}
|
||||||
|
|
||||||
|
DPRINTF_S(g_buf);
|
||||||
|
spawn("sh", "-c", g_buf, path, F_NORMAL);
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
/* Get program name from env var, else return fallback program */
|
/* Get program name from env var, else return fallback program */
|
||||||
static char *xgetenv(const char *name, char *fallback)
|
static char *xgetenv(const char *name, char *fallback)
|
||||||
{
|
{
|
||||||
|
@ -2717,11 +2762,8 @@ nochange:
|
||||||
if (cfg.useeditor &&
|
if (cfg.useeditor &&
|
||||||
get_output(g_buf, CMD_LEN_MAX, "file", FILE_OPTS, newpath, FALSE) &&
|
get_output(g_buf, CMD_LEN_MAX, "file", FILE_OPTS, newpath, FALSE) &&
|
||||||
strstr(g_buf, "text/") == g_buf) {
|
strstr(g_buf, "text/") == g_buf) {
|
||||||
r = xstrlcpy(g_buf, editor, CMD_LEN_MAX);
|
if (!quote_run_sh_cmd(editor, newpath, path))
|
||||||
g_buf[r - 1] = ' ';
|
goto nochange;
|
||||||
xstrlcpy(g_buf + r, newpath, CMD_LEN_MAX - r);
|
|
||||||
DPRINTF_S(g_buf);
|
|
||||||
spawn("sh", "-c", g_buf, path, F_NORMAL);
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3027,11 +3069,8 @@ nochange:
|
||||||
r = show_help(path);
|
r = show_help(path);
|
||||||
break;
|
break;
|
||||||
case SEL_RUNEDIT:
|
case SEL_RUNEDIT:
|
||||||
r = xstrlcpy(g_buf, editor, CMD_LEN_MAX);
|
if (!quote_run_sh_cmd(editor, dents[cur].name, path))
|
||||||
g_buf[r - 1] = ' ';
|
goto nochange;
|
||||||
xstrlcpy(g_buf + r, dents[cur].name, CMD_LEN_MAX - r);
|
|
||||||
r = TRUE;
|
|
||||||
spawn("sh", "-c", g_buf, path, F_NORMAL);
|
|
||||||
break;
|
break;
|
||||||
case SEL_RUNPAGE:
|
case SEL_RUNPAGE:
|
||||||
r = TRUE;
|
r = TRUE;
|
||||||
|
|
Loading…
Reference in a new issue