summaryrefslogtreecommitdiff
path: root/util-linux/e2p/iod.c
diff options
context:
space:
mode:
authorMike Frysinger2005-04-22 02:33:37 +0000
committerMike Frysinger2005-04-22 02:33:37 +0000
commitde9f1f757af7e15881156b610431cd00c262f768 (patch)
treea7fd230099dc3388b179ca51e806495f052c01c5 /util-linux/e2p/iod.c
parent2c12d435e5ccd402f6210827df0b2038093fbcee (diff)
downloadbusybox-de9f1f757af7e15881156b610431cd00c262f768.zip
busybox-de9f1f757af7e15881156b610431cd00c262f768.tar.gz
import lsattr and chattr from e2fsprogs
Diffstat (limited to 'util-linux/e2p/iod.c')
-rw-r--r--util-linux/e2p/iod.c72
1 files changed, 72 insertions, 0 deletions
diff --git a/util-linux/e2p/iod.c b/util-linux/e2p/iod.c
new file mode 100644
index 0000000..808d3a3
--- /dev/null
+++ b/util-linux/e2p/iod.c
@@ -0,0 +1,72 @@
+/*
+ * iod.c - Iterate a function on each entry of a directory
+ *
+ * Copyright (C) 1993, 1994 Remy Card <card@masi.ibp.fr>
+ * Laboratoire MASI, Institut Blaise Pascal
+ * Universite Pierre et Marie Curie (Paris VI)
+ *
+ * This file can be redistributed under the terms of the GNU Library General
+ * Public License
+ */
+
+/*
+ * History:
+ * 93/10/30 - Creation
+ */
+
+#include "e2p.h"
+#if HAVE_UNISTD_H
+#include <unistd.h>
+#endif
+#include <stdlib.h>
+#include <string.h>
+
+int iterate_on_dir (const char * dir_name,
+ int (*func) (const char *, struct dirent *, void *),
+ void * private)
+{
+ DIR * dir;
+ struct dirent *de, *dep;
+ int max_len = -1, len;
+
+#if HAVE_PATHCONF && defined(_PC_NAME_MAX)
+ max_len = pathconf(dir_name, _PC_NAME_MAX);
+#endif
+ if (max_len == -1) {
+#ifdef _POSIX_NAME_MAX
+ max_len = _POSIX_NAME_MAX;
+#else
+#ifdef NAME_MAX
+ max_len = NAME_MAX;
+#else
+ max_len = 256;
+#endif /* NAME_MAX */
+#endif /* _POSIX_NAME_MAX */
+ }
+ max_len += sizeof(struct dirent);
+
+ de = malloc(max_len+1);
+ if (!de)
+ return -1;
+ memset(de, 0, max_len+1);
+
+ dir = opendir (dir_name);
+ if (dir == NULL) {
+ free(de);
+ return -1;
+ }
+ while ((dep = readdir (dir))) {
+ len = sizeof(struct dirent);
+#ifdef HAVE_RECLEN_DIRENT
+ if (len < dep->d_reclen)
+ len = dep->d_reclen;
+ if (len > max_len)
+ len = max_len;
+#endif
+ memcpy(de, dep, len);
+ (*func) (dir_name, de, private);
+ }
+ free(de);
+ closedir(dir);
+ return 0;
+}