X-Git-Url: http://xvm.mit.edu/gitweb/invirt/packages/python-afs.git/blobdiff_plain/80e452e402f54de2b9bea9722e69022e16d17c7c..b18334d13cd65d8eff268ace564e64d325d01c67:/afs/afs.pyx diff --git a/afs/afs.pyx b/afs/afs.pyx index 29a2442..f7f167b 100644 --- a/afs/afs.pyx +++ b/afs/afs.pyx @@ -5,8 +5,8 @@ General PyAFS utilities, such as error handling import sys # otherwise certain headers are unhappy -cdef import from "netinet/in.h": pass -cdef import from "afs/vice.h": pass +cdef extern from "netinet/in.h": pass +cdef extern from "afs/vice.h": pass cdef int _init = 0 @@ -26,6 +26,20 @@ cdef extern int pioctl_read(char *dir, afs_int32 op, void *buffer, unsigned shor pyafs_error(code) return code +cdef extern int pioctl_write(char *dir, afs_int32 op, char *buffer, afs_int32 follow) except -1: + cdef ViceIoctl blob + cdef afs_int32 code + blob.cin = buffer + blob.in_size = 1 + strlen(buffer) + blob.out_size = 0 + code = pioctl(dir, op, &blob, follow) + # This might work with the rest of OpenAFS, but I'm not convinced + # the rest of it is consistent + if code == -1: + raise OSError(errno, strerror(errno)) + pyafs_error(code) + return code + # Error handling class AFSException(Exception):