Browse Source

Support select all with Y

master
Arun Prakash Jana 6 years ago
parent
commit
ebc81c5d34
No known key found for this signature in database GPG Key ID: A75979F35C080412
4 changed files with 33 additions and 13 deletions
  1. +3
    -2
      README.md
  2. +2
    -0
      nnn.1
  3. +25
    -10
      src/nnn.c
  4. +3
    -1
      src/nnn.h

+ 3
- 2
README.md View File

@@ -95,7 +95,7 @@ It runs on Linux, macOS, Raspberry Pi, BSD, Cygwin, Linux subsystem for Windows
- Media information (needs mediainfo/exiftool)
- Convenience
- Create, rename files and directories
- Select files across directories, range selection
- Select files across dirs; all/range selection
- Copy, move, delete selection
- Create sym/hard link(s) to selection
- Transfer files using lftp
@@ -231,7 +231,8 @@ Press <kbd>?</kbd> in `nnn` to see the list anytime.
^O Open with... n Create new/link
D File details ^R Rename entry
⎵, ^K Copy entry path r Open dir in vidir
Y, ^Y Toggle selection y List selection
^Y Toggle selection y List selection
Y Select all
P Copy selection X Delete selection
V Move selection ^X Delete entry
f Archive entry F List archive


+ 2
- 0
nnn.1 View File

@@ -98,6 +98,8 @@ Rename selected entry
Open directory in vidir
.It Ic Y, ^Y
Toggle selection mode
.It Ic Y
Select all entries in dir
.It Ic Space, ^K
Copy entry absolute path
.It Ic y


+ 25
- 10
src/nnn.c View File

@@ -2286,7 +2286,8 @@ static bool show_help(char *path)
"b^O Open with... n Create new/link\n"
"cD File details ^R Rename entry\n"
"8⎵, ^K Copy entry path r Open dir in vidir\n"
"8Y, ^Y Toggle selection y List selection\n"
"b^Y Toggle selection y List selection\n"
"cY Select all\n"
"cP Copy selection X Delete selection\n"
"cV Move selection ^X Delete entry\n"
"cf Archive entry F List archive\n"
@@ -2743,7 +2744,7 @@ static void redraw(char *path)
get_file_sym(dents[cur].mode));
}
} else
printmsg("0 items");
printmsg("0/0");
}

if (mode_changed) {
@@ -3360,11 +3361,23 @@ nochange:
printmsg("selection on");
DPRINTF_S("selection on");
goto nochange;
}
} // fallthrough
case SEL_COPYALL:
if (sel == SEL_COPYALL) {
if (!ndents) {
printmsg("0 entries");
goto nochange;
}

cfg.copymode = 0;
copybufpos = 0;
ncp = 0;
copystartid = 0;
copyendid = ndents - 1;
}
if (!ncp) { /* Handle range selection */
#ifndef DIR_LIMITED_COPY
if (g_crc != crc8fast((uchar *)dents,
if ((sel != SEL_COPYALL) && g_crc != crc8fast((uchar *)dents,
ndents * sizeof(struct entry))) {
cfg.copymode = 0;
printmsg("range error: dir/content changed");
@@ -3372,13 +3385,15 @@ nochange:
goto nochange;
}
#endif
if (cur < copystartid) {
copyendid = copystartid;
copystartid = cur;
} else
copyendid = cur;
if (sel != SEL_COPYALL) {
if (cur < copystartid) {
copyendid = copystartid;
copystartid = cur;
} else
copyendid = cur;
}

if (copystartid < copyendid) {
if (copystartid < copyendid || sel == SEL_COPYALL) {
for (r = copystartid; r <= copyendid; ++r)
if (!appendfpath(newpath, mkpath(path,
dents[r].name, newpath)))


+ 3
- 1
src/nnn.h View File

@@ -73,6 +73,7 @@ enum action {
SEL_REDRAW,
SEL_COPY,
SEL_COPYMUL,
SEL_COPYALL,
SEL_COPYLIST,
SEL_CP,
SEL_MV,
@@ -189,7 +190,8 @@ static struct key bindings[] = {
{ ' ', SEL_COPY },
/* Toggle copy multiple file paths */
{ CONTROL('Y'), SEL_COPYMUL },
{ 'Y', SEL_COPYMUL },
/* Select all files in current dir */
{ 'Y', SEL_COPYALL },
/* Show list of copied files */
{ 'y', SEL_COPYLIST },
/* Copy from copy buffer */


Loading…
Cancel
Save