From 1746218beebc7e180f3eaed905277f9f46983ac4 Mon Sep 17 00:00:00 2001 From: Denys Vlasenko Date: Thu, 24 Jun 2021 11:42:55 +0200 Subject: move iterate_on_dir() from e2fsprogs to libbb Signed-off-by: Denys Vlasenko --- e2fsprogs/e2fs_lib.c | 27 --------------------------- e2fsprogs/e2fs_lib.h | 5 ----- include/libbb.h | 5 +++++ libbb/iterate_on_dir.c | 28 ++++++++++++++++++++++++++++ 4 files changed, 33 insertions(+), 32 deletions(-) create mode 100644 libbb/iterate_on_dir.c diff --git a/e2fsprogs/e2fs_lib.c b/e2fsprogs/e2fs_lib.c index e32336a..9b68d89 100644 --- a/e2fsprogs/e2fs_lib.c +++ b/e2fsprogs/e2fs_lib.c @@ -8,33 +8,6 @@ #include "libbb.h" #include "e2fs_lib.h" -#if INT_MAX == LONG_MAX -#define IF_LONG_IS_SAME(...) __VA_ARGS__ -#define IF_LONG_IS_WIDER(...) -#else -#define IF_LONG_IS_SAME(...) -#define IF_LONG_IS_WIDER(...) __VA_ARGS__ -#endif - -/* Iterate a function on each entry of a directory */ -int iterate_on_dir(const char *dir_name, - int FAST_FUNC (*func)(const char *, struct dirent *, void *), - void *private) -{ - DIR *dir; - struct dirent *de; - - dir = opendir(dir_name); - if (dir == NULL) { - return -1; - } - while ((de = readdir(dir)) != NULL) { - func(dir_name, de, private); - } - closedir(dir); - return 0; -} - /* Print file attributes on an ext2 file system */ const uint32_t e2attr_flags_value[] ALIGN4 = { #ifdef ENABLE_COMPRESSION diff --git a/e2fsprogs/e2fs_lib.h b/e2fsprogs/e2fs_lib.h index 879272f..bab447a 100644 --- a/e2fsprogs/e2fs_lib.h +++ b/e2fsprogs/e2fs_lib.h @@ -11,11 +11,6 @@ PUSH_AND_SET_FUNCTION_VISIBILITY_TO_HIDDEN -/* Iterate a function on each entry of a directory */ -int iterate_on_dir(const char *dir_name, - int FAST_FUNC (*func)(const char *, struct dirent *, void *), - void *private); - /* Print file attributes on an ext2 file system */ void print_e2flags_long(unsigned flags); void print_e2flags(unsigned flags); diff --git a/include/libbb.h b/include/libbb.h index 251d723..7d6ab4a 100644 --- a/include/libbb.h +++ b/include/libbb.h @@ -512,6 +512,11 @@ int recursive_action(const char *fileName, unsigned flags, void *userData ) FAST_FUNC; +/* Simpler version: call a function on each dirent in a directory */ +int iterate_on_dir(const char *dir_name, + int FAST_FUNC (*func)(const char *, struct dirent *, void *), + void *private) FAST_FUNC; + extern int device_open(const char *device, int mode) FAST_FUNC; enum { GETPTY_BUFSIZE = 16 }; /* more than enough for "/dev/ttyXXX" */ extern int xgetpty(char *line) FAST_FUNC; diff --git a/libbb/iterate_on_dir.c b/libbb/iterate_on_dir.c new file mode 100644 index 0000000..deef72e --- /dev/null +++ b/libbb/iterate_on_dir.c @@ -0,0 +1,28 @@ +/* vi: set sw=4 ts=4: */ +/* + * See README for additional information + * + * Licensed under GPLv2, see file LICENSE in this source tree. + */ +//kbuild:lib-y += iterate_on_dir.o + +#include "libbb.h" + +/* Iterate a function on each entry of a directory */ +int FAST_FUNC iterate_on_dir(const char *dir_name, + int FAST_FUNC (*func)(const char *, struct dirent *, void *), + void *private) +{ + DIR *dir; + struct dirent *de; + + dir = opendir(dir_name); + if (dir == NULL) { + return -1; + } + while ((de = readdir(dir)) != NULL) { + func(dir_name, de, private); + } + closedir(dir); + return 0; +} -- cgit v1.1