Browse Source

Remove dir watch before filtering contents

master
Arun Prakash Jana 5 years ago
parent
commit
81318f9218
No known key found for this signature in database GPG Key ID: A75979F35C080412
1 changed files with 13 additions and 14 deletions
  1. +13
    -14
      src/nnn.c

+ 13
- 14
src/nnn.c View File

@@ -1249,21 +1249,8 @@ static int nextsel(int *presel)
if (c == 0) {
c = getch();
DPRINTF_D(c);
} else {
/* Unwatch dir if we are still in a filtered view */
#ifdef LINUX_INOTIFY
if (*presel == FILTER && inotify_wd >= 0) {
inotify_rm_watch(inotify_fd, inotify_wd);
inotify_wd = -1;
}
#elif defined(BSD_KQUEUE)
if (*presel == FILTER && event_fd >= 0) {
close(event_fd);
event_fd = -1;
}
#endif
} else
*presel = 0;
}

if (c == -1) {
++idle;
@@ -3144,6 +3131,18 @@ nochange:
printmsg(mark);
goto nochange;
case SEL_FLTR:
/* Unwatch dir if we are still in a filtered view */
#ifdef LINUX_INOTIFY
if (inotify_wd >= 0) {
inotify_rm_watch(inotify_fd, inotify_wd);
inotify_wd = -1;
}
#elif defined(BSD_KQUEUE)
if (event_fd >= 0) {
close(event_fd);
event_fd = -1;
}
#endif
presel = filterentries(path);
/* Save current */
if (ndents)


Loading…
Cancel
Save