mirror of
https://github.com/jarun/nnn.git
synced 2025-01-25 02:06:50 +00:00
Refactor dentfill()
This commit is contained in:
parent
12a4ab3248
commit
ce6fc35929
34
src/nnn.c
34
src/nnn.c
|
@ -2637,7 +2637,7 @@ static void dentfree(void)
|
|||
|
||||
static int dentfill(char *path, struct entry **dents)
|
||||
{
|
||||
int n = 0, count;
|
||||
int n = 0, count, flags = 0;
|
||||
ulong num_saved;
|
||||
struct dirent *dp;
|
||||
char *namep, *pnb;
|
||||
|
@ -2667,7 +2667,22 @@ static int dentfill(char *path, struct entry **dents)
|
|||
open_max = max_openfds();
|
||||
}
|
||||
|
||||
while ((dp = readdir(dirp))) {
|
||||
dp = readdir(dirp);
|
||||
// if (!dp) /* We have opened the dir, at least . would be returned */
|
||||
// goto exit;
|
||||
|
||||
if (cfg.blkorder || dp->d_type == DT_UNKNOWN) {
|
||||
/*
|
||||
* Optimization added for filesystems which support dirent.d_type
|
||||
* see readdir(3)
|
||||
* Known drawbacks:
|
||||
* - the symlink size is set to 0
|
||||
* - the modification time of the symlink is set to that of the target file
|
||||
*/
|
||||
flags = AT_SYMLINK_NOFOLLOW;
|
||||
}
|
||||
|
||||
do {
|
||||
namep = dp->d_name;
|
||||
|
||||
/* Skip self and parent */
|
||||
|
@ -2711,7 +2726,7 @@ static int dentfill(char *path, struct entry **dents)
|
|||
continue;
|
||||
}
|
||||
|
||||
if (fstatat(fd, namep, &sb, AT_SYMLINK_NOFOLLOW) == -1) {
|
||||
if (fstatat(fd, namep, &sb, flags) == -1) {
|
||||
DPRINTF_S(namep);
|
||||
continue;
|
||||
}
|
||||
|
@ -2760,9 +2775,14 @@ static int dentfill(char *path, struct entry **dents)
|
|||
off += dentp->nlen;
|
||||
|
||||
/* Copy other fields */
|
||||
dentp->mode = sb.st_mode;
|
||||
dentp->t = sb.st_mtime;
|
||||
if (dp->d_type == DT_LNK && !flags) { /* Do not add sizes for links */
|
||||
dentp->mode = (sb.st_mode & ~S_IFMT) | S_IFLNK;
|
||||
dentp->size = 0;
|
||||
} else {
|
||||
dentp->mode = sb.st_mode;
|
||||
dentp->size = sb.st_size;
|
||||
}
|
||||
dentp->flags = 0;
|
||||
|
||||
if (cfg.blkorder) {
|
||||
|
@ -2796,6 +2816,7 @@ static int dentfill(char *path, struct entry **dents)
|
|||
}
|
||||
}
|
||||
|
||||
if (flags) {
|
||||
/* Flag if this is a dir or symlink to a dir */
|
||||
if (S_ISLNK(sb.st_mode)) {
|
||||
sb.st_mode = 0;
|
||||
|
@ -2804,10 +2825,13 @@ static int dentfill(char *path, struct entry **dents)
|
|||
|
||||
if (S_ISDIR(sb.st_mode))
|
||||
dentp->flags |= DIR_OR_LINK_TO_DIR;
|
||||
} else if (dp->d_type == DT_DIR || (dp->d_type == DT_LNK && S_ISDIR(sb.st_mode)))
|
||||
dentp->flags |= DIR_OR_LINK_TO_DIR;
|
||||
|
||||
++n;
|
||||
}
|
||||
} while ((dp = readdir(dirp)));
|
||||
|
||||
//exit:
|
||||
/* Should never be null */
|
||||
if (closedir(dirp) == -1) {
|
||||
dentfree();
|
||||
|
|
Loading…
Reference in a new issue