Group more options

This commit is contained in:
Arun Prakash Jana 2018-12-08 23:03:58 +05:30
parent a6976550f1
commit 4c7fc6be69
No known key found for this signature in database
GPG key ID: A75979F35C080412

126
src/nnn.c
View file

@ -2540,7 +2540,7 @@ static void browse(char *ipath)
char *path, *lastdir, *lastname; char *path, *lastdir, *lastname;
char *dir, *tmp; char *dir, *tmp;
struct stat sb; struct stat sb;
int r, fd, presel, ncp = 0, copystartid = 0, copyendid = 0; int r = -1, fd, presel, ncp = 0, copystartid = 0, copyendid = 0;
enum action sel; enum action sel;
bool dir_changed = FALSE; bool dir_changed = FALSE;
@ -3206,8 +3206,9 @@ nochange:
presel = FILTER; presel = FILTER;
goto begin; goto begin;
} }
case SEL_ARCHIVE: // fallthrough
case SEL_OPEN: // fallthrough case SEL_OPEN: // fallthrough
case SEL_ARCHIVE: case SEL_RENAME:
if (!ndents) if (!ndents)
break; // fallthrough break; // fallthrough
case SEL_LAUNCH: // fallthrough case SEL_LAUNCH: // fallthrough
@ -3215,14 +3216,23 @@ nochange:
{ {
char *ptr = NULL, *ptr1 = NULL, *ptr2 = NULL; char *ptr = NULL, *ptr1 = NULL, *ptr2 = NULL;
if (sel == SEL_OPEN) switch (sel) {
case SEL_OPEN:
tmp = xreadline(NULL, "open with: "); tmp = xreadline(NULL, "open with: ");
else if (sel == SEL_LAUNCH) break;
case SEL_RENAME:
tmp = xreadline(dents[cur].name, "");
break;
case SEL_LAUNCH:
tmp = xreadline(NULL, "launch: "); tmp = xreadline(NULL, "launch: ");
else if (sel == SEL_ARCHIVE) break;
case SEL_ARCHIVE:
tmp = xreadline(dents[cur].name, "name: "); tmp = xreadline(dents[cur].name, "name: ");
else break;
default:
tmp = xreadline(NULL, "name: "); tmp = xreadline(NULL, "name: ");
break;
}
if (tmp == NULL || tmp[0] == '\0') if (tmp == NULL || tmp[0] == '\0')
break; break;
@ -3239,11 +3249,19 @@ nochange:
(r == 'c') ? (r = F_NORMAL) : (r = F_NOWAIT | F_NOTRACE); (r == 'c') ? (r = F_NORMAL) : (r = F_NOWAIT | F_NOTRACE);
} }
if (sel == SEL_OPEN) { switch (sel) {
case SEL_OPEN:
getprogarg(tmp, &ptr); getprogarg(tmp, &ptr);
mkpath(path, dents[cur].name, newpath, PATH_MAX); mkpath(path, dents[cur].name, newpath, PATH_MAX);
spawn(tmp, ptr, newpath, path, r); spawn(tmp, ptr, newpath, path, r);
} else if (sel == SEL_LAUNCH) { break;
case SEL_RENAME:
/* Skip renaming to same name */
if (strcmp(tmp, dents[cur].name) == 0)
goto nochange;
break;
case SEL_LAUNCH:
{
uint args = 0; uint args = 0;
ptr = tmp; ptr = tmp;
@ -3264,7 +3282,9 @@ nochange:
} }
spawn(tmp, ptr1, ptr2, path, r); spawn(tmp, ptr1, ptr2, path, r);
} else if (sel == SEL_ARCHIVE) { break;
}
case SEL_ARCHIVE:
/* newpath is used as temporary buffer */ /* newpath is used as temporary buffer */
if (!getutil(utils[APACK])) { if (!getutil(utils[APACK])) {
printmsg("utility missing"); printmsg("utility missing");
@ -3272,9 +3292,12 @@ nochange:
} }
spawn(utils[APACK], tmp, dents[cur].name, path, F_NORMAL); spawn(utils[APACK], tmp, dents[cur].name, path, F_NORMAL);
break;
default:
break;
} }
if (sel != SEL_NEW) { if (sel != SEL_NEW && sel != SEL_RENAME) {
/* Continue in navigate-as-you-type mode, if enabled */ /* Continue in navigate-as-you-type mode, if enabled */
if (cfg.filtermode) if (cfg.filtermode)
presel = FILTER; presel = FILTER;
@ -3295,76 +3318,51 @@ nochange:
/* Check if another file with same name exists */ /* Check if another file with same name exists */
if (faccessat(fd, tmp, F_OK, AT_SYMLINK_NOFOLLOW) != -1) { if (faccessat(fd, tmp, F_OK, AT_SYMLINK_NOFOLLOW) != -1) {
printmsg("entry exists"); if (sel == SEL_RENAME) {
goto nochange;
}
/* Check if it's a dir or file */
r = get_input("press 'f'(ile) or 'd'(ir)");
if (r == 'f') {
r = openat(fd, tmp, O_CREAT, 0666);
close(r);
} else if (r == 'd')
r = mkdirat(fd, tmp, 0777);
else {
close(fd);
break;
}
if (r == -1) {
printwarn();
close(fd);
goto nochange;
}
close(fd);
xstrlcpy(lastname, tmp, NAME_MAX + 1);
goto begin;
}
case SEL_RENAME:
if (!ndents)
break;
tmp = xreadline(dents[cur].name, "");
if (tmp == NULL || tmp[0] == '\0')
break;
/* Allow only relative, same dir paths */
if (tmp[0] == '/' || strcmp(xbasename(tmp), tmp) != 0) {
printmsg(messages[STR_INPUT_ID]);
goto nochange;
}
/* Skip renaming to same name */
if (strcmp(tmp, dents[cur].name) == 0)
break;
/* Open the descriptor to currently open directory */
fd = open(path, O_RDONLY | O_DIRECTORY);
if (fd == -1) {
printwarn();
goto nochange;
}
/* Check if another file with same name exists */
if (faccessat(fd, tmp, F_OK, AT_SYMLINK_NOFOLLOW) != -1) {
/* File with the same name exists */ /* File with the same name exists */
if (get_input("press 'y' to overwrite") != 'y') { if (get_input("press 'y' to overwrite") != 'y') {
close(fd); close(fd);
break; break;
} }
} else {
close(fd);
printmsg("entry exists");
goto nochange;
}
} }
if (sel == SEL_RENAME) {
/* Rename the file */ /* Rename the file */
if (renameat(fd, dents[cur].name, fd, tmp) != 0) { if (renameat(fd, dents[cur].name, fd, tmp) != 0) {
printwarn();
close(fd); close(fd);
printwarn();
goto nochange; goto nochange;
} }
} else {
/* Check if it's a dir or file */
r = get_input("press 'f'(ile) or 'd'(ir)");
if (r == 'f') {
r = openat(fd, tmp, O_CREAT, 0666);
close(r);
} else if (r == 'd') {
r = mkdirat(fd, tmp, 0777);
} else {
close(fd);
break;
}
/* Check if file creation failed */
if (r == -1) {
close(fd);
printwarn();
goto nochange;
}
}
close(fd); close(fd);
xstrlcpy(lastname, tmp, NAME_MAX + 1); xstrlcpy(lastname, tmp, NAME_MAX + 1);
goto begin; goto begin;
}
case SEL_EXEC: case SEL_EXEC:
if (!ndents) if (!ndents)
goto nochange; // fallthrough goto nochange; // fallthrough