Revert "Paging is achieved through shell command now"

This reverts commit 243301603e.
This commit is contained in:
Arun Prakash Jana 2023-01-16 00:15:54 +05:30
parent 243301603e
commit df05f593de
3 changed files with 11 additions and 5 deletions

1
nnn.1
View File

@ -448,6 +448,7 @@ separated by \fI;\fR:
add \fB|\fR (pipe) after \fB!\fR
Note: This option is incompatible with \fB&\fR (terminal output is masked
for GUI programs) and ignores \fB*\fR (output is already paged for user).
\fI$nnn\fR must be the last argument in this case as well.
export NNN_PLUG='m:-!|mediainfo $nnn;t:-!|tree -ps;l:-!|ls -lah --group-directories-first'

View File

@ -180,6 +180,7 @@ export NNN_PLUG='m:-!|mediainfo $nnn;t:-!|tree -ps;l:-!|ls -lah --group-director
```
This option is incompatible with `&` (terminal output is masked for GUI programs) and ignores `*` (output is already paged for user).
`$nnn` must be the last argument in this case as well.
Notes:

View File

@ -5192,23 +5192,27 @@ static void setexports(void)
static void run_cmd_as_plugin(const char *file, char *runfile, uchar_t flags)
{
size_t len = xstrsncpy(g_buf, file, PATH_MAX) - 1;
size_t len;
xstrsncpy(g_buf, file, PATH_MAX);
len = xstrlen(g_buf);
if (len > 1 && g_buf[len - 1] == '*') {
flags &= ~F_CONFIRM; /* Skip user confirmation */
g_buf[len - 1] = '\0'; /* Get rid of trailing no confirmation symbol */
--len;
}
if (flags & F_PAGE)
get_output(g_buf, NULL, NULL, -1, TRUE);
else if (flags & F_NOTRACE) {
if ((flags & F_PAGE) || (flags & F_NOTRACE)) {
if (is_suffix(g_buf, " $nnn"))
g_buf[len - 5] = '\0';
else
runfile = NULL;
spawn(g_buf, runfile, NULL, NULL, flags);
if (flags & F_PAGE)
get_output(g_buf, runfile, NULL, -1, TRUE);
else // F_NOTRACE
spawn(g_buf, runfile, NULL, NULL, flags);
} else
spawn(utils[UTIL_SH_EXEC], g_buf, NULL, NULL, flags);
}