[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