[Numpy-svn] r3154 - trunk/numpy

numpy-svn at scipy.org numpy-svn at scipy.org
Thu Sep 14 05:01:01 EDT 2006


Author: oliphant
Date: 2006-09-14 04:00:57 -0500 (Thu, 14 Sep 2006)
New Revision: 3154

Modified:
   trunk/numpy/ctypeslib.py
Log:
ndpointer will still work even without ctypes installed.

Modified: trunk/numpy/ctypeslib.py
===================================================================
--- trunk/numpy/ctypeslib.py	2006-09-14 03:52:21 UTC (rev 3153)
+++ trunk/numpy/ctypeslib.py	2006-09-14 09:00:57 UTC (rev 3154)
@@ -13,10 +13,8 @@
 if ctypes is None:
     def _dummy(*args, **kwds):
         raise ImportError, "ctypes is not available."
+    ctypes_load_library = _dummy
     load_library = _dummy
-    ndpointer = _dummy
-    ctypes_load_library = _dummy
-    
     from numpy import intp as c_intp
 else:
     import numpy.core._internal as nic
@@ -40,95 +38,97 @@
         libpath = os.path.join(libdir, libname)
         return ctypes.cdll[libpath]
 
-    def _num_fromflags(flaglist):
-        num = 0
-        for val in flaglist:
-            num += _flagdict[val]
-        return num
+    ctypes_load_library = deprecate(load_library, 'ctypes_load_library',
+                                    'load_library')
 
-    def _flags_fromnum(num):
-        res = []
-        for key, value in _flagdict.items():
-            if (num & value):
-                res.append(key)
-        return res
+def _num_fromflags(flaglist):
+    num = 0
+    for val in flaglist:
+        num += _flagdict[val]
+    return num
 
-    ctypes_load_library = deprecate(load_library, 'ctypes_load_library', 'load_library')
+def _flags_fromnum(num):
+    res = []
+    for key, value in _flagdict.items():
+        if (num & value):
+            res.append(key)
+    return res
 
-    class _ndptr(object):
-        def from_param(cls, obj):
-            if not isinstance(obj, ndarray):
-                raise TypeError, "argument must be an ndarray"
-            if cls._dtype_ is not None \
-                   and obj.dtype != cls._dtype_:
-                raise TypeError, "array must have data type %s" % cls._dtype_
-            if cls._ndim_ is not None \
-                   and obj.ndim != cls._ndim_:
-                raise TypeError, "array must have %d dimension(s)" % cls._ndim_
-            if cls._shape_ is not None \
-                   and obj.shape != cls._shape_:
-                raise TypeError, "array must have shape %s" % str(cls._shape_)
-            if cls._flags_ is not None \
-                   and ((obj.flags.num & cls._flags_) != cls._flags_):
-                raise TypeError, "array must have flags %s" % \
-                      _flags_fromnum(cls._flags_)
-            return obj.ctypes
-        from_param = classmethod(from_param)
 
+class _ndptr(object):
+    def from_param(cls, obj):
+        if not isinstance(obj, ndarray):
+            raise TypeError, "argument must be an ndarray"
+        if cls._dtype_ is not None \
+               and obj.dtype != cls._dtype_:
+            raise TypeError, "array must have data type %s" % cls._dtype_
+        if cls._ndim_ is not None \
+               and obj.ndim != cls._ndim_:
+            raise TypeError, "array must have %d dimension(s)" % cls._ndim_
+        if cls._shape_ is not None \
+               and obj.shape != cls._shape_:
+            raise TypeError, "array must have shape %s" % str(cls._shape_)
+        if cls._flags_ is not None \
+               and ((obj.flags.num & cls._flags_) != cls._flags_):
+            raise TypeError, "array must have flags %s" % \
+                  _flags_fromnum(cls._flags_)
+        return obj.ctypes
+    from_param = classmethod(from_param)
 
-    # Factory for an array-checking class with from_param defined for
-    #  use with ctypes argtypes mechanism
-    _pointer_type_cache = {}
-    def ndpointer(dtype=None, ndim=None, shape=None, flags=None):
-        if dtype is not None:
-            dtype = _dtype(dtype)
-        num = None
-        if flags is not None:
-            if isinstance(flags, str):
-                flags = flags.split(',')
-            elif isinstance(flags, (int, integer)):
-                num = flags
-                flags = _flags_fromnum(num)
-            elif isinstance(flags, flagsobj):
-                num = flags.num
-                flags = _flags_fromnum(num)
-            if num is None:
-                try:
-                    flags = [x.strip().upper() for x in flags]
-                except:
-                    raise TypeError, "invalid flags specification"
-                num = _num_fromflags(flags)
+
+# Factory for an array-checking class with from_param defined for
+#  use with ctypes argtypes mechanism
+_pointer_type_cache = {}
+def ndpointer(dtype=None, ndim=None, shape=None, flags=None):
+    if dtype is not None:
+        dtype = _dtype(dtype)
+    num = None
+    if flags is not None:
+        if isinstance(flags, str):
+            flags = flags.split(',')
+        elif isinstance(flags, (int, integer)):
+            num = flags
+            flags = _flags_fromnum(num)
+        elif isinstance(flags, flagsobj):
+            num = flags.num
+            flags = _flags_fromnum(num)
+        if num is None:
+            try:
+                flags = [x.strip().upper() for x in flags]
+            except:
+                raise TypeError, "invalid flags specification"
+            num = _num_fromflags(flags)
+    try:
+        return _pointer_type_cache[(dtype, ndim, shape, num)]
+    except KeyError:
+        pass
+    if dtype is None:
+        name = 'any'
+    elif dtype.names:
+        name = str(id(dtype))
+    else:
+        name = dtype.str
+    if ndim is not None:
+        name += "_%dd" % ndim
+    if shape is not None:
         try:
-            return _pointer_type_cache[(dtype, ndim, shape, num)]
-        except KeyError:
-            pass
-        if dtype is None:
-            name = 'any'
-        elif dtype.names:
-            name = str(id(dtype))
-        else:
-            name = dtype.str
-        if ndim is not None:
-            name += "_%dd" % ndim
-        if shape is not None:
-            try:
-                strshape = [str(x) for x in shape]
-            except TypeError:
-                strshape = [str(shape)]
-                shape = (shape,)
-            shape = tuple(shape)
-            name += "_"+"x".join(strshape)
-        if flags is not None:
-            name += "_"+"_".join(flags)
-        else:
-            flags = []
-        klass = type("ndpointer_%s"%name, (_ndptr,),
-                     {"_dtype_": dtype,
-                      "_shape_" : shape,
-                      "_ndim_" : ndim,
-                      "_flags_" : num})
-        _pointer_type_cache[dtype] = klass
-        return klass
+            strshape = [str(x) for x in shape]
+        except TypeError:
+            strshape = [str(shape)]
+            shape = (shape,)
+        shape = tuple(shape)
+        name += "_"+"x".join(strshape)
+    if flags is not None:
+        name += "_"+"_".join(flags)
+    else:
+        flags = []
+    klass = type("ndpointer_%s"%name, (_ndptr,),
+                 {"_dtype_": dtype,
+                  "_shape_" : shape,
+                  "_ndim_" : ndim,
+                  "_flags_" : num})
+    _pointer_type_cache[dtype] = klass
+    return klass
 
 def test(level=1, verbosity=1):
     from numpy.testing import NumpyTest




More information about the Numpy-svn mailing list