awips2/pythonPackages/h5py/api16/h5s.c
root 7dbd17a5aa Initial revision of AWIPS2 11.9.0-7p5
Former-commit-id: 133dc97f67 [formerly a02aeb236c] [formerly 9f19e3f712] [formerly 133dc97f67 [formerly a02aeb236c] [formerly 9f19e3f712] [formerly 06a8b51d6d [formerly 9f19e3f712 [formerly 64fa9254b946eae7e61bbc3f513b7c3696c4f54f]]]]
Former-commit-id: 06a8b51d6d
Former-commit-id: 9bb8decbcf [formerly 8e80217e59] [formerly 377dcd10b9 [formerly 3360eb6c5f]]
Former-commit-id: 377dcd10b9
Former-commit-id: e2ecdcfe33
2012-01-06 08:55:05 -06:00

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 */