Former-commit-id:9f19e3f712
[formerly9f19e3f712
[formerly 64fa9254b946eae7e61bbc3f513b7c3696c4f54f]] Former-commit-id:06a8b51d6d
Former-commit-id:3360eb6c5f
5830 lines
229 KiB
C
Executable file
5830 lines
229 KiB
C
Executable file
/* Generated by Cython 0.12 on Sun Mar 14 21:50:01 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__h5g
|
|
#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/h5e.pxd":33
|
|
* # Safe to call more than once.
|
|
* cpdef object register_thread()
|
|
* cpdef object unregister_thread(HDF5ErrorHandler handler=*) # <<<<<<<<<<<<<<
|
|
*
|
|
* cdef extern from "hdf5.h":
|
|
*/
|
|
|
|
struct __pyx_opt_args_4h5py_3h5e_unregister_thread {
|
|
int __pyx_n;
|
|
struct __pyx_obj_4h5py_3h5e_HDF5ErrorHandler *handler;
|
|
};
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5e.pxd":249
|
|
* herr_t H5Ewalk(H5E_direction_t direction, H5E_walk_t func, void* client_data)
|
|
*
|
|
* ctypedef struct err_cookie: # <<<<<<<<<<<<<<
|
|
* H5E_auto_t func
|
|
* void* data
|
|
*/
|
|
|
|
typedef struct {
|
|
H5E_auto_t func;
|
|
void *data;
|
|
} __pyx_t_4h5py_3h5e_err_cookie;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":89
|
|
*
|
|
*
|
|
* cdef class GroupIter: # <<<<<<<<<<<<<<
|
|
*
|
|
* """
|
|
*/
|
|
|
|
struct __pyx_obj_4h5py_3h5g_GroupIter {
|
|
PyObject_HEAD
|
|
unsigned long idx;
|
|
unsigned long nobjs;
|
|
struct __pyx_obj_4h5py_3h5g_GroupID *grp;
|
|
};
|
|
|
|
/* "/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/h5g.pxd":18
|
|
* from h5 cimport ObjectID
|
|
*
|
|
* cdef class GroupID(ObjectID): # <<<<<<<<<<<<<<
|
|
*
|
|
* IF H5PY_18API:
|
|
*/
|
|
|
|
struct __pyx_obj_4h5py_3h5g_GroupID {
|
|
struct __pyx_obj_4h5py_2h5_ObjectID __pyx_base;
|
|
};
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5p.pxd":23
|
|
* # --- Base classes ---
|
|
*
|
|
* cdef class PropID(ObjectID): # <<<<<<<<<<<<<<
|
|
* """ Base class for all property lists """
|
|
* pass
|
|
*/
|
|
|
|
struct __pyx_obj_4h5py_3h5p_PropID {
|
|
struct __pyx_obj_4h5py_2h5_ObjectID __pyx_base;
|
|
};
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5p.pxd":33
|
|
* pass
|
|
*
|
|
* cdef class PropInstanceID(PropID): # <<<<<<<<<<<<<<
|
|
* """ Represents an instance of a property list class (i.e. an actual list
|
|
* which can be passed on to other API functions).
|
|
*/
|
|
|
|
struct __pyx_obj_4h5py_3h5p_PropInstanceID {
|
|
struct __pyx_obj_4h5py_3h5p_PropID __pyx_base;
|
|
};
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5p.pxd":62
|
|
* # --- Object access ---
|
|
*
|
|
* cdef class PropFAID(PropInstanceID): # <<<<<<<<<<<<<<
|
|
* """ File access property list """
|
|
* pass
|
|
*/
|
|
|
|
struct __pyx_obj_4h5py_3h5p_PropFAID {
|
|
struct __pyx_obj_4h5py_3h5p_PropInstanceID __pyx_base;
|
|
};
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5p.pxd":39
|
|
* pass
|
|
*
|
|
* cdef class PropCreateID(PropInstanceID): # <<<<<<<<<<<<<<
|
|
* """ Base class for all object creation lists.
|
|
*
|
|
*/
|
|
|
|
struct __pyx_obj_4h5py_3h5p_PropCreateID {
|
|
struct __pyx_obj_4h5py_3h5p_PropInstanceID __pyx_base;
|
|
};
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5p.pxd":66
|
|
* pass
|
|
*
|
|
* cdef class PropDXID(PropInstanceID): # <<<<<<<<<<<<<<
|
|
* """ Dataset transfer property list """
|
|
* pass
|
|
*/
|
|
|
|
struct __pyx_obj_4h5py_3h5p_PropDXID {
|
|
struct __pyx_obj_4h5py_3h5p_PropInstanceID __pyx_base;
|
|
};
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5p.pxd":51
|
|
* # --- Object creation ---
|
|
*
|
|
* cdef class PropDCID(PropCreateID): # <<<<<<<<<<<<<<
|
|
* """ Dataset creation property list """
|
|
* pass
|
|
*/
|
|
|
|
struct __pyx_obj_4h5py_3h5p_PropDCID {
|
|
struct __pyx_obj_4h5py_3h5p_PropCreateID __pyx_base;
|
|
};
|
|
|
|
/* "/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;
|
|
};
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":159
|
|
* return GroupID(H5Gcreate(loc.id, name, -1))
|
|
*
|
|
* cdef class _GroupVisitor: # <<<<<<<<<<<<<<
|
|
*
|
|
* cdef object func
|
|
*/
|
|
|
|
struct __pyx_obj_4h5py_3h5g__GroupVisitor {
|
|
PyObject_HEAD
|
|
PyObject *func;
|
|
PyObject *retval;
|
|
};
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5p.pxd":55
|
|
* pass
|
|
*
|
|
* cdef class PropFCID(PropCreateID): # <<<<<<<<<<<<<<
|
|
* """ File creation property list """
|
|
* pass
|
|
*/
|
|
|
|
struct __pyx_obj_4h5py_3h5p_PropFCID {
|
|
struct __pyx_obj_4h5py_3h5p_PropCreateID __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/h5p.pxd":27
|
|
* pass
|
|
*
|
|
* cdef class PropClassID(PropID): # <<<<<<<<<<<<<<
|
|
* """ Represents an HDF5 property list class. These can be either (locked)
|
|
* library-defined classes or user-created classes.
|
|
*/
|
|
|
|
struct __pyx_obj_4h5py_3h5p_PropClassID {
|
|
struct __pyx_obj_4h5py_3h5p_PropID __pyx_base;
|
|
};
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5e.pxd":20
|
|
* include "defs.pxd"
|
|
*
|
|
* cdef class HDF5ErrorHandler: # <<<<<<<<<<<<<<
|
|
*
|
|
* """
|
|
*/
|
|
|
|
struct __pyx_obj_4h5py_3h5e_HDF5ErrorHandler {
|
|
PyObject_HEAD
|
|
void *__pyx_auto;
|
|
void *data;
|
|
};
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5p.pxd":46
|
|
* pass
|
|
*
|
|
* cdef class PropCopyID(PropInstanceID): # <<<<<<<<<<<<<<
|
|
* """ Property list for copying objects (as in h5o.copy) """
|
|
*
|
|
*/
|
|
|
|
struct __pyx_obj_4h5py_3h5p_PropCopyID {
|
|
struct __pyx_obj_4h5py_3h5p_PropInstanceID __pyx_base;
|
|
};
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":47
|
|
* LINK_SOFT = H5G_LINK_SOFT
|
|
*
|
|
* cdef class GroupStat(SmartStruct): # <<<<<<<<<<<<<<
|
|
* """Represents the H5G_stat_t structure containing group member info.
|
|
*
|
|
*/
|
|
|
|
struct __pyx_obj_4h5py_3h5g_GroupStat {
|
|
struct __pyx_obj_4h5py_2h5_SmartStruct __pyx_base;
|
|
H5G_stat_t infostruct;
|
|
};
|
|
|
|
#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 int __Pyx_ArgTypeTest(PyObject *obj, PyTypeObject *type, int none_allowed,
|
|
const char *name, int exact); /*proto*/
|
|
|
|
static PyObject *__Pyx_Import(PyObject *name, PyObject *from_list); /*proto*/
|
|
|
|
static INLINE PyObject *__Pyx_PyInt_to_py_time_t(time_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_hid_t(hid_t);
|
|
|
|
static INLINE PyObject *__Pyx_PyInt_to_py_hsize_t(hsize_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 INLINE hsize_t __Pyx_PyInt_from_py_hsize_t(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 h5py.h5p */
|
|
|
|
static PyTypeObject *__pyx_ptype_4h5py_3h5p_PropID = 0;
|
|
static PyTypeObject *__pyx_ptype_4h5py_3h5p_PropClassID = 0;
|
|
static PyTypeObject *__pyx_ptype_4h5py_3h5p_PropInstanceID = 0;
|
|
static PyTypeObject *__pyx_ptype_4h5py_3h5p_PropCreateID = 0;
|
|
static PyTypeObject *__pyx_ptype_4h5py_3h5p_PropCopyID = 0;
|
|
static PyTypeObject *__pyx_ptype_4h5py_3h5p_PropDCID = 0;
|
|
static PyTypeObject *__pyx_ptype_4h5py_3h5p_PropFCID = 0;
|
|
static PyTypeObject *__pyx_ptype_4h5py_3h5p_PropFAID = 0;
|
|
static PyTypeObject *__pyx_ptype_4h5py_3h5p_PropDXID = 0;
|
|
static hid_t (*__pyx_f_4h5py_3h5p_pdefault)(struct __pyx_obj_4h5py_3h5p_PropID *); /*proto*/
|
|
static PyObject *(*__pyx_f_4h5py_3h5p_propwrap)(hid_t); /*proto*/
|
|
/* Module declarations from h5py.h5e */
|
|
|
|
static PyTypeObject *__pyx_ptype_4h5py_3h5e_HDF5ErrorHandler = 0;
|
|
static PyObject *(*__pyx_f_4h5py_3h5e_register_thread)(int __pyx_skip_dispatch); /*proto*/
|
|
static PyObject *(*__pyx_f_4h5py_3h5e_unregister_thread)(int __pyx_skip_dispatch, struct __pyx_opt_args_4h5py_3h5e_unregister_thread *__pyx_optional_args); /*proto*/
|
|
static __pyx_t_4h5py_3h5e_err_cookie (*__pyx_f_4h5py_3h5e_disable_errors)(void); /*proto*/
|
|
static void (*__pyx_f_4h5py_3h5e_enable_errors)(__pyx_t_4h5py_3h5e_err_cookie); /*proto*/
|
|
/* Module declarations from h5py.h5g */
|
|
|
|
static PyTypeObject *__pyx_ptype_4h5py_3h5g_GroupID = 0;
|
|
static PyTypeObject *__pyx_ptype_4h5py_3h5g_GroupStat = 0;
|
|
static PyTypeObject *__pyx_ptype_4h5py_3h5g_GroupIter = 0;
|
|
static PyTypeObject *__pyx_ptype_4h5py_3h5g__GroupVisitor = 0;
|
|
static herr_t __pyx_f_4h5py_3h5g_cb_group_iter(hid_t, char *, void *); /*proto*/
|
|
#define __Pyx_MODULE_NAME "h5py.h5g"
|
|
int __pyx_module_is_main_h5py__h5g = 0;
|
|
|
|
/* Implementation of h5py.h5g */
|
|
static PyObject *__pyx_builtin_StopIteration;
|
|
static PyObject *__pyx_builtin_ValueError;
|
|
static char __pyx_k_1[] = ".";
|
|
static char __pyx_k_2[] = "Starting index must be non-negative";
|
|
static char __pyx_k_4[] = "Invalid index";
|
|
static char __pyx_k_5[] = "\"%s\" is not a symbolic link.";
|
|
static char __pyx_k_6[] = "\n Low-level HDF5 \"H5G\" group interface.\n";
|
|
static char __pyx_k__h5[] = "h5";
|
|
static char __pyx_k__id[] = "id";
|
|
static char __pyx_k__grp[] = "grp";
|
|
static char __pyx_k__idx[] = "idx";
|
|
static char __pyx_k__loc[] = "loc";
|
|
static char __pyx_k__obj[] = "obj";
|
|
static char __pyx_k__LINK[] = "LINK";
|
|
static char __pyx_k__TYPE[] = "TYPE";
|
|
static char __pyx_k__func[] = "func";
|
|
static char __pyx_k__name[] = "name";
|
|
static char __pyx_k__type[] = "type";
|
|
static char __pyx_k__GROUP[] = "GROUP";
|
|
static char __pyx_k__mtime[] = "mtime";
|
|
static char __pyx_k__nlink[] = "nlink";
|
|
static char __pyx_k__nobjs[] = "nobjs";
|
|
static char __pyx_k__objno[] = "objno";
|
|
static char __pyx_k__fileno[] = "fileno";
|
|
static char __pyx_k__remote[] = "remote";
|
|
static char __pyx_k__retval[] = "retval";
|
|
static char __pyx_k__DATASET[] = "DATASET";
|
|
static char __pyx_k__H5Error[] = "H5Error";
|
|
static char __pyx_k__UNKNOWN[] = "UNKNOWN";
|
|
static char __pyx_k__comment[] = "comment";
|
|
static char __pyx_k__linklen[] = "linklen";
|
|
static char __pyx_k____main__[] = "__main__";
|
|
static char __pyx_k__new_name[] = "new_name";
|
|
static char __pyx_k__obj_name[] = "obj_name";
|
|
static char __pyx_k__startidx[] = "startidx";
|
|
static char __pyx_k__LINK_HARD[] = "LINK_HARD";
|
|
static char __pyx_k__LINK_SOFT[] = "LINK_SOFT";
|
|
static char __pyx_k__link_type[] = "link_type";
|
|
static char __pyx_k__LINK_ERROR[] = "LINK_ERROR";
|
|
static char __pyx_k__ValueError[] = "ValueError";
|
|
static char __pyx_k__infostruct[] = "infostruct";
|
|
static char __pyx_k__follow_link[] = "follow_link";
|
|
static char __pyx_k__current_name[] = "current_name";
|
|
static char __pyx_k__get_num_objs[] = "get_num_objs";
|
|
static char __pyx_k__StopIteration[] = "StopIteration";
|
|
static char __pyx_k__get_objname_by_idx[] = "get_objname_by_idx";
|
|
static PyObject *__pyx_kp_s_1;
|
|
static PyObject *__pyx_kp_s_2;
|
|
static PyObject *__pyx_kp_s_4;
|
|
static PyObject *__pyx_kp_s_5;
|
|
static PyObject *__pyx_n_s__DATASET;
|
|
static PyObject *__pyx_n_s__GROUP;
|
|
static PyObject *__pyx_n_s__H5Error;
|
|
static PyObject *__pyx_n_s__LINK;
|
|
static PyObject *__pyx_n_s__LINK_ERROR;
|
|
static PyObject *__pyx_n_s__LINK_HARD;
|
|
static PyObject *__pyx_n_s__LINK_SOFT;
|
|
static PyObject *__pyx_n_s__StopIteration;
|
|
static PyObject *__pyx_n_s__TYPE;
|
|
static PyObject *__pyx_n_s__UNKNOWN;
|
|
static PyObject *__pyx_n_s__ValueError;
|
|
static PyObject *__pyx_n_s____main__;
|
|
static PyObject *__pyx_n_s__comment;
|
|
static PyObject *__pyx_n_s__current_name;
|
|
static PyObject *__pyx_n_s__fileno;
|
|
static PyObject *__pyx_n_s__follow_link;
|
|
static PyObject *__pyx_n_s__func;
|
|
static PyObject *__pyx_n_s__get_num_objs;
|
|
static PyObject *__pyx_n_s__get_objname_by_idx;
|
|
static PyObject *__pyx_n_s__grp;
|
|
static PyObject *__pyx_n_s__h5;
|
|
static PyObject *__pyx_n_s__id;
|
|
static PyObject *__pyx_n_s__idx;
|
|
static PyObject *__pyx_n_s__infostruct;
|
|
static PyObject *__pyx_n_s__link_type;
|
|
static PyObject *__pyx_n_s__linklen;
|
|
static PyObject *__pyx_n_s__loc;
|
|
static PyObject *__pyx_n_s__mtime;
|
|
static PyObject *__pyx_n_s__name;
|
|
static PyObject *__pyx_n_s__new_name;
|
|
static PyObject *__pyx_n_s__nlink;
|
|
static PyObject *__pyx_n_s__nobjs;
|
|
static PyObject *__pyx_n_s__obj;
|
|
static PyObject *__pyx_n_s__obj_name;
|
|
static PyObject *__pyx_n_s__objno;
|
|
static PyObject *__pyx_n_s__remote;
|
|
static PyObject *__pyx_n_s__retval;
|
|
static PyObject *__pyx_n_s__startidx;
|
|
static PyObject *__pyx_n_s__type;
|
|
static PyObject *__pyx_int_1;
|
|
static int __pyx_k_3;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":67
|
|
*
|
|
* property fileno:
|
|
* def __get__(self): # <<<<<<<<<<<<<<
|
|
* return (self.infostruct.fileno[0], self.infostruct.fileno[1])
|
|
* property objno:
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5g_9GroupStat_6fileno___get__(PyObject *__pyx_v_self); /*proto*/
|
|
static PyObject *__pyx_pf_4h5py_3h5g_9GroupStat_6fileno___get__(PyObject *__pyx_v_self) {
|
|
PyObject *__pyx_r = NULL;
|
|
PyObject *__pyx_t_1 = NULL;
|
|
PyObject *__pyx_t_2 = NULL;
|
|
PyObject *__pyx_t_3 = NULL;
|
|
__Pyx_RefNannySetupContext("__get__");
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":68
|
|
* property fileno:
|
|
* def __get__(self):
|
|
* return (self.infostruct.fileno[0], self.infostruct.fileno[1]) # <<<<<<<<<<<<<<
|
|
* property objno:
|
|
* def __get__(self):
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_1 = PyLong_FromUnsignedLong((((struct __pyx_obj_4h5py_3h5g_GroupStat *)__pyx_v_self)->infostruct.fileno[0])); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 68; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_2 = PyLong_FromUnsignedLong((((struct __pyx_obj_4h5py_3h5g_GroupStat *)__pyx_v_self)->infostruct.fileno[1])); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 68; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__pyx_t_3 = PyTuple_New(2); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 68; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_1);
|
|
__Pyx_GIVEREF(__pyx_t_1);
|
|
PyTuple_SET_ITEM(__pyx_t_3, 1, __pyx_t_2);
|
|
__Pyx_GIVEREF(__pyx_t_2);
|
|
__pyx_t_1 = 0;
|
|
__pyx_t_2 = 0;
|
|
__pyx_r = __pyx_t_3;
|
|
__pyx_t_3 = 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_XDECREF(__pyx_t_3);
|
|
__Pyx_AddTraceback("h5py.h5g.GroupStat.fileno.__get__");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":70
|
|
* return (self.infostruct.fileno[0], self.infostruct.fileno[1])
|
|
* property objno:
|
|
* def __get__(self): # <<<<<<<<<<<<<<
|
|
* return (self.infostruct.objno[0], self.infostruct.objno[1])
|
|
* property nlink:
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5g_9GroupStat_5objno___get__(PyObject *__pyx_v_self); /*proto*/
|
|
static PyObject *__pyx_pf_4h5py_3h5g_9GroupStat_5objno___get__(PyObject *__pyx_v_self) {
|
|
PyObject *__pyx_r = NULL;
|
|
PyObject *__pyx_t_1 = NULL;
|
|
PyObject *__pyx_t_2 = NULL;
|
|
PyObject *__pyx_t_3 = NULL;
|
|
__Pyx_RefNannySetupContext("__get__");
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":71
|
|
* property objno:
|
|
* def __get__(self):
|
|
* return (self.infostruct.objno[0], self.infostruct.objno[1]) # <<<<<<<<<<<<<<
|
|
* property nlink:
|
|
* def __get__(self):
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_1 = PyLong_FromUnsignedLong((((struct __pyx_obj_4h5py_3h5g_GroupStat *)__pyx_v_self)->infostruct.objno[0])); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 71; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_2 = PyLong_FromUnsignedLong((((struct __pyx_obj_4h5py_3h5g_GroupStat *)__pyx_v_self)->infostruct.objno[1])); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 71; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__pyx_t_3 = PyTuple_New(2); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 71; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_1);
|
|
__Pyx_GIVEREF(__pyx_t_1);
|
|
PyTuple_SET_ITEM(__pyx_t_3, 1, __pyx_t_2);
|
|
__Pyx_GIVEREF(__pyx_t_2);
|
|
__pyx_t_1 = 0;
|
|
__pyx_t_2 = 0;
|
|
__pyx_r = __pyx_t_3;
|
|
__pyx_t_3 = 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_XDECREF(__pyx_t_3);
|
|
__Pyx_AddTraceback("h5py.h5g.GroupStat.objno.__get__");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":73
|
|
* return (self.infostruct.objno[0], self.infostruct.objno[1])
|
|
* property nlink:
|
|
* def __get__(self): # <<<<<<<<<<<<<<
|
|
* return self.infostruct.nlink
|
|
* property type:
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5g_9GroupStat_5nlink___get__(PyObject *__pyx_v_self); /*proto*/
|
|
static PyObject *__pyx_pf_4h5py_3h5g_9GroupStat_5nlink___get__(PyObject *__pyx_v_self) {
|
|
PyObject *__pyx_r = NULL;
|
|
PyObject *__pyx_t_1 = NULL;
|
|
__Pyx_RefNannySetupContext("__get__");
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":74
|
|
* property nlink:
|
|
* def __get__(self):
|
|
* return self.infostruct.nlink # <<<<<<<<<<<<<<
|
|
* property type:
|
|
* def __get__(self):
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_1 = PyLong_FromUnsignedLong(((struct __pyx_obj_4h5py_3h5g_GroupStat *)__pyx_v_self)->infostruct.nlink); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 74; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_r = __pyx_t_1;
|
|
__pyx_t_1 = 0;
|
|
goto __pyx_L0;
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_1);
|
|
__Pyx_AddTraceback("h5py.h5g.GroupStat.nlink.__get__");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":76
|
|
* return self.infostruct.nlink
|
|
* property type:
|
|
* def __get__(self): # <<<<<<<<<<<<<<
|
|
* return self.infostruct.type
|
|
* property mtime:
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5g_9GroupStat_4type___get__(PyObject *__pyx_v_self); /*proto*/
|
|
static PyObject *__pyx_pf_4h5py_3h5g_9GroupStat_4type___get__(PyObject *__pyx_v_self) {
|
|
PyObject *__pyx_r = NULL;
|
|
PyObject *__pyx_t_1 = NULL;
|
|
__Pyx_RefNannySetupContext("__get__");
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":77
|
|
* property type:
|
|
* def __get__(self):
|
|
* return self.infostruct.type # <<<<<<<<<<<<<<
|
|
* property mtime:
|
|
* def __get__(self):
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_1 = PyInt_FromLong(((struct __pyx_obj_4h5py_3h5g_GroupStat *)__pyx_v_self)->infostruct.type); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 77; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_r = __pyx_t_1;
|
|
__pyx_t_1 = 0;
|
|
goto __pyx_L0;
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_1);
|
|
__Pyx_AddTraceback("h5py.h5g.GroupStat.type.__get__");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":79
|
|
* return self.infostruct.type
|
|
* property mtime:
|
|
* def __get__(self): # <<<<<<<<<<<<<<
|
|
* return self.infostruct.mtime
|
|
* property linklen:
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5g_9GroupStat_5mtime___get__(PyObject *__pyx_v_self); /*proto*/
|
|
static PyObject *__pyx_pf_4h5py_3h5g_9GroupStat_5mtime___get__(PyObject *__pyx_v_self) {
|
|
PyObject *__pyx_r = NULL;
|
|
PyObject *__pyx_t_1 = NULL;
|
|
__Pyx_RefNannySetupContext("__get__");
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":80
|
|
* property mtime:
|
|
* def __get__(self):
|
|
* return self.infostruct.mtime # <<<<<<<<<<<<<<
|
|
* property linklen:
|
|
* def __get__(self):
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_1 = __Pyx_PyInt_to_py_time_t(((struct __pyx_obj_4h5py_3h5g_GroupStat *)__pyx_v_self)->infostruct.mtime); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 80; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_r = __pyx_t_1;
|
|
__pyx_t_1 = 0;
|
|
goto __pyx_L0;
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_1);
|
|
__Pyx_AddTraceback("h5py.h5g.GroupStat.mtime.__get__");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":82
|
|
* return self.infostruct.mtime
|
|
* property linklen:
|
|
* def __get__(self): # <<<<<<<<<<<<<<
|
|
* return self.infostruct.linklen
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5g_9GroupStat_7linklen___get__(PyObject *__pyx_v_self); /*proto*/
|
|
static PyObject *__pyx_pf_4h5py_3h5g_9GroupStat_7linklen___get__(PyObject *__pyx_v_self) {
|
|
PyObject *__pyx_r = NULL;
|
|
PyObject *__pyx_t_1 = NULL;
|
|
__Pyx_RefNannySetupContext("__get__");
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":83
|
|
* property linklen:
|
|
* def __get__(self):
|
|
* return self.infostruct.linklen # <<<<<<<<<<<<<<
|
|
*
|
|
* def _hash(self):
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_1 = __Pyx_PyInt_FromSize_t(((struct __pyx_obj_4h5py_3h5g_GroupStat *)__pyx_v_self)->infostruct.linklen); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 83; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_r = __pyx_t_1;
|
|
__pyx_t_1 = 0;
|
|
goto __pyx_L0;
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_1);
|
|
__Pyx_AddTraceback("h5py.h5g.GroupStat.linklen.__get__");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":85
|
|
* return self.infostruct.linklen
|
|
*
|
|
* def _hash(self): # <<<<<<<<<<<<<<
|
|
* return hash((self.fileno, self.objno, self.nlink, self.type, self.mtime, self.linklen))
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5g_9GroupStat__hash(PyObject *__pyx_v_self, PyObject *unused); /*proto*/
|
|
static PyObject *__pyx_pf_4h5py_3h5g_9GroupStat__hash(PyObject *__pyx_v_self, PyObject *unused) {
|
|
PyObject *__pyx_r = NULL;
|
|
PyObject *__pyx_t_1 = NULL;
|
|
PyObject *__pyx_t_2 = NULL;
|
|
PyObject *__pyx_t_3 = NULL;
|
|
PyObject *__pyx_t_4 = NULL;
|
|
PyObject *__pyx_t_5 = NULL;
|
|
PyObject *__pyx_t_6 = NULL;
|
|
PyObject *__pyx_t_7 = NULL;
|
|
long __pyx_t_8;
|
|
__Pyx_RefNannySetupContext("_hash");
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":86
|
|
*
|
|
* def _hash(self):
|
|
* return hash((self.fileno, self.objno, self.nlink, self.type, self.mtime, self.linklen)) # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_1 = PyObject_GetAttr(__pyx_v_self, __pyx_n_s__fileno); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 86; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_2 = PyObject_GetAttr(__pyx_v_self, __pyx_n_s__objno); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 86; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__pyx_t_3 = PyObject_GetAttr(__pyx_v_self, __pyx_n_s__nlink); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 86; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__pyx_t_4 = PyObject_GetAttr(__pyx_v_self, __pyx_n_s__type); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 86; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
__pyx_t_5 = PyObject_GetAttr(__pyx_v_self, __pyx_n_s__mtime); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 86; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_5);
|
|
__pyx_t_6 = PyObject_GetAttr(__pyx_v_self, __pyx_n_s__linklen); if (unlikely(!__pyx_t_6)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 86; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_6);
|
|
__pyx_t_7 = PyTuple_New(6); if (unlikely(!__pyx_t_7)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 86; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_7);
|
|
PyTuple_SET_ITEM(__pyx_t_7, 0, __pyx_t_1);
|
|
__Pyx_GIVEREF(__pyx_t_1);
|
|
PyTuple_SET_ITEM(__pyx_t_7, 1, __pyx_t_2);
|
|
__Pyx_GIVEREF(__pyx_t_2);
|
|
PyTuple_SET_ITEM(__pyx_t_7, 2, __pyx_t_3);
|
|
__Pyx_GIVEREF(__pyx_t_3);
|
|
PyTuple_SET_ITEM(__pyx_t_7, 3, __pyx_t_4);
|
|
__Pyx_GIVEREF(__pyx_t_4);
|
|
PyTuple_SET_ITEM(__pyx_t_7, 4, __pyx_t_5);
|
|
__Pyx_GIVEREF(__pyx_t_5);
|
|
PyTuple_SET_ITEM(__pyx_t_7, 5, __pyx_t_6);
|
|
__Pyx_GIVEREF(__pyx_t_6);
|
|
__pyx_t_1 = 0;
|
|
__pyx_t_2 = 0;
|
|
__pyx_t_3 = 0;
|
|
__pyx_t_4 = 0;
|
|
__pyx_t_5 = 0;
|
|
__pyx_t_6 = 0;
|
|
__pyx_t_8 = PyObject_Hash(__pyx_t_7); if (unlikely(__pyx_t_8 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 86; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
|
|
__pyx_t_7 = PyInt_FromLong(__pyx_t_8); if (unlikely(!__pyx_t_7)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 86; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_7);
|
|
__pyx_r = __pyx_t_7;
|
|
__pyx_t_7 = 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_XDECREF(__pyx_t_3);
|
|
__Pyx_XDECREF(__pyx_t_4);
|
|
__Pyx_XDECREF(__pyx_t_5);
|
|
__Pyx_XDECREF(__pyx_t_6);
|
|
__Pyx_XDECREF(__pyx_t_7);
|
|
__Pyx_AddTraceback("h5py.h5g.GroupStat._hash");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":100
|
|
* cdef GroupID grp
|
|
*
|
|
* def __init__(self, GroupID grp not None): # <<<<<<<<<<<<<<
|
|
* self.idx = 0
|
|
* self.grp = grp
|
|
*/
|
|
|
|
static int __pyx_pf_4h5py_3h5g_9GroupIter___init__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
|
|
static int __pyx_pf_4h5py_3h5g_9GroupIter___init__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
|
|
struct __pyx_obj_4h5py_3h5g_GroupID *__pyx_v_grp = 0;
|
|
int __pyx_r;
|
|
PyObject *__pyx_t_1 = NULL;
|
|
PyObject *__pyx_t_2 = NULL;
|
|
unsigned long __pyx_t_3;
|
|
static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__grp,0};
|
|
__Pyx_RefNannySetupContext("__init__");
|
|
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:
|
|
values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__grp);
|
|
if (likely(values[0])) kw_args--;
|
|
else goto __pyx_L5_argtuple_error;
|
|
}
|
|
if (unlikely(kw_args > 0)) {
|
|
if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, PyTuple_GET_SIZE(__pyx_args), "__init__") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 100; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
__pyx_v_grp = ((struct __pyx_obj_4h5py_3h5g_GroupID *)values[0]);
|
|
} else if (PyTuple_GET_SIZE(__pyx_args) != 1) {
|
|
goto __pyx_L5_argtuple_error;
|
|
} else {
|
|
__pyx_v_grp = ((struct __pyx_obj_4h5py_3h5g_GroupID *)PyTuple_GET_ITEM(__pyx_args, 0));
|
|
}
|
|
goto __pyx_L4_argument_unpacking_done;
|
|
__pyx_L5_argtuple_error:;
|
|
__Pyx_RaiseArgtupleInvalid("__init__", 1, 1, 1, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 100; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
__pyx_L3_error:;
|
|
__Pyx_AddTraceback("h5py.h5g.GroupIter.__init__");
|
|
return -1;
|
|
__pyx_L4_argument_unpacking_done:;
|
|
if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_grp), __pyx_ptype_4h5py_3h5g_GroupID, 0, "grp", 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 100; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":101
|
|
*
|
|
* def __init__(self, GroupID grp not None):
|
|
* self.idx = 0 # <<<<<<<<<<<<<<
|
|
* self.grp = grp
|
|
* self.nobjs = grp.get_num_objs()
|
|
*/
|
|
((struct __pyx_obj_4h5py_3h5g_GroupIter *)__pyx_v_self)->idx = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":102
|
|
* def __init__(self, GroupID grp not None):
|
|
* self.idx = 0
|
|
* self.grp = grp # <<<<<<<<<<<<<<
|
|
* self.nobjs = grp.get_num_objs()
|
|
*
|
|
*/
|
|
__Pyx_INCREF(((PyObject *)__pyx_v_grp));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_v_grp));
|
|
__Pyx_GOTREF(((struct __pyx_obj_4h5py_3h5g_GroupIter *)__pyx_v_self)->grp);
|
|
__Pyx_DECREF(((PyObject *)((struct __pyx_obj_4h5py_3h5g_GroupIter *)__pyx_v_self)->grp));
|
|
((struct __pyx_obj_4h5py_3h5g_GroupIter *)__pyx_v_self)->grp = __pyx_v_grp;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":103
|
|
* self.idx = 0
|
|
* self.grp = grp
|
|
* self.nobjs = grp.get_num_objs() # <<<<<<<<<<<<<<
|
|
*
|
|
* def __iter__(self):
|
|
*/
|
|
__pyx_t_1 = PyObject_GetAttr(((PyObject *)__pyx_v_grp), __pyx_n_s__get_num_objs); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 103; __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 = 103; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_t_3 = __Pyx_PyInt_AsUnsignedLong(__pyx_t_2); if (unlikely((__pyx_t_3 == (unsigned long)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 103; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
|
|
((struct __pyx_obj_4h5py_3h5g_GroupIter *)__pyx_v_self)->nobjs = __pyx_t_3;
|
|
|
|
__pyx_r = 0;
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_1);
|
|
__Pyx_XDECREF(__pyx_t_2);
|
|
__Pyx_AddTraceback("h5py.h5g.GroupIter.__init__");
|
|
__pyx_r = -1;
|
|
__pyx_L0:;
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":105
|
|
* self.nobjs = grp.get_num_objs()
|
|
*
|
|
* def __iter__(self): # <<<<<<<<<<<<<<
|
|
* return self
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5g_9GroupIter___iter__(PyObject *__pyx_v_self); /*proto*/
|
|
static PyObject *__pyx_pf_4h5py_3h5g_9GroupIter___iter__(PyObject *__pyx_v_self) {
|
|
PyObject *__pyx_r = NULL;
|
|
__Pyx_RefNannySetupContext("__iter__");
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":106
|
|
*
|
|
* def __iter__(self):
|
|
* return self # <<<<<<<<<<<<<<
|
|
*
|
|
* def __next__(self):
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__Pyx_INCREF(__pyx_v_self);
|
|
__pyx_r = __pyx_v_self;
|
|
goto __pyx_L0;
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":108
|
|
* return self
|
|
*
|
|
* def __next__(self): # <<<<<<<<<<<<<<
|
|
* if self.idx == self.nobjs:
|
|
* self.grp = None
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5g_9GroupIter___next__(PyObject *__pyx_v_self); /*proto*/
|
|
static PyObject *__pyx_pf_4h5py_3h5g_9GroupIter___next__(PyObject *__pyx_v_self) {
|
|
PyObject *__pyx_v_retval;
|
|
PyObject *__pyx_r = NULL;
|
|
int __pyx_t_1;
|
|
PyObject *__pyx_t_2 = NULL;
|
|
PyObject *__pyx_t_3 = NULL;
|
|
PyObject *__pyx_t_4 = NULL;
|
|
__Pyx_RefNannySetupContext("__next__");
|
|
__Pyx_INCREF((PyObject *)__pyx_v_self);
|
|
__pyx_v_retval = Py_None; __Pyx_INCREF(Py_None);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":109
|
|
*
|
|
* def __next__(self):
|
|
* if self.idx == self.nobjs: # <<<<<<<<<<<<<<
|
|
* self.grp = None
|
|
* raise StopIteration
|
|
*/
|
|
__pyx_t_1 = (((struct __pyx_obj_4h5py_3h5g_GroupIter *)__pyx_v_self)->idx == ((struct __pyx_obj_4h5py_3h5g_GroupIter *)__pyx_v_self)->nobjs);
|
|
if (__pyx_t_1) {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":110
|
|
* def __next__(self):
|
|
* if self.idx == self.nobjs:
|
|
* self.grp = None # <<<<<<<<<<<<<<
|
|
* raise StopIteration
|
|
*
|
|
*/
|
|
__Pyx_INCREF(Py_None);
|
|
__Pyx_GIVEREF(Py_None);
|
|
__Pyx_GOTREF(((struct __pyx_obj_4h5py_3h5g_GroupIter *)__pyx_v_self)->grp);
|
|
__Pyx_DECREF(((PyObject *)((struct __pyx_obj_4h5py_3h5g_GroupIter *)__pyx_v_self)->grp));
|
|
((struct __pyx_obj_4h5py_3h5g_GroupIter *)__pyx_v_self)->grp = ((struct __pyx_obj_4h5py_3h5g_GroupID *)Py_None);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":111
|
|
* if self.idx == self.nobjs:
|
|
* self.grp = None
|
|
* raise StopIteration # <<<<<<<<<<<<<<
|
|
*
|
|
* retval = self.grp.get_objname_by_idx(self.idx)
|
|
*/
|
|
__Pyx_Raise(__pyx_builtin_StopIteration, 0, 0);
|
|
{__pyx_filename = __pyx_f[0]; __pyx_lineno = 111; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
goto __pyx_L5;
|
|
}
|
|
__pyx_L5:;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":113
|
|
* raise StopIteration
|
|
*
|
|
* retval = self.grp.get_objname_by_idx(self.idx) # <<<<<<<<<<<<<<
|
|
* self.idx = self.idx + 1
|
|
* return retval
|
|
*/
|
|
__pyx_t_2 = PyObject_GetAttr(((PyObject *)((struct __pyx_obj_4h5py_3h5g_GroupIter *)__pyx_v_self)->grp), __pyx_n_s__get_objname_by_idx); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 113; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__pyx_t_3 = PyLong_FromUnsignedLong(((struct __pyx_obj_4h5py_3h5g_GroupIter *)__pyx_v_self)->idx); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 113; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__pyx_t_4 = PyTuple_New(1); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 113; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_3);
|
|
__Pyx_GIVEREF(__pyx_t_3);
|
|
__pyx_t_3 = 0;
|
|
__pyx_t_3 = PyObject_Call(__pyx_t_2, __pyx_t_4, NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 113; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
__Pyx_DECREF(__pyx_v_retval);
|
|
__pyx_v_retval = __pyx_t_3;
|
|
__pyx_t_3 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":114
|
|
*
|
|
* retval = self.grp.get_objname_by_idx(self.idx)
|
|
* self.idx = self.idx + 1 # <<<<<<<<<<<<<<
|
|
* return retval
|
|
*
|
|
*/
|
|
((struct __pyx_obj_4h5py_3h5g_GroupIter *)__pyx_v_self)->idx = (((struct __pyx_obj_4h5py_3h5g_GroupIter *)__pyx_v_self)->idx + 1);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":115
|
|
* retval = self.grp.get_objname_by_idx(self.idx)
|
|
* self.idx = self.idx + 1
|
|
* return retval # <<<<<<<<<<<<<<
|
|
*
|
|
* # === Basic group management ==================================================
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__Pyx_INCREF(__pyx_v_retval);
|
|
__pyx_r = __pyx_v_retval;
|
|
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_XDECREF(__pyx_t_4);
|
|
__Pyx_AddTraceback("h5py.h5g.GroupIter.__next__");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_DECREF(__pyx_v_retval);
|
|
__Pyx_DECREF((PyObject *)__pyx_v_self);
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":120
|
|
*
|
|
*
|
|
* def open(ObjectID loc not None, char* name): # <<<<<<<<<<<<<<
|
|
* """(ObjectID loc, STRING name) => GroupID
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5g_open(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5g_open[] = "(ObjectID loc, STRING name) => GroupID\n\n Open an existing HDF5 group, attached to some other group.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5g_open(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
|
|
struct __pyx_obj_4h5py_2h5_ObjectID *__pyx_v_loc = 0;
|
|
char *__pyx_v_name;
|
|
PyObject *__pyx_r = NULL;
|
|
hid_t __pyx_t_1;
|
|
PyObject *__pyx_t_2 = NULL;
|
|
PyObject *__pyx_t_3 = NULL;
|
|
static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__loc,&__pyx_n_s__name,0};
|
|
__Pyx_RefNannySetupContext("open");
|
|
__pyx_self = __pyx_self;
|
|
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__loc);
|
|
if (likely(values[0])) kw_args--;
|
|
else goto __pyx_L5_argtuple_error;
|
|
case 1:
|
|
values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__name);
|
|
if (likely(values[1])) kw_args--;
|
|
else {
|
|
__Pyx_RaiseArgtupleInvalid("open", 1, 2, 2, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 120; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
}
|
|
if (unlikely(kw_args > 0)) {
|
|
if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, PyTuple_GET_SIZE(__pyx_args), "open") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 120; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
__pyx_v_loc = ((struct __pyx_obj_4h5py_2h5_ObjectID *)values[0]);
|
|
__pyx_v_name = __Pyx_PyBytes_AsString(values[1]); if (unlikely((!__pyx_v_name) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 120; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
} else if (PyTuple_GET_SIZE(__pyx_args) != 2) {
|
|
goto __pyx_L5_argtuple_error;
|
|
} else {
|
|
__pyx_v_loc = ((struct __pyx_obj_4h5py_2h5_ObjectID *)PyTuple_GET_ITEM(__pyx_args, 0));
|
|
__pyx_v_name = __Pyx_PyBytes_AsString(PyTuple_GET_ITEM(__pyx_args, 1)); if (unlikely((!__pyx_v_name) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 120; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
goto __pyx_L4_argument_unpacking_done;
|
|
__pyx_L5_argtuple_error:;
|
|
__Pyx_RaiseArgtupleInvalid("open", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 120; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
__pyx_L3_error:;
|
|
__Pyx_AddTraceback("h5py.h5g.open");
|
|
return NULL;
|
|
__pyx_L4_argument_unpacking_done:;
|
|
if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_loc), __pyx_ptype_4h5py_2h5_ObjectID, 0, "loc", 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 120; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":125
|
|
* Open an existing HDF5 group, attached to some other group.
|
|
* """
|
|
* return GroupID(H5Gopen(loc.id, name)) # <<<<<<<<<<<<<<
|
|
*
|
|
* IF H5PY_18API:
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_1 = H5Gopen(__pyx_v_loc->id, __pyx_v_name); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 125; __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 = 125; __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 = 125; __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_3h5g_GroupID)), __pyx_t_3, NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 125; __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.h5g.open");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":152
|
|
* ELSE:
|
|
*
|
|
* def create(ObjectID loc not None, char* name): # <<<<<<<<<<<<<<
|
|
* """(ObjectID loc, STRING name) => GroupID
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5g_create(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5g_create[] = "(ObjectID loc, STRING name) => GroupID\n\n Create a new group, under a given parent group.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5g_create(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
|
|
struct __pyx_obj_4h5py_2h5_ObjectID *__pyx_v_loc = 0;
|
|
char *__pyx_v_name;
|
|
PyObject *__pyx_r = NULL;
|
|
hid_t __pyx_t_1;
|
|
PyObject *__pyx_t_2 = NULL;
|
|
PyObject *__pyx_t_3 = NULL;
|
|
static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__loc,&__pyx_n_s__name,0};
|
|
__Pyx_RefNannySetupContext("create");
|
|
__pyx_self = __pyx_self;
|
|
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__loc);
|
|
if (likely(values[0])) kw_args--;
|
|
else goto __pyx_L5_argtuple_error;
|
|
case 1:
|
|
values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__name);
|
|
if (likely(values[1])) kw_args--;
|
|
else {
|
|
__Pyx_RaiseArgtupleInvalid("create", 1, 2, 2, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 152; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
}
|
|
if (unlikely(kw_args > 0)) {
|
|
if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, PyTuple_GET_SIZE(__pyx_args), "create") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 152; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
__pyx_v_loc = ((struct __pyx_obj_4h5py_2h5_ObjectID *)values[0]);
|
|
__pyx_v_name = __Pyx_PyBytes_AsString(values[1]); if (unlikely((!__pyx_v_name) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 152; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
} else if (PyTuple_GET_SIZE(__pyx_args) != 2) {
|
|
goto __pyx_L5_argtuple_error;
|
|
} else {
|
|
__pyx_v_loc = ((struct __pyx_obj_4h5py_2h5_ObjectID *)PyTuple_GET_ITEM(__pyx_args, 0));
|
|
__pyx_v_name = __Pyx_PyBytes_AsString(PyTuple_GET_ITEM(__pyx_args, 1)); if (unlikely((!__pyx_v_name) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 152; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
goto __pyx_L4_argument_unpacking_done;
|
|
__pyx_L5_argtuple_error:;
|
|
__Pyx_RaiseArgtupleInvalid("create", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 152; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
__pyx_L3_error:;
|
|
__Pyx_AddTraceback("h5py.h5g.create");
|
|
return NULL;
|
|
__pyx_L4_argument_unpacking_done:;
|
|
if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_loc), __pyx_ptype_4h5py_2h5_ObjectID, 0, "loc", 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 152; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":157
|
|
* Create a new group, under a given parent group.
|
|
* """
|
|
* return GroupID(H5Gcreate(loc.id, name, -1)) # <<<<<<<<<<<<<<
|
|
*
|
|
* cdef class _GroupVisitor:
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_1 = H5Gcreate(__pyx_v_loc->id, __pyx_v_name, -1); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 157; __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 = 157; __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 = 157; __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_3h5g_GroupID)), __pyx_t_3, NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 157; __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.h5g.create");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":164
|
|
* cdef object retval
|
|
*
|
|
* def __init__(self, func): # <<<<<<<<<<<<<<
|
|
* self.func = func
|
|
* self.retval = None
|
|
*/
|
|
|
|
static int __pyx_pf_4h5py_3h5g_13_GroupVisitor___init__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
|
|
static int __pyx_pf_4h5py_3h5g_13_GroupVisitor___init__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
|
|
PyObject *__pyx_v_func = 0;
|
|
int __pyx_r;
|
|
static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__func,0};
|
|
__Pyx_RefNannySetupContext("__init__");
|
|
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:
|
|
values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__func);
|
|
if (likely(values[0])) kw_args--;
|
|
else goto __pyx_L5_argtuple_error;
|
|
}
|
|
if (unlikely(kw_args > 0)) {
|
|
if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, PyTuple_GET_SIZE(__pyx_args), "__init__") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 164; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
__pyx_v_func = values[0];
|
|
} else if (PyTuple_GET_SIZE(__pyx_args) != 1) {
|
|
goto __pyx_L5_argtuple_error;
|
|
} else {
|
|
__pyx_v_func = PyTuple_GET_ITEM(__pyx_args, 0);
|
|
}
|
|
goto __pyx_L4_argument_unpacking_done;
|
|
__pyx_L5_argtuple_error:;
|
|
__Pyx_RaiseArgtupleInvalid("__init__", 1, 1, 1, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 164; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
__pyx_L3_error:;
|
|
__Pyx_AddTraceback("h5py.h5g._GroupVisitor.__init__");
|
|
return -1;
|
|
__pyx_L4_argument_unpacking_done:;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":165
|
|
*
|
|
* def __init__(self, func):
|
|
* self.func = func # <<<<<<<<<<<<<<
|
|
* self.retval = None
|
|
*
|
|
*/
|
|
__Pyx_INCREF(__pyx_v_func);
|
|
__Pyx_GIVEREF(__pyx_v_func);
|
|
__Pyx_GOTREF(((struct __pyx_obj_4h5py_3h5g__GroupVisitor *)__pyx_v_self)->func);
|
|
__Pyx_DECREF(((struct __pyx_obj_4h5py_3h5g__GroupVisitor *)__pyx_v_self)->func);
|
|
((struct __pyx_obj_4h5py_3h5g__GroupVisitor *)__pyx_v_self)->func = __pyx_v_func;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":166
|
|
* def __init__(self, func):
|
|
* self.func = func
|
|
* self.retval = None # <<<<<<<<<<<<<<
|
|
*
|
|
* cdef herr_t cb_group_iter(hid_t gid, char *name, void* vis_in) except 2:
|
|
*/
|
|
__Pyx_INCREF(Py_None);
|
|
__Pyx_GIVEREF(Py_None);
|
|
__Pyx_GOTREF(((struct __pyx_obj_4h5py_3h5g__GroupVisitor *)__pyx_v_self)->retval);
|
|
__Pyx_DECREF(((struct __pyx_obj_4h5py_3h5g__GroupVisitor *)__pyx_v_self)->retval);
|
|
((struct __pyx_obj_4h5py_3h5g__GroupVisitor *)__pyx_v_self)->retval = Py_None;
|
|
|
|
__pyx_r = 0;
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":168
|
|
* self.retval = None
|
|
*
|
|
* cdef herr_t cb_group_iter(hid_t gid, char *name, void* vis_in) except 2: # <<<<<<<<<<<<<<
|
|
*
|
|
* cdef _GroupVisitor vis = <_GroupVisitor>vis_in
|
|
*/
|
|
|
|
static herr_t __pyx_f_4h5py_3h5g_cb_group_iter(hid_t __pyx_v_gid, char *__pyx_v_name, void *__pyx_v_vis_in) {
|
|
struct __pyx_obj_4h5py_3h5g__GroupVisitor *__pyx_v_vis = 0;
|
|
herr_t __pyx_r;
|
|
PyObject *__pyx_t_1 = NULL;
|
|
PyObject *__pyx_t_2 = NULL;
|
|
int __pyx_t_3;
|
|
__Pyx_RefNannySetupContext("cb_group_iter");
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":170
|
|
* cdef herr_t cb_group_iter(hid_t gid, char *name, void* vis_in) except 2:
|
|
*
|
|
* cdef _GroupVisitor vis = <_GroupVisitor>vis_in # <<<<<<<<<<<<<<
|
|
*
|
|
* vis.retval = vis.func(name)
|
|
*/
|
|
__Pyx_INCREF(((PyObject *)((struct __pyx_obj_4h5py_3h5g__GroupVisitor *)__pyx_v_vis_in)));
|
|
__pyx_v_vis = ((struct __pyx_obj_4h5py_3h5g__GroupVisitor *)__pyx_v_vis_in);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":172
|
|
* cdef _GroupVisitor vis = <_GroupVisitor>vis_in
|
|
*
|
|
* vis.retval = vis.func(name) # <<<<<<<<<<<<<<
|
|
*
|
|
* if vis.retval is not None:
|
|
*/
|
|
__pyx_t_1 = __Pyx_PyBytes_FromString(__pyx_v_name); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 172; __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 = 172; __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(__pyx_v_vis->func, __pyx_t_2, NULL); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 172; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
|
|
__Pyx_GIVEREF(__pyx_t_1);
|
|
__Pyx_GOTREF(__pyx_v_vis->retval);
|
|
__Pyx_DECREF(__pyx_v_vis->retval);
|
|
__pyx_v_vis->retval = __pyx_t_1;
|
|
__pyx_t_1 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":174
|
|
* vis.retval = vis.func(name)
|
|
*
|
|
* if vis.retval is not None: # <<<<<<<<<<<<<<
|
|
* return 1
|
|
* return 0
|
|
*/
|
|
__pyx_t_3 = (__pyx_v_vis->retval != Py_None);
|
|
if (__pyx_t_3) {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":175
|
|
*
|
|
* if vis.retval is not None:
|
|
* return 1 # <<<<<<<<<<<<<<
|
|
* return 0
|
|
*
|
|
*/
|
|
__pyx_r = 1;
|
|
goto __pyx_L0;
|
|
goto __pyx_L3;
|
|
}
|
|
__pyx_L3:;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":176
|
|
* if vis.retval is not None:
|
|
* return 1
|
|
* return 0 # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__pyx_r = 0;
|
|
goto __pyx_L0;
|
|
|
|
__pyx_r = 0;
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_1);
|
|
__Pyx_XDECREF(__pyx_t_2);
|
|
__Pyx_AddTraceback("h5py.h5g.cb_group_iter");
|
|
__pyx_r = 2;
|
|
__pyx_L0:;
|
|
__Pyx_XDECREF((PyObject *)__pyx_v_vis);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":179
|
|
*
|
|
*
|
|
* def iterate(GroupID loc not None, object func, int startidx=0, *, # <<<<<<<<<<<<<<
|
|
* char* obj_name='.'):
|
|
* """ (GroupID loc, CALLABLE func, UINT startidx=0, **kwds)
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5g_iterate(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5g_iterate[] = " (GroupID loc, CALLABLE func, UINT startidx=0, **kwds)\n => Return value from func\n\n Iterate a callable (function, method or callable object) over the\n members of a group. Your callable should have the signature::\n\n func(STRING name) => Result\n\n Returning None continues iteration; returning anything else aborts\n iteration and returns that value. Keywords:\n\n STRING obj_name (\".\")\n Iterate over this subgroup instead\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5g_iterate(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
|
|
struct __pyx_obj_4h5py_3h5g_GroupID *__pyx_v_loc = 0;
|
|
PyObject *__pyx_v_func = 0;
|
|
int __pyx_v_startidx;
|
|
char *__pyx_v_obj_name;
|
|
int __pyx_v_i;
|
|
struct __pyx_obj_4h5py_3h5g__GroupVisitor *__pyx_v_vis = 0;
|
|
PyObject *__pyx_r = NULL;
|
|
int __pyx_t_1;
|
|
PyObject *__pyx_t_2 = NULL;
|
|
PyObject *__pyx_t_3 = NULL;
|
|
herr_t __pyx_t_4;
|
|
static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__loc,&__pyx_n_s__func,&__pyx_n_s__startidx,&__pyx_n_s__obj_name,0};
|
|
__Pyx_RefNannySetupContext("iterate");
|
|
__pyx_self = __pyx_self;
|
|
if (unlikely(__pyx_kwds)) {
|
|
Py_ssize_t kw_args = PyDict_Size(__pyx_kwds);
|
|
PyObject* values[4] = {0,0,0,0};
|
|
switch (PyTuple_GET_SIZE(__pyx_args)) {
|
|
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__loc);
|
|
if (likely(values[0])) kw_args--;
|
|
else goto __pyx_L5_argtuple_error;
|
|
case 1:
|
|
values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__func);
|
|
if (likely(values[1])) kw_args--;
|
|
else {
|
|
__Pyx_RaiseArgtupleInvalid("iterate", 0, 2, 3, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 179; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
case 2:
|
|
if (kw_args > 0) {
|
|
PyObject* value = PyDict_GetItem(__pyx_kwds, __pyx_n_s__startidx);
|
|
if (unlikely(value)) { values[2] = value; kw_args--; }
|
|
}
|
|
}
|
|
while (kw_args > 0) {
|
|
PyObject* value;
|
|
value = PyDict_GetItem(__pyx_kwds, __pyx_n_s__obj_name);
|
|
if (value) { values[3] = value; if (!(--kw_args)) break; }
|
|
break;
|
|
}
|
|
if (unlikely(kw_args > 0)) {
|
|
if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, PyTuple_GET_SIZE(__pyx_args), "iterate") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 179; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
__pyx_v_loc = ((struct __pyx_obj_4h5py_3h5g_GroupID *)values[0]);
|
|
__pyx_v_func = values[1];
|
|
if (values[2]) {
|
|
__pyx_v_startidx = __Pyx_PyInt_AsInt(values[2]); if (unlikely((__pyx_v_startidx == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 179; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
} else {
|
|
__pyx_v_startidx = ((int)0);
|
|
}
|
|
if (values[3]) {
|
|
__pyx_v_obj_name = __Pyx_PyBytes_AsString(values[3]); if (unlikely((!__pyx_v_obj_name) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 180; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
} else {
|
|
__pyx_v_obj_name = ((char *)__pyx_k_1);
|
|
}
|
|
} else {
|
|
__pyx_v_startidx = ((int)0);
|
|
__pyx_v_obj_name = ((char *)__pyx_k_1);
|
|
switch (PyTuple_GET_SIZE(__pyx_args)) {
|
|
case 3:
|
|
__pyx_v_startidx = __Pyx_PyInt_AsInt(PyTuple_GET_ITEM(__pyx_args, 2)); if (unlikely((__pyx_v_startidx == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 179; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
case 2:
|
|
__pyx_v_func = PyTuple_GET_ITEM(__pyx_args, 1);
|
|
__pyx_v_loc = ((struct __pyx_obj_4h5py_3h5g_GroupID *)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("iterate", 0, 2, 3, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 179; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
__pyx_L3_error:;
|
|
__Pyx_AddTraceback("h5py.h5g.iterate");
|
|
return NULL;
|
|
__pyx_L4_argument_unpacking_done:;
|
|
__Pyx_INCREF((PyObject *)__pyx_v_loc);
|
|
__Pyx_INCREF(__pyx_v_func);
|
|
if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_loc), __pyx_ptype_4h5py_3h5g_GroupID, 0, "loc", 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 179; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":195
|
|
* Iterate over this subgroup instead
|
|
* """
|
|
* if startidx < 0: # <<<<<<<<<<<<<<
|
|
* raise ValueError("Starting index must be non-negative")
|
|
*
|
|
*/
|
|
__pyx_t_1 = (__pyx_v_startidx < 0);
|
|
if (__pyx_t_1) {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":196
|
|
* """
|
|
* if startidx < 0:
|
|
* raise ValueError("Starting index must be non-negative") # <<<<<<<<<<<<<<
|
|
*
|
|
* cdef int i = startidx
|
|
*/
|
|
__pyx_t_2 = PyTuple_New(1); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 196; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__Pyx_INCREF(((PyObject *)__pyx_kp_s_2));
|
|
PyTuple_SET_ITEM(__pyx_t_2, 0, ((PyObject *)__pyx_kp_s_2));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_kp_s_2));
|
|
__pyx_t_3 = PyObject_Call(__pyx_builtin_ValueError, __pyx_t_2, NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 196; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
|
|
__Pyx_Raise(__pyx_t_3, 0, 0);
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
{__pyx_filename = __pyx_f[0]; __pyx_lineno = 196; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
goto __pyx_L6;
|
|
}
|
|
__pyx_L6:;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":198
|
|
* raise ValueError("Starting index must be non-negative")
|
|
*
|
|
* cdef int i = startidx # <<<<<<<<<<<<<<
|
|
* cdef _GroupVisitor vis = _GroupVisitor(func)
|
|
*
|
|
*/
|
|
__pyx_v_i = __pyx_v_startidx;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":199
|
|
*
|
|
* cdef int i = startidx
|
|
* cdef _GroupVisitor vis = _GroupVisitor(func) # <<<<<<<<<<<<<<
|
|
*
|
|
* H5Giterate(loc.id, obj_name, &i, <H5G_iterate_t>cb_group_iter, <void*>vis)
|
|
*/
|
|
__pyx_t_3 = PyTuple_New(1); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 199; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__Pyx_INCREF(__pyx_v_func);
|
|
PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_v_func);
|
|
__Pyx_GIVEREF(__pyx_v_func);
|
|
__pyx_t_2 = PyObject_Call(((PyObject *)((PyObject*)__pyx_ptype_4h5py_3h5g__GroupVisitor)), __pyx_t_3, NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 199; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
__pyx_v_vis = ((struct __pyx_obj_4h5py_3h5g__GroupVisitor *)__pyx_t_2);
|
|
__pyx_t_2 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":201
|
|
* cdef _GroupVisitor vis = _GroupVisitor(func)
|
|
*
|
|
* H5Giterate(loc.id, obj_name, &i, <H5G_iterate_t>cb_group_iter, <void*>vis) # <<<<<<<<<<<<<<
|
|
*
|
|
* return vis.retval
|
|
*/
|
|
__pyx_t_4 = H5Giterate(__pyx_v_loc->__pyx_base.id, __pyx_v_obj_name, (&__pyx_v_i), ((herr_t (*)(hid_t, char *, void *))__pyx_f_4h5py_3h5g_cb_group_iter), ((void *)__pyx_v_vis)); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 201; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":203
|
|
* H5Giterate(loc.id, obj_name, &i, <H5G_iterate_t>cb_group_iter, <void*>vis)
|
|
*
|
|
* return vis.retval # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__Pyx_INCREF(__pyx_v_vis->retval);
|
|
__pyx_r = __pyx_v_vis->retval;
|
|
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.h5g.iterate");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XDECREF((PyObject *)__pyx_v_vis);
|
|
__Pyx_DECREF((PyObject *)__pyx_v_loc);
|
|
__Pyx_DECREF(__pyx_v_func);
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":206
|
|
*
|
|
*
|
|
* def get_objinfo(ObjectID obj not None, object name='.', int follow_link=1): # <<<<<<<<<<<<<<
|
|
* """(ObjectID obj, STRING name='.', BOOL follow_link=True) => GroupStat object
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5g_get_objinfo(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5g_get_objinfo[] = "(ObjectID obj, STRING name='.', BOOL follow_link=True) => GroupStat object\n\n Obtain information about a named object. If \"name\" is provided,\n \"obj\" is taken to be a GroupID object containing the target.\n The return value is a GroupStat object; see that class's docstring\n for a description of its attributes. \n\n If follow_link is True (default) and the object is a symbolic link, \n the information returned describes its target. Otherwise the \n information describes the link itself.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5g_get_objinfo(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
|
|
struct __pyx_obj_4h5py_2h5_ObjectID *__pyx_v_obj = 0;
|
|
PyObject *__pyx_v_name = 0;
|
|
int __pyx_v_follow_link;
|
|
struct __pyx_obj_4h5py_3h5g_GroupStat *__pyx_v_statobj;
|
|
char *__pyx_v__name;
|
|
PyObject *__pyx_r = NULL;
|
|
PyObject *__pyx_t_1 = NULL;
|
|
char *__pyx_t_2;
|
|
herr_t __pyx_t_3;
|
|
static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__obj,&__pyx_n_s__name,&__pyx_n_s__follow_link,0};
|
|
__Pyx_RefNannySetupContext("get_objinfo");
|
|
__pyx_self = __pyx_self;
|
|
if (unlikely(__pyx_kwds)) {
|
|
Py_ssize_t kw_args = PyDict_Size(__pyx_kwds);
|
|
PyObject* values[3] = {0,0,0};
|
|
values[1] = ((PyObject *)__pyx_kp_s_1);
|
|
switch (PyTuple_GET_SIZE(__pyx_args)) {
|
|
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__obj);
|
|
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__name);
|
|
if (unlikely(value)) { values[1] = value; kw_args--; }
|
|
}
|
|
case 2:
|
|
if (kw_args > 0) {
|
|
PyObject* value = PyDict_GetItem(__pyx_kwds, __pyx_n_s__follow_link);
|
|
if (unlikely(value)) { values[2] = value; kw_args--; }
|
|
}
|
|
}
|
|
if (unlikely(kw_args > 0)) {
|
|
if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, PyTuple_GET_SIZE(__pyx_args), "get_objinfo") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 206; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
__pyx_v_obj = ((struct __pyx_obj_4h5py_2h5_ObjectID *)values[0]);
|
|
__pyx_v_name = values[1];
|
|
if (values[2]) {
|
|
__pyx_v_follow_link = __Pyx_PyInt_AsInt(values[2]); if (unlikely((__pyx_v_follow_link == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 206; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
} else {
|
|
__pyx_v_follow_link = ((int)1);
|
|
}
|
|
} else {
|
|
__pyx_v_name = ((PyObject *)__pyx_kp_s_1);
|
|
__pyx_v_follow_link = ((int)1);
|
|
switch (PyTuple_GET_SIZE(__pyx_args)) {
|
|
case 3: __pyx_v_follow_link = __Pyx_PyInt_AsInt(PyTuple_GET_ITEM(__pyx_args, 2)); if (unlikely((__pyx_v_follow_link == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 206; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
case 2: __pyx_v_name = PyTuple_GET_ITEM(__pyx_args, 1);
|
|
case 1: __pyx_v_obj = ((struct __pyx_obj_4h5py_2h5_ObjectID *)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("get_objinfo", 0, 1, 3, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 206; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
__pyx_L3_error:;
|
|
__Pyx_AddTraceback("h5py.h5g.get_objinfo");
|
|
return NULL;
|
|
__pyx_L4_argument_unpacking_done:;
|
|
__pyx_v_statobj = ((struct __pyx_obj_4h5py_3h5g_GroupStat *)Py_None); __Pyx_INCREF(Py_None);
|
|
if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_obj), __pyx_ptype_4h5py_2h5_ObjectID, 0, "obj", 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 206; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":219
|
|
* """
|
|
* cdef GroupStat statobj
|
|
* statobj = GroupStat() # <<<<<<<<<<<<<<
|
|
* cdef char* _name
|
|
* _name = name
|
|
*/
|
|
__pyx_t_1 = PyObject_Call(((PyObject *)((PyObject*)__pyx_ptype_4h5py_3h5g_GroupStat)), ((PyObject *)__pyx_empty_tuple), NULL); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 219; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__Pyx_DECREF(((PyObject *)__pyx_v_statobj));
|
|
__pyx_v_statobj = ((struct __pyx_obj_4h5py_3h5g_GroupStat *)__pyx_t_1);
|
|
__pyx_t_1 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":221
|
|
* statobj = GroupStat()
|
|
* cdef char* _name
|
|
* _name = name # <<<<<<<<<<<<<<
|
|
*
|
|
* H5Gget_objinfo(obj.id, _name, follow_link, &statobj.infostruct)
|
|
*/
|
|
__pyx_t_2 = __Pyx_PyBytes_AsString(__pyx_v_name); if (unlikely((!__pyx_t_2) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 221; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_v__name = __pyx_t_2;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":223
|
|
* _name = name
|
|
*
|
|
* H5Gget_objinfo(obj.id, _name, follow_link, &statobj.infostruct) # <<<<<<<<<<<<<<
|
|
*
|
|
* return statobj
|
|
*/
|
|
__pyx_t_3 = H5Gget_objinfo(__pyx_v_obj->id, __pyx_v__name, __pyx_v_follow_link, (&__pyx_v_statobj->infostruct)); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 223; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":225
|
|
* H5Gget_objinfo(obj.id, _name, follow_link, &statobj.infostruct)
|
|
*
|
|
* return statobj # <<<<<<<<<<<<<<
|
|
*
|
|
* # === Group member management =================================================
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__Pyx_INCREF(((PyObject *)__pyx_v_statobj));
|
|
__pyx_r = ((PyObject *)__pyx_v_statobj);
|
|
goto __pyx_L0;
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_1);
|
|
__Pyx_AddTraceback("h5py.h5g.get_objinfo");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_DECREF((PyObject *)__pyx_v_statobj);
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":258
|
|
*
|
|
*
|
|
* def _close(self): # <<<<<<<<<<<<<<
|
|
* """()
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5g_7GroupID__close(PyObject *__pyx_v_self, PyObject *unused); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5g_7GroupID__close[] = "()\n\n Terminate access through this identifier. You shouldn't have to\n call this manually; group identifiers are automatically released\n when their Python wrappers are freed.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5g_7GroupID__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/h5g.pyx":265
|
|
* when their Python wrappers are freed.
|
|
* """
|
|
* H5Gclose(self.id) # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__pyx_t_1 = H5Gclose(((struct __pyx_obj_4h5py_3h5g_GroupID *)__pyx_v_self)->__pyx_base.id); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 265; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_AddTraceback("h5py.h5g.GroupID._close");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":268
|
|
*
|
|
*
|
|
* def link(self, char* current_name, char* new_name, # <<<<<<<<<<<<<<
|
|
* int link_type=H5G_LINK_HARD, GroupID remote=None):
|
|
* """(STRING current_name, STRING new_name, INT link_type=LINK_HARD,
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5g_7GroupID_link(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5g_7GroupID_link[] = "(STRING current_name, STRING new_name, INT link_type=LINK_HARD, \n GroupID remote=None)\n\n Create a new hard or soft link. current_name identifies\n the link target (object the link will point to). The new link is\n identified by new_name and (optionally) another group \"remote\".\n\n Link types are:\n\n LINK_HARD\n Hard link to existing object (default)\n\n LINK_SOFT\n Symbolic link; link target need not exist.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5g_7GroupID_link(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
|
|
char *__pyx_v_current_name;
|
|
char *__pyx_v_new_name;
|
|
int __pyx_v_link_type;
|
|
struct __pyx_obj_4h5py_3h5g_GroupID *__pyx_v_remote = 0;
|
|
hid_t __pyx_v_remote_id;
|
|
PyObject *__pyx_r = NULL;
|
|
int __pyx_t_1;
|
|
herr_t __pyx_t_2;
|
|
static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__current_name,&__pyx_n_s__new_name,&__pyx_n_s__link_type,&__pyx_n_s__remote,0};
|
|
__Pyx_RefNannySetupContext("link");
|
|
if (unlikely(__pyx_kwds)) {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":269
|
|
*
|
|
* def link(self, char* current_name, char* new_name,
|
|
* int link_type=H5G_LINK_HARD, GroupID remote=None): # <<<<<<<<<<<<<<
|
|
* """(STRING current_name, STRING new_name, INT link_type=LINK_HARD,
|
|
* GroupID remote=None)
|
|
*/
|
|
Py_ssize_t kw_args = PyDict_Size(__pyx_kwds);
|
|
PyObject* values[4] = {0,0,0,0};
|
|
values[3] = (PyObject*)((struct __pyx_obj_4h5py_3h5g_GroupID *)Py_None);
|
|
switch (PyTuple_GET_SIZE(__pyx_args)) {
|
|
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__current_name);
|
|
if (likely(values[0])) kw_args--;
|
|
else goto __pyx_L5_argtuple_error;
|
|
case 1:
|
|
values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__new_name);
|
|
if (likely(values[1])) kw_args--;
|
|
else {
|
|
__Pyx_RaiseArgtupleInvalid("link", 0, 2, 4, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 268; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
case 2:
|
|
if (kw_args > 1) {
|
|
PyObject* value = PyDict_GetItem(__pyx_kwds, __pyx_n_s__link_type);
|
|
if (unlikely(value)) { values[2] = value; kw_args--; }
|
|
}
|
|
case 3:
|
|
if (kw_args > 1) {
|
|
PyObject* value = PyDict_GetItem(__pyx_kwds, __pyx_n_s__remote);
|
|
if (unlikely(value)) { values[3] = value; kw_args--; }
|
|
}
|
|
}
|
|
if (unlikely(kw_args > 0)) {
|
|
if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, PyTuple_GET_SIZE(__pyx_args), "link") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 268; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
__pyx_v_current_name = __Pyx_PyBytes_AsString(values[0]); if (unlikely((!__pyx_v_current_name) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 268; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
__pyx_v_new_name = __Pyx_PyBytes_AsString(values[1]); if (unlikely((!__pyx_v_new_name) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 268; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
if (values[2]) {
|
|
__pyx_v_link_type = __Pyx_PyInt_AsInt(values[2]); if (unlikely((__pyx_v_link_type == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 269; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
} else {
|
|
__pyx_v_link_type = __pyx_k_3;
|
|
}
|
|
__pyx_v_remote = ((struct __pyx_obj_4h5py_3h5g_GroupID *)values[3]);
|
|
} else {
|
|
__pyx_v_link_type = __pyx_k_3;
|
|
__pyx_v_remote = ((struct __pyx_obj_4h5py_3h5g_GroupID *)Py_None);
|
|
switch (PyTuple_GET_SIZE(__pyx_args)) {
|
|
case 4:
|
|
__pyx_v_remote = ((struct __pyx_obj_4h5py_3h5g_GroupID *)PyTuple_GET_ITEM(__pyx_args, 3));
|
|
case 3:
|
|
__pyx_v_link_type = __Pyx_PyInt_AsInt(PyTuple_GET_ITEM(__pyx_args, 2)); if (unlikely((__pyx_v_link_type == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 269; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
case 2:
|
|
__pyx_v_new_name = __Pyx_PyBytes_AsString(PyTuple_GET_ITEM(__pyx_args, 1)); if (unlikely((!__pyx_v_new_name) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 268; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
__pyx_v_current_name = __Pyx_PyBytes_AsString(PyTuple_GET_ITEM(__pyx_args, 0)); if (unlikely((!__pyx_v_current_name) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 268; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
break;
|
|
default: goto __pyx_L5_argtuple_error;
|
|
}
|
|
}
|
|
goto __pyx_L4_argument_unpacking_done;
|
|
__pyx_L5_argtuple_error:;
|
|
__Pyx_RaiseArgtupleInvalid("link", 0, 2, 4, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 268; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
__pyx_L3_error:;
|
|
__Pyx_AddTraceback("h5py.h5g.GroupID.link");
|
|
return NULL;
|
|
__pyx_L4_argument_unpacking_done:;
|
|
__Pyx_INCREF((PyObject *)__pyx_v_self);
|
|
__Pyx_INCREF((PyObject *)__pyx_v_remote);
|
|
if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_remote), __pyx_ptype_4h5py_3h5g_GroupID, 1, "remote", 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 269; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":286
|
|
* """
|
|
* cdef hid_t remote_id
|
|
* if remote is None: # <<<<<<<<<<<<<<
|
|
* remote_id = self.id
|
|
* else:
|
|
*/
|
|
__pyx_t_1 = (((PyObject *)__pyx_v_remote) == Py_None);
|
|
if (__pyx_t_1) {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":287
|
|
* cdef hid_t remote_id
|
|
* if remote is None:
|
|
* remote_id = self.id # <<<<<<<<<<<<<<
|
|
* else:
|
|
* remote_id = remote.id
|
|
*/
|
|
__pyx_v_remote_id = ((struct __pyx_obj_4h5py_3h5g_GroupID *)__pyx_v_self)->__pyx_base.id;
|
|
goto __pyx_L6;
|
|
}
|
|
/*else*/ {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":289
|
|
* remote_id = self.id
|
|
* else:
|
|
* remote_id = remote.id # <<<<<<<<<<<<<<
|
|
*
|
|
* H5Glink2(self.id, current_name, <H5G_link_t>link_type, remote_id, new_name)
|
|
*/
|
|
__pyx_v_remote_id = __pyx_v_remote->__pyx_base.id;
|
|
}
|
|
__pyx_L6:;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":291
|
|
* remote_id = remote.id
|
|
*
|
|
* H5Glink2(self.id, current_name, <H5G_link_t>link_type, remote_id, new_name) # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__pyx_t_2 = H5Glink2(((struct __pyx_obj_4h5py_3h5g_GroupID *)__pyx_v_self)->__pyx_base.id, __pyx_v_current_name, ((H5G_link_t)__pyx_v_link_type), __pyx_v_remote_id, __pyx_v_new_name); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 291; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_AddTraceback("h5py.h5g.GroupID.link");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_DECREF((PyObject *)__pyx_v_self);
|
|
__Pyx_DECREF((PyObject *)__pyx_v_remote);
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":295
|
|
*
|
|
*
|
|
* def unlink(self, char* name): # <<<<<<<<<<<<<<
|
|
* """(STRING name)
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5g_7GroupID_unlink(PyObject *__pyx_v_self, PyObject *__pyx_arg_name); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5g_7GroupID_unlink[] = "(STRING name)\n\n Remove a link to an object from this group.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5g_7GroupID_unlink(PyObject *__pyx_v_self, PyObject *__pyx_arg_name) {
|
|
char *__pyx_v_name;
|
|
PyObject *__pyx_r = NULL;
|
|
herr_t __pyx_t_1;
|
|
__Pyx_RefNannySetupContext("unlink");
|
|
assert(__pyx_arg_name); {
|
|
__pyx_v_name = __Pyx_PyBytes_AsString(__pyx_arg_name); if (unlikely((!__pyx_v_name) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 295; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
goto __pyx_L4_argument_unpacking_done;
|
|
__pyx_L3_error:;
|
|
__Pyx_AddTraceback("h5py.h5g.GroupID.unlink");
|
|
return NULL;
|
|
__pyx_L4_argument_unpacking_done:;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":300
|
|
* Remove a link to an object from this group.
|
|
* """
|
|
* H5Gunlink(self.id, name) # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__pyx_t_1 = H5Gunlink(((struct __pyx_obj_4h5py_3h5g_GroupID *)__pyx_v_self)->__pyx_base.id, __pyx_v_name); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 300; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_AddTraceback("h5py.h5g.GroupID.unlink");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":304
|
|
*
|
|
*
|
|
* def move(self, char* current_name, char* new_name, GroupID remote=None): # <<<<<<<<<<<<<<
|
|
* """(STRING current_name, STRING new_name, GroupID remote=None)
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5g_7GroupID_move(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5g_7GroupID_move[] = "(STRING current_name, STRING new_name, GroupID remote=None)\n\n Relink an object. current_name identifies the object.\n new_name and (optionally) another group \"remote\" determine\n where it should be moved.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5g_7GroupID_move(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
|
|
char *__pyx_v_current_name;
|
|
char *__pyx_v_new_name;
|
|
struct __pyx_obj_4h5py_3h5g_GroupID *__pyx_v_remote = 0;
|
|
hid_t __pyx_v_remote_id;
|
|
PyObject *__pyx_r = NULL;
|
|
int __pyx_t_1;
|
|
herr_t __pyx_t_2;
|
|
static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__current_name,&__pyx_n_s__new_name,&__pyx_n_s__remote,0};
|
|
__Pyx_RefNannySetupContext("move");
|
|
if (unlikely(__pyx_kwds)) {
|
|
Py_ssize_t kw_args = PyDict_Size(__pyx_kwds);
|
|
PyObject* values[3] = {0,0,0};
|
|
values[2] = (PyObject*)((struct __pyx_obj_4h5py_3h5g_GroupID *)Py_None);
|
|
switch (PyTuple_GET_SIZE(__pyx_args)) {
|
|
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__current_name);
|
|
if (likely(values[0])) kw_args--;
|
|
else goto __pyx_L5_argtuple_error;
|
|
case 1:
|
|
values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__new_name);
|
|
if (likely(values[1])) kw_args--;
|
|
else {
|
|
__Pyx_RaiseArgtupleInvalid("move", 0, 2, 3, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 304; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
case 2:
|
|
if (kw_args > 1) {
|
|
PyObject* value = PyDict_GetItem(__pyx_kwds, __pyx_n_s__remote);
|
|
if (unlikely(value)) { values[2] = value; kw_args--; }
|
|
}
|
|
}
|
|
if (unlikely(kw_args > 0)) {
|
|
if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, PyTuple_GET_SIZE(__pyx_args), "move") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 304; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
__pyx_v_current_name = __Pyx_PyBytes_AsString(values[0]); if (unlikely((!__pyx_v_current_name) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 304; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
__pyx_v_new_name = __Pyx_PyBytes_AsString(values[1]); if (unlikely((!__pyx_v_new_name) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 304; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
__pyx_v_remote = ((struct __pyx_obj_4h5py_3h5g_GroupID *)values[2]);
|
|
} else {
|
|
__pyx_v_remote = ((struct __pyx_obj_4h5py_3h5g_GroupID *)Py_None);
|
|
switch (PyTuple_GET_SIZE(__pyx_args)) {
|
|
case 3:
|
|
__pyx_v_remote = ((struct __pyx_obj_4h5py_3h5g_GroupID *)PyTuple_GET_ITEM(__pyx_args, 2));
|
|
case 2:
|
|
__pyx_v_new_name = __Pyx_PyBytes_AsString(PyTuple_GET_ITEM(__pyx_args, 1)); if (unlikely((!__pyx_v_new_name) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 304; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
__pyx_v_current_name = __Pyx_PyBytes_AsString(PyTuple_GET_ITEM(__pyx_args, 0)); if (unlikely((!__pyx_v_current_name) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 304; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
break;
|
|
default: goto __pyx_L5_argtuple_error;
|
|
}
|
|
}
|
|
goto __pyx_L4_argument_unpacking_done;
|
|
__pyx_L5_argtuple_error:;
|
|
__Pyx_RaiseArgtupleInvalid("move", 0, 2, 3, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 304; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
__pyx_L3_error:;
|
|
__Pyx_AddTraceback("h5py.h5g.GroupID.move");
|
|
return NULL;
|
|
__pyx_L4_argument_unpacking_done:;
|
|
__Pyx_INCREF((PyObject *)__pyx_v_self);
|
|
__Pyx_INCREF((PyObject *)__pyx_v_remote);
|
|
if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_remote), __pyx_ptype_4h5py_3h5g_GroupID, 1, "remote", 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 304; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":312
|
|
* """
|
|
* cdef hid_t remote_id
|
|
* if remote is None: # <<<<<<<<<<<<<<
|
|
* remote_id = self.id
|
|
* else:
|
|
*/
|
|
__pyx_t_1 = (((PyObject *)__pyx_v_remote) == Py_None);
|
|
if (__pyx_t_1) {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":313
|
|
* cdef hid_t remote_id
|
|
* if remote is None:
|
|
* remote_id = self.id # <<<<<<<<<<<<<<
|
|
* else:
|
|
* remote_id = remote.id
|
|
*/
|
|
__pyx_v_remote_id = ((struct __pyx_obj_4h5py_3h5g_GroupID *)__pyx_v_self)->__pyx_base.id;
|
|
goto __pyx_L6;
|
|
}
|
|
/*else*/ {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":315
|
|
* remote_id = self.id
|
|
* else:
|
|
* remote_id = remote.id # <<<<<<<<<<<<<<
|
|
*
|
|
* H5Gmove2(self.id, current_name, remote_id, new_name)
|
|
*/
|
|
__pyx_v_remote_id = __pyx_v_remote->__pyx_base.id;
|
|
}
|
|
__pyx_L6:;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":317
|
|
* remote_id = remote.id
|
|
*
|
|
* H5Gmove2(self.id, current_name, remote_id, new_name) # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__pyx_t_2 = H5Gmove2(((struct __pyx_obj_4h5py_3h5g_GroupID *)__pyx_v_self)->__pyx_base.id, __pyx_v_current_name, __pyx_v_remote_id, __pyx_v_new_name); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 317; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_AddTraceback("h5py.h5g.GroupID.move");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_DECREF((PyObject *)__pyx_v_self);
|
|
__Pyx_DECREF((PyObject *)__pyx_v_remote);
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":321
|
|
*
|
|
*
|
|
* def get_num_objs(self): # <<<<<<<<<<<<<<
|
|
* """() => INT number_of_objects
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5g_7GroupID_get_num_objs(PyObject *__pyx_v_self, PyObject *unused); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5g_7GroupID_get_num_objs[] = "() => INT number_of_objects\n\n Get the number of objects directly attached to a given group.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5g_7GroupID_get_num_objs(PyObject *__pyx_v_self, PyObject *unused) {
|
|
hsize_t __pyx_v_size;
|
|
PyObject *__pyx_r = NULL;
|
|
herr_t __pyx_t_1;
|
|
PyObject *__pyx_t_2 = NULL;
|
|
__Pyx_RefNannySetupContext("get_num_objs");
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":327
|
|
* """
|
|
* cdef hsize_t size
|
|
* H5Gget_num_objs(self.id, &size) # <<<<<<<<<<<<<<
|
|
* return size
|
|
*
|
|
*/
|
|
__pyx_t_1 = H5Gget_num_objs(((struct __pyx_obj_4h5py_3h5g_GroupID *)__pyx_v_self)->__pyx_base.id, (&__pyx_v_size)); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 327; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":328
|
|
* cdef hsize_t size
|
|
* H5Gget_num_objs(self.id, &size)
|
|
* return size # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_2 = __Pyx_PyInt_to_py_hsize_t(__pyx_v_size); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 328; __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.h5g.GroupID.get_num_objs");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":332
|
|
*
|
|
*
|
|
* def get_objname_by_idx(self, hsize_t idx): # <<<<<<<<<<<<<<
|
|
* """(INT idx) => STRING
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5g_7GroupID_get_objname_by_idx(PyObject *__pyx_v_self, PyObject *__pyx_arg_idx); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5g_7GroupID_get_objname_by_idx[] = "(INT idx) => STRING\n\n Get the name of a group member given its zero-based index.\n\n Due to a limitation of the HDF5 library, the generic exception\n H5Error is raised if the idx parameter is out-of-range.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5g_7GroupID_get_objname_by_idx(PyObject *__pyx_v_self, PyObject *__pyx_arg_idx) {
|
|
hsize_t __pyx_v_idx;
|
|
int __pyx_v_size;
|
|
char *__pyx_v_buf;
|
|
PyObject *__pyx_v_pystring;
|
|
PyObject *__pyx_r = NULL;
|
|
int __pyx_t_1;
|
|
int __pyx_t_2;
|
|
PyObject *__pyx_t_3 = NULL;
|
|
PyObject *__pyx_t_4 = NULL;
|
|
PyObject *__pyx_t_5 = NULL;
|
|
void *__pyx_t_6;
|
|
__Pyx_RefNannySetupContext("get_objname_by_idx");
|
|
assert(__pyx_arg_idx); {
|
|
__pyx_v_idx = __Pyx_PyInt_from_py_hsize_t(__pyx_arg_idx); if (unlikely((__pyx_v_idx == (hsize_t)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 332; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
goto __pyx_L4_argument_unpacking_done;
|
|
__pyx_L3_error:;
|
|
__Pyx_AddTraceback("h5py.h5g.GroupID.get_objname_by_idx");
|
|
return NULL;
|
|
__pyx_L4_argument_unpacking_done:;
|
|
__Pyx_INCREF((PyObject *)__pyx_v_self);
|
|
__pyx_v_pystring = Py_None; __Pyx_INCREF(Py_None);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":342
|
|
* cdef int size
|
|
* cdef char* buf
|
|
* buf = NULL # <<<<<<<<<<<<<<
|
|
*
|
|
* # This function does not properly raise an exception
|
|
*/
|
|
__pyx_v_buf = NULL;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":345
|
|
*
|
|
* # This function does not properly raise an exception
|
|
* size = H5Gget_objname_by_idx(self.id, idx, NULL, 0) # <<<<<<<<<<<<<<
|
|
* if size < 0:
|
|
* raise H5Error("Invalid index")
|
|
*/
|
|
__pyx_t_1 = H5Gget_objname_by_idx(((struct __pyx_obj_4h5py_3h5g_GroupID *)__pyx_v_self)->__pyx_base.id, __pyx_v_idx, NULL, 0); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 345; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_v_size = __pyx_t_1;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":346
|
|
* # This function does not properly raise an exception
|
|
* size = H5Gget_objname_by_idx(self.id, idx, NULL, 0)
|
|
* if size < 0: # <<<<<<<<<<<<<<
|
|
* raise H5Error("Invalid index")
|
|
*
|
|
*/
|
|
__pyx_t_2 = (__pyx_v_size < 0);
|
|
if (__pyx_t_2) {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":347
|
|
* size = H5Gget_objname_by_idx(self.id, idx, NULL, 0)
|
|
* if size < 0:
|
|
* raise H5Error("Invalid index") # <<<<<<<<<<<<<<
|
|
*
|
|
* buf = <char*>emalloc(sizeof(char)*(size+1))
|
|
*/
|
|
__pyx_t_3 = __Pyx_GetName(__pyx_m, __pyx_n_s__H5Error); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 347; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__pyx_t_4 = PyTuple_New(1); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 347; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
__Pyx_INCREF(((PyObject *)__pyx_kp_s_4));
|
|
PyTuple_SET_ITEM(__pyx_t_4, 0, ((PyObject *)__pyx_kp_s_4));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_kp_s_4));
|
|
__pyx_t_5 = PyObject_Call(__pyx_t_3, __pyx_t_4, NULL); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 347; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_5);
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
__Pyx_Raise(__pyx_t_5, 0, 0);
|
|
__Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
|
|
{__pyx_filename = __pyx_f[0]; __pyx_lineno = 347; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
goto __pyx_L5;
|
|
}
|
|
__pyx_L5:;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":349
|
|
* raise H5Error("Invalid index")
|
|
*
|
|
* buf = <char*>emalloc(sizeof(char)*(size+1)) # <<<<<<<<<<<<<<
|
|
* try:
|
|
* H5Gget_objname_by_idx(self.id, idx, buf, size+1)
|
|
*/
|
|
__pyx_t_6 = __pyx_f_4h5py_5utils_emalloc(((sizeof(char)) * (__pyx_v_size + 1))); if (unlikely(__pyx_t_6 == NULL && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 349; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_v_buf = ((char *)__pyx_t_6);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":350
|
|
*
|
|
* buf = <char*>emalloc(sizeof(char)*(size+1))
|
|
* try: # <<<<<<<<<<<<<<
|
|
* H5Gget_objname_by_idx(self.id, idx, buf, size+1)
|
|
* pystring = buf
|
|
*/
|
|
/*try:*/ {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":351
|
|
* buf = <char*>emalloc(sizeof(char)*(size+1))
|
|
* try:
|
|
* H5Gget_objname_by_idx(self.id, idx, buf, size+1) # <<<<<<<<<<<<<<
|
|
* pystring = buf
|
|
* return pystring
|
|
*/
|
|
__pyx_t_1 = H5Gget_objname_by_idx(((struct __pyx_obj_4h5py_3h5g_GroupID *)__pyx_v_self)->__pyx_base.id, __pyx_v_idx, __pyx_v_buf, (__pyx_v_size + 1)); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 351; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":352
|
|
* try:
|
|
* H5Gget_objname_by_idx(self.id, idx, buf, size+1)
|
|
* pystring = buf # <<<<<<<<<<<<<<
|
|
* return pystring
|
|
* finally:
|
|
*/
|
|
__pyx_t_5 = __Pyx_PyBytes_FromString(__pyx_v_buf); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 352; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
__Pyx_GOTREF(__pyx_t_5);
|
|
__Pyx_DECREF(__pyx_v_pystring);
|
|
__pyx_v_pystring = __pyx_t_5;
|
|
__pyx_t_5 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":353
|
|
* H5Gget_objname_by_idx(self.id, idx, buf, size+1)
|
|
* pystring = buf
|
|
* return pystring # <<<<<<<<<<<<<<
|
|
* finally:
|
|
* efree(buf)
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__Pyx_INCREF(__pyx_v_pystring);
|
|
__pyx_r = __pyx_v_pystring;
|
|
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_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
__Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 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/h5g.pyx":355
|
|
* return pystring
|
|
* finally:
|
|
* efree(buf) # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__pyx_f_4h5py_5utils_efree(__pyx_v_buf);
|
|
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_XDECREF(__pyx_t_4);
|
|
__Pyx_XDECREF(__pyx_t_5);
|
|
__Pyx_AddTraceback("h5py.h5g.GroupID.get_objname_by_idx");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_DECREF(__pyx_v_pystring);
|
|
__Pyx_DECREF((PyObject *)__pyx_v_self);
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":359
|
|
*
|
|
*
|
|
* def get_objtype_by_idx(self, hsize_t idx): # <<<<<<<<<<<<<<
|
|
* """(INT idx) => INT object_type_code
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5g_7GroupID_get_objtype_by_idx(PyObject *__pyx_v_self, PyObject *__pyx_arg_idx); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5g_7GroupID_get_objtype_by_idx[] = "(INT idx) => INT object_type_code\n\n Get the type of an object attached to a group, given its zero-based\n index. Possible return values are:\n\n - LINK\n - GROUP\n - DATASET\n - TYPE\n\n Due to a limitation of the HDF5 library, the generic exception\n H5Error is raised if the idx parameter is out-of-range.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5g_7GroupID_get_objtype_by_idx(PyObject *__pyx_v_self, PyObject *__pyx_arg_idx) {
|
|
hsize_t __pyx_v_idx;
|
|
int __pyx_v_retval;
|
|
PyObject *__pyx_r = NULL;
|
|
int __pyx_t_1;
|
|
int __pyx_t_2;
|
|
PyObject *__pyx_t_3 = NULL;
|
|
PyObject *__pyx_t_4 = NULL;
|
|
PyObject *__pyx_t_5 = NULL;
|
|
__Pyx_RefNannySetupContext("get_objtype_by_idx");
|
|
assert(__pyx_arg_idx); {
|
|
__pyx_v_idx = __Pyx_PyInt_from_py_hsize_t(__pyx_arg_idx); if (unlikely((__pyx_v_idx == (hsize_t)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 359; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
goto __pyx_L4_argument_unpacking_done;
|
|
__pyx_L3_error:;
|
|
__Pyx_AddTraceback("h5py.h5g.GroupID.get_objtype_by_idx");
|
|
return NULL;
|
|
__pyx_L4_argument_unpacking_done:;
|
|
__Pyx_INCREF((PyObject *)__pyx_v_self);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":375
|
|
* # This function does not properly raise an exception
|
|
* cdef int retval
|
|
* retval = H5Gget_objtype_by_idx(self.id, idx) # <<<<<<<<<<<<<<
|
|
* if retval < 0:
|
|
* raise H5Error("Invalid index")
|
|
*/
|
|
__pyx_t_1 = H5Gget_objtype_by_idx(((struct __pyx_obj_4h5py_3h5g_GroupID *)__pyx_v_self)->__pyx_base.id, __pyx_v_idx); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 375; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_v_retval = __pyx_t_1;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":376
|
|
* cdef int retval
|
|
* retval = H5Gget_objtype_by_idx(self.id, idx)
|
|
* if retval < 0: # <<<<<<<<<<<<<<
|
|
* raise H5Error("Invalid index")
|
|
* return retval
|
|
*/
|
|
__pyx_t_2 = (__pyx_v_retval < 0);
|
|
if (__pyx_t_2) {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":377
|
|
* retval = H5Gget_objtype_by_idx(self.id, idx)
|
|
* if retval < 0:
|
|
* raise H5Error("Invalid index") # <<<<<<<<<<<<<<
|
|
* return retval
|
|
*
|
|
*/
|
|
__pyx_t_3 = __Pyx_GetName(__pyx_m, __pyx_n_s__H5Error); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 377; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__pyx_t_4 = PyTuple_New(1); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 377; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
__Pyx_INCREF(((PyObject *)__pyx_kp_s_4));
|
|
PyTuple_SET_ITEM(__pyx_t_4, 0, ((PyObject *)__pyx_kp_s_4));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_kp_s_4));
|
|
__pyx_t_5 = PyObject_Call(__pyx_t_3, __pyx_t_4, NULL); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 377; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_5);
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
__Pyx_Raise(__pyx_t_5, 0, 0);
|
|
__Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
|
|
{__pyx_filename = __pyx_f[0]; __pyx_lineno = 377; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
goto __pyx_L5;
|
|
}
|
|
__pyx_L5:;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":378
|
|
* if retval < 0:
|
|
* raise H5Error("Invalid index")
|
|
* return retval # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_5 = PyInt_FromLong(__pyx_v_retval); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 378; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_5);
|
|
__pyx_r = __pyx_t_5;
|
|
__pyx_t_5 = 0;
|
|
goto __pyx_L0;
|
|
|
|
__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_XDECREF(__pyx_t_5);
|
|
__Pyx_AddTraceback("h5py.h5g.GroupID.get_objtype_by_idx");
|
|
__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/h5g.pyx":382
|
|
*
|
|
*
|
|
* def get_linkval(self, char* name): # <<<<<<<<<<<<<<
|
|
* """(STRING name) => STRING link_value
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5g_7GroupID_get_linkval(PyObject *__pyx_v_self, PyObject *__pyx_arg_name); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5g_7GroupID_get_linkval[] = "(STRING name) => STRING link_value\n\n Retrieve the value (target name) of a symbolic link.\n Limited to 2048 characters on Windows.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5g_7GroupID_get_linkval(PyObject *__pyx_v_self, PyObject *__pyx_arg_name) {
|
|
char *__pyx_v_name;
|
|
char *__pyx_v_value;
|
|
H5G_stat_t __pyx_v_statbuf;
|
|
PyObject *__pyx_v_linklen;
|
|
PyObject *__pyx_v_pyvalue;
|
|
PyObject *__pyx_r = NULL;
|
|
herr_t __pyx_t_1;
|
|
int __pyx_t_2;
|
|
PyObject *__pyx_t_3 = NULL;
|
|
PyObject *__pyx_t_4 = NULL;
|
|
size_t __pyx_t_5;
|
|
void *__pyx_t_6;
|
|
Py_ssize_t __pyx_t_7;
|
|
__Pyx_RefNannySetupContext("get_linkval");
|
|
assert(__pyx_arg_name); {
|
|
__pyx_v_name = __Pyx_PyBytes_AsString(__pyx_arg_name); if (unlikely((!__pyx_v_name) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 382; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
goto __pyx_L4_argument_unpacking_done;
|
|
__pyx_L3_error:;
|
|
__Pyx_AddTraceback("h5py.h5g.GroupID.get_linkval");
|
|
return NULL;
|
|
__pyx_L4_argument_unpacking_done:;
|
|
__Pyx_INCREF((PyObject *)__pyx_v_self);
|
|
__pyx_v_linklen = Py_None; __Pyx_INCREF(Py_None);
|
|
__pyx_v_pyvalue = Py_None; __Pyx_INCREF(Py_None);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":390
|
|
* cdef char* value
|
|
* cdef H5G_stat_t statbuf
|
|
* value = NULL # <<<<<<<<<<<<<<
|
|
*
|
|
* H5Gget_objinfo(self.id, name, 0, &statbuf)
|
|
*/
|
|
__pyx_v_value = NULL;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":392
|
|
* value = NULL
|
|
*
|
|
* H5Gget_objinfo(self.id, name, 0, &statbuf) # <<<<<<<<<<<<<<
|
|
*
|
|
* if statbuf.type != H5G_LINK:
|
|
*/
|
|
__pyx_t_1 = H5Gget_objinfo(((struct __pyx_obj_4h5py_3h5g_GroupID *)__pyx_v_self)->__pyx_base.id, __pyx_v_name, 0, (&__pyx_v_statbuf)); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 392; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":394
|
|
* H5Gget_objinfo(self.id, name, 0, &statbuf)
|
|
*
|
|
* if statbuf.type != H5G_LINK: # <<<<<<<<<<<<<<
|
|
* raise ValueError('"%s" is not a symbolic link.' % name)
|
|
*
|
|
*/
|
|
__pyx_t_2 = (__pyx_v_statbuf.type != H5G_LINK);
|
|
if (__pyx_t_2) {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":395
|
|
*
|
|
* if statbuf.type != H5G_LINK:
|
|
* raise ValueError('"%s" is not a symbolic link.' % name) # <<<<<<<<<<<<<<
|
|
*
|
|
* IF UNAME_SYSNAME == "Windows":
|
|
*/
|
|
__pyx_t_3 = __Pyx_PyBytes_FromString(__pyx_v_name); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 395; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__pyx_t_4 = PyNumber_Remainder(((PyObject *)__pyx_kp_s_5), __pyx_t_3); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 395; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__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 = 395; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__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 = 395; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__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 = 395; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
goto __pyx_L5;
|
|
}
|
|
__pyx_L5:;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":400
|
|
* linklen = 2049 # Windows statbuf.linklen seems broken
|
|
* ELSE:
|
|
* linklen = statbuf.linklen+1 # <<<<<<<<<<<<<<
|
|
* value = <char*>emalloc(sizeof(char)*linklen)
|
|
* try:
|
|
*/
|
|
__pyx_t_4 = __Pyx_PyInt_FromSize_t((__pyx_v_statbuf.linklen + 1)); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 400; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
__Pyx_DECREF(__pyx_v_linklen);
|
|
__pyx_v_linklen = __pyx_t_4;
|
|
__pyx_t_4 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":401
|
|
* ELSE:
|
|
* linklen = statbuf.linklen+1
|
|
* value = <char*>emalloc(sizeof(char)*linklen) # <<<<<<<<<<<<<<
|
|
* try:
|
|
* H5Gget_linkval(self.id, name, linklen, value)
|
|
*/
|
|
__pyx_t_4 = __Pyx_PyInt_FromSize_t((sizeof(char))); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 401; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
__pyx_t_3 = PyNumber_Multiply(__pyx_t_4, __pyx_v_linklen); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 401; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
__pyx_t_5 = __Pyx_PyInt_AsSize_t(__pyx_t_3); if (unlikely((__pyx_t_5 == (size_t)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 401; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
__pyx_t_6 = __pyx_f_4h5py_5utils_emalloc(__pyx_t_5); if (unlikely(__pyx_t_6 == NULL && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 401; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_v_value = ((char *)__pyx_t_6);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":402
|
|
* linklen = statbuf.linklen+1
|
|
* value = <char*>emalloc(sizeof(char)*linklen)
|
|
* try: # <<<<<<<<<<<<<<
|
|
* H5Gget_linkval(self.id, name, linklen, value)
|
|
* value[linklen-1] = c'\0' # in case HDF5 doesn't null terminate on Windows
|
|
*/
|
|
/*try:*/ {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":403
|
|
* value = <char*>emalloc(sizeof(char)*linklen)
|
|
* try:
|
|
* H5Gget_linkval(self.id, name, linklen, value) # <<<<<<<<<<<<<<
|
|
* value[linklen-1] = c'\0' # in case HDF5 doesn't null terminate on Windows
|
|
* pyvalue = value
|
|
*/
|
|
__pyx_t_5 = __Pyx_PyInt_AsSize_t(__pyx_v_linklen); if (unlikely((__pyx_t_5 == (size_t)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 403; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
__pyx_t_1 = H5Gget_linkval(((struct __pyx_obj_4h5py_3h5g_GroupID *)__pyx_v_self)->__pyx_base.id, __pyx_v_name, __pyx_t_5, __pyx_v_value); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 403; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":404
|
|
* try:
|
|
* H5Gget_linkval(self.id, name, linklen, value)
|
|
* value[linklen-1] = c'\0' # in case HDF5 doesn't null terminate on Windows # <<<<<<<<<<<<<<
|
|
* pyvalue = value
|
|
* return pyvalue
|
|
*/
|
|
__pyx_t_3 = PyNumber_Subtract(__pyx_v_linklen, __pyx_int_1); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 404; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__pyx_t_7 = __Pyx_PyIndex_AsSsize_t(__pyx_t_3); if (unlikely((__pyx_t_7 == (Py_ssize_t)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 404; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
(__pyx_v_value[__pyx_t_7]) = '\x00';
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":405
|
|
* H5Gget_linkval(self.id, name, linklen, value)
|
|
* value[linklen-1] = c'\0' # in case HDF5 doesn't null terminate on Windows
|
|
* pyvalue = value # <<<<<<<<<<<<<<
|
|
* return pyvalue
|
|
* finally:
|
|
*/
|
|
__pyx_t_3 = __Pyx_PyBytes_FromString(__pyx_v_value); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 405; __pyx_clineno = __LINE__; goto __pyx_L7;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__Pyx_DECREF(__pyx_v_pyvalue);
|
|
__pyx_v_pyvalue = __pyx_t_3;
|
|
__pyx_t_3 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":406
|
|
* value[linklen-1] = c'\0' # in case HDF5 doesn't null terminate on Windows
|
|
* pyvalue = value
|
|
* return pyvalue # <<<<<<<<<<<<<<
|
|
* finally:
|
|
* efree(value)
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__Pyx_INCREF(__pyx_v_pyvalue);
|
|
__pyx_r = __pyx_v_pyvalue;
|
|
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_4); __pyx_t_4 = 0;
|
|
__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/h5g.pyx":408
|
|
* return pyvalue
|
|
* finally:
|
|
* efree(value) # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__pyx_f_4h5py_5utils_efree(__pyx_v_value);
|
|
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_XDECREF(__pyx_t_4);
|
|
__Pyx_AddTraceback("h5py.h5g.GroupID.get_linkval");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_DECREF(__pyx_v_linklen);
|
|
__Pyx_DECREF(__pyx_v_pyvalue);
|
|
__Pyx_DECREF((PyObject *)__pyx_v_self);
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":411
|
|
*
|
|
*
|
|
* def set_comment(self, char* name, char* comment): # <<<<<<<<<<<<<<
|
|
* """(STRING name, STRING comment)
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5g_7GroupID_set_comment(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5g_7GroupID_set_comment[] = "(STRING name, STRING comment)\n\n Set the comment on a group member.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5g_7GroupID_set_comment(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
|
|
char *__pyx_v_name;
|
|
char *__pyx_v_comment;
|
|
PyObject *__pyx_r = NULL;
|
|
herr_t __pyx_t_1;
|
|
static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__name,&__pyx_n_s__comment,0};
|
|
__Pyx_RefNannySetupContext("set_comment");
|
|
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__name);
|
|
if (likely(values[0])) kw_args--;
|
|
else goto __pyx_L5_argtuple_error;
|
|
case 1:
|
|
values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__comment);
|
|
if (likely(values[1])) kw_args--;
|
|
else {
|
|
__Pyx_RaiseArgtupleInvalid("set_comment", 1, 2, 2, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 411; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
}
|
|
if (unlikely(kw_args > 0)) {
|
|
if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, PyTuple_GET_SIZE(__pyx_args), "set_comment") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 411; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
__pyx_v_name = __Pyx_PyBytes_AsString(values[0]); if (unlikely((!__pyx_v_name) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 411; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
__pyx_v_comment = __Pyx_PyBytes_AsString(values[1]); if (unlikely((!__pyx_v_comment) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 411; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
} else if (PyTuple_GET_SIZE(__pyx_args) != 2) {
|
|
goto __pyx_L5_argtuple_error;
|
|
} else {
|
|
__pyx_v_name = __Pyx_PyBytes_AsString(PyTuple_GET_ITEM(__pyx_args, 0)); if (unlikely((!__pyx_v_name) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 411; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
__pyx_v_comment = __Pyx_PyBytes_AsString(PyTuple_GET_ITEM(__pyx_args, 1)); if (unlikely((!__pyx_v_comment) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 411; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
goto __pyx_L4_argument_unpacking_done;
|
|
__pyx_L5_argtuple_error:;
|
|
__Pyx_RaiseArgtupleInvalid("set_comment", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 411; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
__pyx_L3_error:;
|
|
__Pyx_AddTraceback("h5py.h5g.GroupID.set_comment");
|
|
return NULL;
|
|
__pyx_L4_argument_unpacking_done:;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":416
|
|
* Set the comment on a group member.
|
|
* """
|
|
* H5Gset_comment(self.id, name, comment) # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__pyx_t_1 = H5Gset_comment(((struct __pyx_obj_4h5py_3h5g_GroupID *)__pyx_v_self)->__pyx_base.id, __pyx_v_name, __pyx_v_comment); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 416; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_AddTraceback("h5py.h5g.GroupID.set_comment");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":419
|
|
*
|
|
*
|
|
* def get_comment(self, char* name): # <<<<<<<<<<<<<<
|
|
* """(STRING name) => STRING comment
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5g_7GroupID_get_comment(PyObject *__pyx_v_self, PyObject *__pyx_arg_name); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5g_7GroupID_get_comment[] = "(STRING name) => STRING comment\n\n Retrieve the comment for a group member.\n ";
|
|
static PyObject *__pyx_pf_4h5py_3h5g_7GroupID_get_comment(PyObject *__pyx_v_self, PyObject *__pyx_arg_name) {
|
|
char *__pyx_v_name;
|
|
int __pyx_v_cmnt_len;
|
|
char *__pyx_v_cmnt;
|
|
PyObject *__pyx_v_py_cmnt;
|
|
PyObject *__pyx_r = NULL;
|
|
int __pyx_t_1;
|
|
void *__pyx_t_2;
|
|
PyObject *__pyx_t_3 = NULL;
|
|
__Pyx_RefNannySetupContext("get_comment");
|
|
assert(__pyx_arg_name); {
|
|
__pyx_v_name = __Pyx_PyBytes_AsString(__pyx_arg_name); if (unlikely((!__pyx_v_name) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 419; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
goto __pyx_L4_argument_unpacking_done;
|
|
__pyx_L3_error:;
|
|
__Pyx_AddTraceback("h5py.h5g.GroupID.get_comment");
|
|
return NULL;
|
|
__pyx_L4_argument_unpacking_done:;
|
|
__Pyx_INCREF((PyObject *)__pyx_v_self);
|
|
__pyx_v_py_cmnt = Py_None; __Pyx_INCREF(Py_None);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":426
|
|
* cdef int cmnt_len
|
|
* cdef char* cmnt
|
|
* cmnt = NULL # <<<<<<<<<<<<<<
|
|
*
|
|
* cmnt_len = H5Gget_comment(self.id, name, 0, NULL)
|
|
*/
|
|
__pyx_v_cmnt = NULL;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":428
|
|
* cmnt = NULL
|
|
*
|
|
* cmnt_len = H5Gget_comment(self.id, name, 0, NULL) # <<<<<<<<<<<<<<
|
|
* assert cmnt_len >= 0
|
|
*
|
|
*/
|
|
__pyx_t_1 = H5Gget_comment(((struct __pyx_obj_4h5py_3h5g_GroupID *)__pyx_v_self)->__pyx_base.id, __pyx_v_name, 0, NULL); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 428; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_v_cmnt_len = __pyx_t_1;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":429
|
|
*
|
|
* cmnt_len = H5Gget_comment(self.id, name, 0, NULL)
|
|
* assert cmnt_len >= 0 # <<<<<<<<<<<<<<
|
|
*
|
|
* cmnt = <char*>emalloc(sizeof(char)*(cmnt_len+1))
|
|
*/
|
|
#ifndef PYREX_WITHOUT_ASSERTIONS
|
|
if (unlikely(!(__pyx_v_cmnt_len >= 0))) {
|
|
PyErr_SetNone(PyExc_AssertionError);
|
|
{__pyx_filename = __pyx_f[0]; __pyx_lineno = 429; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
}
|
|
#endif
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":431
|
|
* assert cmnt_len >= 0
|
|
*
|
|
* cmnt = <char*>emalloc(sizeof(char)*(cmnt_len+1)) # <<<<<<<<<<<<<<
|
|
* try:
|
|
* H5Gget_comment(self.id, name, cmnt_len+1, cmnt)
|
|
*/
|
|
__pyx_t_2 = __pyx_f_4h5py_5utils_emalloc(((sizeof(char)) * (__pyx_v_cmnt_len + 1))); if (unlikely(__pyx_t_2 == NULL && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 431; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_v_cmnt = ((char *)__pyx_t_2);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":432
|
|
*
|
|
* cmnt = <char*>emalloc(sizeof(char)*(cmnt_len+1))
|
|
* try: # <<<<<<<<<<<<<<
|
|
* H5Gget_comment(self.id, name, cmnt_len+1, cmnt)
|
|
* py_cmnt = cmnt
|
|
*/
|
|
/*try:*/ {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":433
|
|
* cmnt = <char*>emalloc(sizeof(char)*(cmnt_len+1))
|
|
* try:
|
|
* H5Gget_comment(self.id, name, cmnt_len+1, cmnt) # <<<<<<<<<<<<<<
|
|
* py_cmnt = cmnt
|
|
* return py_cmnt
|
|
*/
|
|
__pyx_t_1 = H5Gget_comment(((struct __pyx_obj_4h5py_3h5g_GroupID *)__pyx_v_self)->__pyx_base.id, __pyx_v_name, (__pyx_v_cmnt_len + 1), __pyx_v_cmnt); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 433; __pyx_clineno = __LINE__; goto __pyx_L6;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":434
|
|
* try:
|
|
* H5Gget_comment(self.id, name, cmnt_len+1, cmnt)
|
|
* py_cmnt = cmnt # <<<<<<<<<<<<<<
|
|
* return py_cmnt
|
|
* finally:
|
|
*/
|
|
__pyx_t_3 = __Pyx_PyBytes_FromString(__pyx_v_cmnt); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 434; __pyx_clineno = __LINE__; goto __pyx_L6;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__Pyx_DECREF(__pyx_v_py_cmnt);
|
|
__pyx_v_py_cmnt = __pyx_t_3;
|
|
__pyx_t_3 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":435
|
|
* H5Gget_comment(self.id, name, cmnt_len+1, cmnt)
|
|
* py_cmnt = cmnt
|
|
* return py_cmnt # <<<<<<<<<<<<<<
|
|
* finally:
|
|
* efree(cmnt)
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__Pyx_INCREF(__pyx_v_py_cmnt);
|
|
__pyx_r = __pyx_v_py_cmnt;
|
|
goto __pyx_L5;
|
|
}
|
|
/*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_L7;
|
|
__pyx_L5: __pyx_exc_type = 0; __pyx_exc_value = 0; __pyx_exc_tb = 0; __pyx_exc_lineno = 0;
|
|
__pyx_why = 3; goto __pyx_L7;
|
|
__pyx_L6: {
|
|
__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_L7;
|
|
}
|
|
__pyx_L7:;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":437
|
|
* return py_cmnt
|
|
* finally:
|
|
* efree(cmnt) # <<<<<<<<<<<<<<
|
|
*
|
|
* # === Special methods =====================================================
|
|
*/
|
|
__pyx_f_4h5py_5utils_efree(__pyx_v_cmnt);
|
|
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.h5g.GroupID.get_comment");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_DECREF(__pyx_v_py_cmnt);
|
|
__Pyx_DECREF((PyObject *)__pyx_v_self);
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":442
|
|
*
|
|
*
|
|
* def __contains__(self, char* name): # <<<<<<<<<<<<<<
|
|
* """(STRING name)
|
|
*
|
|
*/
|
|
|
|
static int __pyx_pf_4h5py_3h5g_7GroupID___contains__(PyObject *__pyx_v_self, PyObject *__pyx_arg_name); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5g_7GroupID___contains__[] = "(STRING name)\n\n Determine if a group member of the given name is present\n ";
|
|
static int __pyx_pf_4h5py_3h5g_7GroupID___contains__(PyObject *__pyx_v_self, PyObject *__pyx_arg_name) {
|
|
char *__pyx_v_name;
|
|
herr_t __pyx_v_retval;
|
|
__pyx_t_4h5py_3h5e_err_cookie __pyx_v_cookie;
|
|
int __pyx_r;
|
|
__pyx_t_4h5py_3h5e_err_cookie __pyx_t_1;
|
|
herr_t __pyx_t_2;
|
|
PyObject *__pyx_t_3 = NULL;
|
|
PyObject *__pyx_t_4 = NULL;
|
|
int __pyx_t_5;
|
|
__Pyx_RefNannySetupContext("__contains__");
|
|
assert(__pyx_arg_name); {
|
|
__pyx_v_name = __Pyx_PyBytes_AsString(__pyx_arg_name); if (unlikely((!__pyx_v_name) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 442; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
goto __pyx_L4_argument_unpacking_done;
|
|
__pyx_L3_error:;
|
|
__Pyx_AddTraceback("h5py.h5g.GroupID.__contains__");
|
|
return -1;
|
|
__pyx_L4_argument_unpacking_done:;
|
|
__Pyx_INCREF((PyObject *)__pyx_v_self);
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":450
|
|
* cdef err_cookie cookie
|
|
*
|
|
* cookie = disable_errors() # <<<<<<<<<<<<<<
|
|
* try:
|
|
* retval = H5Gget_objinfo(self.id, name, 1, NULL)
|
|
*/
|
|
__pyx_t_1 = __pyx_f_4h5py_3h5e_disable_errors(); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 450; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_v_cookie = __pyx_t_1;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":451
|
|
*
|
|
* cookie = disable_errors()
|
|
* try: # <<<<<<<<<<<<<<
|
|
* retval = H5Gget_objinfo(self.id, name, 1, NULL)
|
|
* finally:
|
|
*/
|
|
/*try:*/ {
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":452
|
|
* cookie = disable_errors()
|
|
* try:
|
|
* retval = H5Gget_objinfo(self.id, name, 1, NULL) # <<<<<<<<<<<<<<
|
|
* finally:
|
|
* enable_errors(cookie)
|
|
*/
|
|
__pyx_t_2 = H5Gget_objinfo(((struct __pyx_obj_4h5py_3h5g_GroupID *)__pyx_v_self)->__pyx_base.id, __pyx_v_name, 1, NULL); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 452; __pyx_clineno = __LINE__; goto __pyx_L6;}
|
|
__pyx_v_retval = __pyx_t_2;
|
|
}
|
|
/*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_L7;
|
|
__pyx_L6: {
|
|
__pyx_why = 4;
|
|
__Pyx_ErrFetch(&__pyx_exc_type, &__pyx_exc_value, &__pyx_exc_tb);
|
|
__pyx_exc_lineno = __pyx_lineno;
|
|
goto __pyx_L7;
|
|
}
|
|
__pyx_L7:;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":454
|
|
* retval = H5Gget_objinfo(self.id, name, 1, NULL)
|
|
* finally:
|
|
* enable_errors(cookie) # <<<<<<<<<<<<<<
|
|
*
|
|
* return bool(retval >= 0)
|
|
*/
|
|
__pyx_f_4h5py_3h5e_enable_errors(__pyx_v_cookie); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 454; __pyx_clineno = __LINE__; goto __pyx_L8_error;}
|
|
goto __pyx_L9;
|
|
__pyx_L8_error:;
|
|
if (__pyx_why == 4) {
|
|
Py_XDECREF(__pyx_exc_type);
|
|
Py_XDECREF(__pyx_exc_value);
|
|
Py_XDECREF(__pyx_exc_tb);
|
|
}
|
|
goto __pyx_L1_error;
|
|
__pyx_L9:;
|
|
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;
|
|
}
|
|
}
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":456
|
|
* enable_errors(cookie)
|
|
*
|
|
* return bool(retval >= 0) # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__pyx_t_3 = __Pyx_PyBool_FromLong((__pyx_v_retval >= 0)); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 456; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__pyx_t_4 = PyTuple_New(1); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 456; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_3);
|
|
__Pyx_GIVEREF(__pyx_t_3);
|
|
__pyx_t_3 = 0;
|
|
__pyx_t_3 = PyObject_Call(((PyObject *)((PyObject*)&PyBool_Type)), __pyx_t_4, NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 456; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
__pyx_t_5 = __Pyx_PyInt_AsInt(__pyx_t_3); if (unlikely((__pyx_t_5 == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 456; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
__pyx_r = __pyx_t_5;
|
|
goto __pyx_L0;
|
|
|
|
__pyx_r = 0;
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_3);
|
|
__Pyx_XDECREF(__pyx_t_4);
|
|
__Pyx_AddTraceback("h5py.h5g.GroupID.__contains__");
|
|
__pyx_r = -1;
|
|
__pyx_L0:;
|
|
__Pyx_DECREF((PyObject *)__pyx_v_self);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":459
|
|
*
|
|
*
|
|
* def __iter__(self): # <<<<<<<<<<<<<<
|
|
* """ Return an iterator over the names of group members. """
|
|
* return GroupIter(self)
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4h5py_3h5g_7GroupID___iter__(PyObject *__pyx_v_self); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5g_7GroupID___iter__[] = " Return an iterator over the names of group members. ";
|
|
static PyObject *__pyx_pf_4h5py_3h5g_7GroupID___iter__(PyObject *__pyx_v_self) {
|
|
PyObject *__pyx_r = NULL;
|
|
PyObject *__pyx_t_1 = NULL;
|
|
PyObject *__pyx_t_2 = NULL;
|
|
__Pyx_RefNannySetupContext("__iter__");
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":461
|
|
* def __iter__(self):
|
|
* """ Return an iterator over the names of group members. """
|
|
* return GroupIter(self) # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_1 = PyTuple_New(1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 461; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__Pyx_INCREF(__pyx_v_self);
|
|
PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_v_self);
|
|
__Pyx_GIVEREF(__pyx_v_self);
|
|
__pyx_t_2 = PyObject_Call(((PyObject *)((PyObject*)__pyx_ptype_4h5py_3h5g_GroupIter)), __pyx_t_1, NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 461; __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.h5g.GroupID.__iter__");
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":464
|
|
*
|
|
*
|
|
* def __len__(self): # <<<<<<<<<<<<<<
|
|
* """ Number of group members """
|
|
* cdef hsize_t size
|
|
*/
|
|
|
|
static Py_ssize_t __pyx_pf_4h5py_3h5g_7GroupID___len__(PyObject *__pyx_v_self); /*proto*/
|
|
static char __pyx_doc_4h5py_3h5g_7GroupID___len__[] = " Number of group members ";
|
|
static Py_ssize_t __pyx_pf_4h5py_3h5g_7GroupID___len__(PyObject *__pyx_v_self) {
|
|
hsize_t __pyx_v_size;
|
|
Py_ssize_t __pyx_r;
|
|
herr_t __pyx_t_1;
|
|
__Pyx_RefNannySetupContext("__len__");
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":467
|
|
* """ Number of group members """
|
|
* cdef hsize_t size
|
|
* H5Gget_num_objs(self.id, &size) # <<<<<<<<<<<<<<
|
|
* return size
|
|
*
|
|
*/
|
|
__pyx_t_1 = H5Gget_num_objs(((struct __pyx_obj_4h5py_3h5g_GroupID *)__pyx_v_self)->__pyx_base.id, (&__pyx_v_size)); if (unlikely(PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 467; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":468
|
|
* cdef hsize_t size
|
|
* H5Gget_num_objs(self.id, &size)
|
|
* return size # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__pyx_r = __pyx_v_size;
|
|
goto __pyx_L0;
|
|
|
|
__pyx_r = 0;
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_AddTraceback("h5py.h5g.GroupID.__len__");
|
|
__pyx_r = -1;
|
|
__pyx_L0:;
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
static PyObject *__pyx_tp_new_4h5py_3h5g_GroupID(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_3h5g_GroupID(PyObject *o) {
|
|
__pyx_ptype_4h5py_2h5_ObjectID->tp_dealloc(o);
|
|
}
|
|
|
|
static int __pyx_tp_traverse_4h5py_3h5g_GroupID(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_3h5g_GroupID(PyObject *o) {
|
|
if (__pyx_ptype_4h5py_2h5_ObjectID->tp_clear) {
|
|
__pyx_ptype_4h5py_2h5_ObjectID->tp_clear(o);
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
static struct PyMethodDef __pyx_methods_4h5py_3h5g_GroupID[] = {
|
|
{__Pyx_NAMESTR("_close"), (PyCFunction)__pyx_pf_4h5py_3h5g_7GroupID__close, METH_NOARGS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5g_7GroupID__close)},
|
|
{__Pyx_NAMESTR("link"), (PyCFunction)__pyx_pf_4h5py_3h5g_7GroupID_link, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5g_7GroupID_link)},
|
|
{__Pyx_NAMESTR("unlink"), (PyCFunction)__pyx_pf_4h5py_3h5g_7GroupID_unlink, METH_O, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5g_7GroupID_unlink)},
|
|
{__Pyx_NAMESTR("move"), (PyCFunction)__pyx_pf_4h5py_3h5g_7GroupID_move, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5g_7GroupID_move)},
|
|
{__Pyx_NAMESTR("get_num_objs"), (PyCFunction)__pyx_pf_4h5py_3h5g_7GroupID_get_num_objs, METH_NOARGS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5g_7GroupID_get_num_objs)},
|
|
{__Pyx_NAMESTR("get_objname_by_idx"), (PyCFunction)__pyx_pf_4h5py_3h5g_7GroupID_get_objname_by_idx, METH_O, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5g_7GroupID_get_objname_by_idx)},
|
|
{__Pyx_NAMESTR("get_objtype_by_idx"), (PyCFunction)__pyx_pf_4h5py_3h5g_7GroupID_get_objtype_by_idx, METH_O, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5g_7GroupID_get_objtype_by_idx)},
|
|
{__Pyx_NAMESTR("get_linkval"), (PyCFunction)__pyx_pf_4h5py_3h5g_7GroupID_get_linkval, METH_O, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5g_7GroupID_get_linkval)},
|
|
{__Pyx_NAMESTR("set_comment"), (PyCFunction)__pyx_pf_4h5py_3h5g_7GroupID_set_comment, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5g_7GroupID_set_comment)},
|
|
{__Pyx_NAMESTR("get_comment"), (PyCFunction)__pyx_pf_4h5py_3h5g_7GroupID_get_comment, METH_O, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5g_7GroupID_get_comment)},
|
|
{__Pyx_NAMESTR("__iter__"), (PyCFunction)__pyx_pf_4h5py_3h5g_7GroupID___iter__, METH_NOARGS|METH_COEXIST, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5g_7GroupID___iter__)},
|
|
{0, 0, 0, 0}
|
|
};
|
|
|
|
static PyNumberMethods __pyx_tp_as_number_GroupID = {
|
|
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_GroupID = {
|
|
__pyx_pf_4h5py_3h5g_7GroupID___len__, /*sq_length*/
|
|
0, /*sq_concat*/
|
|
0, /*sq_repeat*/
|
|
0, /*sq_item*/
|
|
0, /*sq_slice*/
|
|
0, /*sq_ass_item*/
|
|
0, /*sq_ass_slice*/
|
|
__pyx_pf_4h5py_3h5g_7GroupID___contains__, /*sq_contains*/
|
|
0, /*sq_inplace_concat*/
|
|
0, /*sq_inplace_repeat*/
|
|
};
|
|
|
|
static PyMappingMethods __pyx_tp_as_mapping_GroupID = {
|
|
__pyx_pf_4h5py_3h5g_7GroupID___len__, /*mp_length*/
|
|
0, /*mp_subscript*/
|
|
0, /*mp_ass_subscript*/
|
|
};
|
|
|
|
static PyBufferProcs __pyx_tp_as_buffer_GroupID = {
|
|
#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_3h5g_GroupID = {
|
|
PyVarObject_HEAD_INIT(0, 0)
|
|
__Pyx_NAMESTR("h5py.h5g.GroupID"), /*tp_name*/
|
|
sizeof(struct __pyx_obj_4h5py_3h5g_GroupID), /*tp_basicsize*/
|
|
0, /*tp_itemsize*/
|
|
__pyx_tp_dealloc_4h5py_3h5g_GroupID, /*tp_dealloc*/
|
|
0, /*tp_print*/
|
|
0, /*tp_getattr*/
|
|
0, /*tp_setattr*/
|
|
0, /*tp_compare*/
|
|
0, /*tp_repr*/
|
|
&__pyx_tp_as_number_GroupID, /*tp_as_number*/
|
|
&__pyx_tp_as_sequence_GroupID, /*tp_as_sequence*/
|
|
&__pyx_tp_as_mapping_GroupID, /*tp_as_mapping*/
|
|
0, /*tp_hash*/
|
|
0, /*tp_call*/
|
|
0, /*tp_str*/
|
|
0, /*tp_getattro*/
|
|
0, /*tp_setattro*/
|
|
&__pyx_tp_as_buffer_GroupID, /*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 an HDF5 group identifier\n\n Python extensions:\n\n __contains__\n Test for group member (\"if name in grpid\")\n\n __iter__\n Get an iterator over member names\n\n __len__\n Number of members in this group; len(grpid) = N\n\n If HDF5 1.8.X is used, the attribute \"links\" contains a proxy object\n providing access to the H5L family of routines. See the docs\n for h5py.h5l.LinkProxy for more information.\n\n * Hashable: Yes, unless anonymous\n * Equality: True HDF5 identity unless anonymous\n "), /*tp_doc*/
|
|
__pyx_tp_traverse_4h5py_3h5g_GroupID, /*tp_traverse*/
|
|
__pyx_tp_clear_4h5py_3h5g_GroupID, /*tp_clear*/
|
|
0, /*tp_richcompare*/
|
|
0, /*tp_weaklistoffset*/
|
|
__pyx_pf_4h5py_3h5g_7GroupID___iter__, /*tp_iter*/
|
|
0, /*tp_iternext*/
|
|
__pyx_methods_4h5py_3h5g_GroupID, /*tp_methods*/
|
|
0, /*tp_members*/
|
|
0, /*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_3h5g_GroupID, /*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 PyObject *__pyx_tp_new_4h5py_3h5g_GroupStat(PyTypeObject *t, PyObject *a, PyObject *k) {
|
|
PyObject *o = __pyx_ptype_4h5py_2h5_SmartStruct->tp_new(t, a, k);
|
|
if (!o) return 0;
|
|
return o;
|
|
}
|
|
|
|
static void __pyx_tp_dealloc_4h5py_3h5g_GroupStat(PyObject *o) {
|
|
__pyx_ptype_4h5py_2h5_SmartStruct->tp_dealloc(o);
|
|
}
|
|
|
|
static int __pyx_tp_traverse_4h5py_3h5g_GroupStat(PyObject *o, visitproc v, void *a) {
|
|
int e;
|
|
if (__pyx_ptype_4h5py_2h5_SmartStruct->tp_traverse) {
|
|
e = __pyx_ptype_4h5py_2h5_SmartStruct->tp_traverse(o, v, a); if (e) return e;
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
static int __pyx_tp_clear_4h5py_3h5g_GroupStat(PyObject *o) {
|
|
if (__pyx_ptype_4h5py_2h5_SmartStruct->tp_clear) {
|
|
__pyx_ptype_4h5py_2h5_SmartStruct->tp_clear(o);
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
static PyObject *__pyx_getprop_4h5py_3h5g_9GroupStat_fileno(PyObject *o, void *x) {
|
|
return __pyx_pf_4h5py_3h5g_9GroupStat_6fileno___get__(o);
|
|
}
|
|
|
|
static PyObject *__pyx_getprop_4h5py_3h5g_9GroupStat_objno(PyObject *o, void *x) {
|
|
return __pyx_pf_4h5py_3h5g_9GroupStat_5objno___get__(o);
|
|
}
|
|
|
|
static PyObject *__pyx_getprop_4h5py_3h5g_9GroupStat_nlink(PyObject *o, void *x) {
|
|
return __pyx_pf_4h5py_3h5g_9GroupStat_5nlink___get__(o);
|
|
}
|
|
|
|
static PyObject *__pyx_getprop_4h5py_3h5g_9GroupStat_type(PyObject *o, void *x) {
|
|
return __pyx_pf_4h5py_3h5g_9GroupStat_4type___get__(o);
|
|
}
|
|
|
|
static PyObject *__pyx_getprop_4h5py_3h5g_9GroupStat_mtime(PyObject *o, void *x) {
|
|
return __pyx_pf_4h5py_3h5g_9GroupStat_5mtime___get__(o);
|
|
}
|
|
|
|
static PyObject *__pyx_getprop_4h5py_3h5g_9GroupStat_linklen(PyObject *o, void *x) {
|
|
return __pyx_pf_4h5py_3h5g_9GroupStat_7linklen___get__(o);
|
|
}
|
|
|
|
static struct PyMethodDef __pyx_methods_4h5py_3h5g_GroupStat[] = {
|
|
{__Pyx_NAMESTR("_hash"), (PyCFunction)__pyx_pf_4h5py_3h5g_9GroupStat__hash, METH_NOARGS, __Pyx_DOCSTR(0)},
|
|
{0, 0, 0, 0}
|
|
};
|
|
|
|
static struct PyGetSetDef __pyx_getsets_4h5py_3h5g_GroupStat[] = {
|
|
{(char *)"fileno", __pyx_getprop_4h5py_3h5g_9GroupStat_fileno, 0, 0, 0},
|
|
{(char *)"objno", __pyx_getprop_4h5py_3h5g_9GroupStat_objno, 0, 0, 0},
|
|
{(char *)"nlink", __pyx_getprop_4h5py_3h5g_9GroupStat_nlink, 0, 0, 0},
|
|
{(char *)"type", __pyx_getprop_4h5py_3h5g_9GroupStat_type, 0, 0, 0},
|
|
{(char *)"mtime", __pyx_getprop_4h5py_3h5g_9GroupStat_mtime, 0, 0, 0},
|
|
{(char *)"linklen", __pyx_getprop_4h5py_3h5g_9GroupStat_linklen, 0, 0, 0},
|
|
{0, 0, 0, 0, 0}
|
|
};
|
|
|
|
static PyNumberMethods __pyx_tp_as_number_GroupStat = {
|
|
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_GroupStat = {
|
|
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_GroupStat = {
|
|
0, /*mp_length*/
|
|
0, /*mp_subscript*/
|
|
0, /*mp_ass_subscript*/
|
|
};
|
|
|
|
static PyBufferProcs __pyx_tp_as_buffer_GroupStat = {
|
|
#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_3h5g_GroupStat = {
|
|
PyVarObject_HEAD_INIT(0, 0)
|
|
__Pyx_NAMESTR("h5py.h5g.GroupStat"), /*tp_name*/
|
|
sizeof(struct __pyx_obj_4h5py_3h5g_GroupStat), /*tp_basicsize*/
|
|
0, /*tp_itemsize*/
|
|
__pyx_tp_dealloc_4h5py_3h5g_GroupStat, /*tp_dealloc*/
|
|
0, /*tp_print*/
|
|
0, /*tp_getattr*/
|
|
0, /*tp_setattr*/
|
|
0, /*tp_compare*/
|
|
0, /*tp_repr*/
|
|
&__pyx_tp_as_number_GroupStat, /*tp_as_number*/
|
|
&__pyx_tp_as_sequence_GroupStat, /*tp_as_sequence*/
|
|
&__pyx_tp_as_mapping_GroupStat, /*tp_as_mapping*/
|
|
0, /*tp_hash*/
|
|
0, /*tp_call*/
|
|
0, /*tp_str*/
|
|
0, /*tp_getattro*/
|
|
0, /*tp_setattro*/
|
|
&__pyx_tp_as_buffer_GroupStat, /*tp_as_buffer*/
|
|
Py_TPFLAGS_DEFAULT|Py_TPFLAGS_CHECKTYPES|Py_TPFLAGS_BASETYPE|Py_TPFLAGS_HAVE_NEWBUFFER|Py_TPFLAGS_HAVE_GC, /*tp_flags*/
|
|
__Pyx_DOCSTR("Represents the H5G_stat_t structure containing group member info.\n\n Fields (read-only):\n\n * fileno: 2-tuple uniquely identifying the current file\n * objno: 2-tuple uniquely identifying this object\n * nlink: Number of hard links to this object\n * mtime: Modification time of this object\n * linklen: Length of the symbolic link name, or 0 if not a link.\n\n \"Uniquely identifying\" means unique among currently open files, \n not universally unique.\n\n * Hashable: Yes\n * Equality: Yes\n "), /*tp_doc*/
|
|
__pyx_tp_traverse_4h5py_3h5g_GroupStat, /*tp_traverse*/
|
|
__pyx_tp_clear_4h5py_3h5g_GroupStat, /*tp_clear*/
|
|
0, /*tp_richcompare*/
|
|
0, /*tp_weaklistoffset*/
|
|
0, /*tp_iter*/
|
|
0, /*tp_iternext*/
|
|
__pyx_methods_4h5py_3h5g_GroupStat, /*tp_methods*/
|
|
0, /*tp_members*/
|
|
__pyx_getsets_4h5py_3h5g_GroupStat, /*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_3h5g_GroupStat, /*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 PyObject *__pyx_tp_new_4h5py_3h5g_GroupIter(PyTypeObject *t, PyObject *a, PyObject *k) {
|
|
struct __pyx_obj_4h5py_3h5g_GroupIter *p;
|
|
PyObject *o = (*t->tp_alloc)(t, 0);
|
|
if (!o) return 0;
|
|
p = ((struct __pyx_obj_4h5py_3h5g_GroupIter *)o);
|
|
p->grp = ((struct __pyx_obj_4h5py_3h5g_GroupID *)Py_None); Py_INCREF(Py_None);
|
|
return o;
|
|
}
|
|
|
|
static void __pyx_tp_dealloc_4h5py_3h5g_GroupIter(PyObject *o) {
|
|
struct __pyx_obj_4h5py_3h5g_GroupIter *p = (struct __pyx_obj_4h5py_3h5g_GroupIter *)o;
|
|
Py_XDECREF(((PyObject *)p->grp));
|
|
(*Py_TYPE(o)->tp_free)(o);
|
|
}
|
|
|
|
static int __pyx_tp_traverse_4h5py_3h5g_GroupIter(PyObject *o, visitproc v, void *a) {
|
|
int e;
|
|
struct __pyx_obj_4h5py_3h5g_GroupIter *p = (struct __pyx_obj_4h5py_3h5g_GroupIter *)o;
|
|
if (p->grp) {
|
|
e = (*v)(((PyObject*)p->grp), a); if (e) return e;
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
static int __pyx_tp_clear_4h5py_3h5g_GroupIter(PyObject *o) {
|
|
struct __pyx_obj_4h5py_3h5g_GroupIter *p = (struct __pyx_obj_4h5py_3h5g_GroupIter *)o;
|
|
PyObject* tmp;
|
|
tmp = ((PyObject*)p->grp);
|
|
p->grp = ((struct __pyx_obj_4h5py_3h5g_GroupID *)Py_None); Py_INCREF(Py_None);
|
|
Py_XDECREF(tmp);
|
|
return 0;
|
|
}
|
|
|
|
static struct PyMethodDef __pyx_methods_4h5py_3h5g_GroupIter[] = {
|
|
{__Pyx_NAMESTR("__iter__"), (PyCFunction)__pyx_pf_4h5py_3h5g_9GroupIter___iter__, METH_NOARGS|METH_COEXIST, __Pyx_DOCSTR(0)},
|
|
{__Pyx_NAMESTR("__next__"), (PyCFunction)__pyx_pf_4h5py_3h5g_9GroupIter___next__, METH_NOARGS|METH_COEXIST, __Pyx_DOCSTR(0)},
|
|
{0, 0, 0, 0}
|
|
};
|
|
|
|
static PyNumberMethods __pyx_tp_as_number_GroupIter = {
|
|
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_GroupIter = {
|
|
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_GroupIter = {
|
|
0, /*mp_length*/
|
|
0, /*mp_subscript*/
|
|
0, /*mp_ass_subscript*/
|
|
};
|
|
|
|
static PyBufferProcs __pyx_tp_as_buffer_GroupIter = {
|
|
#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_3h5g_GroupIter = {
|
|
PyVarObject_HEAD_INIT(0, 0)
|
|
__Pyx_NAMESTR("h5py.h5g.GroupIter"), /*tp_name*/
|
|
sizeof(struct __pyx_obj_4h5py_3h5g_GroupIter), /*tp_basicsize*/
|
|
0, /*tp_itemsize*/
|
|
__pyx_tp_dealloc_4h5py_3h5g_GroupIter, /*tp_dealloc*/
|
|
0, /*tp_print*/
|
|
0, /*tp_getattr*/
|
|
0, /*tp_setattr*/
|
|
0, /*tp_compare*/
|
|
0, /*tp_repr*/
|
|
&__pyx_tp_as_number_GroupIter, /*tp_as_number*/
|
|
&__pyx_tp_as_sequence_GroupIter, /*tp_as_sequence*/
|
|
&__pyx_tp_as_mapping_GroupIter, /*tp_as_mapping*/
|
|
0, /*tp_hash*/
|
|
0, /*tp_call*/
|
|
0, /*tp_str*/
|
|
0, /*tp_getattro*/
|
|
0, /*tp_setattro*/
|
|
&__pyx_tp_as_buffer_GroupIter, /*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 Iterator over the names of group members. After this iterator is\n exhausted, it releases its reference to the group ID.\n "), /*tp_doc*/
|
|
__pyx_tp_traverse_4h5py_3h5g_GroupIter, /*tp_traverse*/
|
|
__pyx_tp_clear_4h5py_3h5g_GroupIter, /*tp_clear*/
|
|
0, /*tp_richcompare*/
|
|
0, /*tp_weaklistoffset*/
|
|
__pyx_pf_4h5py_3h5g_9GroupIter___iter__, /*tp_iter*/
|
|
__pyx_pf_4h5py_3h5g_9GroupIter___next__, /*tp_iternext*/
|
|
__pyx_methods_4h5py_3h5g_GroupIter, /*tp_methods*/
|
|
0, /*tp_members*/
|
|
0, /*tp_getset*/
|
|
0, /*tp_base*/
|
|
0, /*tp_dict*/
|
|
0, /*tp_descr_get*/
|
|
0, /*tp_descr_set*/
|
|
0, /*tp_dictoffset*/
|
|
__pyx_pf_4h5py_3h5g_9GroupIter___init__, /*tp_init*/
|
|
0, /*tp_alloc*/
|
|
__pyx_tp_new_4h5py_3h5g_GroupIter, /*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 PyObject *__pyx_tp_new_4h5py_3h5g__GroupVisitor(PyTypeObject *t, PyObject *a, PyObject *k) {
|
|
struct __pyx_obj_4h5py_3h5g__GroupVisitor *p;
|
|
PyObject *o = (*t->tp_alloc)(t, 0);
|
|
if (!o) return 0;
|
|
p = ((struct __pyx_obj_4h5py_3h5g__GroupVisitor *)o);
|
|
p->func = Py_None; Py_INCREF(Py_None);
|
|
p->retval = Py_None; Py_INCREF(Py_None);
|
|
return o;
|
|
}
|
|
|
|
static void __pyx_tp_dealloc_4h5py_3h5g__GroupVisitor(PyObject *o) {
|
|
struct __pyx_obj_4h5py_3h5g__GroupVisitor *p = (struct __pyx_obj_4h5py_3h5g__GroupVisitor *)o;
|
|
Py_XDECREF(p->func);
|
|
Py_XDECREF(p->retval);
|
|
(*Py_TYPE(o)->tp_free)(o);
|
|
}
|
|
|
|
static int __pyx_tp_traverse_4h5py_3h5g__GroupVisitor(PyObject *o, visitproc v, void *a) {
|
|
int e;
|
|
struct __pyx_obj_4h5py_3h5g__GroupVisitor *p = (struct __pyx_obj_4h5py_3h5g__GroupVisitor *)o;
|
|
if (p->func) {
|
|
e = (*v)(p->func, a); if (e) return e;
|
|
}
|
|
if (p->retval) {
|
|
e = (*v)(p->retval, a); if (e) return e;
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
static int __pyx_tp_clear_4h5py_3h5g__GroupVisitor(PyObject *o) {
|
|
struct __pyx_obj_4h5py_3h5g__GroupVisitor *p = (struct __pyx_obj_4h5py_3h5g__GroupVisitor *)o;
|
|
PyObject* tmp;
|
|
tmp = ((PyObject*)p->func);
|
|
p->func = Py_None; Py_INCREF(Py_None);
|
|
Py_XDECREF(tmp);
|
|
tmp = ((PyObject*)p->retval);
|
|
p->retval = Py_None; Py_INCREF(Py_None);
|
|
Py_XDECREF(tmp);
|
|
return 0;
|
|
}
|
|
|
|
static struct PyMethodDef __pyx_methods_4h5py_3h5g__GroupVisitor[] = {
|
|
{0, 0, 0, 0}
|
|
};
|
|
|
|
static PyNumberMethods __pyx_tp_as_number__GroupVisitor = {
|
|
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__GroupVisitor = {
|
|
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__GroupVisitor = {
|
|
0, /*mp_length*/
|
|
0, /*mp_subscript*/
|
|
0, /*mp_ass_subscript*/
|
|
};
|
|
|
|
static PyBufferProcs __pyx_tp_as_buffer__GroupVisitor = {
|
|
#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_3h5g__GroupVisitor = {
|
|
PyVarObject_HEAD_INIT(0, 0)
|
|
__Pyx_NAMESTR("h5py.h5g._GroupVisitor"), /*tp_name*/
|
|
sizeof(struct __pyx_obj_4h5py_3h5g__GroupVisitor), /*tp_basicsize*/
|
|
0, /*tp_itemsize*/
|
|
__pyx_tp_dealloc_4h5py_3h5g__GroupVisitor, /*tp_dealloc*/
|
|
0, /*tp_print*/
|
|
0, /*tp_getattr*/
|
|
0, /*tp_setattr*/
|
|
0, /*tp_compare*/
|
|
0, /*tp_repr*/
|
|
&__pyx_tp_as_number__GroupVisitor, /*tp_as_number*/
|
|
&__pyx_tp_as_sequence__GroupVisitor, /*tp_as_sequence*/
|
|
&__pyx_tp_as_mapping__GroupVisitor, /*tp_as_mapping*/
|
|
0, /*tp_hash*/
|
|
0, /*tp_call*/
|
|
0, /*tp_str*/
|
|
0, /*tp_getattro*/
|
|
0, /*tp_setattro*/
|
|
&__pyx_tp_as_buffer__GroupVisitor, /*tp_as_buffer*/
|
|
Py_TPFLAGS_DEFAULT|Py_TPFLAGS_CHECKTYPES|Py_TPFLAGS_BASETYPE|Py_TPFLAGS_HAVE_NEWBUFFER|Py_TPFLAGS_HAVE_GC, /*tp_flags*/
|
|
0, /*tp_doc*/
|
|
__pyx_tp_traverse_4h5py_3h5g__GroupVisitor, /*tp_traverse*/
|
|
__pyx_tp_clear_4h5py_3h5g__GroupVisitor, /*tp_clear*/
|
|
0, /*tp_richcompare*/
|
|
0, /*tp_weaklistoffset*/
|
|
0, /*tp_iter*/
|
|
0, /*tp_iternext*/
|
|
__pyx_methods_4h5py_3h5g__GroupVisitor, /*tp_methods*/
|
|
0, /*tp_members*/
|
|
0, /*tp_getset*/
|
|
0, /*tp_base*/
|
|
0, /*tp_dict*/
|
|
0, /*tp_descr_get*/
|
|
0, /*tp_descr_set*/
|
|
0, /*tp_dictoffset*/
|
|
__pyx_pf_4h5py_3h5g_13_GroupVisitor___init__, /*tp_init*/
|
|
0, /*tp_alloc*/
|
|
__pyx_tp_new_4h5py_3h5g__GroupVisitor, /*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("open"), (PyCFunction)__pyx_pf_4h5py_3h5g_open, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5g_open)},
|
|
{__Pyx_NAMESTR("create"), (PyCFunction)__pyx_pf_4h5py_3h5g_create, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5g_create)},
|
|
{__Pyx_NAMESTR("iterate"), (PyCFunction)__pyx_pf_4h5py_3h5g_iterate, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5g_iterate)},
|
|
{__Pyx_NAMESTR("get_objinfo"), (PyCFunction)__pyx_pf_4h5py_3h5g_get_objinfo, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(__pyx_doc_4h5py_3h5g_get_objinfo)},
|
|
{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("h5g"),
|
|
__Pyx_DOCSTR(__pyx_k_6), /* 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_kp_s_1, __pyx_k_1, sizeof(__pyx_k_1), 0, 0, 1, 0},
|
|
{&__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_kp_s_5, __pyx_k_5, sizeof(__pyx_k_5), 0, 0, 1, 0},
|
|
{&__pyx_n_s__DATASET, __pyx_k__DATASET, sizeof(__pyx_k__DATASET), 0, 0, 1, 1},
|
|
{&__pyx_n_s__GROUP, __pyx_k__GROUP, sizeof(__pyx_k__GROUP), 0, 0, 1, 1},
|
|
{&__pyx_n_s__H5Error, __pyx_k__H5Error, sizeof(__pyx_k__H5Error), 0, 0, 1, 1},
|
|
{&__pyx_n_s__LINK, __pyx_k__LINK, sizeof(__pyx_k__LINK), 0, 0, 1, 1},
|
|
{&__pyx_n_s__LINK_ERROR, __pyx_k__LINK_ERROR, sizeof(__pyx_k__LINK_ERROR), 0, 0, 1, 1},
|
|
{&__pyx_n_s__LINK_HARD, __pyx_k__LINK_HARD, sizeof(__pyx_k__LINK_HARD), 0, 0, 1, 1},
|
|
{&__pyx_n_s__LINK_SOFT, __pyx_k__LINK_SOFT, sizeof(__pyx_k__LINK_SOFT), 0, 0, 1, 1},
|
|
{&__pyx_n_s__StopIteration, __pyx_k__StopIteration, sizeof(__pyx_k__StopIteration), 0, 0, 1, 1},
|
|
{&__pyx_n_s__TYPE, __pyx_k__TYPE, sizeof(__pyx_k__TYPE), 0, 0, 1, 1},
|
|
{&__pyx_n_s__UNKNOWN, __pyx_k__UNKNOWN, sizeof(__pyx_k__UNKNOWN), 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__comment, __pyx_k__comment, sizeof(__pyx_k__comment), 0, 0, 1, 1},
|
|
{&__pyx_n_s__current_name, __pyx_k__current_name, sizeof(__pyx_k__current_name), 0, 0, 1, 1},
|
|
{&__pyx_n_s__fileno, __pyx_k__fileno, sizeof(__pyx_k__fileno), 0, 0, 1, 1},
|
|
{&__pyx_n_s__follow_link, __pyx_k__follow_link, sizeof(__pyx_k__follow_link), 0, 0, 1, 1},
|
|
{&__pyx_n_s__func, __pyx_k__func, sizeof(__pyx_k__func), 0, 0, 1, 1},
|
|
{&__pyx_n_s__get_num_objs, __pyx_k__get_num_objs, sizeof(__pyx_k__get_num_objs), 0, 0, 1, 1},
|
|
{&__pyx_n_s__get_objname_by_idx, __pyx_k__get_objname_by_idx, sizeof(__pyx_k__get_objname_by_idx), 0, 0, 1, 1},
|
|
{&__pyx_n_s__grp, __pyx_k__grp, sizeof(__pyx_k__grp), 0, 0, 1, 1},
|
|
{&__pyx_n_s__h5, __pyx_k__h5, sizeof(__pyx_k__h5), 0, 0, 1, 1},
|
|
{&__pyx_n_s__id, __pyx_k__id, sizeof(__pyx_k__id), 0, 0, 1, 1},
|
|
{&__pyx_n_s__idx, __pyx_k__idx, sizeof(__pyx_k__idx), 0, 0, 1, 1},
|
|
{&__pyx_n_s__infostruct, __pyx_k__infostruct, sizeof(__pyx_k__infostruct), 0, 0, 1, 1},
|
|
{&__pyx_n_s__link_type, __pyx_k__link_type, sizeof(__pyx_k__link_type), 0, 0, 1, 1},
|
|
{&__pyx_n_s__linklen, __pyx_k__linklen, sizeof(__pyx_k__linklen), 0, 0, 1, 1},
|
|
{&__pyx_n_s__loc, __pyx_k__loc, sizeof(__pyx_k__loc), 0, 0, 1, 1},
|
|
{&__pyx_n_s__mtime, __pyx_k__mtime, sizeof(__pyx_k__mtime), 0, 0, 1, 1},
|
|
{&__pyx_n_s__name, __pyx_k__name, sizeof(__pyx_k__name), 0, 0, 1, 1},
|
|
{&__pyx_n_s__new_name, __pyx_k__new_name, sizeof(__pyx_k__new_name), 0, 0, 1, 1},
|
|
{&__pyx_n_s__nlink, __pyx_k__nlink, sizeof(__pyx_k__nlink), 0, 0, 1, 1},
|
|
{&__pyx_n_s__nobjs, __pyx_k__nobjs, sizeof(__pyx_k__nobjs), 0, 0, 1, 1},
|
|
{&__pyx_n_s__obj, __pyx_k__obj, sizeof(__pyx_k__obj), 0, 0, 1, 1},
|
|
{&__pyx_n_s__obj_name, __pyx_k__obj_name, sizeof(__pyx_k__obj_name), 0, 0, 1, 1},
|
|
{&__pyx_n_s__objno, __pyx_k__objno, sizeof(__pyx_k__objno), 0, 0, 1, 1},
|
|
{&__pyx_n_s__remote, __pyx_k__remote, sizeof(__pyx_k__remote), 0, 0, 1, 1},
|
|
{&__pyx_n_s__retval, __pyx_k__retval, sizeof(__pyx_k__retval), 0, 0, 1, 1},
|
|
{&__pyx_n_s__startidx, __pyx_k__startidx, sizeof(__pyx_k__startidx), 0, 0, 1, 1},
|
|
{&__pyx_n_s__type, __pyx_k__type, sizeof(__pyx_k__type), 0, 0, 1, 1},
|
|
{0, 0, 0, 0, 0, 0, 0}
|
|
};
|
|
static int __Pyx_InitCachedBuiltins(void) {
|
|
__pyx_builtin_StopIteration = __Pyx_GetName(__pyx_b, __pyx_n_s__StopIteration); if (!__pyx_builtin_StopIteration) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 111; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_builtin_ValueError = __Pyx_GetName(__pyx_b, __pyx_n_s__ValueError); if (!__pyx_builtin_ValueError) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 196; __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;};
|
|
__pyx_int_1 = PyInt_FromLong(1); if (unlikely(!__pyx_int_1)) {__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 inith5g(void); /*proto*/
|
|
PyMODINIT_FUNC inith5g(void)
|
|
#else
|
|
PyMODINIT_FUNC PyInit_h5g(void); /*proto*/
|
|
PyMODINIT_FUNC PyInit_h5g(void)
|
|
#endif
|
|
{
|
|
PyObject *__pyx_t_1 = NULL;
|
|
PyObject *__pyx_t_2 = NULL;
|
|
PyObject *__pyx_t_3 = NULL;
|
|
PyObject *__pyx_t_4 = NULL;
|
|
int __pyx_t_5;
|
|
PyObject *__pyx_t_6 = NULL;
|
|
PyObject *__pyx_t_7 = 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_h5g(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("h5g"), __pyx_methods, __Pyx_DOCSTR(__pyx_k_6), 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__h5g) {
|
|
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_3h5g_GroupID.tp_base = __pyx_ptype_4h5py_2h5_ObjectID;
|
|
if (PyType_Ready(&__pyx_type_4h5py_3h5g_GroupID) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 229; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
if (__Pyx_SetAttrString(__pyx_m, "GroupID", (PyObject *)&__pyx_type_4h5py_3h5g_GroupID) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 229; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
if (__pyx_type_4h5py_3h5g_GroupID.tp_weaklistoffset == 0) __pyx_type_4h5py_3h5g_GroupID.tp_weaklistoffset = offsetof(struct __pyx_obj_4h5py_3h5g_GroupID, __pyx_base.__weakref__);
|
|
__pyx_ptype_4h5py_3h5g_GroupID = &__pyx_type_4h5py_3h5g_GroupID;
|
|
__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[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_type_4h5py_3h5g_GroupStat.tp_base = __pyx_ptype_4h5py_2h5_SmartStruct;
|
|
if (PyType_Ready(&__pyx_type_4h5py_3h5g_GroupStat) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 47; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
if (__Pyx_SetAttrString(__pyx_m, "GroupStat", (PyObject *)&__pyx_type_4h5py_3h5g_GroupStat) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 47; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
if (__pyx_type_4h5py_3h5g_GroupStat.tp_weaklistoffset == 0) __pyx_type_4h5py_3h5g_GroupStat.tp_weaklistoffset = offsetof(struct __pyx_obj_4h5py_3h5g_GroupStat, __pyx_base.__weakref__);
|
|
__pyx_ptype_4h5py_3h5g_GroupStat = &__pyx_type_4h5py_3h5g_GroupStat;
|
|
if (PyType_Ready(&__pyx_type_4h5py_3h5g_GroupIter) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 89; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
if (__Pyx_SetAttrString(__pyx_m, "GroupIter", (PyObject *)&__pyx_type_4h5py_3h5g_GroupIter) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 89; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_ptype_4h5py_3h5g_GroupIter = &__pyx_type_4h5py_3h5g_GroupIter;
|
|
if (PyType_Ready(&__pyx_type_4h5py_3h5g__GroupVisitor) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 159; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
if (__Pyx_SetAttrString(__pyx_m, "_GroupVisitor", (PyObject *)&__pyx_type_4h5py_3h5g__GroupVisitor) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 159; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_ptype_4h5py_3h5g__GroupVisitor = &__pyx_type_4h5py_3h5g__GroupVisitor;
|
|
/*--- 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_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;}
|
|
__pyx_ptype_4h5py_3h5p_PropID = __Pyx_ImportType("h5py.h5p", "PropID", sizeof(struct __pyx_obj_4h5py_3h5p_PropID)); if (unlikely(!__pyx_ptype_4h5py_3h5p_PropID)) {__pyx_filename = __pyx_f[3]; __pyx_lineno = 23; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_ptype_4h5py_3h5p_PropClassID = __Pyx_ImportType("h5py.h5p", "PropClassID", sizeof(struct __pyx_obj_4h5py_3h5p_PropClassID)); if (unlikely(!__pyx_ptype_4h5py_3h5p_PropClassID)) {__pyx_filename = __pyx_f[3]; __pyx_lineno = 27; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_ptype_4h5py_3h5p_PropInstanceID = __Pyx_ImportType("h5py.h5p", "PropInstanceID", sizeof(struct __pyx_obj_4h5py_3h5p_PropInstanceID)); if (unlikely(!__pyx_ptype_4h5py_3h5p_PropInstanceID)) {__pyx_filename = __pyx_f[3]; __pyx_lineno = 33; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_ptype_4h5py_3h5p_PropCreateID = __Pyx_ImportType("h5py.h5p", "PropCreateID", sizeof(struct __pyx_obj_4h5py_3h5p_PropCreateID)); if (unlikely(!__pyx_ptype_4h5py_3h5p_PropCreateID)) {__pyx_filename = __pyx_f[3]; __pyx_lineno = 39; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_ptype_4h5py_3h5p_PropCopyID = __Pyx_ImportType("h5py.h5p", "PropCopyID", sizeof(struct __pyx_obj_4h5py_3h5p_PropCopyID)); if (unlikely(!__pyx_ptype_4h5py_3h5p_PropCopyID)) {__pyx_filename = __pyx_f[3]; __pyx_lineno = 46; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_ptype_4h5py_3h5p_PropDCID = __Pyx_ImportType("h5py.h5p", "PropDCID", sizeof(struct __pyx_obj_4h5py_3h5p_PropDCID)); if (unlikely(!__pyx_ptype_4h5py_3h5p_PropDCID)) {__pyx_filename = __pyx_f[3]; __pyx_lineno = 51; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_ptype_4h5py_3h5p_PropFCID = __Pyx_ImportType("h5py.h5p", "PropFCID", sizeof(struct __pyx_obj_4h5py_3h5p_PropFCID)); if (unlikely(!__pyx_ptype_4h5py_3h5p_PropFCID)) {__pyx_filename = __pyx_f[3]; __pyx_lineno = 55; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_ptype_4h5py_3h5p_PropFAID = __Pyx_ImportType("h5py.h5p", "PropFAID", sizeof(struct __pyx_obj_4h5py_3h5p_PropFAID)); if (unlikely(!__pyx_ptype_4h5py_3h5p_PropFAID)) {__pyx_filename = __pyx_f[3]; __pyx_lineno = 62; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_ptype_4h5py_3h5p_PropDXID = __Pyx_ImportType("h5py.h5p", "PropDXID", sizeof(struct __pyx_obj_4h5py_3h5p_PropDXID)); if (unlikely(!__pyx_ptype_4h5py_3h5p_PropDXID)) {__pyx_filename = __pyx_f[3]; __pyx_lineno = 66; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_ptype_4h5py_3h5e_HDF5ErrorHandler = __Pyx_ImportType("h5py.h5e", "HDF5ErrorHandler", sizeof(struct __pyx_obj_4h5py_3h5e_HDF5ErrorHandler)); if (unlikely(!__pyx_ptype_4h5py_3h5e_HDF5ErrorHandler)) {__pyx_filename = __pyx_f[4]; __pyx_lineno = 20; __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;
|
|
__pyx_t_3 = __Pyx_ImportModule("h5py.h5p"); if (!__pyx_t_3) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
if (__Pyx_ImportFunction(__pyx_t_3, "pdefault", (void (**)(void))&__pyx_f_4h5py_3h5p_pdefault, "hid_t (struct __pyx_obj_4h5py_3h5p_PropID *)") < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
if (__Pyx_ImportFunction(__pyx_t_3, "propwrap", (void (**)(void))&__pyx_f_4h5py_3h5p_propwrap, "PyObject *(hid_t)") < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
Py_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
__pyx_t_4 = __Pyx_ImportModule("h5py.h5e"); if (!__pyx_t_4) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
if (__Pyx_ImportFunction(__pyx_t_4, "register_thread", (void (**)(void))&__pyx_f_4h5py_3h5e_register_thread, "PyObject *(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_4, "unregister_thread", (void (**)(void))&__pyx_f_4h5py_3h5e_unregister_thread, "PyObject *(int __pyx_skip_dispatch, struct __pyx_opt_args_4h5py_3h5e_unregister_thread *__pyx_optional_args)") < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
if (__Pyx_ImportFunction(__pyx_t_4, "disable_errors", (void (**)(void))&__pyx_f_4h5py_3h5e_disable_errors, "__pyx_t_4h5py_3h5e_err_cookie (void)") < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
if (__Pyx_ImportFunction(__pyx_t_4, "enable_errors", (void (**)(void))&__pyx_f_4h5py_3h5e_enable_errors, "void (__pyx_t_4h5py_3h5e_err_cookie)") < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
Py_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
/*--- Execution code ---*/
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":28
|
|
*
|
|
* # Initialization
|
|
* init_hdf5() # <<<<<<<<<<<<<<
|
|
*
|
|
* # Runtime imports
|
|
*/
|
|
__pyx_t_5 = __pyx_f_4h5py_2h5_init_hdf5(); if (unlikely(__pyx_t_5 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 28; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":31
|
|
*
|
|
* # Runtime imports
|
|
* from h5 import H5Error # <<<<<<<<<<<<<<
|
|
*
|
|
* # === Public constants and data structures ====================================
|
|
*/
|
|
__pyx_t_6 = PyList_New(1); if (unlikely(!__pyx_t_6)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 31; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_6));
|
|
__Pyx_INCREF(((PyObject *)__pyx_n_s__H5Error));
|
|
PyList_SET_ITEM(__pyx_t_6, 0, ((PyObject *)__pyx_n_s__H5Error));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_n_s__H5Error));
|
|
__pyx_t_7 = __Pyx_Import(((PyObject *)__pyx_n_s__h5), ((PyObject *)__pyx_t_6)); if (unlikely(!__pyx_t_7)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 31; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_7);
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_6)); __pyx_t_6 = 0;
|
|
__pyx_t_6 = PyObject_GetAttr(__pyx_t_7, __pyx_n_s__H5Error); if (unlikely(!__pyx_t_6)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 31; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_6);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__H5Error, __pyx_t_6) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 31; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
|
|
__Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":36
|
|
*
|
|
* # Enumerated object types for groups "H5G_obj_t"
|
|
* UNKNOWN = H5G_UNKNOWN # <<<<<<<<<<<<<<
|
|
* LINK = H5G_LINK
|
|
* GROUP = H5G_GROUP
|
|
*/
|
|
__pyx_t_7 = PyInt_FromLong(H5G_UNKNOWN); if (unlikely(!__pyx_t_7)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 36; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_7);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__UNKNOWN, __pyx_t_7) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 36; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":37
|
|
* # Enumerated object types for groups "H5G_obj_t"
|
|
* UNKNOWN = H5G_UNKNOWN
|
|
* LINK = H5G_LINK # <<<<<<<<<<<<<<
|
|
* GROUP = H5G_GROUP
|
|
* DATASET = H5G_DATASET
|
|
*/
|
|
__pyx_t_7 = PyInt_FromLong(H5G_LINK); if (unlikely(!__pyx_t_7)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 37; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_7);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__LINK, __pyx_t_7) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 37; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":38
|
|
* UNKNOWN = H5G_UNKNOWN
|
|
* LINK = H5G_LINK
|
|
* GROUP = H5G_GROUP # <<<<<<<<<<<<<<
|
|
* DATASET = H5G_DATASET
|
|
* TYPE = H5G_TYPE
|
|
*/
|
|
__pyx_t_7 = PyInt_FromLong(H5G_GROUP); if (unlikely(!__pyx_t_7)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 38; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_7);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__GROUP, __pyx_t_7) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 38; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":39
|
|
* LINK = H5G_LINK
|
|
* GROUP = H5G_GROUP
|
|
* DATASET = H5G_DATASET # <<<<<<<<<<<<<<
|
|
* TYPE = H5G_TYPE
|
|
*
|
|
*/
|
|
__pyx_t_7 = PyInt_FromLong(H5G_DATASET); if (unlikely(!__pyx_t_7)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 39; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_7);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__DATASET, __pyx_t_7) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 39; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":40
|
|
* GROUP = H5G_GROUP
|
|
* DATASET = H5G_DATASET
|
|
* TYPE = H5G_TYPE # <<<<<<<<<<<<<<
|
|
*
|
|
* # Enumerated link types "H5G_link_t"
|
|
*/
|
|
__pyx_t_7 = PyInt_FromLong(H5G_TYPE); if (unlikely(!__pyx_t_7)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 40; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_7);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__TYPE, __pyx_t_7) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 40; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":43
|
|
*
|
|
* # Enumerated link types "H5G_link_t"
|
|
* LINK_ERROR = H5G_LINK_ERROR # <<<<<<<<<<<<<<
|
|
* LINK_HARD = H5G_LINK_HARD
|
|
* LINK_SOFT = H5G_LINK_SOFT
|
|
*/
|
|
__pyx_t_7 = PyInt_FromLong(H5G_LINK_ERROR); if (unlikely(!__pyx_t_7)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 43; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_7);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__LINK_ERROR, __pyx_t_7) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 43; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":44
|
|
* # Enumerated link types "H5G_link_t"
|
|
* LINK_ERROR = H5G_LINK_ERROR
|
|
* LINK_HARD = H5G_LINK_HARD # <<<<<<<<<<<<<<
|
|
* LINK_SOFT = H5G_LINK_SOFT
|
|
*
|
|
*/
|
|
__pyx_t_7 = PyInt_FromLong(H5G_LINK_HARD); if (unlikely(!__pyx_t_7)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 44; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_7);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__LINK_HARD, __pyx_t_7) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 44; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":45
|
|
* LINK_ERROR = H5G_LINK_ERROR
|
|
* LINK_HARD = H5G_LINK_HARD
|
|
* LINK_SOFT = H5G_LINK_SOFT # <<<<<<<<<<<<<<
|
|
*
|
|
* cdef class GroupStat(SmartStruct):
|
|
*/
|
|
__pyx_t_7 = PyInt_FromLong(H5G_LINK_SOFT); if (unlikely(!__pyx_t_7)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 45; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_7);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__LINK_SOFT, __pyx_t_7) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 45; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/h5g.pyx":269
|
|
*
|
|
* def link(self, char* current_name, char* new_name,
|
|
* int link_type=H5G_LINK_HARD, GroupID remote=None): # <<<<<<<<<<<<<<
|
|
* """(STRING current_name, STRING new_name, INT link_type=LINK_HARD,
|
|
* GroupID remote=None)
|
|
*/
|
|
__pyx_k_3 = H5G_LINK_HARD;
|
|
|
|
/* "/home/tachyon/slave/unix-release/build/h5py/numpy.pxd":1
|
|
* #+ # <<<<<<<<<<<<<<
|
|
* #
|
|
* # This file is part of h5py, a low-level Python interface to the HDF5 library.
|
|
*/
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_1);
|
|
__Pyx_XDECREF(__pyx_t_2);
|
|
__Pyx_XDECREF(__pyx_t_3);
|
|
__Pyx_XDECREF(__pyx_t_4);
|
|
__Pyx_XDECREF(__pyx_t_6);
|
|
__Pyx_XDECREF(__pyx_t_7);
|
|
if (__pyx_m) {
|
|
__Pyx_AddTraceback("init h5py.h5g");
|
|
Py_DECREF(__pyx_m); __pyx_m = 0;
|
|
} else if (!PyErr_Occurred()) {
|
|
PyErr_SetString(PyExc_ImportError, "init h5py.h5g");
|
|
}
|
|
__pyx_L0:;
|
|
__Pyx_RefNannyFinishContext();
|
|
#if PY_MAJOR_VERSION < 3
|
|
return;
|
|
#else
|
|
return __pyx_m;
|
|
#endif
|
|
}
|
|
|
|
static const char *__pyx_filenames[] = {
|
|
"h5g.pyx",
|
|
"h5.pxd",
|
|
"numpy.pxd",
|
|
"h5p.pxd",
|
|
"h5e.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 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 PyObject *__Pyx_Import(PyObject *name, PyObject *from_list) {
|
|
PyObject *__import__ = 0;
|
|
PyObject *empty_list = 0;
|
|
PyObject *module = 0;
|
|
PyObject *global_dict = 0;
|
|
PyObject *empty_dict = 0;
|
|
PyObject *list;
|
|
__import__ = __Pyx_GetAttrString(__pyx_b, "__import__");
|
|
if (!__import__)
|
|
goto bad;
|
|
if (from_list)
|
|
list = from_list;
|
|
else {
|
|
empty_list = PyList_New(0);
|
|
if (!empty_list)
|
|
goto bad;
|
|
list = empty_list;
|
|
}
|
|
global_dict = PyModule_GetDict(__pyx_m);
|
|
if (!global_dict)
|
|
goto bad;
|
|
empty_dict = PyDict_New();
|
|
if (!empty_dict)
|
|
goto bad;
|
|
module = PyObject_CallFunctionObjArgs(__import__,
|
|
name, global_dict, empty_dict, list, NULL);
|
|
bad:
|
|
Py_XDECREF(empty_list);
|
|
Py_XDECREF(__import__);
|
|
Py_XDECREF(empty_dict);
|
|
return module;
|
|
}
|
|
|
|
static INLINE PyObject *__Pyx_PyInt_to_py_time_t(time_t val) {
|
|
const time_t neg_one = (time_t)-1, const_zero = 0;
|
|
const int is_unsigned = neg_one > const_zero;
|
|
if (sizeof(time_t) < sizeof(long)) {
|
|
return PyInt_FromLong((long)val);
|
|
} else if (sizeof(time_t) == sizeof(long)) {
|
|
if (is_unsigned)
|
|
return PyLong_FromUnsignedLong((unsigned long)val);
|
|
else
|
|
return PyInt_FromLong((long)val);
|
|
} else { /* (sizeof(time_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_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 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 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;
|
|
}
|
|
}
|
|
|
|
static INLINE hsize_t __Pyx_PyInt_from_py_hsize_t(PyObject* x) {
|
|
const hsize_t neg_one = (hsize_t)-1, const_zero = 0;
|
|
const int is_unsigned = neg_one > const_zero;
|
|
if (sizeof(hsize_t) == sizeof(char)) {
|
|
if (is_unsigned)
|
|
return (hsize_t)__Pyx_PyInt_AsUnsignedChar(x);
|
|
else
|
|
return (hsize_t)__Pyx_PyInt_AsSignedChar(x);
|
|
} else if (sizeof(hsize_t) == sizeof(short)) {
|
|
if (is_unsigned)
|
|
return (hsize_t)__Pyx_PyInt_AsUnsignedShort(x);
|
|
else
|
|
return (hsize_t)__Pyx_PyInt_AsSignedShort(x);
|
|
} else if (sizeof(hsize_t) == sizeof(int)) {
|
|
if (is_unsigned)
|
|
return (hsize_t)__Pyx_PyInt_AsUnsignedInt(x);
|
|
else
|
|
return (hsize_t)__Pyx_PyInt_AsSignedInt(x);
|
|
} else if (sizeof(hsize_t) == sizeof(long)) {
|
|
if (is_unsigned)
|
|
return (hsize_t)__Pyx_PyInt_AsUnsignedLong(x);
|
|
else
|
|
return (hsize_t)__Pyx_PyInt_AsSignedLong(x);
|
|
} else if (sizeof(hsize_t) == sizeof(PY_LONG_LONG)) {
|
|
if (is_unsigned)
|
|
return (hsize_t)__Pyx_PyInt_AsUnsignedLongLong(x);
|
|
else
|
|
return (hsize_t)__Pyx_PyInt_AsSignedLongLong(x);
|
|
#if 0
|
|
} else if (sizeof(hsize_t) > sizeof(short) &&
|
|
sizeof(hsize_t) < sizeof(int)) { /* __int32 ILP64 ? */
|
|
if (is_unsigned)
|
|
return (hsize_t)__Pyx_PyInt_AsUnsignedInt(x);
|
|
else
|
|
return (hsize_t)__Pyx_PyInt_AsSignedInt(x);
|
|
#endif
|
|
}
|
|
PyErr_SetString(PyExc_TypeError, "hsize_t");
|
|
return (hsize_t)-1;
|
|
}
|
|
|
|
#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 */
|