about summary refs log tree commit diff
path: root/mdirs.c
diff options
context:
space:
mode:
authorChristian Neukirchen <chneukirchen@gmail.com>2016-07-22 18:47:39 +0200
committerChristian Neukirchen <chneukirchen@gmail.com>2016-07-22 18:47:39 +0200
commit9da61f69f7f3274db4a3bea58842173f2889d156 (patch)
treeb8858131a9f633233cf2562c625137675e67f4d7 /mdirs.c
parent61cd8387850ee834a7779da942819f347bcff5e3 (diff)
downloadmblaze-9da61f69f7f3274db4a3bea58842173f2889d156.tar.gz
mblaze-9da61f69f7f3274db4a3bea58842173f2889d156.tar.xz
mblaze-9da61f69f7f3274db4a3bea58842173f2889d156.zip
really add mdirs
Diffstat (limited to 'mdirs.c')
-rw-r--r--mdirs.c75
1 files changed, 75 insertions, 0 deletions
diff --git a/mdirs.c b/mdirs.c
new file mode 100644
index 0000000..0d5be29
--- /dev/null
+++ b/mdirs.c
@@ -0,0 +1,75 @@
+#include <sys/stat.h>
+#include <sys/types.h>
+
+#include <dirent.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <unistd.h>
+
+void
+pwd()
+{
+	char cwd[PATH_MAX];
+	if (getcwd(cwd, sizeof cwd))
+		puts(cwd);
+}
+
+void
+mdirs(char *fpath)
+{
+	DIR *dir;
+        struct dirent *d;
+	struct stat st;
+
+	dir = opendir(fpath);
+	if (!dir)
+		return;
+
+	if (chdir(fpath) < 0) {
+		closedir(dir);
+		return;
+	}
+
+	int dotonly = 0;
+
+	if (stat("cur", &st) == 0 &&
+	    S_ISDIR(st.st_mode) &&
+	    stat("new", &st) == 0 &&
+	    S_ISDIR(st.st_mode)) {
+		pwd();
+		dotonly = 1;   // Maildir++
+	}
+
+	while ((d = readdir(dir))) {
+		if (d->d_type != DT_DIR && d->d_type != DT_UNKNOWN)
+			continue;
+		if (d->d_name[0] == '.' &&
+		    d->d_name[1] == 0)
+			continue;
+		if (d->d_name[0] == '.' &&
+		    d->d_name[1] == '.' &&
+		    d->d_name[2] == 0)
+			continue;
+
+		if (dotonly && d->d_name[0] != '.')
+			continue;
+		
+		mdirs(d->d_name);
+	}
+		
+	if (chdir("..") < 0)
+		exit(-1);
+
+        closedir(dir);
+}
+
+int
+main(int argc, char *argv[])
+{
+	int i;
+
+	for (i = 0; i < argc; i++)
+		mdirs(argv[i]);
+
+	return 0;
+}