all repos — slstatus @ 4b4b2ac0790a51ea624397f829f29ed92e82fd53

my build of slstatus (tools.suckless.org/slstatus/)

add num_files() function for maildirs ;)
aaron marcher me@drkhsh.at
Sun, 06 Aug 2017 15:02:16 +0200
commit

4b4b2ac0790a51ea624397f829f29ed92e82fd53

parent

ad39aa012c5da8f1f53c8f7366d5177e538da255

3 files changed, 27 insertions(+), 0 deletions(-)

jump to
M README.mdREADME.md

@@ -21,6 +21,7 @@ - IP addresses

- Kernel version - Keyboard indicators - Load averages +- Number of files in a directory (hint: Maildir) - Memory status (free memory, percentage, total memory and used memory) - Swap status (free swap, percentage, total swap and used swap) - Temperature
M config.def.hconfig.def.h

@@ -27,6 +27,7 @@ - ip (ip address) [argument: interface]

- kernel_release (uname -r) [argument: NULL] - keyboard_indicators (caps/num lock indicators) [agrument: NULL] - load_avg (load average) [argument: NULL] +- num_files (number of files in a directory - hint: maildir) [argument: path] - ram_free (free ram in GB) [argument: NULL] - ram_perc (ram usage in percent) [argument: NULL] - ram_total (total ram in GB) [argument: NULL]
M slstatus.cslstatus.c

@@ -1,5 +1,6 @@

/* See LICENSE file for copyright and license details. */ +#include <dirent.h> #include <err.h> #include <fcntl.h> #include <ifaddrs.h>

@@ -51,6 +52,7 @@ static const char *ip(const char *iface);

static const char *kernel_release(void); static const char *keyboard_indicators(void); static const char *load_avg(void); +static const char *num_files(const char *dir); static const char *ram_free(void); static const char *ram_perc(void); static const char *ram_used(void);

@@ -400,6 +402,29 @@ return UNKNOWN_STR;

} return bprintf("%.2f %.2f %.2f", avgs[0], avgs[1], avgs[2]); +} + +static const char * +num_files(const char *dir) +{ + struct dirent *dp; + DIR *fd; + int num = 0; + + if ((fd = opendir(dir)) == NULL) { + warn("Failed to get number of files in directory %s", dir); + return UNKNOWN_STR; + } + + while ((dp = readdir(fd)) != NULL) { + if (!strcmp(dp->d_name, ".") || !strcmp(dp->d_name, "..")) + continue; /* skip self and parent */ + num++; + } + + closedir(fd); + + return bprintf("%d", num); } static const char *