diff options
author | Travis Oliphant <oliphant@enthought.com> | 2006-08-14 20:13:33 +0000 |
---|---|---|
committer | Travis Oliphant <oliphant@enthought.com> | 2006-08-14 20:13:33 +0000 |
commit | a06ddf3e22ee65fe4009c8f0f304d4b26143e600 (patch) | |
tree | 5425d16165803a5f8fead59e5828730af73b49f6 /numpy/lib/utils.py | |
parent | c70b3c6fe0e073fc70eb8b424c30ca6c5c01ea04 (diff) | |
download | numpy-a06ddf3e22ee65fe4009c8f0f304d4b26143e600.tar.gz |
Fix ndpointer and add tests from ticket #245
Diffstat (limited to 'numpy/lib/utils.py')
-rw-r--r-- | numpy/lib/utils.py | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/numpy/lib/utils.py b/numpy/lib/utils.py index d988b2d14..eae0ab7b7 100644 --- a/numpy/lib/utils.py +++ b/numpy/lib/utils.py @@ -2,7 +2,7 @@ import sys, os import inspect import types from numpy.core.numerictypes import obj2sctype, integer -from numpy.core.multiarray import dtype as _dtype, _flagdict +from numpy.core.multiarray import dtype as _dtype, _flagdict, flagsobj from numpy.core import product, ndarray __all__ = ['issubclass_', 'get_numpy_include', 'issubsctype', @@ -101,7 +101,7 @@ class _ndptr(object): 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" % 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" % \ @@ -121,9 +121,15 @@ def ndpointer(dtype=None, ndim=None, shape=None, flags=None): flags = flags.split(',') elif isinstance(flags, (int, integer)): num = flags - flags = _flags_fromnum(flags) + flags = _flags_fromnum(num) + elif isinstance(flags, flagsobj): + num = flags.num + flags = _flags_fromnum(num) if num is None: - flags = [x.strip().upper() for x in flags] + 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)] |