Kaynağa Gözat

Reformat presel handling

master
Arun Prakash Jana 6 yıl önce
ebeveyn
işleme
5879f361b3
Veri tabanında bu imza için bilinen anahtar bulunamadı GPG Anahtar Kimliği: A75979F35C080412
1 değiştirilmiş dosya ile 26 ekleme ve 39 silme
  1. +26
    -39
      nnn.c

+ 26
- 39
nnn.c Dosyayı Görüntüle

@@ -205,6 +205,7 @@ disabledbg()
#define settimeout() timeout(1000)
#define cleartimeout() timeout(-1)
#define errexit() printerr(__LINE__)
#define setdirwatch() (cfg.filtermode ? (presel = FILTER) : (dir_changed = TRUE))

#ifdef LINUX_INOTIFY
#define EVENT_SIZE (sizeof(struct inotify_event))
@@ -990,20 +991,19 @@ static int nextsel(char **run, char **env, int *presel)
if (c == 0)
c = getch();
else {
*presel = 0;

/* Unwatch dir if we are still in a filtered view */
#ifdef LINUX_INOTIFY
if (inotify_wd >= 0) {
if (*presel == FILTER && inotify_wd >= 0) {
inotify_rm_watch(inotify_fd, inotify_wd);
inotify_wd = -1;
}
#elif defined(BSD_KQUEUE)
if (event_fd >= 0) {
if (*presel == FILTER && event_fd >= 0) {
close(event_fd);
event_fd = -1;
}
#endif
*presel = 0;
}

if (c == -1) {
@@ -2511,13 +2511,13 @@ static void browse(char *ipath)

begin:
#ifdef LINUX_INOTIFY
if (dir_changed && inotify_wd >= 0) {
if ((presel == FILTER || dir_changed) && inotify_wd >= 0) {
inotify_rm_watch(inotify_fd, inotify_wd);
inotify_wd = -1;
dir_changed = FALSE;
}
#elif defined(BSD_KQUEUE)
if (dir_changed && event_fd >= 0) {
if ((presel == FILTER || dir_changed) && event_fd >= 0) {
close(event_fd);
event_fd = -1;
dir_changed = FALSE;
@@ -2560,7 +2560,6 @@ nochange:
/* Continue in navigate-as-you-type mode, if enabled */
if (cfg.filtermode)
presel = FILTER;

goto nochange;
}

@@ -2575,11 +2574,10 @@ nochange:

/* Save last working directory */
xstrlcpy(lastdir, path, PATH_MAX);
dir_changed = TRUE;

xstrlcpy(path, dir, PATH_MAX);
if (cfg.filtermode)
presel = FILTER;
setdirwatch();
goto begin;
case SEL_GOIN:
/* Cannot descend in empty directories */
@@ -2612,12 +2610,10 @@ nochange:

/* Save last working directory */
xstrlcpy(lastdir, path, PATH_MAX);
dir_changed = TRUE;

xstrlcpy(path, newpath, PATH_MAX);
lastname[0] = '\0';
if (cfg.filtermode)
presel = FILTER;
setdirwatch();
goto begin;
case S_IFREG:
{
@@ -2696,13 +2692,11 @@ nochange:

/* Save last working directory */
xstrlcpy(lastdir, path, PATH_MAX);
dir_changed = TRUE;

xstrlcpy(path, dir, PATH_MAX);
lastname[0] = '\0';
DPRINTF_S(path);
if (cfg.filtermode)
presel = FILTER;
setdirwatch();
goto begin;
case SEL_CDLAST: // fallthrough
case SEL_VISIT:
@@ -2724,12 +2718,10 @@ nochange:

xstrlcpy(newpath, tmp, PATH_MAX);
xstrlcpy(lastdir, path, PATH_MAX);
dir_changed = TRUE;
xstrlcpy(path, newpath, PATH_MAX);
lastname[0] = '\0';
DPRINTF_S(path);
if (cfg.filtermode)
presel = FILTER;
setdirwatch();
goto begin;
case SEL_CDBM:
tmp = xreadline(NULL, "key: ", cfg.char_key);
@@ -2739,11 +2731,12 @@ nochange:
/* Interpret ~, - and & keys */
if (tmp[1] == '\0') {
switch (tmp[0]) {
case 'q':
case '~': //fallthrough
case '-': //fallthrough
case '&':
presel = tmp[0];
goto begin;
goto nochange;
case '>':
case '.':
case '<':
@@ -2792,12 +2785,8 @@ nochange:
hfltr = g_ctx[r].c_fltr;

cfg.curctx = r;
if (cfg.filtermode)
presel = FILTER;
setdirwatch();
goto begin;
case 'q':
presel = 'q';
goto nochange;
}
}

@@ -2816,14 +2805,12 @@ nochange:

/* Save last working directory */
xstrlcpy(lastdir, path, PATH_MAX);
dir_changed = TRUE;

/* Save the newly opted dir in path */
xstrlcpy(path, newpath, PATH_MAX);
DPRINTF_S(path);

if (cfg.filtermode)
presel = FILTER;
setdirwatch();
goto begin;
case SEL_PIN:
xstrlcpy(mark, path, PATH_MAX);
@@ -2837,17 +2824,18 @@ nochange:
goto nochange;
case SEL_MFLTR:
cfg.filtermode ^= 1;
if (cfg.filtermode)
if (cfg.filtermode) {
presel = FILTER;
else {
/* Save current */
if (ndents)
copycurname();

/* Start watching the directory */
goto begin;
goto nochange;
}
goto nochange;

/* Save current */
if (ndents)
copycurname();

dir_changed = TRUE;
/* Start watching the directory */
goto begin;
case SEL_TOGGLEDOT:
cfg.showhidden ^= 1;
initfilter(cfg.showhidden, hfltr);
@@ -3314,8 +3302,7 @@ nochange:
hfltr = g_ctx[r].c_fltr;

cfg.curctx = r;
if (cfg.filtermode)
presel = FILTER;
setdirwatch();
goto begin;
}



Yükleniyor…
İptal
Kaydet