mirror of
https://github.com/jarun/nnn.git
synced 2024-11-28 05:41:31 +00:00
Maximize rlimit, switch to detail view in du mode
This commit is contained in:
parent
1e9fc04995
commit
74a13c645d
2
Makefile
2
Makefile
|
@ -3,7 +3,7 @@ VERSION = 0.6
|
||||||
PREFIX = /usr/local
|
PREFIX = /usr/local
|
||||||
MANPREFIX = $(PREFIX)/man
|
MANPREFIX = $(PREFIX)/man
|
||||||
|
|
||||||
CFLAGS += -O3 -march=native -Wall -Wextra
|
CFLAGS += -O3 -march=native -Wall -Wextra -Wno-unused-parameter
|
||||||
LDLIBS = -lcurses
|
LDLIBS = -lcurses
|
||||||
|
|
||||||
DISTFILES = nnn.c config.def.h nnn.1 Makefile README.md LICENSE
|
DISTFILES = nnn.c config.def.h nnn.1 Makefile README.md LICENSE
|
||||||
|
|
45
nnn.c
45
nnn.c
|
@ -3,6 +3,7 @@
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/wait.h>
|
#include <sys/wait.h>
|
||||||
#include <sys/statvfs.h>
|
#include <sys/statvfs.h>
|
||||||
|
#include <sys/resource.h>
|
||||||
|
|
||||||
#include <curses.h>
|
#include <curses.h>
|
||||||
#include <dirent.h>
|
#include <dirent.h>
|
||||||
|
@ -123,6 +124,7 @@ static char *fallback_opener;
|
||||||
static char *copier;
|
static char *copier;
|
||||||
static off_t blk_size;
|
static off_t blk_size;
|
||||||
static size_t fs_free;
|
static size_t fs_free;
|
||||||
|
static int open_max;
|
||||||
static const double div_2_pow_10 = 1.0 / 1024.0;
|
static const double div_2_pow_10 = 1.0 / 1024.0;
|
||||||
static const char* size_units[] = {"B", "K", "M", "G", "T", "P", "E", "Z", "Y"};
|
static const char* size_units[] = {"B", "K", "M", "G", "T", "P", "E", "Z", "Y"};
|
||||||
|
|
||||||
|
@ -167,6 +169,28 @@ xrealloc(void *p, size_t size)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
static rlim_t
|
||||||
|
max_openfds()
|
||||||
|
{
|
||||||
|
struct rlimit rl;
|
||||||
|
rlim_t limit;
|
||||||
|
|
||||||
|
limit = getrlimit(RLIMIT_NOFILE, &rl);
|
||||||
|
if (limit != 0)
|
||||||
|
return 32;
|
||||||
|
|
||||||
|
limit = rl.rlim_cur;
|
||||||
|
rl.rlim_cur = rl.rlim_max;
|
||||||
|
|
||||||
|
if (setrlimit(RLIMIT_NOFILE, &rl) == 0)
|
||||||
|
return rl.rlim_max - 64;
|
||||||
|
|
||||||
|
if (limit > 128)
|
||||||
|
return limit - 64;
|
||||||
|
|
||||||
|
return 32;
|
||||||
|
}
|
||||||
|
|
||||||
static size_t
|
static size_t
|
||||||
xstrlcpy(char *dest, const char *src, size_t n)
|
xstrlcpy(char *dest, const char *src, size_t n)
|
||||||
{
|
{
|
||||||
|
@ -936,14 +960,11 @@ show_help(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
sum_sizes(const char *fpath, const struct stat *sb, int typeflag, struct FTW *ftwbuf)
|
sum_bsizes(const char *fpath, const struct stat *sb, int typeflag, struct FTW *ftwbuf)
|
||||||
{
|
{
|
||||||
if (!fpath || !ftwbuf)
|
|
||||||
printmsg("fpath or ftwbuf NULL"); /* TODO: on %s", fpath); */
|
|
||||||
|
|
||||||
/* Handle permission problems */
|
/* Handle permission problems */
|
||||||
if(typeflag == FTW_NS) {
|
if(typeflag == FTW_NS) {
|
||||||
printmsg("No stats (permissions ?)"); /* TODO: on %s", fpath); */
|
printmsg("No stats (permissions ?)");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1023,8 +1044,8 @@ dentfill(char *path, struct entry **dents,
|
||||||
|
|
||||||
while ((dp = readdir(dirp)) != NULL) {
|
while ((dp = readdir(dirp)) != NULL) {
|
||||||
/* Skip self and parent */
|
/* Skip self and parent */
|
||||||
if ((dp->d_name[0] == '.' && dp->d_name[1] == '\0') ||
|
if ((dp->d_name[0] == '.' && (dp->d_name[1] == '\0' ||
|
||||||
(dp->d_name[0] == '.' && dp->d_name[1] == '.' && dp->d_name[2] == '\0'))
|
(dp->d_name[1] == '.' && dp->d_name[2] == '\0'))))
|
||||||
continue;
|
continue;
|
||||||
if (filter(re, dp->d_name) == 0)
|
if (filter(re, dp->d_name) == 0)
|
||||||
continue;
|
continue;
|
||||||
|
@ -1042,8 +1063,8 @@ dentfill(char *path, struct entry **dents,
|
||||||
if (bsizeorder) {
|
if (bsizeorder) {
|
||||||
if (S_ISDIR(sb.st_mode)) {
|
if (S_ISDIR(sb.st_mode)) {
|
||||||
blk_size = 0;
|
blk_size = 0;
|
||||||
if (nftw(newpath, sum_sizes, 128, FTW_MOUNT | FTW_PHYS) == -1) {
|
if (nftw(newpath, sum_bsizes, open_max, FTW_MOUNT | FTW_PHYS) == -1) {
|
||||||
printmsg("nftw(3) failed"); /* TODO: , newpath); */
|
printmsg("nftw(3) failed");
|
||||||
(*dents)[n].bsize = sb.st_blocks;
|
(*dents)[n].bsize = sb.st_blocks;
|
||||||
} else
|
} else
|
||||||
(*dents)[n].bsize = blk_size;
|
(*dents)[n].bsize = blk_size;
|
||||||
|
@ -1507,6 +1528,10 @@ nochange:
|
||||||
goto begin;
|
goto begin;
|
||||||
case SEL_BSIZE:
|
case SEL_BSIZE:
|
||||||
bsizeorder = !bsizeorder;
|
bsizeorder = !bsizeorder;
|
||||||
|
if (bsizeorder) {
|
||||||
|
showdetail = 1;
|
||||||
|
printptr = &printent_long;
|
||||||
|
}
|
||||||
mtimeorder = 0;
|
mtimeorder = 0;
|
||||||
sizeorder = 0;
|
sizeorder = 0;
|
||||||
/* Save current */
|
/* Save current */
|
||||||
|
@ -1619,6 +1644,8 @@ main(int argc, char *argv[])
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
open_max = max_openfds();
|
||||||
|
|
||||||
if (getuid() == 0)
|
if (getuid() == 0)
|
||||||
showhidden = 1;
|
showhidden = 1;
|
||||||
initfilter(showhidden, &ifilter);
|
initfilter(showhidden, &ifilter);
|
||||||
|
|
Loading…
Reference in a new issue