1
0
Fork 0
mirror of https://github.com/jarun/nnn.git synced 2025-01-25 18:26:59 +00:00

check for some alloc failures

This commit is contained in:
NRK 2022-05-12 17:23:29 +06:00
parent e1e47f909f
commit ba72fca69a

View file

@ -1647,8 +1647,13 @@ static void invertselbuf(const int pathlen)
char *found;
int i, nmarked = 0, prev = 0;
struct entry *dentp;
selmark *marked = malloc(nselected * sizeof(selmark));
bool scan = FALSE;
selmark *marked = malloc(nselected * sizeof(selmark));
if (!marked) {
printwarn(NULL);
return;
}
/* First pass: inversion */
for (i = 0; i < ndents; ++i) {
@ -5563,16 +5568,23 @@ static void dirwalk(char *path, int entnum, bool mountpoint)
refresh();
}
static void prep_threads(void)
static bool prep_threads(void)
{
if (!g_state.duinit) {
/* drop MSB 1s */
threadbmp >>= (32 - NUM_DU_THREADS);
if (!core_blocks)
core_blocks = calloc(NUM_DU_THREADS, sizeof(blkcnt_t));
if (!core_data)
core_data = calloc(NUM_DU_THREADS, sizeof(thread_data));
if (!core_files)
core_files = calloc(NUM_DU_THREADS, sizeof(ullong_t));
if (!core_blocks || !core_data || !core_files) {
printwarn(NULL);
return FALSE;
}
#ifndef __APPLE__
/* Increase current open file descriptor limit */
max_openfds();
@ -5583,6 +5595,7 @@ static void prep_threads(void)
memset(core_data, 0, NUM_DU_THREADS * sizeof(thread_data));
memset(core_files, 0, NUM_DU_THREADS * sizeof(ullong_t));
}
return TRUE;
}
/* Skip self and parent */
@ -5627,7 +5640,8 @@ static int dentfill(char *path, struct entry **ppdents)
} else
memset(ihashbmp, 0, HASH_OCTETS << 3);
prep_threads();
if (!prep_threads())
goto exit;
attron(COLOR_PAIR(cfg.curctx + 1));
}
@ -5836,7 +5850,7 @@ static int dentfill(char *path, struct entry **ppdents)
} while ((dp = readdir(dirp)));
exit:
if (cfg.blkorder) {
if (g_state.duinit && cfg.blkorder) {
while (active_threads);
attroff(COLOR_PAIR(cfg.curctx + 1));