mirror of
https://github.com/jarun/nnn.git
synced 2025-01-15 13:26:37 +00:00
Option -B to use bsdtar as archive tool
This commit is contained in:
parent
49a0d9d02c
commit
e73b57c78a
|
@ -15,6 +15,7 @@ _nnn ()
|
||||||
-a
|
-a
|
||||||
-A
|
-A
|
||||||
-b
|
-b
|
||||||
|
-B
|
||||||
-c
|
-c
|
||||||
-C
|
-C
|
||||||
-d
|
-d
|
||||||
|
|
|
@ -14,6 +14,7 @@ end
|
||||||
complete -c nnn -s a -d 'auto-create NNN_FIFO'
|
complete -c nnn -s a -d 'auto-create NNN_FIFO'
|
||||||
complete -c nnn -s A -d 'disable dir auto-enter'
|
complete -c nnn -s A -d 'disable dir auto-enter'
|
||||||
complete -c nnn -s b -r -d 'bookmark key to open' -x -a '(echo $NNN_BMS | awk -F: -v RS=\; \'{print $1"\t"$2}\')'
|
complete -c nnn -s b -r -d 'bookmark key to open' -x -a '(echo $NNN_BMS | awk -F: -v RS=\; \'{print $1"\t"$2}\')'
|
||||||
|
complete -c nnn -s B -d 'use bsdtar for archives'
|
||||||
complete -c nnn -s c -d 'cli-only opener'
|
complete -c nnn -s c -d 'cli-only opener'
|
||||||
complete -c nnn -s C -d 'color by context'
|
complete -c nnn -s C -d 'color by context'
|
||||||
complete -c nnn -s d -d 'start in detail mode'
|
complete -c nnn -s d -d 'start in detail mode'
|
||||||
|
|
|
@ -12,6 +12,7 @@ args=(
|
||||||
'(-a)-a[auto-create NNN_FIFO]'
|
'(-a)-a[auto-create NNN_FIFO]'
|
||||||
'(-A)-A[disable dir auto-enter]'
|
'(-A)-A[disable dir auto-enter]'
|
||||||
'(-b)-b[bookmark key to open]:key char'
|
'(-b)-b[bookmark key to open]:key char'
|
||||||
|
'(-B)-B[use bsdtar for archives]'
|
||||||
'(-c)-c[cli-only opener]'
|
'(-c)-c[cli-only opener]'
|
||||||
'(-C)-C[color by context]'
|
'(-C)-C[color by context]'
|
||||||
'(-d)-d[start in detail mode]'
|
'(-d)-d[start in detail mode]'
|
||||||
|
|
3
nnn.1
3
nnn.1
|
@ -53,6 +53,9 @@ supports the following options:
|
||||||
.Fl "b key"
|
.Fl "b key"
|
||||||
specify bookmark key to open
|
specify bookmark key to open
|
||||||
.Pp
|
.Pp
|
||||||
|
.Fl B
|
||||||
|
use bsdtar for archives (default: atool)
|
||||||
|
.Pp
|
||||||
.Fl c
|
.Fl c
|
||||||
indicates that the opener is a cli-only opener (overrides -e)
|
indicates that the opener is a cli-only opener (overrides -e)
|
||||||
.Pp
|
.Pp
|
||||||
|
|
13
src/nnn.c
13
src/nnn.c
|
@ -373,7 +373,8 @@ typedef struct {
|
||||||
uint_t stayonsel : 1; /* Disable auto-advance on selection */
|
uint_t stayonsel : 1; /* Disable auto-advance on selection */
|
||||||
uint_t trash : 2; /* Trash method 0: rm -rf, 1: trash-cli, 2: gio trash */
|
uint_t trash : 2; /* Trash method 0: rm -rf, 1: trash-cli, 2: gio trash */
|
||||||
uint_t uidgid : 1; /* Show owner and group info */
|
uint_t uidgid : 1; /* Show owner and group info */
|
||||||
uint_t reserved : 6; /* Adjust when adding/removing a field */
|
uint_t usebsdtar : 1; /* Use bsdtar as default archive utility */
|
||||||
|
uint_t reserved : 5; /* Adjust when adding/removing a field */
|
||||||
} runstate;
|
} runstate;
|
||||||
|
|
||||||
/* Contexts or workspaces */
|
/* Contexts or workspaces */
|
||||||
|
@ -2670,7 +2671,7 @@ static void get_archive_cmd(char *cmd, const char *archive)
|
||||||
{
|
{
|
||||||
uchar_t i = 3;
|
uchar_t i = 3;
|
||||||
|
|
||||||
if (getutil(utils[UTIL_ATOOL]))
|
if (!g_state.usebsdtar && getutil(utils[UTIL_ATOOL]))
|
||||||
i = 0;
|
i = 0;
|
||||||
else if (getutil(utils[UTIL_BSDTAR]))
|
else if (getutil(utils[UTIL_BSDTAR]))
|
||||||
i = 1;
|
i = 1;
|
||||||
|
@ -4573,7 +4574,7 @@ static bool handle_archive(char *fpath /* in-out param */, char op)
|
||||||
char arg[] = "-tvf"; /* options for tar/bsdtar to list files */
|
char arg[] = "-tvf"; /* options for tar/bsdtar to list files */
|
||||||
char *util, *outdir = NULL;
|
char *util, *outdir = NULL;
|
||||||
bool x_to = FALSE;
|
bool x_to = FALSE;
|
||||||
bool is_atool = getutil(utils[UTIL_ATOOL]);
|
bool is_atool = (!g_state.usebsdtar && getutil(utils[UTIL_ATOOL]));
|
||||||
|
|
||||||
if (op == 'x') {
|
if (op == 'x') {
|
||||||
outdir = xreadline(is_atool ? "." : xbasename(fpath), messages[MSG_NEW_PATH]);
|
outdir = xreadline(is_atool ? "." : xbasename(fpath), messages[MSG_NEW_PATH]);
|
||||||
|
@ -8095,6 +8096,7 @@ static void usage(void)
|
||||||
#endif
|
#endif
|
||||||
" -A no dir auto-enter during filter\n"
|
" -A no dir auto-enter during filter\n"
|
||||||
" -b key open bookmark key (trumps -s/S)\n"
|
" -b key open bookmark key (trumps -s/S)\n"
|
||||||
|
" -B use bsdtar for archives\n"
|
||||||
" -c cli-only NNN_OPENER (trumps -e)\n"
|
" -c cli-only NNN_OPENER (trumps -e)\n"
|
||||||
" -C 8-color scheme\n"
|
" -C 8-color scheme\n"
|
||||||
" -d detail mode\n"
|
" -d detail mode\n"
|
||||||
|
@ -8290,7 +8292,7 @@ int main(int argc, char *argv[])
|
||||||
|
|
||||||
while ((opt = (env_opts_id > 0
|
while ((opt = (env_opts_id > 0
|
||||||
? env_opts[--env_opts_id]
|
? env_opts[--env_opts_id]
|
||||||
: getopt(argc, argv, "aAb:cCdDeEfF:gHiJKl:nop:P:QrRs:St:T:uUVxh"))) != -1) {
|
: getopt(argc, argv, "aAb:BcCdDeEfF:gHiJKl:nop:P:QrRs:St:T:uUVxh"))) != -1) {
|
||||||
switch (opt) {
|
switch (opt) {
|
||||||
#ifndef NOFIFO
|
#ifndef NOFIFO
|
||||||
case 'a':
|
case 'a':
|
||||||
|
@ -8304,6 +8306,9 @@ int main(int argc, char *argv[])
|
||||||
if (env_opts_id < 0)
|
if (env_opts_id < 0)
|
||||||
arg = optarg;
|
arg = optarg;
|
||||||
break;
|
break;
|
||||||
|
case 'B':
|
||||||
|
g_state.usebsdtar = 1;
|
||||||
|
break;
|
||||||
case 'c':
|
case 'c':
|
||||||
cfg.cliopener = 1;
|
cfg.cliopener = 1;
|
||||||
break;
|
break;
|
||||||
|
|
Loading…
Reference in a new issue