[pypy-commit] cffi cpy-extension: Add a second demo using verify().
arigo
noreply at buildbot.pypy.org
Thu Jun 14 12:51:47 CEST 2012
Author: Armin Rigo <arigo at tunes.org>
Branch: cpy-extension
Changeset: r328:eb826ac7c7d0
Date: 2012-06-14 12:51 +0200
http://bitbucket.org/cffi/cffi/changeset/eb826ac7c7d0/
Log: Add a second demo using verify().
diff --git a/demo/readdir.py b/demo/readdir.py
--- a/demo/readdir.py
+++ b/demo/readdir.py
@@ -24,6 +24,7 @@
int closedir(DIR *dirp);
""")
+ffi.C = ffi.rawload(None)
diff --git a/demo/readdir2.py b/demo/readdir2.py
new file mode 100644
--- /dev/null
+++ b/demo/readdir2.py
@@ -0,0 +1,56 @@
+# A Linux-only demo, using verify() instead of hard-coding the exact layouts
+#
+from cffi import FFI
+
+
+ffi = FFI()
+ffi.cdef("""
+
+ typedef ... DIR;
+
+ struct dirent {
+ unsigned char d_type;
+ char d_name[];
+ ...;
+ };
+
+ int readdir_r(DIR *dirp, struct dirent *entry, struct dirent **result);
+ int openat(int dirfd, const char *pathname, int flags);
+ DIR *fdopendir(int fd);
+ int closedir(DIR *dirp);
+
+""")
+ffi.C = ffi.verify("""
+#ifndef _ATFILE_SOURCE
+# define _ATFILE_SOURCE
+#endif
+#include <fcntl.h>
+#include <sys/types.h>
+#include <dirent.h>
+""")
+
+
+def walk(basefd, path):
+ print '{', path
+ dirfd = ffi.C.openat(basefd, path, 0)
+ if dirfd < 0:
+ # error in openat()
+ return
+ dir = ffi.C.fdopendir(dirfd)
+ dirent = ffi.new("struct dirent")
+ result = ffi.new("struct dirent *")
+ while True:
+ if ffi.C.readdir_r(dir, dirent, result):
+ # error in readdir_r()
+ break
+ if result[0] is None:
+ break
+ name = str(dirent.d_name)
+ print '%3d %s' % (dirent.d_type, name)
+ if dirent.d_type == 4 and name != '.' and name != '..':
+ walk(dirfd, name)
+ ffi.C.closedir(dir)
+ print '}'
+
+
+walk(-1, "/tmp")
More information about the pypy-commit
mailing list