5082 lines
206 KiB
C
Executable file
5082 lines
206 KiB
C
Executable file
/* Generated by Cython 0.12 on Sun Mar 14 21:50:02 2010 */
|
|
|
|
#define PY_SSIZE_T_CLEAN
|
|
#include "Python.h"
|
|
#include "structmember.h"
|
|
#ifndef Py_PYTHON_H
|
|
#error Python headers needed to compile C extensions, please install development version of Python.
|
|
#else
|
|
#ifndef PY_LONG_LONG
|
|
#define PY_LONG_LONG LONG_LONG
|
|
#endif
|
|
#ifndef DL_EXPORT
|
|
#define DL_EXPORT(t) t
|
|
#endif
|
|
#if PY_VERSION_HEX < 0x02040000
|
|
#define METH_COEXIST 0
|
|
#define PyDict_CheckExact(op) (Py_TYPE(op) == &PyDict_Type)
|
|
#define PyDict_Contains(d,o) PySequence_Contains(d,o)
|
|
#endif
|
|
#if PY_VERSION_HEX < 0x02050000
|
|
typedef int Py_ssize_t;
|
|
#define PY_SSIZE_T_MAX INT_MAX
|
|
#define PY_SSIZE_T_MIN INT_MIN
|
|
#define PY_FORMAT_SIZE_T ""
|
|
#define PyInt_FromSsize_t(z) PyInt_FromLong(z)
|
|
#define PyInt_AsSsize_t(o) PyInt_AsLong(o)
|
|
#define PyNumber_Index(o) PyNumber_Int(o)
|
|
#define PyIndex_Check(o) PyNumber_Check(o)
|
|
#endif
|
|
#if PY_VERSION_HEX < 0x02060000
|
|
#define Py_REFCNT(ob) (((PyObject*)(ob))->ob_refcnt)
|
|
#define Py_TYPE(ob) (((PyObject*)(ob))->ob_type)
|
|
#define Py_SIZE(ob) (((PyVarObject*)(ob))->ob_size)
|
|
#define PyVarObject_HEAD_INIT(type, size) \
|
|
PyObject_HEAD_INIT(type) size,
|
|
#define PyType_Modified(t)
|
|
|
|
typedef struct {
|
|
void *buf;
|
|
PyObject *obj;
|
|
Py_ssize_t len;
|
|
Py_ssize_t itemsize;
|
|
int readonly;
|
|
int ndim;
|
|
char *format;
|
|
Py_ssize_t *shape;
|
|
Py_ssize_t *strides;
|
|
Py_ssize_t *suboffsets;
|
|
void *internal;
|
|
} Py_buffer;
|
|
|
|
#define PyBUF_SIMPLE 0
|
|
#define PyBUF_WRITABLE 0x0001
|
|
#define PyBUF_FORMAT 0x0004
|
|
#define PyBUF_ND 0x0008
|
|
#define PyBUF_STRIDES (0x0010 | PyBUF_ND)
|
|
#define PyBUF_C_CONTIGUOUS (0x0020 | PyBUF_STRIDES)
|
|
#define PyBUF_F_CONTIGUOUS (0x0040 | PyBUF_STRIDES)
|
|
#define PyBUF_ANY_CONTIGUOUS (0x0080 | PyBUF_STRIDES)
|
|
#define PyBUF_INDIRECT (0x0100 | PyBUF_STRIDES)
|
|
|
|
#endif
|
|
#if PY_MAJOR_VERSION < 3
|
|
#define __Pyx_BUILTIN_MODULE_NAME "__builtin__"
|
|
#else
|
|
#define __Pyx_BUILTIN_MODULE_NAME "builtins"
|
|
#endif
|
|
#if PY_MAJOR_VERSION >= 3
|
|
#define Py_TPFLAGS_CHECKTYPES 0
|
|
#define Py_TPFLAGS_HAVE_INDEX 0
|
|
#endif
|
|
#if (PY_VERSION_HEX < 0x02060000) || (PY_MAJOR_VERSION >= 3)
|
|
#define Py_TPFLAGS_HAVE_NEWBUFFER 0
|
|
#endif
|
|
#if PY_MAJOR_VERSION >= 3
|
|
#define PyBaseString_Type PyUnicode_Type
|
|
#define PyString_Type PyUnicode_Type
|
|
#define PyString_CheckExact PyUnicode_CheckExact
|
|
#else
|
|
#define PyBytes_Type PyString_Type
|
|
#define PyBytes_CheckExact PyString_CheckExact
|
|
#endif
|
|
#if PY_MAJOR_VERSION >= 3
|
|
#define PyInt_Type PyLong_Type
|
|
#define PyInt_Check(op) PyLong_Check(op)
|
|
#define PyInt_CheckExact(op) PyLong_CheckExact(op)
|
|
#define PyInt_FromString PyLong_FromString
|
|
#define PyInt_FromUnicode PyLong_FromUnicode
|
|
#define PyInt_FromLong PyLong_FromLong
|
|
#define PyInt_FromSize_t PyLong_FromSize_t
|
|
#define PyInt_FromSsize_t PyLong_FromSsize_t
|
|
#define PyInt_AsLong PyLong_AsLong
|
|
#define PyInt_AS_LONG PyLong_AS_LONG
|
|
#define PyInt_AsSsize_t PyLong_AsSsize_t
|
|
#define PyInt_AsUnsignedLongMask PyLong_AsUnsignedLongMask
|
|
#define PyInt_AsUnsignedLongLongMask PyLong_AsUnsignedLongLongMask
|
|
#define __Pyx_PyNumber_Divide(x,y) PyNumber_TrueDivide(x,y)
|
|
#define __Pyx_PyNumber_InPlaceDivide(x,y) PyNumber_InPlaceTrueDivide(x,y)
|
|
#else
|
|
#define __Pyx_PyNumber_Divide(x,y) PyNumber_Divide(x,y)
|
|
#define __Pyx_PyNumber_InPlaceDivide(x,y) PyNumber_InPlaceDivide(x,y)
|
|
#endif
|
|
#if PY_MAJOR_VERSION >= 3
|
|
#define PyMethod_New(func, self, klass) PyInstanceMethod_New(func)
|
|
#endif
|
|
#if !defined(WIN32) && !defined(MS_WINDOWS)
|
|
#ifndef __stdcall
|
|
#define __stdcall
|
|
#endif
|
|
#ifndef __cdecl
|
|
#define __cdecl
|
|
#endif
|
|
#ifndef __fastcall
|
|
#define __fastcall
|
|
#endif
|
|
#else
|
|
#define _USE_MATH_DEFINES
|
|
#endif
|
|
#if PY_VERSION_HEX < 0x02050000
|
|
#define __Pyx_GetAttrString(o,n) PyObject_GetAttrString((o),((char *)(n)))
|
|
#define __Pyx_SetAttrString(o,n,a) PyObject_SetAttrString((o),((char *)(n)),(a))
|
|
#define __Pyx_DelAttrString(o,n) PyObject_DelAttrString((o),((char *)(n)))
|
|
#else
|
|
#define __Pyx_GetAttrString(o,n) PyObject_GetAttrString((o),(n))
|
|
#define __Pyx_SetAttrString(o,n,a) PyObject_SetAttrString((o),(n),(a))
|
|
#define __Pyx_DelAttrString(o,n) PyObject_DelAttrString((o),(n))
|
|
#endif
|
|
#if PY_VERSION_HEX < 0x02050000
|
|
#define __Pyx_NAMESTR(n) ((char *)(n))
|
|
#define __Pyx_DOCSTR(n) ((char *)(n))
|
|
#else
|
|
#define __Pyx_NAMESTR(n) (n)
|
|
#define __Pyx_DOCSTR(n) (n)
|
|
#endif
|
|
#ifdef __cplusplus
|
|
#define __PYX_EXTERN_C extern "C"
|
|
#else
|
|
#define __PYX_EXTERN_C extern
|
|
#endif
|
|
#include <math.h>
|
|
#define __PYX_HAVE_API__h5py__h5s
|
|
#include "stdlib.h"
|
|
#include "string.h"
|
|
#include "time.h"
|
|
#include "unistd.h"
|
|
#include "stdint.h"
|
|
#include "compat.h"
|
|
#include "lzf_filter.h"
|
|
#include "hdf5.h"
|
|
#include "numpy/arrayobject.h"
|
|
|
|
#ifdef __GNUC__
|
|
#define INLINE __inline__
|
|
#elif _WIN32
|
|
#define INLINE __inline
|
|
#else
|
|
#define INLINE
|
|
#endif
|
|
|
|
typedef struct {PyObject **p; char *s; const long n; const char* encoding; const char is_unicode; const char is_str; const char intern; } __Pyx_StringTabEntry; /*proto*/
|
|
|
|
|
|
/* Type Conversion Predeclarations */
|
|
|
|
#if PY_MAJOR_VERSION < 3
|
|
#define __Pyx_PyBytes_FromString PyString_FromString
|
|
#define __Pyx_PyBytes_FromStringAndSize PyString_FromStringAndSize
|
|
#define __Pyx_PyBytes_AsString PyString_AsString
|
|
#else
|
|
#define __Pyx_PyBytes_FromString PyBytes_FromString
|
|
#define __Pyx_PyBytes_FromStringAndSize PyBytes_FromStringAndSize
|
|
#define __Pyx_PyBytes_AsString PyBytes_AsString
|
|
#endif
|
|
|
|
#define __Pyx_PyBytes_FromUString(s) __Pyx_PyBytes_FromString((char*)s)
|
|
#define __Pyx_PyBytes_AsUString(s) ((unsigned char*) __Pyx_PyBytes_AsString(s))
|
|
|
|
#define __Pyx_PyBool_FromLong(b) ((b) ? (Py_INCREF(Py_True), Py_True) : (Py_INCREF(Py_False), Py_False))
|
|
static INLINE int __Pyx_PyObject_IsTrue(PyObject*);
|
|
static INLINE PyObject* __Pyx_PyNumber_Int(PyObject* x);
|
|
|
|
#if !defined(T_PYSSIZET)
|
|
#if PY_VERSION_HEX < 0x02050000
|
|
#define T_PYSSIZET T_INT
|
|
#elif !defined(T_LONGLONG)
|
|
#define T_PYSSIZET \
|
|
((sizeof(Py_ssize_t) == sizeof(int)) ? T_INT : \
|
|
((sizeof(Py_ssize_t) == sizeof(long)) ? T_LONG : -1))
|
|
#else
|
|
#define T_PYSSIZET \
|
|
((sizeof(Py_ssize_t) == sizeof(int)) ? T_INT : \
|
|
((sizeof(Py_ssize_t) == sizeof(long)) ? T_LONG : \
|
|
((sizeof(Py_ssize_t) == sizeof(PY_LONG_LONG)) ? T_LONGLONG : -1)))
|
|
#endif
|
|
#endif
|
|
|
|
|
|
#if !defined(T_ULONGLONG)
|
|
#define __Pyx_T_UNSIGNED_INT(x) \
|
|
((sizeof(x) == sizeof(unsigned char)) ? T_UBYTE : \
|
|
((sizeof(x) == sizeof(unsigned short)) ? T_USHORT : \
|
|
((sizeof(x) == sizeof(unsigned int)) ? T_UINT : \
|
|
((sizeof(x) == sizeof(unsigned long)) ? T_ULONG : -1))))
|
|
#else
|
|
#define __Pyx_T_UNSIGNED_INT(x) \
|
|
((sizeof(x) == sizeof(unsigned char)) ? T_UBYTE : \
|
|
((sizeof(x) == sizeof(unsigned short)) ? T_USHORT : \
|
|
((sizeof(x) == sizeof(unsigned int)) ? T_UINT : \
|
|
((sizeof(x) == sizeof(unsigned long)) ? T_ULONG : \
|
|
((sizeof(x) == sizeof(unsigned PY_LONG_LONG)) ? T_ULONGLONG : -1)))))
|
|
#endif
|
|
#if !defined(T_LONGLONG)
|
|
#define __Pyx_T_SIGNED_INT(x) \
|
|
((sizeof(x) == sizeof(char)) ? T_BYTE : \
|
|
((sizeof(x) == sizeof(short)) ? T_SHORT : \
|
|
((sizeof(x) == sizeof(int)) ? T_INT : \
|
|
((sizeof(x) == sizeof(long)) ? T_LONG : -1))))
|
|
#else
|
|
#define __Pyx_T_SIGNED_INT(x) \
|
|
((sizeof(x) == sizeof(char)) ? T_BYTE : \
|
|
((sizeof(x) == sizeof(short)) ? T_SHORT : \
|
|
((sizeof(x) == sizeof(int)) ? T_INT : \
|
|
((sizeof(x) == sizeof(long)) ? T_LONG : \
|
|
((sizeof(x) == sizeof(PY_LONG_LONG)) ? T_LONGLONG : -1)))))
|
|
#endif
|
|
|
|
#define __Pyx_T_FLOATING(x) \
|
|
((sizeof(x) == sizeof(float)) ? T_FLOAT : \
|
|
((sizeof(x) == sizeof(double)) ? T_DOUBLE : -1))
|
|
|
|
#if !defined(T_SIZET)
|
|
#if !defined(T_ULONGLONG)
|
|
#define T_SIZET \
|
|
((sizeof(size_t) == sizeof(unsigned int)) ? T_UINT : \
|
|
((sizeof(size_t) == sizeof(unsigned long)) ? T_ULONG : -1))
|
|
#else
|
|
#define T_SIZET \
|
|
((sizeof(size_t) == sizeof(unsigned int)) ? T_UINT : \
|
|
((sizeof(size_t) == sizeof(unsigned long)) ? T_ULONG : \
|
|
((sizeof(size_t) == sizeof(unsigned PY_LONG_LONG)) ? T_ULONGLONG : -1)))
|
|
#endif
|
|
#endif
|
|
|
|
static INLINE Py_ssize_t __Pyx_PyIndex_AsSsize_t(PyObject*);
|
|
static INLINE PyObject * __Pyx_PyInt_FromSize_t(size_t);
|
|
static INLINE size_t __Pyx_PyInt_AsSize_t(PyObject*);
|
|
|
|
#define __pyx_PyFloat_AsDouble(x) (PyFloat_CheckExact(x) ? PyFloat_AS_DOUBLE(x) : PyFloat_AsDouble(x))
|
|
|
|
|
|
#ifdef __GNUC__
|
|
/* Test for GCC > 2.95 */
|
|
#if __GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95))
|
|
#define likely(x) __builtin_expect(!!(x), 1)
|
|
#define unlikely(x) __builtin_expect(!!(x), 0)
|
|
#else /* __GNUC__ > 2 ... */
|
|
#define likely(x) (x)
|
|
#define unlikely(x) (x)
|
|
#endif /* __GNUC__ > 2 ... */
|
|
#else /* __GNUC__ */
|
|
#define likely(x) (x)
|
|
#define unlikely(x) (x)
|
|
#endif /* __GNUC__ */
|
|
|
|
static PyObject *__pyx_m;
|
|
static PyObject *__pyx_b;
|
|
static PyObject *__pyx_empty_tuple;
|
|
static PyObject *__pyx_empty_bytes;
|
|
static int __pyx_lineno;
|
|
static int __pyx_clineno = 0;
|
|
static const char * __pyx_cfilenm= __FILE__;
|
|
static const char *__pyx_filename;
|
|
static const char **__pyx_f;
|
|
|
|
|
|
/* Type declarations */
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/utils.pxd":20
|
|
* cdef void efree(void* ptr)
|
|
*
|
|
* cpdef int check_numpy_read(ndarray arr, hid_t space_id=*) except -1 # <<<<<<<<<<<<<<
|
|
* cpdef int check_numpy_write(ndarray arr, hid_t space_id=*) except -1
|
|
*
|
|
*/
|
|
|
|
struct __pyx_opt_args_4h5py_5utils_check_numpy_read {
|
|
int __pyx_n;
|
|
hid_t space_id;
|
|
};
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/utils.pxd":21
|
|
*
|
|
* cpdef int check_numpy_read(ndarray arr, hid_t space_id=*) except -1
|
|
* cpdef int check_numpy_write(ndarray arr, hid_t space_id=*) except -1 # <<<<<<<<<<<<<<
|
|
*
|
|
* cdef int convert_tuple(object tuple, hsize_t *dims, hsize_t rank) except -1
|
|
*/
|
|
|
|
struct __pyx_opt_args_4h5py_5utils_check_numpy_write {
|
|
int __pyx_n;
|
|
hid_t space_id;
|
|
};
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5.pxd":28
|
|
* cpdef H5PYConfig get_config()
|
|
*
|
|
* cdef class ObjectID: # <<<<<<<<<<<<<<
|
|
*
|
|
* cdef object __weakref__
|
|
*/
|
|
|
|
struct __pyx_obj_4h5py_2h5_ObjectID {
|
|
PyObject_HEAD
|
|
PyObject *__weakref__;
|
|
hid_t id;
|
|
int _locked;
|
|
PyObject *_hash;
|
|
};
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pxd":17
|
|
* from h5 cimport class ObjectID
|
|
*
|
|
* cdef class SpaceID(ObjectID): # <<<<<<<<<<<<<<
|
|
* pass
|
|
*
|
|
*/
|
|
|
|
struct __pyx_obj_4h5py_3h5s_SpaceID {
|
|
struct __pyx_obj_4h5py_2h5_ObjectID __pyx_base;
|
|
};
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5.pxd":15
|
|
* include "defs.pxd"
|
|
*
|
|
* cdef class H5PYConfig: # <<<<<<<<<<<<<<
|
|
*
|
|
* cdef object _r_name
|
|
*/
|
|
|
|
struct __pyx_obj_4h5py_2h5_H5PYConfig {
|
|
PyObject_HEAD
|
|
PyObject *_r_name;
|
|
PyObject *_i_name;
|
|
PyObject *_f_name;
|
|
PyObject *_t_name;
|
|
PyObject *API_16;
|
|
PyObject *API_18;
|
|
PyObject *DEBUG;
|
|
PyObject *THREADS;
|
|
};
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5.pxd":35
|
|
* cdef object _hash
|
|
*
|
|
* cdef class SmartStruct: # <<<<<<<<<<<<<<
|
|
* cdef object __weakref__
|
|
* cdef object _title
|
|
*/
|
|
|
|
struct __pyx_obj_4h5py_2h5_SmartStruct {
|
|
PyObject_HEAD
|
|
PyObject *__weakref__;
|
|
PyObject *_title;
|
|
};
|
|
|
|
#ifndef CYTHON_REFNANNY
|
|
#define CYTHON_REFNANNY 0
|
|
#endif
|
|
|
|
#if CYTHON_REFNANNY
|
|
typedef struct {
|
|
void (*INCREF)(void*, PyObject*, int);
|
|
void (*DECREF)(void*, PyObject*, int);
|
|
void (*GOTREF)(void*, PyObject*, int);
|
|
void (*GIVEREF)(void*, PyObject*, int);
|
|
void* (*SetupContext)(const char*, int, const char*);
|
|
void (*FinishContext)(void**);
|
|
} __Pyx_RefNannyAPIStruct;
|
|
static __Pyx_RefNannyAPIStruct *__Pyx_RefNanny = NULL;
|
|
static __Pyx_RefNannyAPIStruct * __Pyx_RefNannyImportAPI(const char *modname) {
|
|
PyObject *m = NULL, *p = NULL;
|
|
void *r = NULL;
|
|
m = PyImport_ImportModule((char *)modname);
|
|
if (!m) goto end;
|
|
p = PyObject_GetAttrString(m, (char *)"RefNannyAPI");
|
|
if (!p) goto end;
|
|
r = PyLong_AsVoidPtr(p);
|
|
end:
|
|
Py_XDECREF(p);
|
|
Py_XDECREF(m);
|
|
return (__Pyx_RefNannyAPIStruct *)r;
|
|
}
|
|
#define __Pyx_RefNannySetupContext(name) void *__pyx_refnanny = __Pyx_RefNanny->SetupContext((name), __LINE__, __FILE__)
|
|
#define __Pyx_RefNannyFinishContext() __Pyx_RefNanny->FinishContext(&__pyx_refnanny)
|
|
#define __Pyx_INCREF(r) __Pyx_RefNanny->INCREF(__pyx_refnanny, (PyObject *)(r), __LINE__)
|
|
#define __Pyx_DECREF(r) __Pyx_RefNanny->DECREF(__pyx_refnanny, (PyObject *)(r), __LINE__)
|
|
#define __Pyx_GOTREF(r) __Pyx_RefNanny->GOTREF(__pyx_refnanny, (PyObject *)(r), __LINE__)
|
|
#define __Pyx_GIVEREF(r) __Pyx_RefNanny->GIVEREF(__pyx_refnanny, (PyObject *)(r), __LINE__)
|
|
#define __Pyx_XDECREF(r) do { if((r) != NULL) {__Pyx_DECREF(r);} } while(0)
|
|
#else
|
|
#define __Pyx_RefNannySetupContext(name)
|
|
#define __Pyx_RefNannyFinishContext()
|
|
#define __Pyx_INCREF(r) Py_INCREF(r)
|
|
#define __Pyx_DECREF(r) Py_DECREF(r)
|
|
#define __Pyx_GOTREF(r)
|
|
#define __Pyx_GIVEREF(r)
|
|
#define __Pyx_XDECREF(r) Py_XDECREF(r)
|
|
#endif /* CYTHON_REFNANNY */
|
|
#define __Pyx_XGIVEREF(r) do { if((r) != NULL) {__Pyx_GIVEREF(r);} } while(0)
|
|
#define __Pyx_XGOTREF(r) do { if((r) != NULL) {__Pyx_GOTREF(r);} } while(0)
|
|
|
|
static void __Pyx_RaiseDoubleKeywordsError(
|
|
const char* func_name, PyObject* kw_name); /*proto*/
|
|
|
|
static void __Pyx_RaiseArgtupleInvalid(const char* func_name, int exact,
|
|
Py_ssize_t num_min, Py_ssize_t num_max, Py_ssize_t num_found); /*proto*/
|
|
|
|
static int __Pyx_ParseOptionalKeywords(PyObject *kwds, PyObject **argnames[], PyObject *kwds2, PyObject *values[], Py_ssize_t num_pos_args, const char* function_name); /*proto*/
|
|
|
|
static INLINE void __Pyx_ErrRestore(PyObject *type, PyObject *value, PyObject *tb); /*proto*/
|
|
static INLINE void __Pyx_ErrFetch(PyObject **type, PyObject **value, PyObject **tb); /*proto*/
|
|
|
|
static INLINE int __Pyx_TypeTest(PyObject *obj, PyTypeObject *type); /*proto*/
|
|
|
|
static int __Pyx_ArgTypeTest(PyObject *obj, PyTypeObject *type, int none_allowed,
|
|
const char *name, int exact); /*proto*/
|
|
|
|
static INLINE PyObject *__Pyx_PyInt_to_py_hsize_t(hsize_t);
|
|
|
|
static INLINE PyObject *__Pyx_PyInt_to_py_hid_t(hid_t);
|
|
|
|
static PyObject *__Pyx_GetName(PyObject *dict, PyObject *name); /*proto*/
|
|
|
|
static void __Pyx_Raise(PyObject *type, PyObject *value, PyObject *tb); /*proto*/
|
|
|
|
static INLINE PyObject *__Pyx_PyInt_to_py_hssize_t(hssize_t);
|
|
|
|
static INLINE unsigned char __Pyx_PyInt_AsUnsignedChar(PyObject *);
|
|
|
|
static INLINE unsigned short __Pyx_PyInt_AsUnsignedShort(PyObject *);
|
|
|
|
static INLINE unsigned int __Pyx_PyInt_AsUnsignedInt(PyObject *);
|
|
|
|
static INLINE char __Pyx_PyInt_AsChar(PyObject *);
|
|
|
|
static INLINE short __Pyx_PyInt_AsShort(PyObject *);
|
|
|
|
static INLINE int __Pyx_PyInt_AsInt(PyObject *);
|
|
|
|
static INLINE signed char __Pyx_PyInt_AsSignedChar(PyObject *);
|
|
|
|
static INLINE signed short __Pyx_PyInt_AsSignedShort(PyObject *);
|
|
|
|
static INLINE signed int __Pyx_PyInt_AsSignedInt(PyObject *);
|
|
|
|
static INLINE unsigned long __Pyx_PyInt_AsUnsignedLong(PyObject *);
|
|
|
|
static INLINE unsigned PY_LONG_LONG __Pyx_PyInt_AsUnsignedLongLong(PyObject *);
|
|
|
|
static INLINE long __Pyx_PyInt_AsLong(PyObject *);
|
|
|
|
static INLINE PY_LONG_LONG __Pyx_PyInt_AsLongLong(PyObject *);
|
|
|
|
static INLINE signed long __Pyx_PyInt_AsSignedLong(PyObject *);
|
|
|
|
static INLINE signed PY_LONG_LONG __Pyx_PyInt_AsSignedLongLong(PyObject *);
|
|
|
|
static PyTypeObject *__Pyx_ImportType(const char *module_name, const char *class_name, long size); /*proto*/
|
|
|
|
static PyObject *__Pyx_ImportModule(const char *name); /*proto*/
|
|
|
|
static int __Pyx_ImportFunction(PyObject *module, const char *funcname, void (**f)(void), const char *sig); /*proto*/
|
|
|
|
static void __Pyx_AddTraceback(const char *funcname); /*proto*/
|
|
|
|
static int __Pyx_InitStrings(__Pyx_StringTabEntry *t); /*proto*/
|
|
/* Module declarations from h5py.h5 */
|
|
|
|
static PyTypeObject *__pyx_ptype_4h5py_2h5_H5PYConfig = 0;
|
|
static PyTypeObject *__pyx_ptype_4h5py_2h5_ObjectID = 0;
|
|
static PyTypeObject *__pyx_ptype_4h5py_2h5_SmartStruct = 0;
|
|
static struct __pyx_obj_4h5py_2h5_H5PYConfig *(*__pyx_f_4h5py_2h5_get_config)(int __pyx_skip_dispatch); /*proto*/
|
|
static int (*__pyx_f_4h5py_2h5_init_hdf5)(void); /*proto*/
|
|
/* Module declarations from numpy */
|
|
|
|
/* Module declarations from h5py.numpy */
|
|
|
|
static PyTypeObject *__pyx_ptype_4h5py_5numpy_dtype = 0;
|
|
static PyTypeObject *__pyx_ptype_4h5py_5numpy_ndarray = 0;
|
|
/* Module declarations from h5py.utils */
|
|
|
|
static void *(*__pyx_f_4h5py_5utils_emalloc)(size_t); /*proto*/
|
|
static void (*__pyx_f_4h5py_5utils_efree)(void *); /*proto*/
|
|
static int (*__pyx_f_4h5py_5utils_check_numpy_read)(PyArrayObject *, int __pyx_skip_dispatch, struct __pyx_opt_args_4h5py_5utils_check_numpy_read *__pyx_optional_args); /*proto*/
|
|
static int (*__pyx_f_4h5py_5utils_check_numpy_write)(PyArrayObject *, int __pyx_skip_dispatch, struct __pyx_opt_args_4h5py_5utils_check_numpy_write *__pyx_optional_args); /*proto*/
|
|
static int (*__pyx_f_4h5py_5utils_convert_tuple)(PyObject *, hsize_t *, hsize_t); /*proto*/
|
|
static PyObject *(*__pyx_f_4h5py_5utils_convert_dims)(hsize_t *, hsize_t); /*proto*/
|
|
static int (*__pyx_f_4h5py_5utils_require_tuple)(PyObject *, int, int, char *); /*proto*/
|
|
static PyObject *(*__pyx_f_4h5py_5utils_create_numpy_hsize)(int, hsize_t *); /*proto*/
|
|
static PyObject *(*__pyx_f_4h5py_5utils_create_hsize_array)(PyObject *); /*proto*/
|
|
/* Module declarations from python_ref */
|
|
|
|
/* Module declarations from python_string */
|
|
|
|
/* Module declarations from h5py.h5s */
|
|
|
|
static PyTypeObject *__pyx_ptype_4h5py_3h5s_SpaceID = 0;
|
|
static PyObject *__pyx_f_4h5py_3h5s_lockid(hid_t); /*proto*/
|
|
#define __Pyx_MODULE_NAME "h5py.h5s"
|
|
int __pyx_module_is_main_h5py__h5s = 0;
|
|
|
|
/* Implementation of h5py.h5s */
|
|
static PyObject *__pyx_builtin_ValueError;
|
|
static char __pyx_k_1[] = "get_simple_extent_dims";
|
|
static char __pyx_k_2[] = "%d is not a simple dataspace";
|
|
static char __pyx_k_4[] = "Coordinate array must have shape (<npoints>, %d)";
|
|
static char __pyx_k_5[] = "get_simple_extent_ndims";
|
|
static char __pyx_k_7[] = " Numpy-style shape tuple representing dimensions. () == scalar.\n ";
|
|
static char __pyx_k_8[] = "\n Low-level interface to the \"H5S\" family of data-space functions.\n";
|
|
static char __pyx_k__id[] = "id";
|
|
static char __pyx_k__nd[] = "nd";
|
|
static char __pyx_k__op[] = "op";
|
|
static char __pyx_k__ALL[] = "ALL";
|
|
static char __pyx_k__data[] = "data";
|
|
static char __pyx_k__block[] = "block";
|
|
static char __pyx_k__count[] = "count";
|
|
static char __pyx_k__start[] = "start";
|
|
static char __pyx_k__SCALAR[] = "SCALAR";
|
|
static char __pyx_k__SIMPLE[] = "SIMPLE";
|
|
static char __pyx_k__coords[] = "coords";
|
|
static char __pyx_k__offset[] = "offset";
|
|
static char __pyx_k__stride[] = "stride";
|
|
static char __pyx_k__SEL_ALL[] = "SEL_ALL";
|
|
static char __pyx_k___locked[] = "_locked";
|
|
static char __pyx_k__maxdims[] = "maxdims";
|
|
static char __pyx_k__NO_CLASS[] = "NO_CLASS";
|
|
static char __pyx_k__SEL_NONE[] = "SEL_NONE";
|
|
static char __pyx_k____main__[] = "__main__";
|
|
static char __pyx_k__dims_tpl[] = "dims_tpl";
|
|
static char __pyx_k__SELECT_OR[] = "SELECT_OR";
|
|
static char __pyx_k__SEL_ERROR[] = "SEL_ERROR";
|
|
static char __pyx_k__UNLIMITED[] = "UNLIMITED";
|
|
static char __pyx_k__SELECT_AND[] = "SELECT_AND";
|
|
static char __pyx_k__SELECT_SET[] = "SELECT_SET";
|
|
static char __pyx_k__SELECT_XOR[] = "SELECT_XOR";
|
|
static char __pyx_k__SEL_POINTS[] = "SEL_POINTS";
|
|
static char __pyx_k__ValueError[] = "ValueError";
|
|
static char __pyx_k__dimensions[] = "dimensions";
|
|
static char __pyx_k__SELECT_NOOP[] = "SELECT_NOOP";
|
|
static char __pyx_k__SELECT_NOTA[] = "SELECT_NOTA";
|
|
static char __pyx_k__SELECT_NOTB[] = "SELECT_NOTB";
|
|
static char __pyx_k__max_dims_tpl[] = "max_dims_tpl";
|
|
static char __pyx_k__SELECT_APPEND[] = "SELECT_APPEND";
|
|
static char __pyx_k__SELECT_INVALID[] = "SELECT_INVALID";
|
|
static char __pyx_k__SELECT_PREPEND[] = "SELECT_PREPEND";
|
|
static char __pyx_k__SEL_HYPERSLABS[] = "SEL_HYPERSLABS";
|
|
static PyObject *__pyx_n_s_1;
|
|
static PyObject *__pyx_kp_s_2;
|
|
static PyObject *__pyx_kp_s_4;
|
|
static PyObject *__pyx_n_s_5;
|
|
static PyObject *__pyx_n_s__ALL;
|
|
static PyObject *__pyx_n_s__NO_CLASS;
|
|
static PyObject *__pyx_n_s__SCALAR;
|
|
static PyObject *__pyx_n_s__SELECT_AND;
|
|
static PyObject *__pyx_n_s__SELECT_APPEND;
|
|
static PyObject *__pyx_n_s__SELECT_INVALID;
|
|
static PyObject *__pyx_n_s__SELECT_NOOP;
|
|
static PyObject *__pyx_n_s__SELECT_NOTA;
|
|
static PyObject *__pyx_n_s__SELECT_NOTB;
|
|
static PyObject *__pyx_n_s__SELECT_OR;
|
|
static PyObject *__pyx_n_s__SELECT_PREPEND;
|
|
static PyObject *__pyx_n_s__SELECT_SET;
|
|
static PyObject *__pyx_n_s__SELECT_XOR;
|
|
static PyObject *__pyx_n_s__SEL_ALL;
|
|
static PyObject *__pyx_n_s__SEL_ERROR;
|
|
static PyObject *__pyx_n_s__SEL_HYPERSLABS;
|
|
static PyObject *__pyx_n_s__SEL_NONE;
|
|
static PyObject *__pyx_n_s__SEL_POINTS;
|
|
static PyObject *__pyx_n_s__SIMPLE;
|
|
static PyObject *__pyx_n_s__UNLIMITED;
|
|
static PyObject *__pyx_n_s__ValueError;
|
|
static PyObject *__pyx_n_s____main__;
|
|
static PyObject *__pyx_n_s___locked;
|
|
static PyObject *__pyx_n_s__block;
|
|
static PyObject *__pyx_n_s__coords;
|
|
static PyObject *__pyx_n_s__count;
|
|
static PyObject *__pyx_n_s__data;
|
|
static PyObject *__pyx_n_s__dimensions;
|
|
static PyObject *__pyx_n_s__dims_tpl;
|
|
static PyObject *__pyx_n_s__id;
|
|
static PyObject *__pyx_n_s__max_dims_tpl;
|
|
static PyObject *__pyx_n_s__maxdims;
|
|
static PyObject *__pyx_n_s__nd;
|
|
static PyObject *__pyx_n_s__offset;
|
|
static PyObject *__pyx_n_s__op;
|
|
static PyObject *__pyx_n_s__start;
|
|
static PyObject *__pyx_n_s__stride;
|
|
static int __pyx_k_3;
|
|
static int __pyx_k_6;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":29
|
|
* init_hdf5()
|
|
*
|
|
* cdef object lockid(hid_t id_): # <<<<<<<<<<<<<<
|
|
* cdef SpaceID space
|
|
* space = SpaceID(id_)
|
|
*/
|
|
|
|
static PyObject *__pyx_f_4h5py_3h5s_lockid(hid_t __pyx_v_id_) {
|
|
struct __pyx_obj_4h5py_3h5s_SpaceID *__pyx_v_space;
|
|
PyObject *__pyx_r = NULL;
|
|
PyObject *__pyx_t_1 = NULL;
|
|
PyObject *__pyx_t_2 = NULL;
|
|
__Pyx_RefNannySetupContext("lockid");
|
|
__pyx_v_space = ((struct __pyx_obj_4h5py_3h5s_SpaceID *)Py_None); __Pyx_INCREF(Py_None);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":31
|
|
* cdef object lockid(hid_t id_):
|
|
* cdef SpaceID space
|
|
* space = SpaceID(id_) # <<<<<<<<<<<<<<
|
|
* space._locked = 1
|
|
* return space
|
|
*/
|
|
__pyx_t_1 = __Pyx_PyInt_to_py_hid_t(__pyx_v_id_); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 31; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_2 = PyTuple_New(1); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 31; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_1);
|
|
__Pyx_GIVEREF(__pyx_t_1);
|
|
__pyx_t_1 = 0;
|
|
__pyx_t_1 = PyObject_Call(((PyObject *)((PyObject*)__pyx_ptype_4h5py_3h5s_SpaceID)), __pyx_t_2, NULL); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 31; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
|
|
__Pyx_DECREF(((PyObject *)__pyx_v_space));
|
|
__pyx_v_space = ((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_t_1);
|
|
__pyx_t_1 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":32
|
|
* cdef SpaceID space
|
|
* space = SpaceID(id_)
|
|
* space._locked = 1 # <<<<<<<<<<<<<<
|
|
* return space
|
|
*
|
|
*/
|
|
__pyx_v_space->__pyx_base._locked = 1;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":33
|
|
* space = SpaceID(id_)
|
|
* space._locked = 1
|
|
* return space # <<<<<<<<<<<<<<
|
|
*
|
|
* # === Public constants and data structures ====================================
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__Pyx_INCREF(((PyObject *)__pyx_v_space));
|
|
__pyx_r = ((PyObject *)__pyx_v_space);
|
|
goto __pyx_L0;
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_1);
|
|
__Pyx_XDECREF(__pyx_t_2);
|
|
__Pyx_AddTraceback("h5py.h5s.lockid");
|
|
__pyx_r = 0;
|
|
__pyx_L0:;
|
|
__Pyx_DECREF((PyObject *)__pyx_v_space);
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":68
|
|
*
|
|
*
|
|
* def create(int class_code): # <<<<<<<<<<<<<<
|
|
* """(INT class_code) => SpaceID
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5s_create(PyObject *__pyx_self, PyObject *__pyx_arg_class_code); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5s_create[] = "(INT class_code) => SpaceID\n\n Create a new HDF5 dataspace object, of the given class.\n Legal values are SCALAR and SIMPLE.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5s_create(PyObject *__pyx_self, PyObject *__pyx_arg_class_code) {
|
|
int __pyx_v_class_code;
|
|
PyObject *__pyx_r = NULL;
|
|
hid_t __pyx_t_1;
|
|
PyObject *__pyx_t_2 = NULL;
|
|
PyObject *__pyx_t_3 = NULL;
|
|
__Pyx_RefNannySetupContext("create");
|
|
__pyx_self = __pyx_self;
|
|
assert(__pyx_arg_class_code); {
|
|
__pyx_v_class_code = __Pyx_PyInt_AsInt(__pyx_arg_class_code); if (unlikely((__pyx_v_class_code == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 68; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
goto __pyx_L4_argument_unpacking_done;
|
|
__pyx_L3_error:;
|
|
__Pyx_AddTraceback("h5py.h5s.create");
|
|
return NULL;
|
|
__pyx_L4_argument_unpacking_done:;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":74
|
|
* Legal values are SCALAR and SIMPLE.
|
|
* """
|
|
* return SpaceID(H5Screate(<H5S_class_t>class_code)) # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_1 = H5Screate(((H5S_class_t)__pyx_v_class_code)); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 74; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_t_2 = __Pyx_PyInt_to_py_hid_t(__pyx_t_1); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 74; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__pyx_t_3 = PyTuple_New(1); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 74; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_2);
|
|
__Pyx_GIVEREF(__pyx_t_2);
|
|
__pyx_t_2 = 0;
|
|
__pyx_t_2 = PyObject_Call(((PyObject *)((PyObject*)__pyx_ptype_4h5py_3h5s_SpaceID)), __pyx_t_3, NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 74; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
__pyx_r = __pyx_t_2;
|
|
__pyx_t_2 = 0;
|
|
goto __pyx_L0;
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_2);
|
|
__Pyx_XDECREF(__pyx_t_3);
|
|
__Pyx_AddTraceback("h5py.h5s.create");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":77
|
|
*
|
|
*
|
|
* def create_simple(object dims_tpl, object max_dims_tpl=None): # <<<<<<<<<<<<<<
|
|
* """(TUPLE dims_tpl, TUPLE max_dims_tpl) => SpaceID
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5s_create_simple(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5s_create_simple[] = "(TUPLE dims_tpl, TUPLE max_dims_tpl) => SpaceID\n\n Create a simple (slab) dataspace from a tuple of dimensions. \n Every element of dims_tpl must be a positive integer. \n\n You can optionally specify the maximum dataspace size. The \n special value UNLIMITED, as an element of max_dims, indicates \n an unlimited dimension.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5s_create_simple(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
|
|
PyObject *__pyx_v_dims_tpl = 0;
|
|
PyObject *__pyx_v_max_dims_tpl = 0;
|
|
int __pyx_v_rank;
|
|
hsize_t *__pyx_v_dims;
|
|
hsize_t *__pyx_v_max_dims;
|
|
PyObject *__pyx_r = NULL;
|
|
int __pyx_t_1;
|
|
Py_ssize_t __pyx_t_2;
|
|
void *__pyx_t_3;
|
|
int __pyx_t_4;
|
|
hid_t __pyx_t_5;
|
|
PyObject *__pyx_t_6 = NULL;
|
|
PyObject *__pyx_t_7 = NULL;
|
|
static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__dims_tpl,&__pyx_n_s__max_dims_tpl,0};
|
|
__Pyx_RefNannySetupContext("create_simple");
|
|
__pyx_self = __pyx_self;
|
|
if (unlikely(__pyx_kwds)) {
|
|
Py_ssize_t kw_args = PyDict_Size(__pyx_kwds);
|
|
PyObject* values[2] = {0,0};
|
|
values[1] = ((PyObject *)Py_None);
|
|
switch (PyTuple_GET_SIZE(__pyx_args)) {
|
|
case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
|
|
case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
|
|
case 0: break;
|
|
default: goto __pyx_L5_argtuple_error;
|
|
}
|
|
switch (PyTuple_GET_SIZE(__pyx_args)) {
|
|
case 0:
|
|
values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__dims_tpl);
|
|
if (likely(values[0])) kw_args--;
|
|
else goto __pyx_L5_argtuple_error;
|
|
case 1:
|
|
if (kw_args > 0) {
|
|
PyObject* value = PyDict_GetItem(__pyx_kwds, __pyx_n_s__max_dims_tpl);
|
|
if (unlikely(value)) { values[1] = value; kw_args--; }
|
|
}
|
|
}
|
|
if (unlikely(kw_args > 0)) {
|
|
if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, PyTuple_GET_SIZE(__pyx_args), "create_simple") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 77; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
__pyx_v_dims_tpl = values[0];
|
|
__pyx_v_max_dims_tpl = values[1];
|
|
} else {
|
|
__pyx_v_max_dims_tpl = ((PyObject *)Py_None);
|
|
switch (PyTuple_GET_SIZE(__pyx_args)) {
|
|
case 2: __pyx_v_max_dims_tpl = PyTuple_GET_ITEM(__pyx_args, 1);
|
|
case 1: __pyx_v_dims_tpl = PyTuple_GET_ITEM(__pyx_args, 0);
|
|
break;
|
|
default: goto __pyx_L5_argtuple_error;
|
|
}
|
|
}
|
|
goto __pyx_L4_argument_unpacking_done;
|
|
__pyx_L5_argtuple_error:;
|
|
__Pyx_RaiseArgtupleInvalid("create_simple", 0, 1, 2, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 77; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
__pyx_L3_error:;
|
|
__Pyx_AddTraceback("h5py.h5s.create_simple");
|
|
return NULL;
|
|
__pyx_L4_argument_unpacking_done:;
|
|
__Pyx_INCREF(__pyx_v_dims_tpl);
|
|
__Pyx_INCREF(__pyx_v_max_dims_tpl);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":88
|
|
* """
|
|
* cdef int rank
|
|
* cdef hsize_t* dims = NULL # <<<<<<<<<<<<<<
|
|
* cdef hsize_t* max_dims = NULL
|
|
*
|
|
*/
|
|
__pyx_v_dims = NULL;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":89
|
|
* cdef int rank
|
|
* cdef hsize_t* dims = NULL
|
|
* cdef hsize_t* max_dims = NULL # <<<<<<<<<<<<<<
|
|
*
|
|
* require_tuple(dims_tpl, 0, -1, "dims_tpl")
|
|
*/
|
|
__pyx_v_max_dims = NULL;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":91
|
|
* cdef hsize_t* max_dims = NULL
|
|
*
|
|
* require_tuple(dims_tpl, 0, -1, "dims_tpl") # <<<<<<<<<<<<<<
|
|
* rank = len(dims_tpl)
|
|
* require_tuple(max_dims_tpl, 1, rank, "max_dims_tpl")
|
|
*/
|
|
__pyx_t_1 = __pyx_f_4h5py_5utils_require_tuple(__pyx_v_dims_tpl, 0, -1, __pyx_k__dims_tpl); if (unlikely(__pyx_t_1 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 91; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":92
|
|
*
|
|
* require_tuple(dims_tpl, 0, -1, "dims_tpl")
|
|
* rank = len(dims_tpl) # <<<<<<<<<<<<<<
|
|
* require_tuple(max_dims_tpl, 1, rank, "max_dims_tpl")
|
|
*
|
|
*/
|
|
__pyx_t_2 = PyObject_Length(__pyx_v_dims_tpl); if (unlikely(__pyx_t_2 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 92; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_v_rank = __pyx_t_2;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":93
|
|
* require_tuple(dims_tpl, 0, -1, "dims_tpl")
|
|
* rank = len(dims_tpl)
|
|
* require_tuple(max_dims_tpl, 1, rank, "max_dims_tpl") # <<<<<<<<<<<<<<
|
|
*
|
|
* try:
|
|
*/
|
|
__pyx_t_1 = __pyx_f_4h5py_5utils_require_tuple(__pyx_v_max_dims_tpl, 1, __pyx_v_rank, __pyx_k__max_dims_tpl); if (unlikely(__pyx_t_1 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 93; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":95
|
|
* require_tuple(max_dims_tpl, 1, rank, "max_dims_tpl")
|
|
*
|
|
* try: # <<<<<<<<<<<<<<
|
|
* dims = <hsize_t*>emalloc(sizeof(hsize_t)*rank)
|
|
* convert_tuple(dims_tpl, dims, rank)
|
|
*/
|
|
/*try:*/ {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":96
|
|
*
|
|
* try:
|
|
* dims = <hsize_t*>emalloc(sizeof(hsize_t)*rank) # <<<<<<<<<<<<<<
|
|
* convert_tuple(dims_tpl, dims, rank)
|
|
*
|
|
*/
|
|
__pyx_t_3 = __pyx_f_4h5py_5utils_emalloc(((sizeof(hsize_t)) * __pyx_v_rank)); if (unlikely(__pyx_t_3 == NULL && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 96; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
__pyx_v_dims = ((hsize_t *)__pyx_t_3);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":97
|
|
* try:
|
|
* dims = <hsize_t*>emalloc(sizeof(hsize_t)*rank)
|
|
* convert_tuple(dims_tpl, dims, rank) # <<<<<<<<<<<<<<
|
|
*
|
|
* if max_dims_tpl is not None:
|
|
*/
|
|
__pyx_t_1 = __pyx_f_4h5py_5utils_convert_tuple(__pyx_v_dims_tpl, __pyx_v_dims, __pyx_v_rank); if (unlikely(__pyx_t_1 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 97; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":99
|
|
* convert_tuple(dims_tpl, dims, rank)
|
|
*
|
|
* if max_dims_tpl is not None: # <<<<<<<<<<<<<<
|
|
* max_dims = <hsize_t*>emalloc(sizeof(hsize_t)*rank)
|
|
* convert_tuple(max_dims_tpl, max_dims, rank)
|
|
*/
|
|
__pyx_t_4 = (__pyx_v_max_dims_tpl != Py_None);
|
|
if (__pyx_t_4) {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":100
|
|
*
|
|
* if max_dims_tpl is not None:
|
|
* max_dims = <hsize_t*>emalloc(sizeof(hsize_t)*rank) # <<<<<<<<<<<<<<
|
|
* convert_tuple(max_dims_tpl, max_dims, rank)
|
|
*
|
|
*/
|
|
__pyx_t_3 = __pyx_f_4h5py_5utils_emalloc(((sizeof(hsize_t)) * __pyx_v_rank)); if (unlikely(__pyx_t_3 == NULL && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 100; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
__pyx_v_max_dims = ((hsize_t *)__pyx_t_3);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":101
|
|
* if max_dims_tpl is not None:
|
|
* max_dims = <hsize_t*>emalloc(sizeof(hsize_t)*rank)
|
|
* convert_tuple(max_dims_tpl, max_dims, rank) # <<<<<<<<<<<<<<
|
|
*
|
|
* return SpaceID(H5Screate_simple(rank, dims, max_dims))
|
|
*/
|
|
__pyx_t_1 = __pyx_f_4h5py_5utils_convert_tuple(__pyx_v_max_dims_tpl, __pyx_v_max_dims, __pyx_v_rank); if (unlikely(__pyx_t_1 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 101; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
goto __pyx_L9;
|
|
}
|
|
__pyx_L9:;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":103
|
|
* convert_tuple(max_dims_tpl, max_dims, rank)
|
|
*
|
|
* return SpaceID(H5Screate_simple(rank, dims, max_dims)) # <<<<<<<<<<<<<<
|
|
*
|
|
* finally:
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_5 = H5Screate_simple(__pyx_v_rank, __pyx_v_dims, __pyx_v_max_dims); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 103; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
__pyx_t_6 = __Pyx_PyInt_to_py_hid_t(__pyx_t_5); if (unlikely(!__pyx_t_6)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 103; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
__Pyx_GOTREF(__pyx_t_6);
|
|
__pyx_t_7 = PyTuple_New(1); if (unlikely(!__pyx_t_7)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 103; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
__Pyx_GOTREF(__pyx_t_7);
|
|
PyTuple_SET_ITEM(__pyx_t_7, 0, __pyx_t_6);
|
|
__Pyx_GIVEREF(__pyx_t_6);
|
|
__pyx_t_6 = 0;
|
|
__pyx_t_6 = PyObject_Call(((PyObject *)((PyObject*)__pyx_ptype_4h5py_3h5s_SpaceID)), __pyx_t_7, NULL); if (unlikely(!__pyx_t_6)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 103; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
__Pyx_GOTREF(__pyx_t_6);
|
|
__Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
|
|
__pyx_r = __pyx_t_6;
|
|
__pyx_t_6 = 0;
|
|
goto __pyx_L6;
|
|
}
|
|
/*finally:*/ {
|
|
int __pyx_why;
|
|
PyObject *__pyx_exc_type, *__pyx_exc_value, *__pyx_exc_tb;
|
|
int __pyx_exc_lineno;
|
|
__pyx_exc_type = 0; __pyx_exc_value = 0; __pyx_exc_tb = 0; __pyx_exc_lineno = 0;
|
|
__pyx_why = 0; goto __pyx_L8;
|
|
__pyx_L6: __pyx_exc_type = 0; __pyx_exc_value = 0; __pyx_exc_tb = 0; __pyx_exc_lineno = 0;
|
|
__pyx_why = 3; goto __pyx_L8;
|
|
__pyx_L7: {
|
|
__pyx_why = 4;
|
|
__Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
|
|
__Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
|
|
__Pyx_ErrFetch(&__pyx_exc_type, &__pyx_exc_value, &__pyx_exc_tb);
|
|
__pyx_exc_lineno = __pyx_lineno;
|
|
goto __pyx_L8;
|
|
}
|
|
__pyx_L8:;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":106
|
|
*
|
|
* finally:
|
|
* efree(dims) # <<<<<<<<<<<<<<
|
|
* efree(max_dims)
|
|
*
|
|
*/
|
|
__pyx_f_4h5py_5utils_efree(__pyx_v_dims);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":107
|
|
* finally:
|
|
* efree(dims)
|
|
* efree(max_dims) # <<<<<<<<<<<<<<
|
|
*
|
|
* IF H5PY_18API:
|
|
*/
|
|
__pyx_f_4h5py_5utils_efree(__pyx_v_max_dims);
|
|
switch (__pyx_why) {
|
|
case 3: goto __pyx_L0;
|
|
case 4: {
|
|
__Pyx_ErrRestore(__pyx_exc_type, __pyx_exc_value, __pyx_exc_tb);
|
|
__pyx_lineno = __pyx_exc_lineno;
|
|
__pyx_exc_type = 0;
|
|
__pyx_exc_value = 0;
|
|
__pyx_exc_tb = 0;
|
|
goto __pyx_L1_error;
|
|
}
|
|
}
|
|
}
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_6);
|
|
__Pyx_XDECREF(__pyx_t_7);
|
|
__Pyx_AddTraceback("h5py.h5s.create_simple");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_DECREF(__pyx_v_dims_tpl);
|
|
__Pyx_DECREF(__pyx_v_max_dims_tpl);
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":141
|
|
* """ Numpy-style shape tuple representing dimensions. () == scalar.
|
|
* """
|
|
* def __get__(self): # <<<<<<<<<<<<<<
|
|
* return self.get_simple_extent_dims()
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_5shape___get__(PyObject *__pyx_v_self); /*proto*/
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_5shape___get__(PyObject *__pyx_v_self) {
|
|
PyObject *__pyx_r = NULL;
|
|
PyObject *__pyx_t_1 = NULL;
|
|
PyObject *__pyx_t_2 = NULL;
|
|
__Pyx_RefNannySetupContext("__get__");
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":142
|
|
* """
|
|
* def __get__(self):
|
|
* return self.get_simple_extent_dims() # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_1 = PyObject_GetAttr(__pyx_v_self, __pyx_n_s_1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 142; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_2 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_empty_tuple), NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 142; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_r = __pyx_t_2;
|
|
__pyx_t_2 = 0;
|
|
goto __pyx_L0;
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_1);
|
|
__Pyx_XDECREF(__pyx_t_2);
|
|
__Pyx_AddTraceback("h5py.h5s.SpaceID.shape.__get__");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":145
|
|
*
|
|
*
|
|
* def _close(self): # <<<<<<<<<<<<<<
|
|
* """()
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID__close(PyObject *__pyx_v_self, PyObject *unused); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5s_7SpaceID__close[] = "()\n\n Terminate access through this identifier. You shouldn't have to\n call this manually; dataspace objects are automatically destroyed\n when their Python wrappers are freed.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID__close(PyObject *__pyx_v_self, PyObject *unused) {
|
|
PyObject *__pyx_r = NULL;
|
|
herr_t __pyx_t_1;
|
|
__Pyx_RefNannySetupContext("_close");
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":152
|
|
* when their Python wrappers are freed.
|
|
* """
|
|
* H5Sclose(self.id) # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__pyx_t_1 = H5Sclose(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 152; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_AddTraceback("h5py.h5s.SpaceID._close");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":155
|
|
*
|
|
*
|
|
* def copy(self): # <<<<<<<<<<<<<<
|
|
* """() => SpaceID
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_copy(PyObject *__pyx_v_self, PyObject *unused); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5s_7SpaceID_copy[] = "() => SpaceID\n\n Create a new copy of this dataspace.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_copy(PyObject *__pyx_v_self, PyObject *unused) {
|
|
PyObject *__pyx_r = NULL;
|
|
hid_t __pyx_t_1;
|
|
PyObject *__pyx_t_2 = NULL;
|
|
PyObject *__pyx_t_3 = NULL;
|
|
__Pyx_RefNannySetupContext("copy");
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":160
|
|
* Create a new copy of this dataspace.
|
|
* """
|
|
* return SpaceID(H5Scopy(self.id)) # <<<<<<<<<<<<<<
|
|
*
|
|
* IF H5PY_18API:
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_1 = H5Scopy(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 160; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_t_2 = __Pyx_PyInt_to_py_hid_t(__pyx_t_1); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 160; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__pyx_t_3 = PyTuple_New(1); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 160; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_2);
|
|
__Pyx_GIVEREF(__pyx_t_2);
|
|
__pyx_t_2 = 0;
|
|
__pyx_t_2 = PyObject_Call(((PyObject *)((PyObject*)__pyx_ptype_4h5py_3h5s_SpaceID)), __pyx_t_3, NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 160; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
__pyx_r = __pyx_t_2;
|
|
__pyx_t_2 = 0;
|
|
goto __pyx_L0;
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_2);
|
|
__Pyx_XDECREF(__pyx_t_3);
|
|
__Pyx_AddTraceback("h5py.h5s.SpaceID.copy");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":198
|
|
*
|
|
*
|
|
* def is_simple(self): # <<<<<<<<<<<<<<
|
|
* """() => BOOL is_simple
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_is_simple(PyObject *__pyx_v_self, PyObject *unused); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5s_7SpaceID_is_simple[] = "() => BOOL is_simple\n\n Determine if an existing dataspace is \"simple\" (including scalar\n dataspaces). Currently all HDF5 dataspaces are simple.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_is_simple(PyObject *__pyx_v_self, PyObject *unused) {
|
|
PyObject *__pyx_r = NULL;
|
|
htri_t __pyx_t_1;
|
|
PyObject *__pyx_t_2 = NULL;
|
|
__Pyx_RefNannySetupContext("is_simple");
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":204
|
|
* dataspaces). Currently all HDF5 dataspaces are simple.
|
|
* """
|
|
* return <bint>(H5Sis_simple(self.id)) # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_1 = H5Sis_simple(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 204; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_t_2 = __Pyx_PyBool_FromLong(((int)__pyx_t_1)); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 204; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__pyx_r = __pyx_t_2;
|
|
__pyx_t_2 = 0;
|
|
goto __pyx_L0;
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_2);
|
|
__Pyx_AddTraceback("h5py.h5s.SpaceID.is_simple");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":207
|
|
*
|
|
*
|
|
* def offset_simple(self, object offset=None): # <<<<<<<<<<<<<<
|
|
* """(TUPLE offset=None)
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_offset_simple(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5s_7SpaceID_offset_simple[] = "(TUPLE offset=None)\n\n Set the offset of a dataspace. The length of the given tuple must\n match the rank of the dataspace. If None is provided (default), \n the offsets on all axes will be set to 0.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_offset_simple(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
|
|
PyObject *__pyx_v_offset = 0;
|
|
int __pyx_v_rank;
|
|
int __pyx_v_i;
|
|
hssize_t *__pyx_v_dims;
|
|
PyObject *__pyx_r = NULL;
|
|
htri_t __pyx_t_1;
|
|
int __pyx_t_2;
|
|
PyObject *__pyx_t_3 = NULL;
|
|
PyObject *__pyx_t_4 = NULL;
|
|
int __pyx_t_5;
|
|
void *__pyx_t_6;
|
|
herr_t __pyx_t_7;
|
|
static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__offset,0};
|
|
__Pyx_RefNannySetupContext("offset_simple");
|
|
if (unlikely(__pyx_kwds)) {
|
|
Py_ssize_t kw_args = PyDict_Size(__pyx_kwds);
|
|
PyObject* values[1] = {0};
|
|
values[0] = ((PyObject *)Py_None);
|
|
switch (PyTuple_GET_SIZE(__pyx_args)) {
|
|
case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
|
|
case 0: break;
|
|
default: goto __pyx_L5_argtuple_error;
|
|
}
|
|
switch (PyTuple_GET_SIZE(__pyx_args)) {
|
|
case 0:
|
|
if (kw_args > 1) {
|
|
PyObject* value = PyDict_GetItem(__pyx_kwds, __pyx_n_s__offset);
|
|
if (unlikely(value)) { values[0] = value; kw_args--; }
|
|
}
|
|
}
|
|
if (unlikely(kw_args > 0)) {
|
|
if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, PyTuple_GET_SIZE(__pyx_args), "offset_simple") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 207; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
__pyx_v_offset = values[0];
|
|
} else {
|
|
__pyx_v_offset = ((PyObject *)Py_None);
|
|
switch (PyTuple_GET_SIZE(__pyx_args)) {
|
|
case 1: __pyx_v_offset = PyTuple_GET_ITEM(__pyx_args, 0);
|
|
case 0: break;
|
|
default: goto __pyx_L5_argtuple_error;
|
|
}
|
|
}
|
|
goto __pyx_L4_argument_unpacking_done;
|
|
__pyx_L5_argtuple_error:;
|
|
__Pyx_RaiseArgtupleInvalid("offset_simple", 0, 0, 1, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 207; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
__pyx_L3_error:;
|
|
__Pyx_AddTraceback("h5py.h5s.SpaceID.offset_simple");
|
|
return NULL;
|
|
__pyx_L4_argument_unpacking_done:;
|
|
__Pyx_INCREF((PyObject *)__pyx_v_self);
|
|
__Pyx_INCREF(__pyx_v_offset);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":216
|
|
* cdef int rank
|
|
* cdef int i
|
|
* cdef hssize_t *dims = NULL # <<<<<<<<<<<<<<
|
|
*
|
|
* try:
|
|
*/
|
|
__pyx_v_dims = NULL;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":218
|
|
* cdef hssize_t *dims = NULL
|
|
*
|
|
* try: # <<<<<<<<<<<<<<
|
|
* if not H5Sis_simple(self.id):
|
|
* raise ValueError("%d is not a simple dataspace" % self.id)
|
|
*/
|
|
/*try:*/ {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":219
|
|
*
|
|
* try:
|
|
* if not H5Sis_simple(self.id): # <<<<<<<<<<<<<<
|
|
* raise ValueError("%d is not a simple dataspace" % self.id)
|
|
*
|
|
*/
|
|
__pyx_t_1 = H5Sis_simple(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 219; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
__pyx_t_2 = (!__pyx_t_1);
|
|
if (__pyx_t_2) {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":220
|
|
* try:
|
|
* if not H5Sis_simple(self.id):
|
|
* raise ValueError("%d is not a simple dataspace" % self.id) # <<<<<<<<<<<<<<
|
|
*
|
|
* rank = H5Sget_simple_extent_ndims(self.id)
|
|
*/
|
|
__pyx_t_3 = __Pyx_PyInt_to_py_hid_t(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 220; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__pyx_t_4 = PyNumber_Remainder(((PyObject *)__pyx_kp_s_2), __pyx_t_3); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 220; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
__pyx_t_3 = PyTuple_New(1); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 220; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_4);
|
|
__Pyx_GIVEREF(__pyx_t_4);
|
|
__pyx_t_4 = 0;
|
|
__pyx_t_4 = PyObject_Call(__pyx_builtin_ValueError, __pyx_t_3, NULL); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 220; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
__Pyx_Raise(__pyx_t_4, 0, 0);
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
{__pyx_filename = __pyx_f[0]; __pyx_lineno = 220; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
goto __pyx_L9;
|
|
}
|
|
__pyx_L9:;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":222
|
|
* raise ValueError("%d is not a simple dataspace" % self.id)
|
|
*
|
|
* rank = H5Sget_simple_extent_ndims(self.id) # <<<<<<<<<<<<<<
|
|
*
|
|
* require_tuple(offset, 1, rank, "offset")
|
|
*/
|
|
__pyx_t_5 = H5Sget_simple_extent_ndims(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 222; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
__pyx_v_rank = __pyx_t_5;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":224
|
|
* rank = H5Sget_simple_extent_ndims(self.id)
|
|
*
|
|
* require_tuple(offset, 1, rank, "offset") # <<<<<<<<<<<<<<
|
|
* dims = <hssize_t*>emalloc(sizeof(hssize_t)*rank)
|
|
* if(offset is not None):
|
|
*/
|
|
__pyx_t_5 = __pyx_f_4h5py_5utils_require_tuple(__pyx_v_offset, 1, __pyx_v_rank, __pyx_k__offset); if (unlikely(__pyx_t_5 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 224; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":225
|
|
*
|
|
* require_tuple(offset, 1, rank, "offset")
|
|
* dims = <hssize_t*>emalloc(sizeof(hssize_t)*rank) # <<<<<<<<<<<<<<
|
|
* if(offset is not None):
|
|
* convert_tuple(offset, <hsize_t*>dims, rank)
|
|
*/
|
|
__pyx_t_6 = __pyx_f_4h5py_5utils_emalloc(((sizeof(hssize_t)) * __pyx_v_rank)); if (unlikely(__pyx_t_6 == NULL && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 225; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
__pyx_v_dims = ((hssize_t *)__pyx_t_6);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":226
|
|
* require_tuple(offset, 1, rank, "offset")
|
|
* dims = <hssize_t*>emalloc(sizeof(hssize_t)*rank)
|
|
* if(offset is not None): # <<<<<<<<<<<<<<
|
|
* convert_tuple(offset, <hsize_t*>dims, rank)
|
|
* else:
|
|
*/
|
|
__pyx_t_2 = (__pyx_v_offset != Py_None);
|
|
if (__pyx_t_2) {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":227
|
|
* dims = <hssize_t*>emalloc(sizeof(hssize_t)*rank)
|
|
* if(offset is not None):
|
|
* convert_tuple(offset, <hsize_t*>dims, rank) # <<<<<<<<<<<<<<
|
|
* else:
|
|
* # The HDF5 docs say passing in NULL resets the offset to 0.
|
|
*/
|
|
__pyx_t_5 = __pyx_f_4h5py_5utils_convert_tuple(__pyx_v_offset, ((hsize_t *)__pyx_v_dims), __pyx_v_rank); if (unlikely(__pyx_t_5 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 227; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
goto __pyx_L10;
|
|
}
|
|
/*else*/ {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":232
|
|
* # Instead it raises an exception. Imagine my surprise. We'll
|
|
* # do this manually.
|
|
* for i from 0<=i<rank: # <<<<<<<<<<<<<<
|
|
* dims[i] = 0
|
|
*
|
|
*/
|
|
__pyx_t_5 = __pyx_v_rank;
|
|
for (__pyx_v_i = 0; __pyx_v_i < __pyx_t_5; __pyx_v_i++) {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":233
|
|
* # do this manually.
|
|
* for i from 0<=i<rank:
|
|
* dims[i] = 0 # <<<<<<<<<<<<<<
|
|
*
|
|
* H5Soffset_simple(self.id, dims)
|
|
*/
|
|
(__pyx_v_dims[__pyx_v_i]) = 0;
|
|
}
|
|
}
|
|
__pyx_L10:;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":235
|
|
* dims[i] = 0
|
|
*
|
|
* H5Soffset_simple(self.id, dims) # <<<<<<<<<<<<<<
|
|
*
|
|
* finally:
|
|
*/
|
|
__pyx_t_7 = H5Soffset_simple(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id, __pyx_v_dims); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 235; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
}
|
|
/*finally:*/ {
|
|
int __pyx_why;
|
|
PyObject *__pyx_exc_type, *__pyx_exc_value, *__pyx_exc_tb;
|
|
int __pyx_exc_lineno;
|
|
__pyx_exc_type = 0; __pyx_exc_value = 0; __pyx_exc_tb = 0; __pyx_exc_lineno = 0;
|
|
__pyx_why = 0; goto __pyx_L8;
|
|
__pyx_L7: {
|
|
__pyx_why = 4;
|
|
__Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
__Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
__Pyx_ErrFetch(&__pyx_exc_type, &__pyx_exc_value, &__pyx_exc_tb);
|
|
__pyx_exc_lineno = __pyx_lineno;
|
|
goto __pyx_L8;
|
|
}
|
|
__pyx_L8:;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":238
|
|
*
|
|
* finally:
|
|
* efree(dims) # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__pyx_f_4h5py_5utils_efree(__pyx_v_dims);
|
|
switch (__pyx_why) {
|
|
case 4: {
|
|
__Pyx_ErrRestore(__pyx_exc_type, __pyx_exc_value, __pyx_exc_tb);
|
|
__pyx_lineno = __pyx_exc_lineno;
|
|
__pyx_exc_type = 0;
|
|
__pyx_exc_value = 0;
|
|
__pyx_exc_tb = 0;
|
|
goto __pyx_L1_error;
|
|
}
|
|
}
|
|
}
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_3);
|
|
__Pyx_XDECREF(__pyx_t_4);
|
|
__Pyx_AddTraceback("h5py.h5s.SpaceID.offset_simple");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_DECREF((PyObject *)__pyx_v_self);
|
|
__Pyx_DECREF(__pyx_v_offset);
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":241
|
|
*
|
|
*
|
|
* def get_simple_extent_ndims(self): # <<<<<<<<<<<<<<
|
|
* """() => INT rank
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_get_simple_extent_ndims(PyObject *__pyx_v_self, PyObject *unused); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5s_7SpaceID_get_simple_extent_ndims[] = "() => INT rank\n \n Determine the rank of a \"simple\" (slab) dataspace.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_get_simple_extent_ndims(PyObject *__pyx_v_self, PyObject *unused) {
|
|
PyObject *__pyx_r = NULL;
|
|
int __pyx_t_1;
|
|
PyObject *__pyx_t_2 = NULL;
|
|
__Pyx_RefNannySetupContext("get_simple_extent_ndims");
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":246
|
|
* Determine the rank of a "simple" (slab) dataspace.
|
|
* """
|
|
* return H5Sget_simple_extent_ndims(self.id) # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_1 = H5Sget_simple_extent_ndims(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 246; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_t_2 = PyInt_FromLong(__pyx_t_1); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 246; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__pyx_r = __pyx_t_2;
|
|
__pyx_t_2 = 0;
|
|
goto __pyx_L0;
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_2);
|
|
__Pyx_AddTraceback("h5py.h5s.SpaceID.get_simple_extent_ndims");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":249
|
|
*
|
|
*
|
|
* def get_simple_extent_dims(self, int maxdims=0): # <<<<<<<<<<<<<<
|
|
* """(BOOL maxdims=False) => TUPLE shape
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_get_simple_extent_dims(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5s_7SpaceID_get_simple_extent_dims[] = "(BOOL maxdims=False) => TUPLE shape\n\n Determine the shape of a \"simple\" (slab) dataspace. If \"maxdims\" \n is True, retrieve the maximum dataspace size instead.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_get_simple_extent_dims(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
|
|
int __pyx_v_maxdims;
|
|
int __pyx_v_rank;
|
|
hsize_t *__pyx_v_dims;
|
|
PyObject *__pyx_r = NULL;
|
|
int __pyx_t_1;
|
|
void *__pyx_t_2;
|
|
PyObject *__pyx_t_3 = NULL;
|
|
static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__maxdims,0};
|
|
__Pyx_RefNannySetupContext("get_simple_extent_dims");
|
|
if (unlikely(__pyx_kwds)) {
|
|
Py_ssize_t kw_args = PyDict_Size(__pyx_kwds);
|
|
PyObject* values[1] = {0};
|
|
switch (PyTuple_GET_SIZE(__pyx_args)) {
|
|
case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
|
|
case 0: break;
|
|
default: goto __pyx_L5_argtuple_error;
|
|
}
|
|
switch (PyTuple_GET_SIZE(__pyx_args)) {
|
|
case 0:
|
|
if (kw_args > 1) {
|
|
PyObject* value = PyDict_GetItem(__pyx_kwds, __pyx_n_s__maxdims);
|
|
if (unlikely(value)) { values[0] = value; kw_args--; }
|
|
}
|
|
}
|
|
if (unlikely(kw_args > 0)) {
|
|
if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, PyTuple_GET_SIZE(__pyx_args), "get_simple_extent_dims") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 249; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
if (values[0]) {
|
|
__pyx_v_maxdims = __Pyx_PyInt_AsInt(values[0]); if (unlikely((__pyx_v_maxdims == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 249; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
} else {
|
|
__pyx_v_maxdims = ((int)0);
|
|
}
|
|
} else {
|
|
__pyx_v_maxdims = ((int)0);
|
|
switch (PyTuple_GET_SIZE(__pyx_args)) {
|
|
case 1: __pyx_v_maxdims = __Pyx_PyInt_AsInt(PyTuple_GET_ITEM(__pyx_args, 0)); if (unlikely((__pyx_v_maxdims == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 249; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
case 0: break;
|
|
default: goto __pyx_L5_argtuple_error;
|
|
}
|
|
}
|
|
goto __pyx_L4_argument_unpacking_done;
|
|
__pyx_L5_argtuple_error:;
|
|
__Pyx_RaiseArgtupleInvalid("get_simple_extent_dims", 0, 0, 1, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 249; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
__pyx_L3_error:;
|
|
__Pyx_AddTraceback("h5py.h5s.SpaceID.get_simple_extent_dims");
|
|
return NULL;
|
|
__pyx_L4_argument_unpacking_done:;
|
|
__Pyx_INCREF((PyObject *)__pyx_v_self);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":256
|
|
* """
|
|
* cdef int rank
|
|
* cdef hsize_t* dims = NULL # <<<<<<<<<<<<<<
|
|
*
|
|
* rank = H5Sget_simple_extent_dims(self.id, NULL, NULL)
|
|
*/
|
|
__pyx_v_dims = NULL;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":258
|
|
* cdef hsize_t* dims = NULL
|
|
*
|
|
* rank = H5Sget_simple_extent_dims(self.id, NULL, NULL) # <<<<<<<<<<<<<<
|
|
*
|
|
* dims = <hsize_t*>emalloc(sizeof(hsize_t)*rank)
|
|
*/
|
|
__pyx_t_1 = H5Sget_simple_extent_dims(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id, NULL, NULL); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 258; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_v_rank = __pyx_t_1;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":260
|
|
* rank = H5Sget_simple_extent_dims(self.id, NULL, NULL)
|
|
*
|
|
* dims = <hsize_t*>emalloc(sizeof(hsize_t)*rank) # <<<<<<<<<<<<<<
|
|
* try:
|
|
* if maxdims:
|
|
*/
|
|
__pyx_t_2 = __pyx_f_4h5py_5utils_emalloc(((sizeof(hsize_t)) * __pyx_v_rank)); if (unlikely(__pyx_t_2 == NULL && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 260; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_v_dims = ((hsize_t *)__pyx_t_2);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":261
|
|
*
|
|
* dims = <hsize_t*>emalloc(sizeof(hsize_t)*rank)
|
|
* try: # <<<<<<<<<<<<<<
|
|
* if maxdims:
|
|
* H5Sget_simple_extent_dims(self.id, NULL, dims)
|
|
*/
|
|
/*try:*/ {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":262
|
|
* dims = <hsize_t*>emalloc(sizeof(hsize_t)*rank)
|
|
* try:
|
|
* if maxdims: # <<<<<<<<<<<<<<
|
|
* H5Sget_simple_extent_dims(self.id, NULL, dims)
|
|
* else:
|
|
*/
|
|
__pyx_t_1 = __pyx_v_maxdims;
|
|
if (__pyx_t_1) {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":263
|
|
* try:
|
|
* if maxdims:
|
|
* H5Sget_simple_extent_dims(self.id, NULL, dims) # <<<<<<<<<<<<<<
|
|
* else:
|
|
* H5Sget_simple_extent_dims(self.id, dims, NULL)
|
|
*/
|
|
__pyx_t_1 = H5Sget_simple_extent_dims(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id, NULL, __pyx_v_dims); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 263; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
goto __pyx_L9;
|
|
}
|
|
/*else*/ {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":265
|
|
* H5Sget_simple_extent_dims(self.id, NULL, dims)
|
|
* else:
|
|
* H5Sget_simple_extent_dims(self.id, dims, NULL) # <<<<<<<<<<<<<<
|
|
*
|
|
* return convert_dims(dims, rank)
|
|
*/
|
|
__pyx_t_1 = H5Sget_simple_extent_dims(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id, __pyx_v_dims, NULL); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 265; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
}
|
|
__pyx_L9:;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":267
|
|
* H5Sget_simple_extent_dims(self.id, dims, NULL)
|
|
*
|
|
* return convert_dims(dims, rank) # <<<<<<<<<<<<<<
|
|
*
|
|
* finally:
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_3 = __pyx_f_4h5py_5utils_convert_dims(__pyx_v_dims, __pyx_v_rank); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 267; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__pyx_r = __pyx_t_3;
|
|
__pyx_t_3 = 0;
|
|
goto __pyx_L6;
|
|
}
|
|
/*finally:*/ {
|
|
int __pyx_why;
|
|
PyObject *__pyx_exc_type, *__pyx_exc_value, *__pyx_exc_tb;
|
|
int __pyx_exc_lineno;
|
|
__pyx_exc_type = 0; __pyx_exc_value = 0; __pyx_exc_tb = 0; __pyx_exc_lineno = 0;
|
|
__pyx_why = 0; goto __pyx_L8;
|
|
__pyx_L6: __pyx_exc_type = 0; __pyx_exc_value = 0; __pyx_exc_tb = 0; __pyx_exc_lineno = 0;
|
|
__pyx_why = 3; goto __pyx_L8;
|
|
__pyx_L7: {
|
|
__pyx_why = 4;
|
|
__Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
__Pyx_ErrFetch(&__pyx_exc_type, &__pyx_exc_value, &__pyx_exc_tb);
|
|
__pyx_exc_lineno = __pyx_lineno;
|
|
goto __pyx_L8;
|
|
}
|
|
__pyx_L8:;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":270
|
|
*
|
|
* finally:
|
|
* efree(dims) # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__pyx_f_4h5py_5utils_efree(__pyx_v_dims);
|
|
switch (__pyx_why) {
|
|
case 3: goto __pyx_L0;
|
|
case 4: {
|
|
__Pyx_ErrRestore(__pyx_exc_type, __pyx_exc_value, __pyx_exc_tb);
|
|
__pyx_lineno = __pyx_exc_lineno;
|
|
__pyx_exc_type = 0;
|
|
__pyx_exc_value = 0;
|
|
__pyx_exc_tb = 0;
|
|
goto __pyx_L1_error;
|
|
}
|
|
}
|
|
}
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_3);
|
|
__Pyx_AddTraceback("h5py.h5s.SpaceID.get_simple_extent_dims");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_DECREF((PyObject *)__pyx_v_self);
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":273
|
|
*
|
|
*
|
|
* def get_simple_extent_npoints(self): # <<<<<<<<<<<<<<
|
|
* """() => LONG npoints
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_get_simple_extent_npoints(PyObject *__pyx_v_self, PyObject *unused); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5s_7SpaceID_get_simple_extent_npoints[] = "() => LONG npoints\n\n Determine the total number of elements in a dataspace.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_get_simple_extent_npoints(PyObject *__pyx_v_self, PyObject *unused) {
|
|
PyObject *__pyx_r = NULL;
|
|
hssize_t __pyx_t_1;
|
|
PyObject *__pyx_t_2 = NULL;
|
|
__Pyx_RefNannySetupContext("get_simple_extent_npoints");
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":278
|
|
* Determine the total number of elements in a dataspace.
|
|
* """
|
|
* return H5Sget_simple_extent_npoints(self.id) # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_1 = H5Sget_simple_extent_npoints(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 278; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_t_2 = __Pyx_PyInt_to_py_hssize_t(__pyx_t_1); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 278; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__pyx_r = __pyx_t_2;
|
|
__pyx_t_2 = 0;
|
|
goto __pyx_L0;
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_2);
|
|
__Pyx_AddTraceback("h5py.h5s.SpaceID.get_simple_extent_npoints");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":281
|
|
*
|
|
*
|
|
* def get_simple_extent_type(self): # <<<<<<<<<<<<<<
|
|
* """() => INT class_code
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_get_simple_extent_type(PyObject *__pyx_v_self, PyObject *unused); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5s_7SpaceID_get_simple_extent_type[] = "() => INT class_code\n\n Class code is either SCALAR or SIMPLE.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_get_simple_extent_type(PyObject *__pyx_v_self, PyObject *unused) {
|
|
PyObject *__pyx_r = NULL;
|
|
H5S_class_t __pyx_t_1;
|
|
PyObject *__pyx_t_2 = NULL;
|
|
__Pyx_RefNannySetupContext("get_simple_extent_type");
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":286
|
|
* Class code is either SCALAR or SIMPLE.
|
|
* """
|
|
* return <int>H5Sget_simple_extent_type(self.id) # <<<<<<<<<<<<<<
|
|
*
|
|
* # === Extents =============================================================
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_1 = H5Sget_simple_extent_type(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 286; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_t_2 = PyInt_FromLong(((int)__pyx_t_1)); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 286; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__pyx_r = __pyx_t_2;
|
|
__pyx_t_2 = 0;
|
|
goto __pyx_L0;
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_2);
|
|
__Pyx_AddTraceback("h5py.h5s.SpaceID.get_simple_extent_type");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":291
|
|
*
|
|
*
|
|
* def extent_copy(self, SpaceID source not None): # <<<<<<<<<<<<<<
|
|
* """(SpaceID source)
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_extent_copy(PyObject *__pyx_v_self, PyObject *__pyx_v_source); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5s_7SpaceID_extent_copy[] = "(SpaceID source)\n\n Replace this dataspace's extent with another's, changing its\n typecode if necessary.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_extent_copy(PyObject *__pyx_v_self, PyObject *__pyx_v_source) {
|
|
PyObject *__pyx_r = NULL;
|
|
herr_t __pyx_t_1;
|
|
__Pyx_RefNannySetupContext("extent_copy");
|
|
if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_source), __pyx_ptype_4h5py_3h5s_SpaceID, 0, "source", 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 291; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":297
|
|
* typecode if necessary.
|
|
* """
|
|
* H5Sextent_copy(self.id, source.id) # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__pyx_t_1 = H5Sextent_copy(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id, ((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_source)->__pyx_base.id); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 297; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_AddTraceback("h5py.h5s.SpaceID.extent_copy");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":300
|
|
*
|
|
*
|
|
* def set_extent_simple(self, object dims_tpl, object max_dims_tpl=None): # <<<<<<<<<<<<<<
|
|
* """(TUPLE dims_tpl, TUPLE max_dims_tpl=None)
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_set_extent_simple(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5s_7SpaceID_set_extent_simple[] = "(TUPLE dims_tpl, TUPLE max_dims_tpl=None)\n\n Reset the dataspace extent via a tuple of dimensions. \n Every element of dims_tpl must be a positive integer. \n\n You can optionally specify the maximum dataspace size. The \n special value UNLIMITED, as an element of max_dims, indicates \n an unlimited dimension.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_set_extent_simple(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
|
|
PyObject *__pyx_v_dims_tpl = 0;
|
|
PyObject *__pyx_v_max_dims_tpl = 0;
|
|
int __pyx_v_rank;
|
|
hsize_t *__pyx_v_dims;
|
|
hsize_t *__pyx_v_max_dims;
|
|
PyObject *__pyx_r = NULL;
|
|
int __pyx_t_1;
|
|
Py_ssize_t __pyx_t_2;
|
|
void *__pyx_t_3;
|
|
int __pyx_t_4;
|
|
herr_t __pyx_t_5;
|
|
static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__dims_tpl,&__pyx_n_s__max_dims_tpl,0};
|
|
__Pyx_RefNannySetupContext("set_extent_simple");
|
|
if (unlikely(__pyx_kwds)) {
|
|
Py_ssize_t kw_args = PyDict_Size(__pyx_kwds);
|
|
PyObject* values[2] = {0,0};
|
|
values[1] = ((PyObject *)Py_None);
|
|
switch (PyTuple_GET_SIZE(__pyx_args)) {
|
|
case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
|
|
case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
|
|
case 0: break;
|
|
default: goto __pyx_L5_argtuple_error;
|
|
}
|
|
switch (PyTuple_GET_SIZE(__pyx_args)) {
|
|
case 0:
|
|
values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__dims_tpl);
|
|
if (likely(values[0])) kw_args--;
|
|
else goto __pyx_L5_argtuple_error;
|
|
case 1:
|
|
if (kw_args > 1) {
|
|
PyObject* value = PyDict_GetItem(__pyx_kwds, __pyx_n_s__max_dims_tpl);
|
|
if (unlikely(value)) { values[1] = value; kw_args--; }
|
|
}
|
|
}
|
|
if (unlikely(kw_args > 0)) {
|
|
if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, PyTuple_GET_SIZE(__pyx_args), "set_extent_simple") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 300; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
__pyx_v_dims_tpl = values[0];
|
|
__pyx_v_max_dims_tpl = values[1];
|
|
} else {
|
|
__pyx_v_max_dims_tpl = ((PyObject *)Py_None);
|
|
switch (PyTuple_GET_SIZE(__pyx_args)) {
|
|
case 2: __pyx_v_max_dims_tpl = PyTuple_GET_ITEM(__pyx_args, 1);
|
|
case 1: __pyx_v_dims_tpl = PyTuple_GET_ITEM(__pyx_args, 0);
|
|
break;
|
|
default: goto __pyx_L5_argtuple_error;
|
|
}
|
|
}
|
|
goto __pyx_L4_argument_unpacking_done;
|
|
__pyx_L5_argtuple_error:;
|
|
__Pyx_RaiseArgtupleInvalid("set_extent_simple", 0, 1, 2, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 300; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
__pyx_L3_error:;
|
|
__Pyx_AddTraceback("h5py.h5s.SpaceID.set_extent_simple");
|
|
return NULL;
|
|
__pyx_L4_argument_unpacking_done:;
|
|
__Pyx_INCREF((PyObject *)__pyx_v_self);
|
|
__Pyx_INCREF(__pyx_v_dims_tpl);
|
|
__Pyx_INCREF(__pyx_v_max_dims_tpl);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":311
|
|
* """
|
|
* cdef int rank
|
|
* cdef hsize_t* dims = NULL # <<<<<<<<<<<<<<
|
|
* cdef hsize_t* max_dims = NULL
|
|
*
|
|
*/
|
|
__pyx_v_dims = NULL;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":312
|
|
* cdef int rank
|
|
* cdef hsize_t* dims = NULL
|
|
* cdef hsize_t* max_dims = NULL # <<<<<<<<<<<<<<
|
|
*
|
|
* require_tuple(dims_tpl, 0, -1, "dims_tpl")
|
|
*/
|
|
__pyx_v_max_dims = NULL;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":314
|
|
* cdef hsize_t* max_dims = NULL
|
|
*
|
|
* require_tuple(dims_tpl, 0, -1, "dims_tpl") # <<<<<<<<<<<<<<
|
|
* rank = len(dims_tpl)
|
|
* require_tuple(max_dims_tpl, 1, rank, "max_dims_tpl")
|
|
*/
|
|
__pyx_t_1 = __pyx_f_4h5py_5utils_require_tuple(__pyx_v_dims_tpl, 0, -1, __pyx_k__dims_tpl); if (unlikely(__pyx_t_1 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 314; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":315
|
|
*
|
|
* require_tuple(dims_tpl, 0, -1, "dims_tpl")
|
|
* rank = len(dims_tpl) # <<<<<<<<<<<<<<
|
|
* require_tuple(max_dims_tpl, 1, rank, "max_dims_tpl")
|
|
*
|
|
*/
|
|
__pyx_t_2 = PyObject_Length(__pyx_v_dims_tpl); if (unlikely(__pyx_t_2 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 315; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_v_rank = __pyx_t_2;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":316
|
|
* require_tuple(dims_tpl, 0, -1, "dims_tpl")
|
|
* rank = len(dims_tpl)
|
|
* require_tuple(max_dims_tpl, 1, rank, "max_dims_tpl") # <<<<<<<<<<<<<<
|
|
*
|
|
* try:
|
|
*/
|
|
__pyx_t_1 = __pyx_f_4h5py_5utils_require_tuple(__pyx_v_max_dims_tpl, 1, __pyx_v_rank, __pyx_k__max_dims_tpl); if (unlikely(__pyx_t_1 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 316; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":318
|
|
* require_tuple(max_dims_tpl, 1, rank, "max_dims_tpl")
|
|
*
|
|
* try: # <<<<<<<<<<<<<<
|
|
* dims = <hsize_t*>emalloc(sizeof(hsize_t)*rank)
|
|
* convert_tuple(dims_tpl, dims, rank)
|
|
*/
|
|
/*try:*/ {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":319
|
|
*
|
|
* try:
|
|
* dims = <hsize_t*>emalloc(sizeof(hsize_t)*rank) # <<<<<<<<<<<<<<
|
|
* convert_tuple(dims_tpl, dims, rank)
|
|
*
|
|
*/
|
|
__pyx_t_3 = __pyx_f_4h5py_5utils_emalloc(((sizeof(hsize_t)) * __pyx_v_rank)); if (unlikely(__pyx_t_3 == NULL && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 319; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
__pyx_v_dims = ((hsize_t *)__pyx_t_3);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":320
|
|
* try:
|
|
* dims = <hsize_t*>emalloc(sizeof(hsize_t)*rank)
|
|
* convert_tuple(dims_tpl, dims, rank) # <<<<<<<<<<<<<<
|
|
*
|
|
* if max_dims_tpl is not None:
|
|
*/
|
|
__pyx_t_1 = __pyx_f_4h5py_5utils_convert_tuple(__pyx_v_dims_tpl, __pyx_v_dims, __pyx_v_rank); if (unlikely(__pyx_t_1 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 320; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":322
|
|
* convert_tuple(dims_tpl, dims, rank)
|
|
*
|
|
* if max_dims_tpl is not None: # <<<<<<<<<<<<<<
|
|
* max_dims = <hsize_t*>emalloc(sizeof(hsize_t)*rank)
|
|
* convert_tuple(max_dims_tpl, max_dims, rank)
|
|
*/
|
|
__pyx_t_4 = (__pyx_v_max_dims_tpl != Py_None);
|
|
if (__pyx_t_4) {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":323
|
|
*
|
|
* if max_dims_tpl is not None:
|
|
* max_dims = <hsize_t*>emalloc(sizeof(hsize_t)*rank) # <<<<<<<<<<<<<<
|
|
* convert_tuple(max_dims_tpl, max_dims, rank)
|
|
*
|
|
*/
|
|
__pyx_t_3 = __pyx_f_4h5py_5utils_emalloc(((sizeof(hsize_t)) * __pyx_v_rank)); if (unlikely(__pyx_t_3 == NULL && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 323; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
__pyx_v_max_dims = ((hsize_t *)__pyx_t_3);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":324
|
|
* if max_dims_tpl is not None:
|
|
* max_dims = <hsize_t*>emalloc(sizeof(hsize_t)*rank)
|
|
* convert_tuple(max_dims_tpl, max_dims, rank) # <<<<<<<<<<<<<<
|
|
*
|
|
* H5Sset_extent_simple(self.id, rank, dims, max_dims)
|
|
*/
|
|
__pyx_t_1 = __pyx_f_4h5py_5utils_convert_tuple(__pyx_v_max_dims_tpl, __pyx_v_max_dims, __pyx_v_rank); if (unlikely(__pyx_t_1 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 324; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
goto __pyx_L9;
|
|
}
|
|
__pyx_L9:;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":326
|
|
* convert_tuple(max_dims_tpl, max_dims, rank)
|
|
*
|
|
* H5Sset_extent_simple(self.id, rank, dims, max_dims) # <<<<<<<<<<<<<<
|
|
*
|
|
* finally:
|
|
*/
|
|
__pyx_t_5 = H5Sset_extent_simple(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id, __pyx_v_rank, __pyx_v_dims, __pyx_v_max_dims); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 326; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
}
|
|
/*finally:*/ {
|
|
int __pyx_why;
|
|
PyObject *__pyx_exc_type, *__pyx_exc_value, *__pyx_exc_tb;
|
|
int __pyx_exc_lineno;
|
|
__pyx_exc_type = 0; __pyx_exc_value = 0; __pyx_exc_tb = 0; __pyx_exc_lineno = 0;
|
|
__pyx_why = 0; goto __pyx_L8;
|
|
__pyx_L7: {
|
|
__pyx_why = 4;
|
|
__Pyx_ErrFetch(&__pyx_exc_type, &__pyx_exc_value, &__pyx_exc_tb);
|
|
__pyx_exc_lineno = __pyx_lineno;
|
|
goto __pyx_L8;
|
|
}
|
|
__pyx_L8:;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":329
|
|
*
|
|
* finally:
|
|
* efree(dims) # <<<<<<<<<<<<<<
|
|
* efree(max_dims)
|
|
*
|
|
*/
|
|
__pyx_f_4h5py_5utils_efree(__pyx_v_dims);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":330
|
|
* finally:
|
|
* efree(dims)
|
|
* efree(max_dims) # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__pyx_f_4h5py_5utils_efree(__pyx_v_max_dims);
|
|
switch (__pyx_why) {
|
|
case 4: {
|
|
__Pyx_ErrRestore(__pyx_exc_type, __pyx_exc_value, __pyx_exc_tb);
|
|
__pyx_lineno = __pyx_exc_lineno;
|
|
__pyx_exc_type = 0;
|
|
__pyx_exc_value = 0;
|
|
__pyx_exc_tb = 0;
|
|
goto __pyx_L1_error;
|
|
}
|
|
}
|
|
}
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_AddTraceback("h5py.h5s.SpaceID.set_extent_simple");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_DECREF((PyObject *)__pyx_v_self);
|
|
__Pyx_DECREF(__pyx_v_dims_tpl);
|
|
__Pyx_DECREF(__pyx_v_max_dims_tpl);
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":333
|
|
*
|
|
*
|
|
* def set_extent_none(self): # <<<<<<<<<<<<<<
|
|
* """()
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_set_extent_none(PyObject *__pyx_v_self, PyObject *unused); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5s_7SpaceID_set_extent_none[] = "()\n\n Remove the dataspace extent; typecode changes to NO_CLASS.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_set_extent_none(PyObject *__pyx_v_self, PyObject *unused) {
|
|
PyObject *__pyx_r = NULL;
|
|
herr_t __pyx_t_1;
|
|
__Pyx_RefNannySetupContext("set_extent_none");
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":338
|
|
* Remove the dataspace extent; typecode changes to NO_CLASS.
|
|
* """
|
|
* H5Sset_extent_none(self.id) # <<<<<<<<<<<<<<
|
|
*
|
|
* # === General selection operations ========================================
|
|
*/
|
|
__pyx_t_1 = H5Sset_extent_none(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 338; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_AddTraceback("h5py.h5s.SpaceID.set_extent_none");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":343
|
|
*
|
|
*
|
|
* def get_select_type(self): # <<<<<<<<<<<<<<
|
|
* """ () => INT select_code
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_get_select_type(PyObject *__pyx_v_self, PyObject *unused); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5s_7SpaceID_get_select_type[] = " () => INT select_code\n\n Determine selection type. Return values are:\n\n - SEL_NONE\n - SEL_ALL\n - SEL_POINTS\n - SEL_HYPERSLABS\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_get_select_type(PyObject *__pyx_v_self, PyObject *unused) {
|
|
PyObject *__pyx_r = NULL;
|
|
H5S_sel_type __pyx_t_1;
|
|
PyObject *__pyx_t_2 = NULL;
|
|
__Pyx_RefNannySetupContext("get_select_type");
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":353
|
|
* - SEL_HYPERSLABS
|
|
* """
|
|
* return <int>H5Sget_select_type(self.id) # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_1 = H5Sget_select_type(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 353; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_t_2 = PyInt_FromLong(((int)__pyx_t_1)); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 353; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__pyx_r = __pyx_t_2;
|
|
__pyx_t_2 = 0;
|
|
goto __pyx_L0;
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_2);
|
|
__Pyx_AddTraceback("h5py.h5s.SpaceID.get_select_type");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":356
|
|
*
|
|
*
|
|
* def get_select_npoints(self): # <<<<<<<<<<<<<<
|
|
* """() => LONG npoints
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_get_select_npoints(PyObject *__pyx_v_self, PyObject *unused); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5s_7SpaceID_get_select_npoints[] = "() => LONG npoints\n\n Determine the total number of points currently selected. \n Works for all selection techniques.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_get_select_npoints(PyObject *__pyx_v_self, PyObject *unused) {
|
|
PyObject *__pyx_r = NULL;
|
|
hssize_t __pyx_t_1;
|
|
PyObject *__pyx_t_2 = NULL;
|
|
__Pyx_RefNannySetupContext("get_select_npoints");
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":362
|
|
* Works for all selection techniques.
|
|
* """
|
|
* return H5Sget_select_npoints(self.id) # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_1 = H5Sget_select_npoints(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 362; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_t_2 = __Pyx_PyInt_to_py_hssize_t(__pyx_t_1); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 362; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__pyx_r = __pyx_t_2;
|
|
__pyx_t_2 = 0;
|
|
goto __pyx_L0;
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_2);
|
|
__Pyx_AddTraceback("h5py.h5s.SpaceID.get_select_npoints");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":365
|
|
*
|
|
*
|
|
* def get_select_bounds(self): # <<<<<<<<<<<<<<
|
|
* """() => (TUPLE start, TUPLE end)
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_get_select_bounds(PyObject *__pyx_v_self, PyObject *unused); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5s_7SpaceID_get_select_bounds[] = "() => (TUPLE start, TUPLE end)\n\n Determine the bounding box which exactly contains \n the current selection.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_get_select_bounds(PyObject *__pyx_v_self, PyObject *unused) {
|
|
int __pyx_v_rank;
|
|
hsize_t *__pyx_v_start;
|
|
hsize_t *__pyx_v_end;
|
|
PyObject *__pyx_v_start_tpl;
|
|
PyObject *__pyx_v_end_tpl;
|
|
PyObject *__pyx_r = NULL;
|
|
int __pyx_t_1;
|
|
hssize_t __pyx_t_2;
|
|
int __pyx_t_3;
|
|
void *__pyx_t_4;
|
|
herr_t __pyx_t_5;
|
|
PyObject *__pyx_t_6 = NULL;
|
|
__Pyx_RefNannySetupContext("get_select_bounds");
|
|
__Pyx_INCREF((PyObject *)__pyx_v_self);
|
|
__pyx_v_start_tpl = Py_None; __Pyx_INCREF(Py_None);
|
|
__pyx_v_end_tpl = Py_None; __Pyx_INCREF(Py_None);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":372
|
|
* """
|
|
* cdef int rank
|
|
* cdef hsize_t *start = NULL # <<<<<<<<<<<<<<
|
|
* cdef hsize_t *end = NULL
|
|
*
|
|
*/
|
|
__pyx_v_start = NULL;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":373
|
|
* cdef int rank
|
|
* cdef hsize_t *start = NULL
|
|
* cdef hsize_t *end = NULL # <<<<<<<<<<<<<<
|
|
*
|
|
* rank = H5Sget_simple_extent_ndims(self.id)
|
|
*/
|
|
__pyx_v_end = NULL;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":375
|
|
* cdef hsize_t *end = NULL
|
|
*
|
|
* rank = H5Sget_simple_extent_ndims(self.id) # <<<<<<<<<<<<<<
|
|
*
|
|
* if H5Sget_select_npoints(self.id) == 0:
|
|
*/
|
|
__pyx_t_1 = H5Sget_simple_extent_ndims(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 375; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_v_rank = __pyx_t_1;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":377
|
|
* rank = H5Sget_simple_extent_ndims(self.id)
|
|
*
|
|
* if H5Sget_select_npoints(self.id) == 0: # <<<<<<<<<<<<<<
|
|
* return None
|
|
*
|
|
*/
|
|
__pyx_t_2 = H5Sget_select_npoints(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 377; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_t_3 = (__pyx_t_2 == 0);
|
|
if (__pyx_t_3) {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":378
|
|
*
|
|
* if H5Sget_select_npoints(self.id) == 0:
|
|
* return None # <<<<<<<<<<<<<<
|
|
*
|
|
* start = <hsize_t*>emalloc(sizeof(hsize_t)*rank)
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__Pyx_INCREF(Py_None);
|
|
__pyx_r = Py_None;
|
|
goto __pyx_L0;
|
|
goto __pyx_L5;
|
|
}
|
|
__pyx_L5:;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":380
|
|
* return None
|
|
*
|
|
* start = <hsize_t*>emalloc(sizeof(hsize_t)*rank) # <<<<<<<<<<<<<<
|
|
* end = <hsize_t*>emalloc(sizeof(hsize_t)*rank)
|
|
*
|
|
*/
|
|
__pyx_t_4 = __pyx_f_4h5py_5utils_emalloc(((sizeof(hsize_t)) * __pyx_v_rank)); if (unlikely(__pyx_t_4 == NULL && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 380; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_v_start = ((hsize_t *)__pyx_t_4);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":381
|
|
*
|
|
* start = <hsize_t*>emalloc(sizeof(hsize_t)*rank)
|
|
* end = <hsize_t*>emalloc(sizeof(hsize_t)*rank) # <<<<<<<<<<<<<<
|
|
*
|
|
* try:
|
|
*/
|
|
__pyx_t_4 = __pyx_f_4h5py_5utils_emalloc(((sizeof(hsize_t)) * __pyx_v_rank)); if (unlikely(__pyx_t_4 == NULL && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 381; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_v_end = ((hsize_t *)__pyx_t_4);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":383
|
|
* end = <hsize_t*>emalloc(sizeof(hsize_t)*rank)
|
|
*
|
|
* try: # <<<<<<<<<<<<<<
|
|
* H5Sget_select_bounds(self.id, start, end)
|
|
*
|
|
*/
|
|
/*try:*/ {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":384
|
|
*
|
|
* try:
|
|
* H5Sget_select_bounds(self.id, start, end) # <<<<<<<<<<<<<<
|
|
*
|
|
* start_tpl = convert_dims(start, rank)
|
|
*/
|
|
__pyx_t_5 = H5Sget_select_bounds(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id, __pyx_v_start, __pyx_v_end); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 384; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":386
|
|
* H5Sget_select_bounds(self.id, start, end)
|
|
*
|
|
* start_tpl = convert_dims(start, rank) # <<<<<<<<<<<<<<
|
|
* end_tpl = convert_dims(end, rank)
|
|
* return (start_tpl, end_tpl)
|
|
*/
|
|
__pyx_t_6 = __pyx_f_4h5py_5utils_convert_dims(__pyx_v_start, __pyx_v_rank); if (unlikely(!__pyx_t_6)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 386; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
__Pyx_GOTREF(__pyx_t_6);
|
|
__Pyx_DECREF(__pyx_v_start_tpl);
|
|
__pyx_v_start_tpl = __pyx_t_6;
|
|
__pyx_t_6 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":387
|
|
*
|
|
* start_tpl = convert_dims(start, rank)
|
|
* end_tpl = convert_dims(end, rank) # <<<<<<<<<<<<<<
|
|
* return (start_tpl, end_tpl)
|
|
*
|
|
*/
|
|
__pyx_t_6 = __pyx_f_4h5py_5utils_convert_dims(__pyx_v_end, __pyx_v_rank); if (unlikely(!__pyx_t_6)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 387; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
__Pyx_GOTREF(__pyx_t_6);
|
|
__Pyx_DECREF(__pyx_v_end_tpl);
|
|
__pyx_v_end_tpl = __pyx_t_6;
|
|
__pyx_t_6 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":388
|
|
* start_tpl = convert_dims(start, rank)
|
|
* end_tpl = convert_dims(end, rank)
|
|
* return (start_tpl, end_tpl) # <<<<<<<<<<<<<<
|
|
*
|
|
* finally:
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_6 = PyTuple_New(2); if (unlikely(!__pyx_t_6)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 388; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
__Pyx_GOTREF(__pyx_t_6);
|
|
__Pyx_INCREF(__pyx_v_start_tpl);
|
|
PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_v_start_tpl);
|
|
__Pyx_GIVEREF(__pyx_v_start_tpl);
|
|
__Pyx_INCREF(__pyx_v_end_tpl);
|
|
PyTuple_SET_ITEM(__pyx_t_6, 1, __pyx_v_end_tpl);
|
|
__Pyx_GIVEREF(__pyx_v_end_tpl);
|
|
__pyx_r = __pyx_t_6;
|
|
__pyx_t_6 = 0;
|
|
goto __pyx_L6;
|
|
}
|
|
/*finally:*/ {
|
|
int __pyx_why;
|
|
PyObject *__pyx_exc_type, *__pyx_exc_value, *__pyx_exc_tb;
|
|
int __pyx_exc_lineno;
|
|
__pyx_exc_type = 0; __pyx_exc_value = 0; __pyx_exc_tb = 0; __pyx_exc_lineno = 0;
|
|
__pyx_why = 0; goto __pyx_L8;
|
|
__pyx_L6: __pyx_exc_type = 0; __pyx_exc_value = 0; __pyx_exc_tb = 0; __pyx_exc_lineno = 0;
|
|
__pyx_why = 3; goto __pyx_L8;
|
|
__pyx_L7: {
|
|
__pyx_why = 4;
|
|
__Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
|
|
__Pyx_ErrFetch(&__pyx_exc_type, &__pyx_exc_value, &__pyx_exc_tb);
|
|
__pyx_exc_lineno = __pyx_lineno;
|
|
goto __pyx_L8;
|
|
}
|
|
__pyx_L8:;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":391
|
|
*
|
|
* finally:
|
|
* efree(start) # <<<<<<<<<<<<<<
|
|
* efree(end)
|
|
*
|
|
*/
|
|
__pyx_f_4h5py_5utils_efree(__pyx_v_start);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":392
|
|
* finally:
|
|
* efree(start)
|
|
* efree(end) # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__pyx_f_4h5py_5utils_efree(__pyx_v_end);
|
|
switch (__pyx_why) {
|
|
case 3: goto __pyx_L0;
|
|
case 4: {
|
|
__Pyx_ErrRestore(__pyx_exc_type, __pyx_exc_value, __pyx_exc_tb);
|
|
__pyx_lineno = __pyx_exc_lineno;
|
|
__pyx_exc_type = 0;
|
|
__pyx_exc_value = 0;
|
|
__pyx_exc_tb = 0;
|
|
goto __pyx_L1_error;
|
|
}
|
|
}
|
|
}
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_6);
|
|
__Pyx_AddTraceback("h5py.h5s.SpaceID.get_select_bounds");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_DECREF(__pyx_v_start_tpl);
|
|
__Pyx_DECREF(__pyx_v_end_tpl);
|
|
__Pyx_DECREF((PyObject *)__pyx_v_self);
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":395
|
|
*
|
|
*
|
|
* def select_all(self): # <<<<<<<<<<<<<<
|
|
* """()
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_select_all(PyObject *__pyx_v_self, PyObject *unused); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5s_7SpaceID_select_all[] = "()\n\n Select all points in the dataspace.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_select_all(PyObject *__pyx_v_self, PyObject *unused) {
|
|
PyObject *__pyx_r = NULL;
|
|
herr_t __pyx_t_1;
|
|
__Pyx_RefNannySetupContext("select_all");
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":400
|
|
* Select all points in the dataspace.
|
|
* """
|
|
* H5Sselect_all(self.id) # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__pyx_t_1 = H5Sselect_all(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 400; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_AddTraceback("h5py.h5s.SpaceID.select_all");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":403
|
|
*
|
|
*
|
|
* def select_none(self): # <<<<<<<<<<<<<<
|
|
* """()
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_select_none(PyObject *__pyx_v_self, PyObject *unused); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5s_7SpaceID_select_none[] = "()\n\n Deselect entire dataspace.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_select_none(PyObject *__pyx_v_self, PyObject *unused) {
|
|
PyObject *__pyx_r = NULL;
|
|
herr_t __pyx_t_1;
|
|
__Pyx_RefNannySetupContext("select_none");
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":408
|
|
* Deselect entire dataspace.
|
|
* """
|
|
* H5Sselect_none(self.id) # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__pyx_t_1 = H5Sselect_none(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 408; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_AddTraceback("h5py.h5s.SpaceID.select_none");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":411
|
|
*
|
|
*
|
|
* def select_valid(self): # <<<<<<<<<<<<<<
|
|
* """() => BOOL
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_select_valid(PyObject *__pyx_v_self, PyObject *unused); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5s_7SpaceID_select_valid[] = "() => BOOL\n \n Determine if the current selection falls within\n the dataspace extent.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_select_valid(PyObject *__pyx_v_self, PyObject *unused) {
|
|
PyObject *__pyx_r = NULL;
|
|
htri_t __pyx_t_1;
|
|
PyObject *__pyx_t_2 = NULL;
|
|
__Pyx_RefNannySetupContext("select_valid");
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":417
|
|
* the dataspace extent.
|
|
* """
|
|
* return <bint>(H5Sselect_valid(self.id)) # <<<<<<<<<<<<<<
|
|
*
|
|
* # === Point selection functions ===========================================
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_1 = H5Sselect_valid(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 417; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_t_2 = __Pyx_PyBool_FromLong(((int)__pyx_t_1)); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 417; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__pyx_r = __pyx_t_2;
|
|
__pyx_t_2 = 0;
|
|
goto __pyx_L0;
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_2);
|
|
__Pyx_AddTraceback("h5py.h5s.SpaceID.select_valid");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":422
|
|
*
|
|
*
|
|
* def get_select_elem_npoints(self): # <<<<<<<<<<<<<<
|
|
* """() => LONG npoints
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_get_select_elem_npoints(PyObject *__pyx_v_self, PyObject *unused); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5s_7SpaceID_get_select_elem_npoints[] = "() => LONG npoints\n\n Determine the number of elements selected in point-selection mode.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_get_select_elem_npoints(PyObject *__pyx_v_self, PyObject *unused) {
|
|
PyObject *__pyx_r = NULL;
|
|
hssize_t __pyx_t_1;
|
|
PyObject *__pyx_t_2 = NULL;
|
|
__Pyx_RefNannySetupContext("get_select_elem_npoints");
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":427
|
|
* Determine the number of elements selected in point-selection mode.
|
|
* """
|
|
* return H5Sget_select_elem_npoints(self.id) # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_1 = H5Sget_select_elem_npoints(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 427; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_t_2 = __Pyx_PyInt_to_py_hssize_t(__pyx_t_1); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 427; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__pyx_r = __pyx_t_2;
|
|
__pyx_t_2 = 0;
|
|
goto __pyx_L0;
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_2);
|
|
__Pyx_AddTraceback("h5py.h5s.SpaceID.get_select_elem_npoints");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":430
|
|
*
|
|
*
|
|
* def get_select_elem_pointlist(self): # <<<<<<<<<<<<<<
|
|
* """() => NDARRAY
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_get_select_elem_pointlist(PyObject *__pyx_v_self, PyObject *unused); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5s_7SpaceID_get_select_elem_pointlist[] = "() => NDARRAY\n\n Get a list of all selected elements. Return is a Numpy array of\n unsigned ints, with shape ``(<npoints>, <space rank)``.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_get_select_elem_pointlist(PyObject *__pyx_v_self, PyObject *unused) {
|
|
hsize_t __pyx_v_dims[2];
|
|
PyArrayObject *__pyx_v_buf;
|
|
PyObject *__pyx_r = NULL;
|
|
hssize_t __pyx_t_1;
|
|
int __pyx_t_2;
|
|
PyObject *__pyx_t_3 = NULL;
|
|
herr_t __pyx_t_4;
|
|
__Pyx_RefNannySetupContext("get_select_elem_pointlist");
|
|
__pyx_v_buf = ((PyArrayObject *)Py_None); __Pyx_INCREF(Py_None);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":439
|
|
* cdef ndarray buf
|
|
*
|
|
* dims[0] = H5Sget_select_elem_npoints(self.id) # <<<<<<<<<<<<<<
|
|
* dims[1] = H5Sget_simple_extent_ndims(self.id)
|
|
*
|
|
*/
|
|
__pyx_t_1 = H5Sget_select_elem_npoints(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 439; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
(__pyx_v_dims[0]) = __pyx_t_1;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":440
|
|
*
|
|
* dims[0] = H5Sget_select_elem_npoints(self.id)
|
|
* dims[1] = H5Sget_simple_extent_ndims(self.id) # <<<<<<<<<<<<<<
|
|
*
|
|
* buf = create_numpy_hsize(2, dims)
|
|
*/
|
|
__pyx_t_2 = H5Sget_simple_extent_ndims(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 440; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
(__pyx_v_dims[1]) = __pyx_t_2;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":442
|
|
* dims[1] = H5Sget_simple_extent_ndims(self.id)
|
|
*
|
|
* buf = create_numpy_hsize(2, dims) # <<<<<<<<<<<<<<
|
|
*
|
|
* H5Sget_select_elem_pointlist(self.id, 0, dims[0], <hsize_t*>buf.data)
|
|
*/
|
|
__pyx_t_3 = __pyx_f_4h5py_5utils_create_numpy_hsize(2, __pyx_v_dims); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 442; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
if (!(likely(((__pyx_t_3) == Py_None) || likely(__Pyx_TypeTest(__pyx_t_3, __pyx_ptype_4h5py_5numpy_ndarray))))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 442; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(((PyObject *)__pyx_v_buf));
|
|
__pyx_v_buf = ((PyArrayObject *)__pyx_t_3);
|
|
__pyx_t_3 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":444
|
|
* buf = create_numpy_hsize(2, dims)
|
|
*
|
|
* H5Sget_select_elem_pointlist(self.id, 0, dims[0], <hsize_t*>buf.data) # <<<<<<<<<<<<<<
|
|
*
|
|
* return buf
|
|
*/
|
|
__pyx_t_4 = H5Sget_select_elem_pointlist(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id, 0, (__pyx_v_dims[0]), ((hsize_t *)__pyx_v_buf->data)); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 444; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":446
|
|
* H5Sget_select_elem_pointlist(self.id, 0, dims[0], <hsize_t*>buf.data)
|
|
*
|
|
* return buf # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__Pyx_INCREF(((PyObject *)__pyx_v_buf));
|
|
__pyx_r = ((PyObject *)__pyx_v_buf);
|
|
goto __pyx_L0;
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_3);
|
|
__Pyx_AddTraceback("h5py.h5s.SpaceID.get_select_elem_pointlist");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_DECREF((PyObject *)__pyx_v_buf);
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":449
|
|
*
|
|
*
|
|
* def select_elements(self, object coords, int op=H5S_SELECT_SET): # <<<<<<<<<<<<<<
|
|
* """(SEQUENCE coords, INT op=SELECT_SET)
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_select_elements(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5s_7SpaceID_select_elements[] = "(SEQUENCE coords, INT op=SELECT_SET)\n\n Select elements by specifying coordinates points. The argument\n \"coords\" may be an ndarray or any nested sequence which can be\n converted to an array of uints with the shape::\n\n (<npoints>, <space rank>)\n \n Examples::\n\n >>> obj.shape\n (10, 10)\n >>> obj.select_elements([(1,2), (3,4), (5,9)])\n\n A zero-length selection (i.e. shape ``(0, <rank>)``) is not allowed\n by the HDF5 library. \n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_select_elements(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
|
|
PyObject *__pyx_v_coords = 0;
|
|
int __pyx_v_op;
|
|
PyArrayObject *__pyx_v_hcoords;
|
|
size_t __pyx_v_nelements;
|
|
PyObject *__pyx_r = NULL;
|
|
PyObject *__pyx_t_1 = NULL;
|
|
int __pyx_t_2;
|
|
int __pyx_t_3;
|
|
int __pyx_t_4;
|
|
int __pyx_t_5;
|
|
PyObject *__pyx_t_6 = NULL;
|
|
herr_t __pyx_t_7;
|
|
static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__coords,&__pyx_n_s__op,0};
|
|
__Pyx_RefNannySetupContext("select_elements");
|
|
if (unlikely(__pyx_kwds)) {
|
|
Py_ssize_t kw_args = PyDict_Size(__pyx_kwds);
|
|
PyObject* values[2] = {0,0};
|
|
switch (PyTuple_GET_SIZE(__pyx_args)) {
|
|
case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
|
|
case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
|
|
case 0: break;
|
|
default: goto __pyx_L5_argtuple_error;
|
|
}
|
|
switch (PyTuple_GET_SIZE(__pyx_args)) {
|
|
case 0:
|
|
values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__coords);
|
|
if (likely(values[0])) kw_args--;
|
|
else goto __pyx_L5_argtuple_error;
|
|
case 1:
|
|
if (kw_args > 1) {
|
|
PyObject* value = PyDict_GetItem(__pyx_kwds, __pyx_n_s__op);
|
|
if (unlikely(value)) { values[1] = value; kw_args--; }
|
|
}
|
|
}
|
|
if (unlikely(kw_args > 0)) {
|
|
if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, PyTuple_GET_SIZE(__pyx_args), "select_elements") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 449; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
__pyx_v_coords = values[0];
|
|
if (values[1]) {
|
|
__pyx_v_op = __Pyx_PyInt_AsInt(values[1]); if (unlikely((__pyx_v_op == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 449; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
} else {
|
|
__pyx_v_op = __pyx_k_3;
|
|
}
|
|
} else {
|
|
__pyx_v_op = __pyx_k_3;
|
|
switch (PyTuple_GET_SIZE(__pyx_args)) {
|
|
case 2: __pyx_v_op = __Pyx_PyInt_AsInt(PyTuple_GET_ITEM(__pyx_args, 1)); if (unlikely((__pyx_v_op == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 449; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
case 1: __pyx_v_coords = PyTuple_GET_ITEM(__pyx_args, 0);
|
|
break;
|
|
default: goto __pyx_L5_argtuple_error;
|
|
}
|
|
}
|
|
goto __pyx_L4_argument_unpacking_done;
|
|
__pyx_L5_argtuple_error:;
|
|
__Pyx_RaiseArgtupleInvalid("select_elements", 0, 1, 2, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 449; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
__pyx_L3_error:;
|
|
__Pyx_AddTraceback("h5py.h5s.SpaceID.select_elements");
|
|
return NULL;
|
|
__pyx_L4_argument_unpacking_done:;
|
|
__Pyx_INCREF((PyObject *)__pyx_v_self);
|
|
__Pyx_INCREF(__pyx_v_coords);
|
|
__pyx_v_hcoords = ((PyArrayObject *)Py_None); __Pyx_INCREF(Py_None);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":475
|
|
* # a compatible type and initializing it to the input.
|
|
*
|
|
* hcoords = create_hsize_array(coords) # <<<<<<<<<<<<<<
|
|
*
|
|
* if hcoords.nd != 2 or hcoords.dimensions[1] != H5Sget_simple_extent_ndims(self.id):
|
|
*/
|
|
__pyx_t_1 = __pyx_f_4h5py_5utils_create_hsize_array(__pyx_v_coords); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 475; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
if (!(likely(((__pyx_t_1) == Py_None) || likely(__Pyx_TypeTest(__pyx_t_1, __pyx_ptype_4h5py_5numpy_ndarray))))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 475; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(((PyObject *)__pyx_v_hcoords));
|
|
__pyx_v_hcoords = ((PyArrayObject *)__pyx_t_1);
|
|
__pyx_t_1 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":477
|
|
* hcoords = create_hsize_array(coords)
|
|
*
|
|
* if hcoords.nd != 2 or hcoords.dimensions[1] != H5Sget_simple_extent_ndims(self.id): # <<<<<<<<<<<<<<
|
|
* raise ValueError("Coordinate array must have shape (<npoints>, %d)" % self.get_simple_extent_ndims())
|
|
*
|
|
*/
|
|
__pyx_t_2 = (__pyx_v_hcoords->nd != 2);
|
|
if (!__pyx_t_2) {
|
|
__pyx_t_3 = H5Sget_simple_extent_ndims(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 477; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_t_4 = ((__pyx_v_hcoords->dimensions[1]) != __pyx_t_3);
|
|
__pyx_t_5 = __pyx_t_4;
|
|
} else {
|
|
__pyx_t_5 = __pyx_t_2;
|
|
}
|
|
if (__pyx_t_5) {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":478
|
|
*
|
|
* if hcoords.nd != 2 or hcoords.dimensions[1] != H5Sget_simple_extent_ndims(self.id):
|
|
* raise ValueError("Coordinate array must have shape (<npoints>, %d)" % self.get_simple_extent_ndims()) # <<<<<<<<<<<<<<
|
|
*
|
|
* nelements = hcoords.dimensions[0]
|
|
*/
|
|
__pyx_t_1 = PyObject_GetAttr(__pyx_v_self, __pyx_n_s_5); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 478; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_6 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_empty_tuple), NULL); if (unlikely(!__pyx_t_6)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 478; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_6);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_t_1 = PyNumber_Remainder(((PyObject *)__pyx_kp_s_4), __pyx_t_6); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 478; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
|
|
__pyx_t_6 = PyTuple_New(1); if (unlikely(!__pyx_t_6)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 478; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_6);
|
|
PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_1);
|
|
__Pyx_GIVEREF(__pyx_t_1);
|
|
__pyx_t_1 = 0;
|
|
__pyx_t_1 = PyObject_Call(__pyx_builtin_ValueError, __pyx_t_6, NULL); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 478; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
|
|
__Pyx_Raise(__pyx_t_1, 0, 0);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
{__pyx_filename = __pyx_f[0]; __pyx_lineno = 478; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
goto __pyx_L6;
|
|
}
|
|
__pyx_L6:;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":480
|
|
* raise ValueError("Coordinate array must have shape (<npoints>, %d)" % self.get_simple_extent_ndims())
|
|
*
|
|
* nelements = hcoords.dimensions[0] # <<<<<<<<<<<<<<
|
|
*
|
|
* H5Sselect_elements(self.id, <H5S_seloper_t>op, nelements, <hsize_t**>hcoords.data)
|
|
*/
|
|
__pyx_v_nelements = (__pyx_v_hcoords->dimensions[0]);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":482
|
|
* nelements = hcoords.dimensions[0]
|
|
*
|
|
* H5Sselect_elements(self.id, <H5S_seloper_t>op, nelements, <hsize_t**>hcoords.data) # <<<<<<<<<<<<<<
|
|
*
|
|
* # === Hyperslab selection functions =======================================
|
|
*/
|
|
__pyx_t_7 = H5Sselect_elements(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id, ((H5S_seloper_t)__pyx_v_op), __pyx_v_nelements, ((hsize_t **)__pyx_v_hcoords->data)); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 482; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_1);
|
|
__Pyx_XDECREF(__pyx_t_6);
|
|
__Pyx_AddTraceback("h5py.h5s.SpaceID.select_elements");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_DECREF((PyObject *)__pyx_v_hcoords);
|
|
__Pyx_DECREF((PyObject *)__pyx_v_self);
|
|
__Pyx_DECREF(__pyx_v_coords);
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":487
|
|
*
|
|
*
|
|
* def get_select_hyper_nblocks(self): # <<<<<<<<<<<<<<
|
|
* """() => LONG nblocks
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_get_select_hyper_nblocks(PyObject *__pyx_v_self, PyObject *unused); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5s_7SpaceID_get_select_hyper_nblocks[] = "() => LONG nblocks\n\n Get the number of hyperslab blocks currently selected.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_get_select_hyper_nblocks(PyObject *__pyx_v_self, PyObject *unused) {
|
|
PyObject *__pyx_r = NULL;
|
|
hssize_t __pyx_t_1;
|
|
PyObject *__pyx_t_2 = NULL;
|
|
__Pyx_RefNannySetupContext("get_select_hyper_nblocks");
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":492
|
|
* Get the number of hyperslab blocks currently selected.
|
|
* """
|
|
* return H5Sget_select_hyper_nblocks(self.id) # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_1 = H5Sget_select_hyper_nblocks(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 492; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_t_2 = __Pyx_PyInt_to_py_hssize_t(__pyx_t_1); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 492; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__pyx_r = __pyx_t_2;
|
|
__pyx_t_2 = 0;
|
|
goto __pyx_L0;
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_2);
|
|
__Pyx_AddTraceback("h5py.h5s.SpaceID.get_select_hyper_nblocks");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":495
|
|
*
|
|
*
|
|
* def get_select_hyper_blocklist(self): # <<<<<<<<<<<<<<
|
|
* """() => NDARRAY
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_get_select_hyper_blocklist(PyObject *__pyx_v_self, PyObject *unused); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5s_7SpaceID_get_select_hyper_blocklist[] = "() => NDARRAY\n\n Get the current hyperslab selection. The returned array has shape::\n\n (<npoints>, 2, <rank>)\n\n and can be interpreted as a nested sequence::\n\n [ (corner_coordinate_1, opposite_coordinate_1), ... ]\n\n with length equal to the total number of blocks.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_get_select_hyper_blocklist(PyObject *__pyx_v_self, PyObject *unused) {
|
|
hsize_t __pyx_v_dims[3];
|
|
PyArrayObject *__pyx_v_buf;
|
|
PyObject *__pyx_r = NULL;
|
|
hssize_t __pyx_t_1;
|
|
int __pyx_t_2;
|
|
PyObject *__pyx_t_3 = NULL;
|
|
herr_t __pyx_t_4;
|
|
__Pyx_RefNannySetupContext("get_select_hyper_blocklist");
|
|
__pyx_v_buf = ((PyArrayObject *)Py_None); __Pyx_INCREF(Py_None);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":511
|
|
* cdef ndarray buf
|
|
*
|
|
* dims[0] = H5Sget_select_hyper_nblocks(self.id) # <<<<<<<<<<<<<<
|
|
* dims[1] = 2
|
|
* dims[2] = H5Sget_simple_extent_ndims(self.id)
|
|
*/
|
|
__pyx_t_1 = H5Sget_select_hyper_nblocks(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 511; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
(__pyx_v_dims[0]) = __pyx_t_1;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":512
|
|
*
|
|
* dims[0] = H5Sget_select_hyper_nblocks(self.id)
|
|
* dims[1] = 2 # <<<<<<<<<<<<<<
|
|
* dims[2] = H5Sget_simple_extent_ndims(self.id)
|
|
*
|
|
*/
|
|
(__pyx_v_dims[1]) = 2;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":513
|
|
* dims[0] = H5Sget_select_hyper_nblocks(self.id)
|
|
* dims[1] = 2
|
|
* dims[2] = H5Sget_simple_extent_ndims(self.id) # <<<<<<<<<<<<<<
|
|
*
|
|
* buf = create_numpy_hsize(3, dims)
|
|
*/
|
|
__pyx_t_2 = H5Sget_simple_extent_ndims(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 513; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
(__pyx_v_dims[2]) = __pyx_t_2;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":515
|
|
* dims[2] = H5Sget_simple_extent_ndims(self.id)
|
|
*
|
|
* buf = create_numpy_hsize(3, dims) # <<<<<<<<<<<<<<
|
|
*
|
|
* H5Sget_select_hyper_blocklist(self.id, 0, dims[0], <hsize_t*>buf.data)
|
|
*/
|
|
__pyx_t_3 = __pyx_f_4h5py_5utils_create_numpy_hsize(3, __pyx_v_dims); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 515; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
if (!(likely(((__pyx_t_3) == Py_None) || likely(__Pyx_TypeTest(__pyx_t_3, __pyx_ptype_4h5py_5numpy_ndarray))))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 515; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(((PyObject *)__pyx_v_buf));
|
|
__pyx_v_buf = ((PyArrayObject *)__pyx_t_3);
|
|
__pyx_t_3 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":517
|
|
* buf = create_numpy_hsize(3, dims)
|
|
*
|
|
* H5Sget_select_hyper_blocklist(self.id, 0, dims[0], <hsize_t*>buf.data) # <<<<<<<<<<<<<<
|
|
*
|
|
* return buf
|
|
*/
|
|
__pyx_t_4 = H5Sget_select_hyper_blocklist(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id, 0, (__pyx_v_dims[0]), ((hsize_t *)__pyx_v_buf->data)); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 517; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":519
|
|
* H5Sget_select_hyper_blocklist(self.id, 0, dims[0], <hsize_t*>buf.data)
|
|
*
|
|
* return buf # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__Pyx_INCREF(((PyObject *)__pyx_v_buf));
|
|
__pyx_r = ((PyObject *)__pyx_v_buf);
|
|
goto __pyx_L0;
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_3);
|
|
__Pyx_AddTraceback("h5py.h5s.SpaceID.get_select_hyper_blocklist");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_DECREF((PyObject *)__pyx_v_buf);
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":522
|
|
*
|
|
*
|
|
* def select_hyperslab(self, object start, object count, object stride=None, # <<<<<<<<<<<<<<
|
|
* object block=None, int op=H5S_SELECT_SET):
|
|
* """(TUPLE start, TUPLE count, TUPLE stride=None, TUPLE block=None,
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_select_hyperslab(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5s_7SpaceID_select_hyperslab[] = "(TUPLE start, TUPLE count, TUPLE stride=None, TUPLE block=None, \n INT op=SELECT_SET)\n \n Select a block region from an existing dataspace. See the HDF5\n documentation for the meaning of the \"block\" and \"op\" keywords.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5s_7SpaceID_select_hyperslab(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
|
|
PyObject *__pyx_v_start = 0;
|
|
PyObject *__pyx_v_count = 0;
|
|
PyObject *__pyx_v_stride = 0;
|
|
PyObject *__pyx_v_block = 0;
|
|
int __pyx_v_op;
|
|
int __pyx_v_rank;
|
|
hsize_t *__pyx_v_start_array;
|
|
hsize_t *__pyx_v_count_array;
|
|
hsize_t *__pyx_v_stride_array;
|
|
hsize_t *__pyx_v_block_array;
|
|
PyObject *__pyx_r = NULL;
|
|
int __pyx_t_1;
|
|
void *__pyx_t_2;
|
|
int __pyx_t_3;
|
|
herr_t __pyx_t_4;
|
|
static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__start,&__pyx_n_s__count,&__pyx_n_s__stride,&__pyx_n_s__block,&__pyx_n_s__op,0};
|
|
__Pyx_RefNannySetupContext("select_hyperslab");
|
|
if (unlikely(__pyx_kwds)) {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":523
|
|
*
|
|
* def select_hyperslab(self, object start, object count, object stride=None,
|
|
* object block=None, int op=H5S_SELECT_SET): # <<<<<<<<<<<<<<
|
|
* """(TUPLE start, TUPLE count, TUPLE stride=None, TUPLE block=None,
|
|
* INT op=SELECT_SET)
|
|
*/
|
|
Py_ssize_t kw_args = PyDict_Size(__pyx_kwds);
|
|
PyObject* values[5] = {0,0,0,0,0};
|
|
values[2] = ((PyObject *)Py_None);
|
|
values[3] = ((PyObject *)Py_None);
|
|
switch (PyTuple_GET_SIZE(__pyx_args)) {
|
|
case 5: values[4] = PyTuple_GET_ITEM(__pyx_args, 4);
|
|
case 4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
|
|
case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
|
|
case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
|
|
case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
|
|
case 0: break;
|
|
default: goto __pyx_L5_argtuple_error;
|
|
}
|
|
switch (PyTuple_GET_SIZE(__pyx_args)) {
|
|
case 0:
|
|
values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__start);
|
|
if (likely(values[0])) kw_args--;
|
|
else goto __pyx_L5_argtuple_error;
|
|
case 1:
|
|
values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__count);
|
|
if (likely(values[1])) kw_args--;
|
|
else {
|
|
__Pyx_RaiseArgtupleInvalid("select_hyperslab", 0, 2, 5, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 522; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
case 2:
|
|
if (kw_args > 1) {
|
|
PyObject* value = PyDict_GetItem(__pyx_kwds, __pyx_n_s__stride);
|
|
if (unlikely(value)) { values[2] = value; kw_args--; }
|
|
}
|
|
case 3:
|
|
if (kw_args > 1) {
|
|
PyObject* value = PyDict_GetItem(__pyx_kwds, __pyx_n_s__block);
|
|
if (unlikely(value)) { values[3] = value; kw_args--; }
|
|
}
|
|
case 4:
|
|
if (kw_args > 1) {
|
|
PyObject* value = PyDict_GetItem(__pyx_kwds, __pyx_n_s__op);
|
|
if (unlikely(value)) { values[4] = value; kw_args--; }
|
|
}
|
|
}
|
|
if (unlikely(kw_args > 0)) {
|
|
if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, PyTuple_GET_SIZE(__pyx_args), "select_hyperslab") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 522; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
__pyx_v_start = values[0];
|
|
__pyx_v_count = values[1];
|
|
__pyx_v_stride = values[2];
|
|
__pyx_v_block = values[3];
|
|
if (values[4]) {
|
|
__pyx_v_op = __Pyx_PyInt_AsInt(values[4]); if (unlikely((__pyx_v_op == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 523; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
} else {
|
|
__pyx_v_op = __pyx_k_6;
|
|
}
|
|
} else {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":522
|
|
*
|
|
*
|
|
* def select_hyperslab(self, object start, object count, object stride=None, # <<<<<<<<<<<<<<
|
|
* object block=None, int op=H5S_SELECT_SET):
|
|
* """(TUPLE start, TUPLE count, TUPLE stride=None, TUPLE block=None,
|
|
*/
|
|
__pyx_v_stride = ((PyObject *)Py_None);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":523
|
|
*
|
|
* def select_hyperslab(self, object start, object count, object stride=None,
|
|
* object block=None, int op=H5S_SELECT_SET): # <<<<<<<<<<<<<<
|
|
* """(TUPLE start, TUPLE count, TUPLE stride=None, TUPLE block=None,
|
|
* INT op=SELECT_SET)
|
|
*/
|
|
__pyx_v_block = ((PyObject *)Py_None);
|
|
__pyx_v_op = __pyx_k_6;
|
|
switch (PyTuple_GET_SIZE(__pyx_args)) {
|
|
case 5:
|
|
__pyx_v_op = __Pyx_PyInt_AsInt(PyTuple_GET_ITEM(__pyx_args, 4)); if (unlikely((__pyx_v_op == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 523; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
case 4:
|
|
__pyx_v_block = PyTuple_GET_ITEM(__pyx_args, 3);
|
|
case 3:
|
|
__pyx_v_stride = PyTuple_GET_ITEM(__pyx_args, 2);
|
|
case 2:
|
|
__pyx_v_count = PyTuple_GET_ITEM(__pyx_args, 1);
|
|
__pyx_v_start = PyTuple_GET_ITEM(__pyx_args, 0);
|
|
break;
|
|
default: goto __pyx_L5_argtuple_error;
|
|
}
|
|
}
|
|
goto __pyx_L4_argument_unpacking_done;
|
|
__pyx_L5_argtuple_error:;
|
|
__Pyx_RaiseArgtupleInvalid("select_hyperslab", 0, 2, 5, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 522; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
__pyx_L3_error:;
|
|
__Pyx_AddTraceback("h5py.h5s.SpaceID.select_hyperslab");
|
|
return NULL;
|
|
__pyx_L4_argument_unpacking_done:;
|
|
__Pyx_INCREF((PyObject *)__pyx_v_self);
|
|
__Pyx_INCREF(__pyx_v_start);
|
|
__Pyx_INCREF(__pyx_v_count);
|
|
__Pyx_INCREF(__pyx_v_stride);
|
|
__Pyx_INCREF(__pyx_v_block);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":531
|
|
* """
|
|
* cdef int rank
|
|
* cdef hsize_t* start_array = NULL # <<<<<<<<<<<<<<
|
|
* cdef hsize_t* count_array = NULL
|
|
* cdef hsize_t* stride_array = NULL
|
|
*/
|
|
__pyx_v_start_array = NULL;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":532
|
|
* cdef int rank
|
|
* cdef hsize_t* start_array = NULL
|
|
* cdef hsize_t* count_array = NULL # <<<<<<<<<<<<<<
|
|
* cdef hsize_t* stride_array = NULL
|
|
* cdef hsize_t* block_array = NULL
|
|
*/
|
|
__pyx_v_count_array = NULL;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":533
|
|
* cdef hsize_t* start_array = NULL
|
|
* cdef hsize_t* count_array = NULL
|
|
* cdef hsize_t* stride_array = NULL # <<<<<<<<<<<<<<
|
|
* cdef hsize_t* block_array = NULL
|
|
*
|
|
*/
|
|
__pyx_v_stride_array = NULL;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":534
|
|
* cdef hsize_t* count_array = NULL
|
|
* cdef hsize_t* stride_array = NULL
|
|
* cdef hsize_t* block_array = NULL # <<<<<<<<<<<<<<
|
|
*
|
|
* # Dataspace rank. All provided tuples must match this.
|
|
*/
|
|
__pyx_v_block_array = NULL;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":537
|
|
*
|
|
* # Dataspace rank. All provided tuples must match this.
|
|
* rank = H5Sget_simple_extent_ndims(self.id) # <<<<<<<<<<<<<<
|
|
*
|
|
* require_tuple(start, 0, rank, "start")
|
|
*/
|
|
__pyx_t_1 = H5Sget_simple_extent_ndims(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 537; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_v_rank = __pyx_t_1;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":539
|
|
* rank = H5Sget_simple_extent_ndims(self.id)
|
|
*
|
|
* require_tuple(start, 0, rank, "start") # <<<<<<<<<<<<<<
|
|
* require_tuple(count, 0, rank, "count")
|
|
* require_tuple(stride, 1, rank, "stride")
|
|
*/
|
|
__pyx_t_1 = __pyx_f_4h5py_5utils_require_tuple(__pyx_v_start, 0, __pyx_v_rank, __pyx_k__start); if (unlikely(__pyx_t_1 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 539; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":540
|
|
*
|
|
* require_tuple(start, 0, rank, "start")
|
|
* require_tuple(count, 0, rank, "count") # <<<<<<<<<<<<<<
|
|
* require_tuple(stride, 1, rank, "stride")
|
|
* require_tuple(block, 1, rank, "block")
|
|
*/
|
|
__pyx_t_1 = __pyx_f_4h5py_5utils_require_tuple(__pyx_v_count, 0, __pyx_v_rank, __pyx_k__count); if (unlikely(__pyx_t_1 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 540; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":541
|
|
* require_tuple(start, 0, rank, "start")
|
|
* require_tuple(count, 0, rank, "count")
|
|
* require_tuple(stride, 1, rank, "stride") # <<<<<<<<<<<<<<
|
|
* require_tuple(block, 1, rank, "block")
|
|
*
|
|
*/
|
|
__pyx_t_1 = __pyx_f_4h5py_5utils_require_tuple(__pyx_v_stride, 1, __pyx_v_rank, __pyx_k__stride); if (unlikely(__pyx_t_1 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 541; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":542
|
|
* require_tuple(count, 0, rank, "count")
|
|
* require_tuple(stride, 1, rank, "stride")
|
|
* require_tuple(block, 1, rank, "block") # <<<<<<<<<<<<<<
|
|
*
|
|
* try:
|
|
*/
|
|
__pyx_t_1 = __pyx_f_4h5py_5utils_require_tuple(__pyx_v_block, 1, __pyx_v_rank, __pyx_k__block); if (unlikely(__pyx_t_1 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 542; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":544
|
|
* require_tuple(block, 1, rank, "block")
|
|
*
|
|
* try: # <<<<<<<<<<<<<<
|
|
* start_array = <hsize_t*>emalloc(sizeof(hsize_t)*rank)
|
|
* count_array = <hsize_t*>emalloc(sizeof(hsize_t)*rank)
|
|
*/
|
|
/*try:*/ {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":545
|
|
*
|
|
* try:
|
|
* start_array = <hsize_t*>emalloc(sizeof(hsize_t)*rank) # <<<<<<<<<<<<<<
|
|
* count_array = <hsize_t*>emalloc(sizeof(hsize_t)*rank)
|
|
* convert_tuple(start, start_array, rank)
|
|
*/
|
|
__pyx_t_2 = __pyx_f_4h5py_5utils_emalloc(((sizeof(hsize_t)) * __pyx_v_rank)); if (unlikely(__pyx_t_2 == NULL && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 545; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
__pyx_v_start_array = ((hsize_t *)__pyx_t_2);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":546
|
|
* try:
|
|
* start_array = <hsize_t*>emalloc(sizeof(hsize_t)*rank)
|
|
* count_array = <hsize_t*>emalloc(sizeof(hsize_t)*rank) # <<<<<<<<<<<<<<
|
|
* convert_tuple(start, start_array, rank)
|
|
* convert_tuple(count, count_array, rank)
|
|
*/
|
|
__pyx_t_2 = __pyx_f_4h5py_5utils_emalloc(((sizeof(hsize_t)) * __pyx_v_rank)); if (unlikely(__pyx_t_2 == NULL && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 546; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
__pyx_v_count_array = ((hsize_t *)__pyx_t_2);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":547
|
|
* start_array = <hsize_t*>emalloc(sizeof(hsize_t)*rank)
|
|
* count_array = <hsize_t*>emalloc(sizeof(hsize_t)*rank)
|
|
* convert_tuple(start, start_array, rank) # <<<<<<<<<<<<<<
|
|
* convert_tuple(count, count_array, rank)
|
|
*
|
|
*/
|
|
__pyx_t_1 = __pyx_f_4h5py_5utils_convert_tuple(__pyx_v_start, __pyx_v_start_array, __pyx_v_rank); if (unlikely(__pyx_t_1 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 547; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":548
|
|
* count_array = <hsize_t*>emalloc(sizeof(hsize_t)*rank)
|
|
* convert_tuple(start, start_array, rank)
|
|
* convert_tuple(count, count_array, rank) # <<<<<<<<<<<<<<
|
|
*
|
|
* if stride is not None:
|
|
*/
|
|
__pyx_t_1 = __pyx_f_4h5py_5utils_convert_tuple(__pyx_v_count, __pyx_v_count_array, __pyx_v_rank); if (unlikely(__pyx_t_1 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 548; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":550
|
|
* convert_tuple(count, count_array, rank)
|
|
*
|
|
* if stride is not None: # <<<<<<<<<<<<<<
|
|
* stride_array = <hsize_t*>emalloc(sizeof(hsize_t)*rank)
|
|
* convert_tuple(stride, stride_array, rank)
|
|
*/
|
|
__pyx_t_3 = (__pyx_v_stride != Py_None);
|
|
if (__pyx_t_3) {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":551
|
|
*
|
|
* if stride is not None:
|
|
* stride_array = <hsize_t*>emalloc(sizeof(hsize_t)*rank) # <<<<<<<<<<<<<<
|
|
* convert_tuple(stride, stride_array, rank)
|
|
* if block is not None:
|
|
*/
|
|
__pyx_t_2 = __pyx_f_4h5py_5utils_emalloc(((sizeof(hsize_t)) * __pyx_v_rank)); if (unlikely(__pyx_t_2 == NULL && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 551; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
__pyx_v_stride_array = ((hsize_t *)__pyx_t_2);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":552
|
|
* if stride is not None:
|
|
* stride_array = <hsize_t*>emalloc(sizeof(hsize_t)*rank)
|
|
* convert_tuple(stride, stride_array, rank) # <<<<<<<<<<<<<<
|
|
* if block is not None:
|
|
* block_array = <hsize_t*>emalloc(sizeof(hsize_t)*rank)
|
|
*/
|
|
__pyx_t_1 = __pyx_f_4h5py_5utils_convert_tuple(__pyx_v_stride, __pyx_v_stride_array, __pyx_v_rank); if (unlikely(__pyx_t_1 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 552; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
goto __pyx_L9;
|
|
}
|
|
__pyx_L9:;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":553
|
|
* stride_array = <hsize_t*>emalloc(sizeof(hsize_t)*rank)
|
|
* convert_tuple(stride, stride_array, rank)
|
|
* if block is not None: # <<<<<<<<<<<<<<
|
|
* block_array = <hsize_t*>emalloc(sizeof(hsize_t)*rank)
|
|
* convert_tuple(block, block_array, rank)
|
|
*/
|
|
__pyx_t_3 = (__pyx_v_block != Py_None);
|
|
if (__pyx_t_3) {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":554
|
|
* convert_tuple(stride, stride_array, rank)
|
|
* if block is not None:
|
|
* block_array = <hsize_t*>emalloc(sizeof(hsize_t)*rank) # <<<<<<<<<<<<<<
|
|
* convert_tuple(block, block_array, rank)
|
|
*
|
|
*/
|
|
__pyx_t_2 = __pyx_f_4h5py_5utils_emalloc(((sizeof(hsize_t)) * __pyx_v_rank)); if (unlikely(__pyx_t_2 == NULL && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 554; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
__pyx_v_block_array = ((hsize_t *)__pyx_t_2);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":555
|
|
* if block is not None:
|
|
* block_array = <hsize_t*>emalloc(sizeof(hsize_t)*rank)
|
|
* convert_tuple(block, block_array, rank) # <<<<<<<<<<<<<<
|
|
*
|
|
* H5Sselect_hyperslab(self.id, <H5S_seloper_t>op, start_array,
|
|
*/
|
|
__pyx_t_1 = __pyx_f_4h5py_5utils_convert_tuple(__pyx_v_block, __pyx_v_block_array, __pyx_v_rank); if (unlikely(__pyx_t_1 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 555; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
goto __pyx_L10;
|
|
}
|
|
__pyx_L10:;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":558
|
|
*
|
|
* H5Sselect_hyperslab(self.id, <H5S_seloper_t>op, start_array,
|
|
* stride_array, count_array, block_array) # <<<<<<<<<<<<<<
|
|
*
|
|
* finally:
|
|
*/
|
|
__pyx_t_4 = H5Sselect_hyperslab(((struct __pyx_obj_4h5py_3h5s_SpaceID *)__pyx_v_self)->__pyx_base.id, ((H5S_seloper_t)__pyx_v_op), __pyx_v_start_array, __pyx_v_stride_array, __pyx_v_count_array, __pyx_v_block_array); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 557; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
}
|
|
/*finally:*/ {
|
|
int __pyx_why;
|
|
PyObject *__pyx_exc_type, *__pyx_exc_value, *__pyx_exc_tb;
|
|
int __pyx_exc_lineno;
|
|
__pyx_exc_type = 0; __pyx_exc_value = 0; __pyx_exc_tb = 0; __pyx_exc_lineno = 0;
|
|
__pyx_why = 0; goto __pyx_L8;
|
|
__pyx_L7: {
|
|
__pyx_why = 4;
|
|
__Pyx_ErrFetch(&__pyx_exc_type, &__pyx_exc_value, &__pyx_exc_tb);
|
|
__pyx_exc_lineno = __pyx_lineno;
|
|
goto __pyx_L8;
|
|
}
|
|
__pyx_L8:;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":561
|
|
*
|
|
* finally:
|
|
* efree(start_array) # <<<<<<<<<<<<<<
|
|
* efree(count_array)
|
|
* efree(stride_array)
|
|
*/
|
|
__pyx_f_4h5py_5utils_efree(__pyx_v_start_array);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":562
|
|
* finally:
|
|
* efree(start_array)
|
|
* efree(count_array) # <<<<<<<<<<<<<<
|
|
* efree(stride_array)
|
|
* efree(block_array)
|
|
*/
|
|
__pyx_f_4h5py_5utils_efree(__pyx_v_count_array);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":563
|
|
* efree(start_array)
|
|
* efree(count_array)
|
|
* efree(stride_array) # <<<<<<<<<<<<<<
|
|
* efree(block_array)
|
|
*
|
|
*/
|
|
__pyx_f_4h5py_5utils_efree(__pyx_v_stride_array);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":564
|
|
* efree(count_array)
|
|
* efree(stride_array)
|
|
* efree(block_array) # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__pyx_f_4h5py_5utils_efree(__pyx_v_block_array);
|
|
switch (__pyx_why) {
|
|
case 4: {
|
|
__Pyx_ErrRestore(__pyx_exc_type, __pyx_exc_value, __pyx_exc_tb);
|
|
__pyx_lineno = __pyx_exc_lineno;
|
|
__pyx_exc_type = 0;
|
|
__pyx_exc_value = 0;
|
|
__pyx_exc_tb = 0;
|
|
goto __pyx_L1_error;
|
|
}
|
|
}
|
|
}
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_AddTraceback("h5py.h5s.SpaceID.select_hyperslab");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_DECREF((PyObject *)__pyx_v_self);
|
|
__Pyx_DECREF(__pyx_v_start);
|
|
__Pyx_DECREF(__pyx_v_count);
|
|
__Pyx_DECREF(__pyx_v_stride);
|
|
__Pyx_DECREF(__pyx_v_block);
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
static PyObject *__pyx_tp_new_4h5py_3h5s_SpaceID(PyTypeObject *t, PyObject *a, PyObject *k) {
|
|
PyObject *o = __pyx_ptype_4h5py_2h5_ObjectID->tp_new(t, a, k);
|
|
if (!o) return 0;
|
|
return o;
|
|
}
|
|
|
|
static void __pyx_tp_dealloc_4h5py_3h5s_SpaceID(PyObject *o) {
|
|
__pyx_ptype_4h5py_2h5_ObjectID->tp_dealloc(o);
|
|
}
|
|
|
|
static int __pyx_tp_traverse_4h5py_3h5s_SpaceID(PyObject *o, visitproc v, void *a) {
|
|
int e;
|
|
if (__pyx_ptype_4h5py_2h5_ObjectID->tp_traverse) {
|
|
e = __pyx_ptype_4h5py_2h5_ObjectID->tp_traverse(o, v, a); if (e) return e;
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
static int __pyx_tp_clear_4h5py_3h5s_SpaceID(PyObject *o) {
|
|
if (__pyx_ptype_4h5py_2h5_ObjectID->tp_clear) {
|
|
__pyx_ptype_4h5py_2h5_ObjectID->tp_clear(o);
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
static PyObject *__pyx_getprop_4h5py_3h5s_7SpaceID_shape(PyObject *o, void *x) {
|
|
return __pyx_pf_4h5py_3h5s_7SpaceID_5shape___get__(o);
|
|
}
|
|
|
|
static struct PyMethodDef __pyx_methods_4h5py_3h5s_SpaceID[] = {
|
|
{__Pyx_NAMESTR("_close"), (PyCFunction)__pyx_pf_4h5py_3h5s_7SpaceID__close, METH_NOARGS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5s_7SpaceID__close)},
|
|
{__Pyx_NAMESTR("copy"), (PyCFunction)__pyx_pf_4h5py_3h5s_7SpaceID_copy, METH_NOARGS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5s_7SpaceID_copy)},
|
|
{__Pyx_NAMESTR("is_simple"), (PyCFunction)__pyx_pf_4h5py_3h5s_7SpaceID_is_simple, METH_NOARGS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5s_7SpaceID_is_simple)},
|
|
{__Pyx_NAMESTR("offset_simple"), (PyCFunction)__pyx_pf_4h5py_3h5s_7SpaceID_offset_simple, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5s_7SpaceID_offset_simple)},
|
|
{__Pyx_NAMESTR("get_simple_extent_ndims"), (PyCFunction)__pyx_pf_4h5py_3h5s_7SpaceID_get_simple_extent_ndims, METH_NOARGS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5s_7SpaceID_get_simple_extent_ndims)},
|
|
{__Pyx_NAMESTR("get_simple_extent_dims"), (PyCFunction)__pyx_pf_4h5py_3h5s_7SpaceID_get_simple_extent_dims, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5s_7SpaceID_get_simple_extent_dims)},
|
|
{__Pyx_NAMESTR("get_simple_extent_npoints"), (PyCFunction)__pyx_pf_4h5py_3h5s_7SpaceID_get_simple_extent_npoints, METH_NOARGS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5s_7SpaceID_get_simple_extent_npoints)},
|
|
{__Pyx_NAMESTR("get_simple_extent_type"), (PyCFunction)__pyx_pf_4h5py_3h5s_7SpaceID_get_simple_extent_type, METH_NOARGS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5s_7SpaceID_get_simple_extent_type)},
|
|
{__Pyx_NAMESTR("extent_copy"), (PyCFunction)__pyx_pf_4h5py_3h5s_7SpaceID_extent_copy, METH_O, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5s_7SpaceID_extent_copy)},
|
|
{__Pyx_NAMESTR("set_extent_simple"), (PyCFunction)__pyx_pf_4h5py_3h5s_7SpaceID_set_extent_simple, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5s_7SpaceID_set_extent_simple)},
|
|
{__Pyx_NAMESTR("set_extent_none"), (PyCFunction)__pyx_pf_4h5py_3h5s_7SpaceID_set_extent_none, METH_NOARGS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5s_7SpaceID_set_extent_none)},
|
|
{__Pyx_NAMESTR("get_select_type"), (PyCFunction)__pyx_pf_4h5py_3h5s_7SpaceID_get_select_type, METH_NOARGS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5s_7SpaceID_get_select_type)},
|
|
{__Pyx_NAMESTR("get_select_npoints"), (PyCFunction)__pyx_pf_4h5py_3h5s_7SpaceID_get_select_npoints, METH_NOARGS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5s_7SpaceID_get_select_npoints)},
|
|
{__Pyx_NAMESTR("get_select_bounds"), (PyCFunction)__pyx_pf_4h5py_3h5s_7SpaceID_get_select_bounds, METH_NOARGS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5s_7SpaceID_get_select_bounds)},
|
|
{__Pyx_NAMESTR("select_all"), (PyCFunction)__pyx_pf_4h5py_3h5s_7SpaceID_select_all, METH_NOARGS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5s_7SpaceID_select_all)},
|
|
{__Pyx_NAMESTR("select_none"), (PyCFunction)__pyx_pf_4h5py_3h5s_7SpaceID_select_none, METH_NOARGS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5s_7SpaceID_select_none)},
|
|
{__Pyx_NAMESTR("select_valid"), (PyCFunction)__pyx_pf_4h5py_3h5s_7SpaceID_select_valid, METH_NOARGS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5s_7SpaceID_select_valid)},
|
|
{__Pyx_NAMESTR("get_select_elem_npoints"), (PyCFunction)__pyx_pf_4h5py_3h5s_7SpaceID_get_select_elem_npoints, METH_NOARGS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5s_7SpaceID_get_select_elem_npoints)},
|
|
{__Pyx_NAMESTR("get_select_elem_pointlist"), (PyCFunction)__pyx_pf_4h5py_3h5s_7SpaceID_get_select_elem_pointlist, METH_NOARGS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5s_7SpaceID_get_select_elem_pointlist)},
|
|
{__Pyx_NAMESTR("select_elements"), (PyCFunction)__pyx_pf_4h5py_3h5s_7SpaceID_select_elements, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5s_7SpaceID_select_elements)},
|
|
{__Pyx_NAMESTR("get_select_hyper_nblocks"), (PyCFunction)__pyx_pf_4h5py_3h5s_7SpaceID_get_select_hyper_nblocks, METH_NOARGS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5s_7SpaceID_get_select_hyper_nblocks)},
|
|
{__Pyx_NAMESTR("get_select_hyper_blocklist"), (PyCFunction)__pyx_pf_4h5py_3h5s_7SpaceID_get_select_hyper_blocklist, METH_NOARGS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5s_7SpaceID_get_select_hyper_blocklist)},
|
|
{__Pyx_NAMESTR("select_hyperslab"), (PyCFunction)__pyx_pf_4h5py_3h5s_7SpaceID_select_hyperslab, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5s_7SpaceID_select_hyperslab)},
|
|
{0, 0, 0, 0}
|
|
};
|
|
|
|
static struct PyGetSetDef __pyx_getsets_4h5py_3h5s_SpaceID[] = {
|
|
{(char *)"shape", __pyx_getprop_4h5py_3h5s_7SpaceID_shape, 0, __Pyx_DOCSTR(__pyx_k_7), 0},
|
|
{0, 0, 0, 0, 0}
|
|
};
|
|
|
|
static PyNumberMethods __pyx_tp_as_number_SpaceID = {
|
|
0, /*nb_add*/
|
|
0, /*nb_subtract*/
|
|
0, /*nb_multiply*/
|
|
#if PY_MAJOR_VERSION < 3
|
|
0, /*nb_divide*/
|
|
#endif
|
|
0, /*nb_remainder*/
|
|
0, /*nb_divmod*/
|
|
0, /*nb_power*/
|
|
0, /*nb_negative*/
|
|
0, /*nb_positive*/
|
|
0, /*nb_absolute*/
|
|
0, /*nb_nonzero*/
|
|
0, /*nb_invert*/
|
|
0, /*nb_lshift*/
|
|
0, /*nb_rshift*/
|
|
0, /*nb_and*/
|
|
0, /*nb_xor*/
|
|
0, /*nb_or*/
|
|
#if PY_MAJOR_VERSION < 3
|
|
0, /*nb_coerce*/
|
|
#endif
|
|
0, /*nb_int*/
|
|
#if PY_MAJOR_VERSION >= 3
|
|
0, /*reserved*/
|
|
#else
|
|
0, /*nb_long*/
|
|
#endif
|
|
0, /*nb_float*/
|
|
#if PY_MAJOR_VERSION < 3
|
|
0, /*nb_oct*/
|
|
#endif
|
|
#if PY_MAJOR_VERSION < 3
|
|
0, /*nb_hex*/
|
|
#endif
|
|
0, /*nb_inplace_add*/
|
|
0, /*nb_inplace_subtract*/
|
|
0, /*nb_inplace_multiply*/
|
|
#if PY_MAJOR_VERSION < 3
|
|
0, /*nb_inplace_divide*/
|
|
#endif
|
|
0, /*nb_inplace_remainder*/
|
|
0, /*nb_inplace_power*/
|
|
0, /*nb_inplace_lshift*/
|
|
0, /*nb_inplace_rshift*/
|
|
0, /*nb_inplace_and*/
|
|
0, /*nb_inplace_xor*/
|
|
0, /*nb_inplace_or*/
|
|
0, /*nb_floor_divide*/
|
|
0, /*nb_true_divide*/
|
|
0, /*nb_inplace_floor_divide*/
|
|
0, /*nb_inplace_true_divide*/
|
|
#if (PY_MAJOR_VERSION >= 3) || (Py_TPFLAGS_DEFAULT & Py_TPFLAGS_HAVE_INDEX)
|
|
0, /*nb_index*/
|
|
#endif
|
|
};
|
|
|
|
static PySequenceMethods __pyx_tp_as_sequence_SpaceID = {
|
|
0, /*sq_length*/
|
|
0, /*sq_concat*/
|
|
0, /*sq_repeat*/
|
|
0, /*sq_item*/
|
|
0, /*sq_slice*/
|
|
0, /*sq_ass_item*/
|
|
0, /*sq_ass_slice*/
|
|
0, /*sq_contains*/
|
|
0, /*sq_inplace_concat*/
|
|
0, /*sq_inplace_repeat*/
|
|
};
|
|
|
|
static PyMappingMethods __pyx_tp_as_mapping_SpaceID = {
|
|
0, /*mp_length*/
|
|
0, /*mp_subscript*/
|
|
0, /*mp_ass_subscript*/
|
|
};
|
|
|
|
static PyBufferProcs __pyx_tp_as_buffer_SpaceID = {
|
|
#if PY_MAJOR_VERSION < 3
|
|
0, /*bf_getreadbuffer*/
|
|
#endif
|
|
#if PY_MAJOR_VERSION < 3
|
|
0, /*bf_getwritebuffer*/
|
|
#endif
|
|
#if PY_MAJOR_VERSION < 3
|
|
0, /*bf_getsegcount*/
|
|
#endif
|
|
#if PY_MAJOR_VERSION < 3
|
|
0, /*bf_getcharbuffer*/
|
|
#endif
|
|
#if PY_VERSION_HEX >= 0x02060000
|
|
0, /*bf_getbuffer*/
|
|
#endif
|
|
#if PY_VERSION_HEX >= 0x02060000
|
|
0, /*bf_releasebuffer*/
|
|
#endif
|
|
};
|
|
|
|
PyTypeObject __pyx_type_4h5py_3h5s_SpaceID = {
|
|
PyVarObject_HEAD_INIT(0, 0)
|
|
__Pyx_NAMESTR("h5py.h5s.SpaceID"), /*tp_name*/
|
|
sizeof(struct __pyx_obj_4h5py_3h5s_SpaceID), /*tp_basicsize*/
|
|
0, /*tp_itemsize*/
|
|
__pyx_tp_dealloc_4h5py_3h5s_SpaceID, /*tp_dealloc*/
|
|
0, /*tp_print*/
|
|
0, /*tp_getattr*/
|
|
0, /*tp_setattr*/
|
|
0, /*tp_compare*/
|
|
0, /*tp_repr*/
|
|
&__pyx_tp_as_number_SpaceID, /*tp_as_number*/
|
|
&__pyx_tp_as_sequence_SpaceID, /*tp_as_sequence*/
|
|
&__pyx_tp_as_mapping_SpaceID, /*tp_as_mapping*/
|
|
0, /*tp_hash*/
|
|
0, /*tp_call*/
|
|
0, /*tp_str*/
|
|
0, /*tp_getattro*/
|
|
0, /*tp_setattro*/
|
|
&__pyx_tp_as_buffer_SpaceID, /*tp_as_buffer*/
|
|
Py_TPFLAGS_DEFAULT|Py_TPFLAGS_CHECKTYPES|Py_TPFLAGS_BASETYPE|Py_TPFLAGS_HAVE_NEWBUFFER|Py_TPFLAGS_HAVE_GC, /*tp_flags*/
|
|
__Pyx_DOCSTR("\n Represents a dataspace identifier.\n\n Properties:\n\n shape\n Numpy-style shape tuple with dimensions.\n\n * Hashable: No\n * Equality: Unimplemented\n\n Can be pickled if HDF5 1.8 is available.\n "), /*tp_doc*/
|
|
__pyx_tp_traverse_4h5py_3h5s_SpaceID, /*tp_traverse*/
|
|
__pyx_tp_clear_4h5py_3h5s_SpaceID, /*tp_clear*/
|
|
0, /*tp_richcompare*/
|
|
0, /*tp_weaklistoffset*/
|
|
0, /*tp_iter*/
|
|
0, /*tp_iternext*/
|
|
__pyx_methods_4h5py_3h5s_SpaceID, /*tp_methods*/
|
|
0, /*tp_members*/
|
|
__pyx_getsets_4h5py_3h5s_SpaceID, /*tp_getset*/
|
|
0, /*tp_base*/
|
|
0, /*tp_dict*/
|
|
0, /*tp_descr_get*/
|
|
0, /*tp_descr_set*/
|
|
0, /*tp_dictoffset*/
|
|
0, /*tp_init*/
|
|
0, /*tp_alloc*/
|
|
__pyx_tp_new_4h5py_3h5s_SpaceID, /*tp_new*/
|
|
0, /*tp_free*/
|
|
0, /*tp_is_gc*/
|
|
0, /*tp_bases*/
|
|
0, /*tp_mro*/
|
|
0, /*tp_cache*/
|
|
0, /*tp_subclasses*/
|
|
0, /*tp_weaklist*/
|
|
0, /*tp_del*/
|
|
#if PY_VERSION_HEX >= 0x02060000
|
|
0, /*tp_version_tag*/
|
|
#endif
|
|
};
|
|
|
|
static struct PyMethodDef __pyx_methods[] = {
|
|
{__Pyx_NAMESTR("create"), (PyCFunction)__pyx_pf_4h5py_3h5s_create, METH_O, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5s_create)},
|
|
{__Pyx_NAMESTR("create_simple"), (PyCFunction)__pyx_pf_4h5py_3h5s_create_simple, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5s_create_simple)},
|
|
{0, 0, 0, 0}
|
|
};
|
|
|
|
static void __pyx_init_filenames(void); /*proto*/
|
|
|
|
#if PY_MAJOR_VERSION >= 3
|
|
static struct PyModuleDef __pyx_moduledef = {
|
|
PyModuleDef_HEAD_INIT,
|
|
__Pyx_NAMESTR("h5s"),
|
|
__Pyx_DOCSTR(__pyx_k_8), /* m_doc */
|
|
-1, /* m_size */
|
|
__pyx_methods /* m_methods */,
|
|
NULL, /* m_reload */
|
|
NULL, /* m_traverse */
|
|
NULL, /* m_clear */
|
|
NULL /* m_free */
|
|
};
|
|
#endif
|
|
|
|
static __Pyx_StringTabEntry __pyx_string_tab[] = {
|
|
{&__pyx_n_s_1, __pyx_k_1, sizeof(__pyx_k_1), 0, 0, 1, 1},
|
|
{&__pyx_kp_s_2, __pyx_k_2, sizeof(__pyx_k_2), 0, 0, 1, 0},
|
|
{&__pyx_kp_s_4, __pyx_k_4, sizeof(__pyx_k_4), 0, 0, 1, 0},
|
|
{&__pyx_n_s_5, __pyx_k_5, sizeof(__pyx_k_5), 0, 0, 1, 1},
|
|
{&__pyx_n_s__ALL, __pyx_k__ALL, sizeof(__pyx_k__ALL), 0, 0, 1, 1},
|
|
{&__pyx_n_s__NO_CLASS, __pyx_k__NO_CLASS, sizeof(__pyx_k__NO_CLASS), 0, 0, 1, 1},
|
|
{&__pyx_n_s__SCALAR, __pyx_k__SCALAR, sizeof(__pyx_k__SCALAR), 0, 0, 1, 1},
|
|
{&__pyx_n_s__SELECT_AND, __pyx_k__SELECT_AND, sizeof(__pyx_k__SELECT_AND), 0, 0, 1, 1},
|
|
{&__pyx_n_s__SELECT_APPEND, __pyx_k__SELECT_APPEND, sizeof(__pyx_k__SELECT_APPEND), 0, 0, 1, 1},
|
|
{&__pyx_n_s__SELECT_INVALID, __pyx_k__SELECT_INVALID, sizeof(__pyx_k__SELECT_INVALID), 0, 0, 1, 1},
|
|
{&__pyx_n_s__SELECT_NOOP, __pyx_k__SELECT_NOOP, sizeof(__pyx_k__SELECT_NOOP), 0, 0, 1, 1},
|
|
{&__pyx_n_s__SELECT_NOTA, __pyx_k__SELECT_NOTA, sizeof(__pyx_k__SELECT_NOTA), 0, 0, 1, 1},
|
|
{&__pyx_n_s__SELECT_NOTB, __pyx_k__SELECT_NOTB, sizeof(__pyx_k__SELECT_NOTB), 0, 0, 1, 1},
|
|
{&__pyx_n_s__SELECT_OR, __pyx_k__SELECT_OR, sizeof(__pyx_k__SELECT_OR), 0, 0, 1, 1},
|
|
{&__pyx_n_s__SELECT_PREPEND, __pyx_k__SELECT_PREPEND, sizeof(__pyx_k__SELECT_PREPEND), 0, 0, 1, 1},
|
|
{&__pyx_n_s__SELECT_SET, __pyx_k__SELECT_SET, sizeof(__pyx_k__SELECT_SET), 0, 0, 1, 1},
|
|
{&__pyx_n_s__SELECT_XOR, __pyx_k__SELECT_XOR, sizeof(__pyx_k__SELECT_XOR), 0, 0, 1, 1},
|
|
{&__pyx_n_s__SEL_ALL, __pyx_k__SEL_ALL, sizeof(__pyx_k__SEL_ALL), 0, 0, 1, 1},
|
|
{&__pyx_n_s__SEL_ERROR, __pyx_k__SEL_ERROR, sizeof(__pyx_k__SEL_ERROR), 0, 0, 1, 1},
|
|
{&__pyx_n_s__SEL_HYPERSLABS, __pyx_k__SEL_HYPERSLABS, sizeof(__pyx_k__SEL_HYPERSLABS), 0, 0, 1, 1},
|
|
{&__pyx_n_s__SEL_NONE, __pyx_k__SEL_NONE, sizeof(__pyx_k__SEL_NONE), 0, 0, 1, 1},
|
|
{&__pyx_n_s__SEL_POINTS, __pyx_k__SEL_POINTS, sizeof(__pyx_k__SEL_POINTS), 0, 0, 1, 1},
|
|
{&__pyx_n_s__SIMPLE, __pyx_k__SIMPLE, sizeof(__pyx_k__SIMPLE), 0, 0, 1, 1},
|
|
{&__pyx_n_s__UNLIMITED, __pyx_k__UNLIMITED, sizeof(__pyx_k__UNLIMITED), 0, 0, 1, 1},
|
|
{&__pyx_n_s__ValueError, __pyx_k__ValueError, sizeof(__pyx_k__ValueError), 0, 0, 1, 1},
|
|
{&__pyx_n_s____main__, __pyx_k____main__, sizeof(__pyx_k____main__), 0, 0, 1, 1},
|
|
{&__pyx_n_s___locked, __pyx_k___locked, sizeof(__pyx_k___locked), 0, 0, 1, 1},
|
|
{&__pyx_n_s__block, __pyx_k__block, sizeof(__pyx_k__block), 0, 0, 1, 1},
|
|
{&__pyx_n_s__coords, __pyx_k__coords, sizeof(__pyx_k__coords), 0, 0, 1, 1},
|
|
{&__pyx_n_s__count, __pyx_k__count, sizeof(__pyx_k__count), 0, 0, 1, 1},
|
|
{&__pyx_n_s__data, __pyx_k__data, sizeof(__pyx_k__data), 0, 0, 1, 1},
|
|
{&__pyx_n_s__dimensions, __pyx_k__dimensions, sizeof(__pyx_k__dimensions), 0, 0, 1, 1},
|
|
{&__pyx_n_s__dims_tpl, __pyx_k__dims_tpl, sizeof(__pyx_k__dims_tpl), 0, 0, 1, 1},
|
|
{&__pyx_n_s__id, __pyx_k__id, sizeof(__pyx_k__id), 0, 0, 1, 1},
|
|
{&__pyx_n_s__max_dims_tpl, __pyx_k__max_dims_tpl, sizeof(__pyx_k__max_dims_tpl), 0, 0, 1, 1},
|
|
{&__pyx_n_s__maxdims, __pyx_k__maxdims, sizeof(__pyx_k__maxdims), 0, 0, 1, 1},
|
|
{&__pyx_n_s__nd, __pyx_k__nd, sizeof(__pyx_k__nd), 0, 0, 1, 1},
|
|
{&__pyx_n_s__offset, __pyx_k__offset, sizeof(__pyx_k__offset), 0, 0, 1, 1},
|
|
{&__pyx_n_s__op, __pyx_k__op, sizeof(__pyx_k__op), 0, 0, 1, 1},
|
|
{&__pyx_n_s__start, __pyx_k__start, sizeof(__pyx_k__start), 0, 0, 1, 1},
|
|
{&__pyx_n_s__stride, __pyx_k__stride, sizeof(__pyx_k__stride), 0, 0, 1, 1},
|
|
{0, 0, 0, 0, 0, 0, 0}
|
|
};
|
|
static int __Pyx_InitCachedBuiltins(void) {
|
|
__pyx_builtin_ValueError = __Pyx_GetName(__pyx_b, __pyx_n_s__ValueError); if (!__pyx_builtin_ValueError) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 220; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
return 0;
|
|
__pyx_L1_error:;
|
|
return -1;
|
|
}
|
|
|
|
static int __Pyx_InitGlobals(void) {
|
|
if (__Pyx_InitStrings(__pyx_string_tab) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;};
|
|
return 0;
|
|
__pyx_L1_error:;
|
|
return -1;
|
|
}
|
|
|
|
#if PY_MAJOR_VERSION < 3
|
|
PyMODINIT_FUNC inith5s(void); /*proto*/
|
|
PyMODINIT_FUNC inith5s(void)
|
|
#else
|
|
PyMODINIT_FUNC PyInit_h5s(void); /*proto*/
|
|
PyMODINIT_FUNC PyInit_h5s(void)
|
|
#endif
|
|
{
|
|
PyObject *__pyx_t_1 = NULL;
|
|
PyObject *__pyx_t_2 = NULL;
|
|
int __pyx_t_3;
|
|
PyObject *__pyx_t_4 = NULL;
|
|
#if CYTHON_REFNANNY
|
|
void* __pyx_refnanny = NULL;
|
|
__Pyx_RefNanny = __Pyx_RefNannyImportAPI("refnanny");
|
|
if (!__Pyx_RefNanny) {
|
|
PyErr_Clear();
|
|
__Pyx_RefNanny = __Pyx_RefNannyImportAPI("Cython.Runtime.refnanny");
|
|
if (!__Pyx_RefNanny)
|
|
Py_FatalError("failed to import 'refnanny' module");
|
|
}
|
|
__pyx_refnanny = __Pyx_RefNanny->SetupContext("PyMODINIT_FUNC PyInit_h5s(void)", __LINE__, __FILE__);
|
|
#endif
|
|
__pyx_init_filenames();
|
|
__pyx_empty_tuple = PyTuple_New(0); if (unlikely(!__pyx_empty_tuple)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
#if PY_MAJOR_VERSION < 3
|
|
__pyx_empty_bytes = PyString_FromStringAndSize("", 0); if (unlikely(!__pyx_empty_bytes)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
#else
|
|
__pyx_empty_bytes = PyBytes_FromStringAndSize("", 0); if (unlikely(!__pyx_empty_bytes)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
#endif
|
|
/*--- Library function declarations ---*/
|
|
/*--- Threads initialization code ---*/
|
|
#if defined(__PYX_FORCE_INIT_THREADS) && __PYX_FORCE_INIT_THREADS
|
|
#ifdef WITH_THREAD /* Python build with threading support? */
|
|
PyEval_InitThreads();
|
|
#endif
|
|
#endif
|
|
/*--- Module creation code ---*/
|
|
#if PY_MAJOR_VERSION < 3
|
|
__pyx_m = Py_InitModule4(__Pyx_NAMESTR("h5s"), __pyx_methods, __Pyx_DOCSTR(__pyx_k_8), 0, PYTHON_API_VERSION);
|
|
#else
|
|
__pyx_m = PyModule_Create(&__pyx_moduledef);
|
|
#endif
|
|
if (!__pyx_m) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;};
|
|
#if PY_MAJOR_VERSION < 3
|
|
Py_INCREF(__pyx_m);
|
|
#endif
|
|
__pyx_b = PyImport_AddModule(__Pyx_NAMESTR(__Pyx_BUILTIN_MODULE_NAME));
|
|
if (!__pyx_b) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;};
|
|
if (__Pyx_SetAttrString(__pyx_m, "__builtins__", __pyx_b) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;};
|
|
/*--- Initialize various global constants etc. ---*/
|
|
if (unlikely(__Pyx_InitGlobals() < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
if (__pyx_module_is_main_h5py__h5s) {
|
|
if (__Pyx_SetAttrString(__pyx_m, "__name__", __pyx_n_s____main__) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;};
|
|
}
|
|
/*--- Builtin init code ---*/
|
|
if (unlikely(__Pyx_InitCachedBuiltins() < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
/*--- Global init code ---*/
|
|
/*--- Function export code ---*/
|
|
/*--- Type init code ---*/
|
|
__pyx_ptype_4h5py_2h5_ObjectID = __Pyx_ImportType("h5py.h5", "ObjectID", sizeof(struct __pyx_obj_4h5py_2h5_ObjectID)); if (unlikely(!__pyx_ptype_4h5py_2h5_ObjectID)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_type_4h5py_3h5s_SpaceID.tp_base = __pyx_ptype_4h5py_2h5_ObjectID;
|
|
if (PyType_Ready(&__pyx_type_4h5py_3h5s_SpaceID) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 122; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
if (__Pyx_SetAttrString(__pyx_m, "SpaceID", (PyObject *)&__pyx_type_4h5py_3h5s_SpaceID) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 122; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
if (__pyx_type_4h5py_3h5s_SpaceID.tp_weaklistoffset == 0) __pyx_type_4h5py_3h5s_SpaceID.tp_weaklistoffset = offsetof(struct __pyx_obj_4h5py_3h5s_SpaceID, __pyx_base.__weakref__);
|
|
__pyx_ptype_4h5py_3h5s_SpaceID = &__pyx_type_4h5py_3h5s_SpaceID;
|
|
/*--- Type import code ---*/
|
|
__pyx_ptype_4h5py_2h5_H5PYConfig = __Pyx_ImportType("h5py.h5", "H5PYConfig", sizeof(struct __pyx_obj_4h5py_2h5_H5PYConfig)); if (unlikely(!__pyx_ptype_4h5py_2h5_H5PYConfig)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 15; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_ptype_4h5py_2h5_SmartStruct = __Pyx_ImportType("h5py.h5", "SmartStruct", sizeof(struct __pyx_obj_4h5py_2h5_SmartStruct)); if (unlikely(!__pyx_ptype_4h5py_2h5_SmartStruct)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 35; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_ptype_4h5py_5numpy_dtype = __Pyx_ImportType("numpy", "dtype", sizeof(PyArray_Descr)); if (unlikely(!__pyx_ptype_4h5py_5numpy_dtype)) {__pyx_filename = __pyx_f[2]; __pyx_lineno = 69; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_ptype_4h5py_5numpy_ndarray = __Pyx_ImportType("numpy", "ndarray", sizeof(PyArrayObject)); if (unlikely(!__pyx_ptype_4h5py_5numpy_ndarray)) {__pyx_filename = __pyx_f[2]; __pyx_lineno = 74; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
/*--- Function import code ---*/
|
|
__pyx_t_1 = __Pyx_ImportModule("h5py.h5"); if (!__pyx_t_1) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
if (__Pyx_ImportFunction(__pyx_t_1, "get_config", (void (**)(void))&__pyx_f_4h5py_2h5_get_config, "struct __pyx_obj_4h5py_2h5_H5PYConfig *(int __pyx_skip_dispatch)") < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
if (__Pyx_ImportFunction(__pyx_t_1, "init_hdf5", (void (**)(void))&__pyx_f_4h5py_2h5_init_hdf5, "int (void)") < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
Py_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_t_2 = __Pyx_ImportModule("h5py.utils"); if (!__pyx_t_2) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
if (__Pyx_ImportFunction(__pyx_t_2, "emalloc", (void (**)(void))&__pyx_f_4h5py_5utils_emalloc, "void *(size_t)") < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
if (__Pyx_ImportFunction(__pyx_t_2, "efree", (void (**)(void))&__pyx_f_4h5py_5utils_efree, "void (void *)") < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
if (__Pyx_ImportFunction(__pyx_t_2, "check_numpy_read", (void (**)(void))&__pyx_f_4h5py_5utils_check_numpy_read, "int (PyArrayObject *, int __pyx_skip_dispatch, struct __pyx_opt_args_4h5py_5utils_check_numpy_read *__pyx_optional_args)") < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
if (__Pyx_ImportFunction(__pyx_t_2, "check_numpy_write", (void (**)(void))&__pyx_f_4h5py_5utils_check_numpy_write, "int (PyArrayObject *, int __pyx_skip_dispatch, struct __pyx_opt_args_4h5py_5utils_check_numpy_write *__pyx_optional_args)") < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
if (__Pyx_ImportFunction(__pyx_t_2, "convert_tuple", (void (**)(void))&__pyx_f_4h5py_5utils_convert_tuple, "int (PyObject *, hsize_t *, hsize_t)") < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
if (__Pyx_ImportFunction(__pyx_t_2, "convert_dims", (void (**)(void))&__pyx_f_4h5py_5utils_convert_dims, "PyObject *(hsize_t *, hsize_t)") < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
if (__Pyx_ImportFunction(__pyx_t_2, "require_tuple", (void (**)(void))&__pyx_f_4h5py_5utils_require_tuple, "int (PyObject *, int, int, char *)") < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
if (__Pyx_ImportFunction(__pyx_t_2, "create_numpy_hsize", (void (**)(void))&__pyx_f_4h5py_5utils_create_numpy_hsize, "PyObject *(int, hsize_t *)") < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
if (__Pyx_ImportFunction(__pyx_t_2, "create_hsize_array", (void (**)(void))&__pyx_f_4h5py_5utils_create_hsize_array, "PyObject *(PyObject *)") < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
Py_DECREF(__pyx_t_2); __pyx_t_2 = 0;
|
|
/*--- Execution code ---*/
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":27
|
|
*
|
|
* # Initialization
|
|
* init_hdf5() # <<<<<<<<<<<<<<
|
|
*
|
|
* cdef object lockid(hid_t id_):
|
|
*/
|
|
__pyx_t_3 = __pyx_f_4h5py_2h5_init_hdf5(); if (unlikely(__pyx_t_3 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 27; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":38
|
|
*
|
|
* #enum H5S_seloper_t:
|
|
* SELECT_NOOP = H5S_SELECT_NOOP # <<<<<<<<<<<<<<
|
|
* SELECT_SET = H5S_SELECT_SET
|
|
* SELECT_OR = H5S_SELECT_OR
|
|
*/
|
|
__pyx_t_4 = PyInt_FromLong(H5S_SELECT_NOOP); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 38; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__SELECT_NOOP, __pyx_t_4) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 38; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":39
|
|
* #enum H5S_seloper_t:
|
|
* SELECT_NOOP = H5S_SELECT_NOOP
|
|
* SELECT_SET = H5S_SELECT_SET # <<<<<<<<<<<<<<
|
|
* SELECT_OR = H5S_SELECT_OR
|
|
* SELECT_AND = H5S_SELECT_AND
|
|
*/
|
|
__pyx_t_4 = PyInt_FromLong(H5S_SELECT_SET); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 39; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__SELECT_SET, __pyx_t_4) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 39; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":40
|
|
* SELECT_NOOP = H5S_SELECT_NOOP
|
|
* SELECT_SET = H5S_SELECT_SET
|
|
* SELECT_OR = H5S_SELECT_OR # <<<<<<<<<<<<<<
|
|
* SELECT_AND = H5S_SELECT_AND
|
|
* SELECT_XOR = H5S_SELECT_XOR
|
|
*/
|
|
__pyx_t_4 = PyInt_FromLong(H5S_SELECT_OR); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 40; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__SELECT_OR, __pyx_t_4) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 40; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":41
|
|
* SELECT_SET = H5S_SELECT_SET
|
|
* SELECT_OR = H5S_SELECT_OR
|
|
* SELECT_AND = H5S_SELECT_AND # <<<<<<<<<<<<<<
|
|
* SELECT_XOR = H5S_SELECT_XOR
|
|
* SELECT_NOTB = H5S_SELECT_NOTB
|
|
*/
|
|
__pyx_t_4 = PyInt_FromLong(H5S_SELECT_AND); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 41; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__SELECT_AND, __pyx_t_4) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 41; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":42
|
|
* SELECT_OR = H5S_SELECT_OR
|
|
* SELECT_AND = H5S_SELECT_AND
|
|
* SELECT_XOR = H5S_SELECT_XOR # <<<<<<<<<<<<<<
|
|
* SELECT_NOTB = H5S_SELECT_NOTB
|
|
* SELECT_NOTA = H5S_SELECT_NOTA
|
|
*/
|
|
__pyx_t_4 = PyInt_FromLong(H5S_SELECT_XOR); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 42; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__SELECT_XOR, __pyx_t_4) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 42; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":43
|
|
* SELECT_AND = H5S_SELECT_AND
|
|
* SELECT_XOR = H5S_SELECT_XOR
|
|
* SELECT_NOTB = H5S_SELECT_NOTB # <<<<<<<<<<<<<<
|
|
* SELECT_NOTA = H5S_SELECT_NOTA
|
|
* SELECT_APPEND = H5S_SELECT_APPEND
|
|
*/
|
|
__pyx_t_4 = PyInt_FromLong(H5S_SELECT_NOTB); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 43; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__SELECT_NOTB, __pyx_t_4) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 43; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":44
|
|
* SELECT_XOR = H5S_SELECT_XOR
|
|
* SELECT_NOTB = H5S_SELECT_NOTB
|
|
* SELECT_NOTA = H5S_SELECT_NOTA # <<<<<<<<<<<<<<
|
|
* SELECT_APPEND = H5S_SELECT_APPEND
|
|
* SELECT_PREPEND = H5S_SELECT_PREPEND
|
|
*/
|
|
__pyx_t_4 = PyInt_FromLong(H5S_SELECT_NOTA); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 44; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__SELECT_NOTA, __pyx_t_4) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 44; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":45
|
|
* SELECT_NOTB = H5S_SELECT_NOTB
|
|
* SELECT_NOTA = H5S_SELECT_NOTA
|
|
* SELECT_APPEND = H5S_SELECT_APPEND # <<<<<<<<<<<<<<
|
|
* SELECT_PREPEND = H5S_SELECT_PREPEND
|
|
* SELECT_INVALID = H5S_SELECT_INVALID
|
|
*/
|
|
__pyx_t_4 = PyInt_FromLong(H5S_SELECT_APPEND); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 45; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__SELECT_APPEND, __pyx_t_4) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 45; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":46
|
|
* SELECT_NOTA = H5S_SELECT_NOTA
|
|
* SELECT_APPEND = H5S_SELECT_APPEND
|
|
* SELECT_PREPEND = H5S_SELECT_PREPEND # <<<<<<<<<<<<<<
|
|
* SELECT_INVALID = H5S_SELECT_INVALID
|
|
*
|
|
*/
|
|
__pyx_t_4 = PyInt_FromLong(H5S_SELECT_PREPEND); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 46; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__SELECT_PREPEND, __pyx_t_4) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 46; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":47
|
|
* SELECT_APPEND = H5S_SELECT_APPEND
|
|
* SELECT_PREPEND = H5S_SELECT_PREPEND
|
|
* SELECT_INVALID = H5S_SELECT_INVALID # <<<<<<<<<<<<<<
|
|
*
|
|
* ALL = lockid(H5S_ALL) # This is accepted in lieu of an actual identifier
|
|
*/
|
|
__pyx_t_4 = PyInt_FromLong(H5S_SELECT_INVALID); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 47; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__SELECT_INVALID, __pyx_t_4) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 47; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":49
|
|
* SELECT_INVALID = H5S_SELECT_INVALID
|
|
*
|
|
* ALL = lockid(H5S_ALL) # This is accepted in lieu of an actual identifier # <<<<<<<<<<<<<<
|
|
* # in functions like H5Dread, so wrap it.
|
|
* UNLIMITED = H5S_UNLIMITED
|
|
*/
|
|
__pyx_t_4 = __pyx_f_4h5py_3h5s_lockid(H5S_ALL); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 49; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__ALL, __pyx_t_4) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 49; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":51
|
|
* ALL = lockid(H5S_ALL) # This is accepted in lieu of an actual identifier
|
|
* # in functions like H5Dread, so wrap it.
|
|
* UNLIMITED = H5S_UNLIMITED # <<<<<<<<<<<<<<
|
|
*
|
|
* #enum H5S_class_t
|
|
*/
|
|
__pyx_t_4 = __Pyx_PyInt_to_py_hsize_t(H5S_UNLIMITED); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 51; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__UNLIMITED, __pyx_t_4) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 51; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":54
|
|
*
|
|
* #enum H5S_class_t
|
|
* NO_CLASS = H5S_NO_CLASS # <<<<<<<<<<<<<<
|
|
* SCALAR = H5S_SCALAR
|
|
* SIMPLE = H5S_SIMPLE
|
|
*/
|
|
__pyx_t_4 = PyInt_FromLong(H5S_NO_CLASS); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 54; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__NO_CLASS, __pyx_t_4) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 54; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":55
|
|
* #enum H5S_class_t
|
|
* NO_CLASS = H5S_NO_CLASS
|
|
* SCALAR = H5S_SCALAR # <<<<<<<<<<<<<<
|
|
* SIMPLE = H5S_SIMPLE
|
|
*
|
|
*/
|
|
__pyx_t_4 = PyInt_FromLong(H5S_SCALAR); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 55; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__SCALAR, __pyx_t_4) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 55; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":56
|
|
* NO_CLASS = H5S_NO_CLASS
|
|
* SCALAR = H5S_SCALAR
|
|
* SIMPLE = H5S_SIMPLE # <<<<<<<<<<<<<<
|
|
*
|
|
* #enum H5S_sel_type
|
|
*/
|
|
__pyx_t_4 = PyInt_FromLong(H5S_SIMPLE); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 56; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__SIMPLE, __pyx_t_4) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 56; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":59
|
|
*
|
|
* #enum H5S_sel_type
|
|
* SEL_ERROR = H5S_SEL_ERROR # <<<<<<<<<<<<<<
|
|
* SEL_NONE = H5S_SEL_NONE
|
|
* SEL_POINTS = H5S_SEL_POINTS
|
|
*/
|
|
__pyx_t_4 = PyInt_FromLong(H5S_SEL_ERROR); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 59; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__SEL_ERROR, __pyx_t_4) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 59; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":60
|
|
* #enum H5S_sel_type
|
|
* SEL_ERROR = H5S_SEL_ERROR
|
|
* SEL_NONE = H5S_SEL_NONE # <<<<<<<<<<<<<<
|
|
* SEL_POINTS = H5S_SEL_POINTS
|
|
* SEL_HYPERSLABS = H5S_SEL_HYPERSLABS
|
|
*/
|
|
__pyx_t_4 = PyInt_FromLong(H5S_SEL_NONE); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 60; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__SEL_NONE, __pyx_t_4) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 60; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":61
|
|
* SEL_ERROR = H5S_SEL_ERROR
|
|
* SEL_NONE = H5S_SEL_NONE
|
|
* SEL_POINTS = H5S_SEL_POINTS # <<<<<<<<<<<<<<
|
|
* SEL_HYPERSLABS = H5S_SEL_HYPERSLABS
|
|
* SEL_ALL = H5S_SEL_ALL
|
|
*/
|
|
__pyx_t_4 = PyInt_FromLong(H5S_SEL_POINTS); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 61; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__SEL_POINTS, __pyx_t_4) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 61; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":62
|
|
* SEL_NONE = H5S_SEL_NONE
|
|
* SEL_POINTS = H5S_SEL_POINTS
|
|
* SEL_HYPERSLABS = H5S_SEL_HYPERSLABS # <<<<<<<<<<<<<<
|
|
* SEL_ALL = H5S_SEL_ALL
|
|
*
|
|
*/
|
|
__pyx_t_4 = PyInt_FromLong(H5S_SEL_HYPERSLABS); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 62; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__SEL_HYPERSLABS, __pyx_t_4) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 62; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":63
|
|
* SEL_POINTS = H5S_SEL_POINTS
|
|
* SEL_HYPERSLABS = H5S_SEL_HYPERSLABS
|
|
* SEL_ALL = H5S_SEL_ALL # <<<<<<<<<<<<<<
|
|
*
|
|
* # === Basic dataspace operations ==============================================
|
|
*/
|
|
__pyx_t_4 = PyInt_FromLong(H5S_SEL_ALL); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 63; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__SEL_ALL, __pyx_t_4) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 63; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":449
|
|
*
|
|
*
|
|
* def select_elements(self, object coords, int op=H5S_SELECT_SET): # <<<<<<<<<<<<<<
|
|
* """(SEQUENCE coords, INT op=SELECT_SET)
|
|
*
|
|
*/
|
|
__pyx_k_3 = H5S_SELECT_SET;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5s.pyx":523
|
|
*
|
|
* def select_hyperslab(self, object start, object count, object stride=None,
|
|
* object block=None, int op=H5S_SELECT_SET): # <<<<<<<<<<<<<<
|
|
* """(TUPLE start, TUPLE count, TUPLE stride=None, TUPLE block=None,
|
|
* INT op=SELECT_SET)
|
|
*/
|
|
__pyx_k_6 = H5S_SELECT_SET;
|
|
|
|
/* "/usr/local/lib/python2.6/dist-packages/Cython-0.12-py2.6-linux-x86_64.egg/Cython/Includes/python_ref.pxd":1
|
|
* cdef extern from "Python.h": # <<<<<<<<<<<<<<
|
|
* ctypedef struct PyTypeObject
|
|
* ctypedef struct PyObject:
|
|
*/
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_1);
|
|
__Pyx_XDECREF(__pyx_t_2);
|
|
__Pyx_XDECREF(__pyx_t_4);
|
|
if (__pyx_m) {
|
|
__Pyx_AddTraceback("init h5py.h5s");
|
|
Py_DECREF(__pyx_m); __pyx_m = 0;
|
|
} else if (!PyErr_Occurred()) {
|
|
PyErr_SetString(PyExc_ImportError, "init h5py.h5s");
|
|
}
|
|
__pyx_L0:;
|
|
__Pyx_RefNannyFinishContext();
|
|
#if PY_MAJOR_VERSION < 3
|
|
return;
|
|
#else
|
|
return __pyx_m;
|
|
#endif
|
|
}
|
|
|
|
static const char *__pyx_filenames[] = {
|
|
"h5s.pyx",
|
|
"h5.pxd",
|
|
"numpy.pxd",
|
|
};
|
|
|
|
/* Runtime support code */
|
|
|
|
static void __pyx_init_filenames(void) {
|
|
__pyx_f = __pyx_filenames;
|
|
}
|
|
|
|
static void __Pyx_RaiseDoubleKeywordsError(
|
|
const char* func_name,
|
|
PyObject* kw_name)
|
|
{
|
|
PyErr_Format(PyExc_TypeError,
|
|
#if PY_MAJOR_VERSION >= 3
|
|
"%s() got multiple values for keyword argument '%U'", func_name, kw_name);
|
|
#else
|
|
"%s() got multiple values for keyword argument '%s'", func_name,
|
|
PyString_AS_STRING(kw_name));
|
|
#endif
|
|
}
|
|
|
|
static void __Pyx_RaiseArgtupleInvalid(
|
|
const char* func_name,
|
|
int exact,
|
|
Py_ssize_t num_min,
|
|
Py_ssize_t num_max,
|
|
Py_ssize_t num_found)
|
|
{
|
|
Py_ssize_t num_expected;
|
|
const char *number, *more_or_less;
|
|
|
|
if (num_found < num_min) {
|
|
num_expected = num_min;
|
|
more_or_less = "at least";
|
|
} else {
|
|
num_expected = num_max;
|
|
more_or_less = "at most";
|
|
}
|
|
if (exact) {
|
|
more_or_less = "exactly";
|
|
}
|
|
number = (num_expected == 1) ? "" : "s";
|
|
PyErr_Format(PyExc_TypeError,
|
|
#if PY_VERSION_HEX < 0x02050000
|
|
"%s() takes %s %d positional argument%s (%d given)",
|
|
#else
|
|
"%s() takes %s %zd positional argument%s (%zd given)",
|
|
#endif
|
|
func_name, more_or_less, num_expected, number, num_found);
|
|
}
|
|
|
|
static int __Pyx_ParseOptionalKeywords(
|
|
PyObject *kwds,
|
|
PyObject **argnames[],
|
|
PyObject *kwds2,
|
|
PyObject *values[],
|
|
Py_ssize_t num_pos_args,
|
|
const char* function_name)
|
|
{
|
|
PyObject *key = 0, *value = 0;
|
|
Py_ssize_t pos = 0;
|
|
PyObject*** name;
|
|
PyObject*** first_kw_arg = argnames + num_pos_args;
|
|
|
|
while (PyDict_Next(kwds, &pos, &key, &value)) {
|
|
name = first_kw_arg;
|
|
while (*name && (**name != key)) name++;
|
|
if (*name) {
|
|
values[name-argnames] = value;
|
|
} else {
|
|
#if PY_MAJOR_VERSION < 3
|
|
if (unlikely(!PyString_CheckExact(key)) && unlikely(!PyString_Check(key))) {
|
|
#else
|
|
if (unlikely(!PyUnicode_CheckExact(key)) && unlikely(!PyUnicode_Check(key))) {
|
|
#endif
|
|
goto invalid_keyword_type;
|
|
} else {
|
|
for (name = first_kw_arg; *name; name++) {
|
|
#if PY_MAJOR_VERSION >= 3
|
|
if (PyUnicode_GET_SIZE(**name) == PyUnicode_GET_SIZE(key) &&
|
|
PyUnicode_Compare(**name, key) == 0) break;
|
|
#else
|
|
if (PyString_GET_SIZE(**name) == PyString_GET_SIZE(key) &&
|
|
_PyString_Eq(**name, key)) break;
|
|
#endif
|
|
}
|
|
if (*name) {
|
|
values[name-argnames] = value;
|
|
} else {
|
|
/* unexpected keyword found */
|
|
for (name=argnames; name != first_kw_arg; name++) {
|
|
if (**name == key) goto arg_passed_twice;
|
|
#if PY_MAJOR_VERSION >= 3
|
|
if (PyUnicode_GET_SIZE(**name) == PyUnicode_GET_SIZE(key) &&
|
|
PyUnicode_Compare(**name, key) == 0) goto arg_passed_twice;
|
|
#else
|
|
if (PyString_GET_SIZE(**name) == PyString_GET_SIZE(key) &&
|
|
_PyString_Eq(**name, key)) goto arg_passed_twice;
|
|
#endif
|
|
}
|
|
if (kwds2) {
|
|
if (unlikely(PyDict_SetItem(kwds2, key, value))) goto bad;
|
|
} else {
|
|
goto invalid_keyword;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return 0;
|
|
arg_passed_twice:
|
|
__Pyx_RaiseDoubleKeywordsError(function_name, **name);
|
|
goto bad;
|
|
invalid_keyword_type:
|
|
PyErr_Format(PyExc_TypeError,
|
|
"%s() keywords must be strings", function_name);
|
|
goto bad;
|
|
invalid_keyword:
|
|
PyErr_Format(PyExc_TypeError,
|
|
#if PY_MAJOR_VERSION < 3
|
|
"%s() got an unexpected keyword argument '%s'",
|
|
function_name, PyString_AsString(key));
|
|
#else
|
|
"%s() got an unexpected keyword argument '%U'",
|
|
function_name, key);
|
|
#endif
|
|
bad:
|
|
return -1;
|
|
}
|
|
|
|
static INLINE void __Pyx_ErrRestore(PyObject *type, PyObject *value, PyObject *tb) {
|
|
PyObject *tmp_type, *tmp_value, *tmp_tb;
|
|
PyThreadState *tstate = PyThreadState_GET();
|
|
|
|
tmp_type = tstate->curexc_type;
|
|
tmp_value = tstate->curexc_value;
|
|
tmp_tb = tstate->curexc_traceback;
|
|
tstate->curexc_type = type;
|
|
tstate->curexc_value = value;
|
|
tstate->curexc_traceback = tb;
|
|
Py_XDECREF(tmp_type);
|
|
Py_XDECREF(tmp_value);
|
|
Py_XDECREF(tmp_tb);
|
|
}
|
|
|
|
static INLINE void __Pyx_ErrFetch(PyObject **type, PyObject **value, PyObject **tb) {
|
|
PyThreadState *tstate = PyThreadState_GET();
|
|
*type = tstate->curexc_type;
|
|
*value = tstate->curexc_value;
|
|
*tb = tstate->curexc_traceback;
|
|
|
|
tstate->curexc_type = 0;
|
|
tstate->curexc_value = 0;
|
|
tstate->curexc_traceback = 0;
|
|
}
|
|
|
|
|
|
static INLINE int __Pyx_TypeTest(PyObject *obj, PyTypeObject *type) {
|
|
if (unlikely(!type)) {
|
|
PyErr_Format(PyExc_SystemError, "Missing type object");
|
|
return 0;
|
|
}
|
|
if (likely(PyObject_TypeCheck(obj, type)))
|
|
return 1;
|
|
PyErr_Format(PyExc_TypeError, "Cannot convert %.200s to %.200s",
|
|
Py_TYPE(obj)->tp_name, type->tp_name);
|
|
return 0;
|
|
}
|
|
|
|
static int __Pyx_ArgTypeTest(PyObject *obj, PyTypeObject *type, int none_allowed,
|
|
const char *name, int exact)
|
|
{
|
|
if (!type) {
|
|
PyErr_Format(PyExc_SystemError, "Missing type object");
|
|
return 0;
|
|
}
|
|
if (none_allowed && obj == Py_None) return 1;
|
|
else if (exact) {
|
|
if (Py_TYPE(obj) == type) return 1;
|
|
}
|
|
else {
|
|
if (PyObject_TypeCheck(obj, type)) return 1;
|
|
}
|
|
PyErr_Format(PyExc_TypeError,
|
|
"Argument '%s' has incorrect type (expected %s, got %s)",
|
|
name, type->tp_name, Py_TYPE(obj)->tp_name);
|
|
return 0;
|
|
}
|
|
|
|
static INLINE PyObject *__Pyx_PyInt_to_py_hsize_t(hsize_t val) {
|
|
const hsize_t neg_one = (hsize_t)-1, const_zero = 0;
|
|
const int is_unsigned = neg_one > const_zero;
|
|
if (sizeof(hsize_t) < sizeof(long)) {
|
|
return PyInt_FromLong((long)val);
|
|
} else if (sizeof(hsize_t) == sizeof(long)) {
|
|
if (is_unsigned)
|
|
return PyLong_FromUnsignedLong((unsigned long)val);
|
|
else
|
|
return PyInt_FromLong((long)val);
|
|
} else { /* (sizeof(hsize_t) > sizeof(long)) */
|
|
if (is_unsigned)
|
|
return PyLong_FromUnsignedLongLong((unsigned PY_LONG_LONG)val);
|
|
else
|
|
return PyLong_FromLongLong((PY_LONG_LONG)val);
|
|
}
|
|
}
|
|
|
|
static INLINE PyObject *__Pyx_PyInt_to_py_hid_t(hid_t val) {
|
|
const hid_t neg_one = (hid_t)-1, const_zero = 0;
|
|
const int is_unsigned = neg_one > const_zero;
|
|
if (sizeof(hid_t) < sizeof(long)) {
|
|
return PyInt_FromLong((long)val);
|
|
} else if (sizeof(hid_t) == sizeof(long)) {
|
|
if (is_unsigned)
|
|
return PyLong_FromUnsignedLong((unsigned long)val);
|
|
else
|
|
return PyInt_FromLong((long)val);
|
|
} else { /* (sizeof(hid_t) > sizeof(long)) */
|
|
if (is_unsigned)
|
|
return PyLong_FromUnsignedLongLong((unsigned PY_LONG_LONG)val);
|
|
else
|
|
return PyLong_FromLongLong((PY_LONG_LONG)val);
|
|
}
|
|
}
|
|
|
|
static PyObject *__Pyx_GetName(PyObject *dict, PyObject *name) {
|
|
PyObject *result;
|
|
result = PyObject_GetAttr(dict, name);
|
|
if (!result)
|
|
PyErr_SetObject(PyExc_NameError, name);
|
|
return result;
|
|
}
|
|
|
|
#if PY_MAJOR_VERSION < 3
|
|
static void __Pyx_Raise(PyObject *type, PyObject *value, PyObject *tb) {
|
|
Py_XINCREF(type);
|
|
Py_XINCREF(value);
|
|
Py_XINCREF(tb);
|
|
/* First, check the traceback argument, replacing None with NULL. */
|
|
if (tb == Py_None) {
|
|
Py_DECREF(tb);
|
|
tb = 0;
|
|
}
|
|
else if (tb != NULL && !PyTraceBack_Check(tb)) {
|
|
PyErr_SetString(PyExc_TypeError,
|
|
"raise: arg 3 must be a traceback or None");
|
|
goto raise_error;
|
|
}
|
|
/* Next, replace a missing value with None */
|
|
if (value == NULL) {
|
|
value = Py_None;
|
|
Py_INCREF(value);
|
|
}
|
|
#if PY_VERSION_HEX < 0x02050000
|
|
if (!PyClass_Check(type))
|
|
#else
|
|
if (!PyType_Check(type))
|
|
#endif
|
|
{
|
|
/* Raising an instance. The value should be a dummy. */
|
|
if (value != Py_None) {
|
|
PyErr_SetString(PyExc_TypeError,
|
|
"instance exception may not have a separate value");
|
|
goto raise_error;
|
|
}
|
|
/* Normalize to raise <class>, <instance> */
|
|
Py_DECREF(value);
|
|
value = type;
|
|
#if PY_VERSION_HEX < 0x02050000
|
|
if (PyInstance_Check(type)) {
|
|
type = (PyObject*) ((PyInstanceObject*)type)->in_class;
|
|
Py_INCREF(type);
|
|
}
|
|
else {
|
|
type = 0;
|
|
PyErr_SetString(PyExc_TypeError,
|
|
"raise: exception must be an old-style class or instance");
|
|
goto raise_error;
|
|
}
|
|
#else
|
|
type = (PyObject*) Py_TYPE(type);
|
|
Py_INCREF(type);
|
|
if (!PyType_IsSubtype((PyTypeObject *)type, (PyTypeObject *)PyExc_BaseException)) {
|
|
PyErr_SetString(PyExc_TypeError,
|
|
"raise: exception class must be a subclass of BaseException");
|
|
goto raise_error;
|
|
}
|
|
#endif
|
|
}
|
|
|
|
__Pyx_ErrRestore(type, value, tb);
|
|
return;
|
|
raise_error:
|
|
Py_XDECREF(value);
|
|
Py_XDECREF(type);
|
|
Py_XDECREF(tb);
|
|
return;
|
|
}
|
|
|
|
#else /* Python 3+ */
|
|
|
|
static void __Pyx_Raise(PyObject *type, PyObject *value, PyObject *tb) {
|
|
if (tb == Py_None) {
|
|
tb = 0;
|
|
} else if (tb && !PyTraceBack_Check(tb)) {
|
|
PyErr_SetString(PyExc_TypeError,
|
|
"raise: arg 3 must be a traceback or None");
|
|
goto bad;
|
|
}
|
|
if (value == Py_None)
|
|
value = 0;
|
|
|
|
if (PyExceptionInstance_Check(type)) {
|
|
if (value) {
|
|
PyErr_SetString(PyExc_TypeError,
|
|
"instance exception may not have a separate value");
|
|
goto bad;
|
|
}
|
|
value = type;
|
|
type = (PyObject*) Py_TYPE(value);
|
|
} else if (!PyExceptionClass_Check(type)) {
|
|
PyErr_SetString(PyExc_TypeError,
|
|
"raise: exception class must be a subclass of BaseException");
|
|
goto bad;
|
|
}
|
|
|
|
PyErr_SetObject(type, value);
|
|
|
|
if (tb) {
|
|
PyThreadState *tstate = PyThreadState_GET();
|
|
PyObject* tmp_tb = tstate->curexc_traceback;
|
|
if (tb != tmp_tb) {
|
|
Py_INCREF(tb);
|
|
tstate->curexc_traceback = tb;
|
|
Py_XDECREF(tmp_tb);
|
|
}
|
|
}
|
|
|
|
bad:
|
|
return;
|
|
}
|
|
#endif
|
|
|
|
static INLINE PyObject *__Pyx_PyInt_to_py_hssize_t(hssize_t val) {
|
|
const hssize_t neg_one = (hssize_t)-1, const_zero = 0;
|
|
const int is_unsigned = neg_one > const_zero;
|
|
if (sizeof(hssize_t) < sizeof(long)) {
|
|
return PyInt_FromLong((long)val);
|
|
} else if (sizeof(hssize_t) == sizeof(long)) {
|
|
if (is_unsigned)
|
|
return PyLong_FromUnsignedLong((unsigned long)val);
|
|
else
|
|
return PyInt_FromLong((long)val);
|
|
} else { /* (sizeof(hssize_t) > sizeof(long)) */
|
|
if (is_unsigned)
|
|
return PyLong_FromUnsignedLongLong((unsigned PY_LONG_LONG)val);
|
|
else
|
|
return PyLong_FromLongLong((PY_LONG_LONG)val);
|
|
}
|
|
}
|
|
|
|
static INLINE unsigned char __Pyx_PyInt_AsUnsignedChar(PyObject* x) {
|
|
const unsigned char neg_one = (unsigned char)-1, const_zero = 0;
|
|
const int is_unsigned = neg_one > const_zero;
|
|
if (sizeof(unsigned char) < sizeof(long)) {
|
|
long val = __Pyx_PyInt_AsLong(x);
|
|
if (unlikely(val != (long)(unsigned char)val)) {
|
|
if (!unlikely(val == -1 && PyErr_Occurred())) {
|
|
PyErr_SetString(PyExc_OverflowError,
|
|
(is_unsigned && unlikely(val < 0)) ?
|
|
"can't convert negative value to unsigned char" :
|
|
"value too large to convert to unsigned char");
|
|
}
|
|
return (unsigned char)-1;
|
|
}
|
|
return (unsigned char)val;
|
|
}
|
|
return (unsigned char)__Pyx_PyInt_AsUnsignedLong(x);
|
|
}
|
|
|
|
static INLINE unsigned short __Pyx_PyInt_AsUnsignedShort(PyObject* x) {
|
|
const unsigned short neg_one = (unsigned short)-1, const_zero = 0;
|
|
const int is_unsigned = neg_one > const_zero;
|
|
if (sizeof(unsigned short) < sizeof(long)) {
|
|
long val = __Pyx_PyInt_AsLong(x);
|
|
if (unlikely(val != (long)(unsigned short)val)) {
|
|
if (!unlikely(val == -1 && PyErr_Occurred())) {
|
|
PyErr_SetString(PyExc_OverflowError,
|
|
(is_unsigned && unlikely(val < 0)) ?
|
|
"can't convert negative value to unsigned short" :
|
|
"value too large to convert to unsigned short");
|
|
}
|
|
return (unsigned short)-1;
|
|
}
|
|
return (unsigned short)val;
|
|
}
|
|
return (unsigned short)__Pyx_PyInt_AsUnsignedLong(x);
|
|
}
|
|
|
|
static INLINE unsigned int __Pyx_PyInt_AsUnsignedInt(PyObject* x) {
|
|
const unsigned int neg_one = (unsigned int)-1, const_zero = 0;
|
|
const int is_unsigned = neg_one > const_zero;
|
|
if (sizeof(unsigned int) < sizeof(long)) {
|
|
long val = __Pyx_PyInt_AsLong(x);
|
|
if (unlikely(val != (long)(unsigned int)val)) {
|
|
if (!unlikely(val == -1 && PyErr_Occurred())) {
|
|
PyErr_SetString(PyExc_OverflowError,
|
|
(is_unsigned && unlikely(val < 0)) ?
|
|
"can't convert negative value to unsigned int" :
|
|
"value too large to convert to unsigned int");
|
|
}
|
|
return (unsigned int)-1;
|
|
}
|
|
return (unsigned int)val;
|
|
}
|
|
return (unsigned int)__Pyx_PyInt_AsUnsignedLong(x);
|
|
}
|
|
|
|
static INLINE char __Pyx_PyInt_AsChar(PyObject* x) {
|
|
const char neg_one = (char)-1, const_zero = 0;
|
|
const int is_unsigned = neg_one > const_zero;
|
|
if (sizeof(char) < sizeof(long)) {
|
|
long val = __Pyx_PyInt_AsLong(x);
|
|
if (unlikely(val != (long)(char)val)) {
|
|
if (!unlikely(val == -1 && PyErr_Occurred())) {
|
|
PyErr_SetString(PyExc_OverflowError,
|
|
(is_unsigned && unlikely(val < 0)) ?
|
|
"can't convert negative value to char" :
|
|
"value too large to convert to char");
|
|
}
|
|
return (char)-1;
|
|
}
|
|
return (char)val;
|
|
}
|
|
return (char)__Pyx_PyInt_AsLong(x);
|
|
}
|
|
|
|
static INLINE short __Pyx_PyInt_AsShort(PyObject* x) {
|
|
const short neg_one = (short)-1, const_zero = 0;
|
|
const int is_unsigned = neg_one > const_zero;
|
|
if (sizeof(short) < sizeof(long)) {
|
|
long val = __Pyx_PyInt_AsLong(x);
|
|
if (unlikely(val != (long)(short)val)) {
|
|
if (!unlikely(val == -1 && PyErr_Occurred())) {
|
|
PyErr_SetString(PyExc_OverflowError,
|
|
(is_unsigned && unlikely(val < 0)) ?
|
|
"can't convert negative value to short" :
|
|
"value too large to convert to short");
|
|
}
|
|
return (short)-1;
|
|
}
|
|
return (short)val;
|
|
}
|
|
return (short)__Pyx_PyInt_AsLong(x);
|
|
}
|
|
|
|
static INLINE int __Pyx_PyInt_AsInt(PyObject* x) {
|
|
const int neg_one = (int)-1, const_zero = 0;
|
|
const int is_unsigned = neg_one > const_zero;
|
|
if (sizeof(int) < sizeof(long)) {
|
|
long val = __Pyx_PyInt_AsLong(x);
|
|
if (unlikely(val != (long)(int)val)) {
|
|
if (!unlikely(val == -1 && PyErr_Occurred())) {
|
|
PyErr_SetString(PyExc_OverflowError,
|
|
(is_unsigned && unlikely(val < 0)) ?
|
|
"can't convert negative value to int" :
|
|
"value too large to convert to int");
|
|
}
|
|
return (int)-1;
|
|
}
|
|
return (int)val;
|
|
}
|
|
return (int)__Pyx_PyInt_AsLong(x);
|
|
}
|
|
|
|
static INLINE signed char __Pyx_PyInt_AsSignedChar(PyObject* x) {
|
|
const signed char neg_one = (signed char)-1, const_zero = 0;
|
|
const int is_unsigned = neg_one > const_zero;
|
|
if (sizeof(signed char) < sizeof(long)) {
|
|
long val = __Pyx_PyInt_AsLong(x);
|
|
if (unlikely(val != (long)(signed char)val)) {
|
|
if (!unlikely(val == -1 && PyErr_Occurred())) {
|
|
PyErr_SetString(PyExc_OverflowError,
|
|
(is_unsigned && unlikely(val < 0)) ?
|
|
"can't convert negative value to signed char" :
|
|
"value too large to convert to signed char");
|
|
}
|
|
return (signed char)-1;
|
|
}
|
|
return (signed char)val;
|
|
}
|
|
return (signed char)__Pyx_PyInt_AsSignedLong(x);
|
|
}
|
|
|
|
static INLINE signed short __Pyx_PyInt_AsSignedShort(PyObject* x) {
|
|
const signed short neg_one = (signed short)-1, const_zero = 0;
|
|
const int is_unsigned = neg_one > const_zero;
|
|
if (sizeof(signed short) < sizeof(long)) {
|
|
long val = __Pyx_PyInt_AsLong(x);
|
|
if (unlikely(val != (long)(signed short)val)) {
|
|
if (!unlikely(val == -1 && PyErr_Occurred())) {
|
|
PyErr_SetString(PyExc_OverflowError,
|
|
(is_unsigned && unlikely(val < 0)) ?
|
|
"can't convert negative value to signed short" :
|
|
"value too large to convert to signed short");
|
|
}
|
|
return (signed short)-1;
|
|
}
|
|
return (signed short)val;
|
|
}
|
|
return (signed short)__Pyx_PyInt_AsSignedLong(x);
|
|
}
|
|
|
|
static INLINE signed int __Pyx_PyInt_AsSignedInt(PyObject* x) {
|
|
const signed int neg_one = (signed int)-1, const_zero = 0;
|
|
const int is_unsigned = neg_one > const_zero;
|
|
if (sizeof(signed int) < sizeof(long)) {
|
|
long val = __Pyx_PyInt_AsLong(x);
|
|
if (unlikely(val != (long)(signed int)val)) {
|
|
if (!unlikely(val == -1 && PyErr_Occurred())) {
|
|
PyErr_SetString(PyExc_OverflowError,
|
|
(is_unsigned && unlikely(val < 0)) ?
|
|
"can't convert negative value to signed int" :
|
|
"value too large to convert to signed int");
|
|
}
|
|
return (signed int)-1;
|
|
}
|
|
return (signed int)val;
|
|
}
|
|
return (signed int)__Pyx_PyInt_AsSignedLong(x);
|
|
}
|
|
|
|
static INLINE unsigned long __Pyx_PyInt_AsUnsignedLong(PyObject* x) {
|
|
const unsigned long neg_one = (unsigned long)-1, const_zero = 0;
|
|
const int is_unsigned = neg_one > const_zero;
|
|
#if PY_VERSION_HEX < 0x03000000
|
|
if (likely(PyInt_Check(x))) {
|
|
long val = PyInt_AS_LONG(x);
|
|
if (is_unsigned && unlikely(val < 0)) {
|
|
PyErr_SetString(PyExc_OverflowError,
|
|
"can't convert negative value to unsigned long");
|
|
return (unsigned long)-1;
|
|
}
|
|
return (unsigned long)val;
|
|
} else
|
|
#endif
|
|
if (likely(PyLong_Check(x))) {
|
|
if (is_unsigned) {
|
|
if (unlikely(Py_SIZE(x) < 0)) {
|
|
PyErr_SetString(PyExc_OverflowError,
|
|
"can't convert negative value to unsigned long");
|
|
return (unsigned long)-1;
|
|
}
|
|
return PyLong_AsUnsignedLong(x);
|
|
} else {
|
|
return PyLong_AsLong(x);
|
|
}
|
|
} else {
|
|
unsigned long val;
|
|
PyObject *tmp = __Pyx_PyNumber_Int(x);
|
|
if (!tmp) return (unsigned long)-1;
|
|
val = __Pyx_PyInt_AsUnsignedLong(tmp);
|
|
Py_DECREF(tmp);
|
|
return val;
|
|
}
|
|
}
|
|
|
|
static INLINE unsigned PY_LONG_LONG __Pyx_PyInt_AsUnsignedLongLong(PyObject* x) {
|
|
const unsigned PY_LONG_LONG neg_one = (unsigned PY_LONG_LONG)-1, const_zero = 0;
|
|
const int is_unsigned = neg_one > const_zero;
|
|
#if PY_VERSION_HEX < 0x03000000
|
|
if (likely(PyInt_Check(x))) {
|
|
long val = PyInt_AS_LONG(x);
|
|
if (is_unsigned && unlikely(val < 0)) {
|
|
PyErr_SetString(PyExc_OverflowError,
|
|
"can't convert negative value to unsigned PY_LONG_LONG");
|
|
return (unsigned PY_LONG_LONG)-1;
|
|
}
|
|
return (unsigned PY_LONG_LONG)val;
|
|
} else
|
|
#endif
|
|
if (likely(PyLong_Check(x))) {
|
|
if (is_unsigned) {
|
|
if (unlikely(Py_SIZE(x) < 0)) {
|
|
PyErr_SetString(PyExc_OverflowError,
|
|
"can't convert negative value to unsigned PY_LONG_LONG");
|
|
return (unsigned PY_LONG_LONG)-1;
|
|
}
|
|
return PyLong_AsUnsignedLongLong(x);
|
|
} else {
|
|
return PyLong_AsLongLong(x);
|
|
}
|
|
} else {
|
|
unsigned PY_LONG_LONG val;
|
|
PyObject *tmp = __Pyx_PyNumber_Int(x);
|
|
if (!tmp) return (unsigned PY_LONG_LONG)-1;
|
|
val = __Pyx_PyInt_AsUnsignedLongLong(tmp);
|
|
Py_DECREF(tmp);
|
|
return val;
|
|
}
|
|
}
|
|
|
|
static INLINE long __Pyx_PyInt_AsLong(PyObject* x) {
|
|
const long neg_one = (long)-1, const_zero = 0;
|
|
const int is_unsigned = neg_one > const_zero;
|
|
#if PY_VERSION_HEX < 0x03000000
|
|
if (likely(PyInt_Check(x))) {
|
|
long val = PyInt_AS_LONG(x);
|
|
if (is_unsigned && unlikely(val < 0)) {
|
|
PyErr_SetString(PyExc_OverflowError,
|
|
"can't convert negative value to long");
|
|
return (long)-1;
|
|
}
|
|
return (long)val;
|
|
} else
|
|
#endif
|
|
if (likely(PyLong_Check(x))) {
|
|
if (is_unsigned) {
|
|
if (unlikely(Py_SIZE(x) < 0)) {
|
|
PyErr_SetString(PyExc_OverflowError,
|
|
"can't convert negative value to long");
|
|
return (long)-1;
|
|
}
|
|
return PyLong_AsUnsignedLong(x);
|
|
} else {
|
|
return PyLong_AsLong(x);
|
|
}
|
|
} else {
|
|
long val;
|
|
PyObject *tmp = __Pyx_PyNumber_Int(x);
|
|
if (!tmp) return (long)-1;
|
|
val = __Pyx_PyInt_AsLong(tmp);
|
|
Py_DECREF(tmp);
|
|
return val;
|
|
}
|
|
}
|
|
|
|
static INLINE PY_LONG_LONG __Pyx_PyInt_AsLongLong(PyObject* x) {
|
|
const PY_LONG_LONG neg_one = (PY_LONG_LONG)-1, const_zero = 0;
|
|
const int is_unsigned = neg_one > const_zero;
|
|
#if PY_VERSION_HEX < 0x03000000
|
|
if (likely(PyInt_Check(x))) {
|
|
long val = PyInt_AS_LONG(x);
|
|
if (is_unsigned && unlikely(val < 0)) {
|
|
PyErr_SetString(PyExc_OverflowError,
|
|
"can't convert negative value to PY_LONG_LONG");
|
|
return (PY_LONG_LONG)-1;
|
|
}
|
|
return (PY_LONG_LONG)val;
|
|
} else
|
|
#endif
|
|
if (likely(PyLong_Check(x))) {
|
|
if (is_unsigned) {
|
|
if (unlikely(Py_SIZE(x) < 0)) {
|
|
PyErr_SetString(PyExc_OverflowError,
|
|
"can't convert negative value to PY_LONG_LONG");
|
|
return (PY_LONG_LONG)-1;
|
|
}
|
|
return PyLong_AsUnsignedLongLong(x);
|
|
} else {
|
|
return PyLong_AsLongLong(x);
|
|
}
|
|
} else {
|
|
PY_LONG_LONG val;
|
|
PyObject *tmp = __Pyx_PyNumber_Int(x);
|
|
if (!tmp) return (PY_LONG_LONG)-1;
|
|
val = __Pyx_PyInt_AsLongLong(tmp);
|
|
Py_DECREF(tmp);
|
|
return val;
|
|
}
|
|
}
|
|
|
|
static INLINE signed long __Pyx_PyInt_AsSignedLong(PyObject* x) {
|
|
const signed long neg_one = (signed long)-1, const_zero = 0;
|
|
const int is_unsigned = neg_one > const_zero;
|
|
#if PY_VERSION_HEX < 0x03000000
|
|
if (likely(PyInt_Check(x))) {
|
|
long val = PyInt_AS_LONG(x);
|
|
if (is_unsigned && unlikely(val < 0)) {
|
|
PyErr_SetString(PyExc_OverflowError,
|
|
"can't convert negative value to signed long");
|
|
return (signed long)-1;
|
|
}
|
|
return (signed long)val;
|
|
} else
|
|
#endif
|
|
if (likely(PyLong_Check(x))) {
|
|
if (is_unsigned) {
|
|
if (unlikely(Py_SIZE(x) < 0)) {
|
|
PyErr_SetString(PyExc_OverflowError,
|
|
"can't convert negative value to signed long");
|
|
return (signed long)-1;
|
|
}
|
|
return PyLong_AsUnsignedLong(x);
|
|
} else {
|
|
return PyLong_AsLong(x);
|
|
}
|
|
} else {
|
|
signed long val;
|
|
PyObject *tmp = __Pyx_PyNumber_Int(x);
|
|
if (!tmp) return (signed long)-1;
|
|
val = __Pyx_PyInt_AsSignedLong(tmp);
|
|
Py_DECREF(tmp);
|
|
return val;
|
|
}
|
|
}
|
|
|
|
static INLINE signed PY_LONG_LONG __Pyx_PyInt_AsSignedLongLong(PyObject* x) {
|
|
const signed PY_LONG_LONG neg_one = (signed PY_LONG_LONG)-1, const_zero = 0;
|
|
const int is_unsigned = neg_one > const_zero;
|
|
#if PY_VERSION_HEX < 0x03000000
|
|
if (likely(PyInt_Check(x))) {
|
|
long val = PyInt_AS_LONG(x);
|
|
if (is_unsigned && unlikely(val < 0)) {
|
|
PyErr_SetString(PyExc_OverflowError,
|
|
"can't convert negative value to signed PY_LONG_LONG");
|
|
return (signed PY_LONG_LONG)-1;
|
|
}
|
|
return (signed PY_LONG_LONG)val;
|
|
} else
|
|
#endif
|
|
if (likely(PyLong_Check(x))) {
|
|
if (is_unsigned) {
|
|
if (unlikely(Py_SIZE(x) < 0)) {
|
|
PyErr_SetString(PyExc_OverflowError,
|
|
"can't convert negative value to signed PY_LONG_LONG");
|
|
return (signed PY_LONG_LONG)-1;
|
|
}
|
|
return PyLong_AsUnsignedLongLong(x);
|
|
} else {
|
|
return PyLong_AsLongLong(x);
|
|
}
|
|
} else {
|
|
signed PY_LONG_LONG val;
|
|
PyObject *tmp = __Pyx_PyNumber_Int(x);
|
|
if (!tmp) return (signed PY_LONG_LONG)-1;
|
|
val = __Pyx_PyInt_AsSignedLongLong(tmp);
|
|
Py_DECREF(tmp);
|
|
return val;
|
|
}
|
|
}
|
|
|
|
#ifndef __PYX_HAVE_RT_ImportType
|
|
#define __PYX_HAVE_RT_ImportType
|
|
static PyTypeObject *__Pyx_ImportType(const char *module_name, const char *class_name,
|
|
long size)
|
|
{
|
|
PyObject *py_module = 0;
|
|
PyObject *result = 0;
|
|
PyObject *py_name = 0;
|
|
|
|
py_module = __Pyx_ImportModule(module_name);
|
|
if (!py_module)
|
|
goto bad;
|
|
#if PY_MAJOR_VERSION < 3
|
|
py_name = PyString_FromString(class_name);
|
|
#else
|
|
py_name = PyUnicode_FromString(class_name);
|
|
#endif
|
|
if (!py_name)
|
|
goto bad;
|
|
result = PyObject_GetAttr(py_module, py_name);
|
|
Py_DECREF(py_name);
|
|
py_name = 0;
|
|
Py_DECREF(py_module);
|
|
py_module = 0;
|
|
if (!result)
|
|
goto bad;
|
|
if (!PyType_Check(result)) {
|
|
PyErr_Format(PyExc_TypeError,
|
|
"%s.%s is not a type object",
|
|
module_name, class_name);
|
|
goto bad;
|
|
}
|
|
if (((PyTypeObject *)result)->tp_basicsize != size) {
|
|
PyErr_Format(PyExc_ValueError,
|
|
"%s.%s does not appear to be the correct type object",
|
|
module_name, class_name);
|
|
goto bad;
|
|
}
|
|
return (PyTypeObject *)result;
|
|
bad:
|
|
Py_XDECREF(py_module);
|
|
Py_XDECREF(result);
|
|
return 0;
|
|
}
|
|
#endif
|
|
|
|
#ifndef __PYX_HAVE_RT_ImportModule
|
|
#define __PYX_HAVE_RT_ImportModule
|
|
static PyObject *__Pyx_ImportModule(const char *name) {
|
|
PyObject *py_name = 0;
|
|
PyObject *py_module = 0;
|
|
|
|
#if PY_MAJOR_VERSION < 3
|
|
py_name = PyString_FromString(name);
|
|
#else
|
|
py_name = PyUnicode_FromString(name);
|
|
#endif
|
|
if (!py_name)
|
|
goto bad;
|
|
py_module = PyImport_Import(py_name);
|
|
Py_DECREF(py_name);
|
|
return py_module;
|
|
bad:
|
|
Py_XDECREF(py_name);
|
|
return 0;
|
|
}
|
|
#endif
|
|
|
|
#ifndef __PYX_HAVE_RT_ImportFunction
|
|
#define __PYX_HAVE_RT_ImportFunction
|
|
static int __Pyx_ImportFunction(PyObject *module, const char *funcname, void (**f)(void), const char *sig) {
|
|
PyObject *d = 0;
|
|
PyObject *cobj = 0;
|
|
union {
|
|
void (*fp)(void);
|
|
void *p;
|
|
} tmp;
|
|
#if PY_VERSION_HEX < 0x03010000
|
|
const char *desc, *s1, *s2;
|
|
#endif
|
|
|
|
d = PyObject_GetAttrString(module, (char *)"__pyx_capi__");
|
|
if (!d)
|
|
goto bad;
|
|
cobj = PyDict_GetItemString(d, funcname);
|
|
if (!cobj) {
|
|
PyErr_Format(PyExc_ImportError,
|
|
"%s does not export expected C function %s",
|
|
PyModule_GetName(module), funcname);
|
|
goto bad;
|
|
}
|
|
#if PY_VERSION_HEX < 0x03010000
|
|
desc = (const char *)PyCObject_GetDesc(cobj);
|
|
if (!desc)
|
|
goto bad;
|
|
s1 = desc; s2 = sig;
|
|
while (*s1 != '\0' && *s1 == *s2) { s1++; s2++; }
|
|
if (*s1 != *s2) {
|
|
PyErr_Format(PyExc_TypeError,
|
|
"C function %s.%s has wrong signature (expected %s, got %s)",
|
|
PyModule_GetName(module), funcname, sig, desc);
|
|
goto bad;
|
|
}
|
|
tmp.p = PyCObject_AsVoidPtr(cobj);
|
|
#else
|
|
if (!PyCapsule_IsValid(cobj, sig)) {
|
|
PyErr_Format(PyExc_TypeError,
|
|
"C function %s.%s has wrong signature (expected %s, got %s)",
|
|
PyModule_GetName(module), funcname, sig, PyCapsule_GetName(cobj));
|
|
goto bad;
|
|
}
|
|
tmp.p = PyCapsule_GetPointer(cobj, sig);
|
|
#endif
|
|
*f = tmp.fp;
|
|
if (!(*f))
|
|
goto bad;
|
|
Py_DECREF(d);
|
|
return 0;
|
|
bad:
|
|
Py_XDECREF(d);
|
|
return -1;
|
|
}
|
|
#endif
|
|
|
|
#include "compile.h"
|
|
#include "frameobject.h"
|
|
#include "traceback.h"
|
|
|
|
static void __Pyx_AddTraceback(const char *funcname) {
|
|
PyObject *py_srcfile = 0;
|
|
PyObject *py_funcname = 0;
|
|
PyObject *py_globals = 0;
|
|
PyCodeObject *py_code = 0;
|
|
PyFrameObject *py_frame = 0;
|
|
|
|
#if PY_MAJOR_VERSION < 3
|
|
py_srcfile = PyString_FromString(__pyx_filename);
|
|
#else
|
|
py_srcfile = PyUnicode_FromString(__pyx_filename);
|
|
#endif
|
|
if (!py_srcfile) goto bad;
|
|
if (__pyx_clineno) {
|
|
#if PY_MAJOR_VERSION < 3
|
|
py_funcname = PyString_FromFormat( "%s (%s:%d)", funcname, __pyx_cfilenm, __pyx_clineno);
|
|
#else
|
|
py_funcname = PyUnicode_FromFormat( "%s (%s:%d)", funcname, __pyx_cfilenm, __pyx_clineno);
|
|
#endif
|
|
}
|
|
else {
|
|
#if PY_MAJOR_VERSION < 3
|
|
py_funcname = PyString_FromString(funcname);
|
|
#else
|
|
py_funcname = PyUnicode_FromString(funcname);
|
|
#endif
|
|
}
|
|
if (!py_funcname) goto bad;
|
|
py_globals = PyModule_GetDict(__pyx_m);
|
|
if (!py_globals) goto bad;
|
|
py_code = PyCode_New(
|
|
0, /*int argcount,*/
|
|
#if PY_MAJOR_VERSION >= 3
|
|
0, /*int kwonlyargcount,*/
|
|
#endif
|
|
0, /*int nlocals,*/
|
|
0, /*int stacksize,*/
|
|
0, /*int flags,*/
|
|
__pyx_empty_bytes, /*PyObject *code,*/
|
|
__pyx_empty_tuple, /*PyObject *consts,*/
|
|
__pyx_empty_tuple, /*PyObject *names,*/
|
|
__pyx_empty_tuple, /*PyObject *varnames,*/
|
|
__pyx_empty_tuple, /*PyObject *freevars,*/
|
|
__pyx_empty_tuple, /*PyObject *cellvars,*/
|
|
py_srcfile, /*PyObject *filename,*/
|
|
py_funcname, /*PyObject *name,*/
|
|
__pyx_lineno, /*int firstlineno,*/
|
|
__pyx_empty_bytes /*PyObject *lnotab*/
|
|
);
|
|
if (!py_code) goto bad;
|
|
py_frame = PyFrame_New(
|
|
PyThreadState_GET(), /*PyThreadState *tstate,*/
|
|
py_code, /*PyCodeObject *code,*/
|
|
py_globals, /*PyObject *globals,*/
|
|
0 /*PyObject *locals*/
|
|
);
|
|
if (!py_frame) goto bad;
|
|
py_frame->f_lineno = __pyx_lineno;
|
|
PyTraceBack_Here(py_frame);
|
|
bad:
|
|
Py_XDECREF(py_srcfile);
|
|
Py_XDECREF(py_funcname);
|
|
Py_XDECREF(py_code);
|
|
Py_XDECREF(py_frame);
|
|
}
|
|
|
|
static int __Pyx_InitStrings(__Pyx_StringTabEntry *t) {
|
|
while (t->p) {
|
|
#if PY_MAJOR_VERSION < 3
|
|
if (t->is_unicode) {
|
|
*t->p = PyUnicode_DecodeUTF8(t->s, t->n - 1, NULL);
|
|
} else if (t->intern) {
|
|
*t->p = PyString_InternFromString(t->s);
|
|
} else {
|
|
*t->p = PyString_FromStringAndSize(t->s, t->n - 1);
|
|
}
|
|
#else /* Python 3+ has unicode identifiers */
|
|
if (t->is_unicode | t->is_str) {
|
|
if (t->intern) {
|
|
*t->p = PyUnicode_InternFromString(t->s);
|
|
} else if (t->encoding) {
|
|
*t->p = PyUnicode_Decode(t->s, t->n - 1, t->encoding, NULL);
|
|
} else {
|
|
*t->p = PyUnicode_FromStringAndSize(t->s, t->n - 1);
|
|
}
|
|
} else {
|
|
*t->p = PyBytes_FromStringAndSize(t->s, t->n - 1);
|
|
}
|
|
#endif
|
|
if (!*t->p)
|
|
return -1;
|
|
++t;
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
/* Type Conversion Functions */
|
|
|
|
static INLINE int __Pyx_PyObject_IsTrue(PyObject* x) {
|
|
if (x == Py_True) return 1;
|
|
else if ((x == Py_False) | (x == Py_None)) return 0;
|
|
else return PyObject_IsTrue(x);
|
|
}
|
|
|
|
static INLINE PyObject* __Pyx_PyNumber_Int(PyObject* x) {
|
|
PyNumberMethods *m;
|
|
const char *name = NULL;
|
|
PyObject *res = NULL;
|
|
#if PY_VERSION_HEX < 0x03000000
|
|
if (PyInt_Check(x) || PyLong_Check(x))
|
|
#else
|
|
if (PyLong_Check(x))
|
|
#endif
|
|
return Py_INCREF(x), x;
|
|
m = Py_TYPE(x)->tp_as_number;
|
|
#if PY_VERSION_HEX < 0x03000000
|
|
if (m && m->nb_int) {
|
|
name = "int";
|
|
res = PyNumber_Int(x);
|
|
}
|
|
else if (m && m->nb_long) {
|
|
name = "long";
|
|
res = PyNumber_Long(x);
|
|
}
|
|
#else
|
|
if (m && m->nb_int) {
|
|
name = "int";
|
|
res = PyNumber_Long(x);
|
|
}
|
|
#endif
|
|
if (res) {
|
|
#if PY_VERSION_HEX < 0x03000000
|
|
if (!PyInt_Check(res) && !PyLong_Check(res)) {
|
|
#else
|
|
if (!PyLong_Check(res)) {
|
|
#endif
|
|
PyErr_Format(PyExc_TypeError,
|
|
"__%s__ returned non-%s (type %.200s)",
|
|
name, name, Py_TYPE(res)->tp_name);
|
|
Py_DECREF(res);
|
|
return NULL;
|
|
}
|
|
}
|
|
else if (!PyErr_Occurred()) {
|
|
PyErr_SetString(PyExc_TypeError,
|
|
"an integer is required");
|
|
}
|
|
return res;
|
|
}
|
|
|
|
static INLINE Py_ssize_t __Pyx_PyIndex_AsSsize_t(PyObject* b) {
|
|
Py_ssize_t ival;
|
|
PyObject* x = PyNumber_Index(b);
|
|
if (!x) return -1;
|
|
ival = PyInt_AsSsize_t(x);
|
|
Py_DECREF(x);
|
|
return ival;
|
|
}
|
|
|
|
static INLINE PyObject * __Pyx_PyInt_FromSize_t(size_t ival) {
|
|
#if PY_VERSION_HEX < 0x02050000
|
|
if (ival <= LONG_MAX)
|
|
return PyInt_FromLong((long)ival);
|
|
else {
|
|
unsigned char *bytes = (unsigned char *) &ival;
|
|
int one = 1; int little = (int)*(unsigned char*)&one;
|
|
return _PyLong_FromByteArray(bytes, sizeof(size_t), little, 0);
|
|
}
|
|
#else
|
|
return PyInt_FromSize_t(ival);
|
|
#endif
|
|
}
|
|
|
|
static INLINE size_t __Pyx_PyInt_AsSize_t(PyObject* x) {
|
|
unsigned PY_LONG_LONG val = __Pyx_PyInt_AsUnsignedLongLong(x);
|
|
if (unlikely(val == (unsigned PY_LONG_LONG)-1 && PyErr_Occurred())) {
|
|
return (size_t)-1;
|
|
} else if (unlikely(val != (unsigned PY_LONG_LONG)(size_t)val)) {
|
|
PyErr_SetString(PyExc_OverflowError,
|
|
"value too large to convert to size_t");
|
|
return (size_t)-1;
|
|
}
|
|
return (size_t)val;
|
|
}
|
|
|
|
|
|
#endif /* Py_PYTHON_H */
|