mirror of
https://gitlab.com/scemama/irpf90.git
synced 2024-06-02 11:25:19 +02:00
5801 lines
243 KiB
C
5801 lines
243 KiB
C
/* Generated by Cython 0.15.1 on Mon Jul 1 13:12:13 2013 */
|
|
|
|
#define PY_SSIZE_T_CLEAN
|
|
#include "Python.h"
|
|
#ifndef Py_PYTHON_H
|
|
#error Python headers needed to compile C extensions, please install development version of Python.
|
|
#else
|
|
|
|
#include <stddef.h> /* For offsetof */
|
|
#ifndef offsetof
|
|
#define offsetof(type, member) ( (size_t) & ((type*)0) -> member )
|
|
#endif
|
|
|
|
#if !defined(WIN32) && !defined(MS_WINDOWS)
|
|
#ifndef __stdcall
|
|
#define __stdcall
|
|
#endif
|
|
#ifndef __cdecl
|
|
#define __cdecl
|
|
#endif
|
|
#ifndef __fastcall
|
|
#define __fastcall
|
|
#endif
|
|
#endif
|
|
|
|
#ifndef DL_IMPORT
|
|
#define DL_IMPORT(t) t
|
|
#endif
|
|
#ifndef DL_EXPORT
|
|
#define DL_EXPORT(t) t
|
|
#endif
|
|
|
|
#ifndef PY_LONG_LONG
|
|
#define PY_LONG_LONG LONG_LONG
|
|
#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) __Pyx_PyInt_AsInt(o)
|
|
#define PyNumber_Index(o) PyNumber_Int(o)
|
|
#define PyIndex_Check(o) PyNumber_Check(o)
|
|
#define PyErr_WarnEx(category, message, stacklevel) PyErr_Warn(category, message)
|
|
#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 PyStringObject PyUnicodeObject
|
|
#define PyString_Type PyUnicode_Type
|
|
#define PyString_Check PyUnicode_Check
|
|
#define PyString_CheckExact PyUnicode_CheckExact
|
|
#endif
|
|
|
|
#if PY_VERSION_HEX < 0x02060000
|
|
#define PyBytesObject PyStringObject
|
|
#define PyBytes_Type PyString_Type
|
|
#define PyBytes_Check PyString_Check
|
|
#define PyBytes_CheckExact PyString_CheckExact
|
|
#define PyBytes_FromString PyString_FromString
|
|
#define PyBytes_FromStringAndSize PyString_FromStringAndSize
|
|
#define PyBytes_FromFormat PyString_FromFormat
|
|
#define PyBytes_DecodeEscape PyString_DecodeEscape
|
|
#define PyBytes_AsString PyString_AsString
|
|
#define PyBytes_AsStringAndSize PyString_AsStringAndSize
|
|
#define PyBytes_Size PyString_Size
|
|
#define PyBytes_AS_STRING PyString_AS_STRING
|
|
#define PyBytes_GET_SIZE PyString_GET_SIZE
|
|
#define PyBytes_Repr PyString_Repr
|
|
#define PyBytes_Concat PyString_Concat
|
|
#define PyBytes_ConcatAndDel PyString_ConcatAndDel
|
|
#endif
|
|
|
|
#if PY_VERSION_HEX < 0x02060000
|
|
#define PySet_Check(obj) PyObject_TypeCheck(obj, &PySet_Type)
|
|
#define PyFrozenSet_Check(obj) PyObject_TypeCheck(obj, &PyFrozenSet_Type)
|
|
#endif
|
|
#ifndef PySet_CheckExact
|
|
#define PySet_CheckExact(obj) (Py_TYPE(obj) == &PySet_Type)
|
|
#endif
|
|
|
|
#define __Pyx_TypeCheck(obj, type) PyObject_TypeCheck(obj, (PyTypeObject *)type)
|
|
|
|
#if PY_MAJOR_VERSION >= 3
|
|
#define PyIntObject PyLongObject
|
|
#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
|
|
#endif
|
|
|
|
#if PY_MAJOR_VERSION >= 3
|
|
#define PyBoolObject PyLongObject
|
|
#endif
|
|
|
|
#if PY_VERSION_HEX < 0x03020000
|
|
typedef long Py_hash_t;
|
|
#define __Pyx_PyInt_FromHash_t PyInt_FromLong
|
|
#define __Pyx_PyInt_AsHash_t PyInt_AsLong
|
|
#else
|
|
#define __Pyx_PyInt_FromHash_t PyInt_FromSsize_t
|
|
#define __Pyx_PyInt_AsHash_t PyInt_AsSsize_t
|
|
#endif
|
|
|
|
|
|
#if PY_MAJOR_VERSION >= 3
|
|
#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) || (PY_VERSION_HEX >= 0x03010300)
|
|
#define __Pyx_PySequence_GetSlice(obj, a, b) PySequence_GetSlice(obj, a, b)
|
|
#define __Pyx_PySequence_SetSlice(obj, a, b, value) PySequence_SetSlice(obj, a, b, value)
|
|
#define __Pyx_PySequence_DelSlice(obj, a, b) PySequence_DelSlice(obj, a, b)
|
|
#else
|
|
#define __Pyx_PySequence_GetSlice(obj, a, b) (unlikely(!(obj)) ? \
|
|
(PyErr_SetString(PyExc_SystemError, "null argument to internal routine"), (PyObject*)0) : \
|
|
(likely((obj)->ob_type->tp_as_mapping) ? (PySequence_GetSlice(obj, a, b)) : \
|
|
(PyErr_Format(PyExc_TypeError, "'%.200s' object is unsliceable", (obj)->ob_type->tp_name), (PyObject*)0)))
|
|
#define __Pyx_PySequence_SetSlice(obj, a, b, value) (unlikely(!(obj)) ? \
|
|
(PyErr_SetString(PyExc_SystemError, "null argument to internal routine"), -1) : \
|
|
(likely((obj)->ob_type->tp_as_mapping) ? (PySequence_SetSlice(obj, a, b, value)) : \
|
|
(PyErr_Format(PyExc_TypeError, "'%.200s' object doesn't support slice assignment", (obj)->ob_type->tp_name), -1)))
|
|
#define __Pyx_PySequence_DelSlice(obj, a, b) (unlikely(!(obj)) ? \
|
|
(PyErr_SetString(PyExc_SystemError, "null argument to internal routine"), -1) : \
|
|
(likely((obj)->ob_type->tp_as_mapping) ? (PySequence_DelSlice(obj, a, b)) : \
|
|
(PyErr_Format(PyExc_TypeError, "'%.200s' object doesn't support slice deletion", (obj)->ob_type->tp_name), -1)))
|
|
#endif
|
|
|
|
#if PY_MAJOR_VERSION >= 3
|
|
#define PyMethod_New(func, self, klass) ((self) ? PyMethod_New(func, self) : PyInstanceMethod_New(func))
|
|
#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
|
|
|
|
#ifndef __PYX_EXTERN_C
|
|
#ifdef __cplusplus
|
|
#define __PYX_EXTERN_C extern "C"
|
|
#else
|
|
#define __PYX_EXTERN_C extern
|
|
#endif
|
|
#endif
|
|
|
|
#if defined(WIN32) || defined(MS_WINDOWS)
|
|
#define _USE_MATH_DEFINES
|
|
#endif
|
|
#include <math.h>
|
|
#define __PYX_HAVE__util
|
|
#define __PYX_HAVE_API__util
|
|
#ifdef _OPENMP
|
|
#include <omp.h>
|
|
#endif /* _OPENMP */
|
|
|
|
#ifdef PYREX_WITHOUT_ASSERTIONS
|
|
#define CYTHON_WITHOUT_ASSERTIONS
|
|
#endif
|
|
|
|
|
|
/* inline attribute */
|
|
#ifndef CYTHON_INLINE
|
|
#if defined(__GNUC__)
|
|
#define CYTHON_INLINE __inline__
|
|
#elif defined(_MSC_VER)
|
|
#define CYTHON_INLINE __inline
|
|
#elif defined (__STDC_VERSION__) && __STDC_VERSION__ >= 199901L
|
|
#define CYTHON_INLINE inline
|
|
#else
|
|
#define CYTHON_INLINE
|
|
#endif
|
|
#endif
|
|
|
|
/* unused attribute */
|
|
#ifndef CYTHON_UNUSED
|
|
# if defined(__GNUC__)
|
|
# if !(defined(__cplusplus)) || (__GNUC__ > 3 || (__GNUC__ == 3 && __GNUC_MINOR__ >= 4))
|
|
# define CYTHON_UNUSED __attribute__ ((__unused__))
|
|
# else
|
|
# define CYTHON_UNUSED
|
|
# endif
|
|
# elif defined(__ICC) || defined(__INTEL_COMPILER)
|
|
# define CYTHON_UNUSED __attribute__ ((__unused__))
|
|
# else
|
|
# define CYTHON_UNUSED
|
|
# endif
|
|
#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 */
|
|
|
|
#define __Pyx_PyBytes_FromUString(s) PyBytes_FromString((char*)s)
|
|
#define __Pyx_PyBytes_AsUString(s) ((unsigned char*) PyBytes_AsString(s))
|
|
|
|
#define __Pyx_Owned_Py_None(b) (Py_INCREF(Py_None), Py_None)
|
|
#define __Pyx_PyBool_FromLong(b) ((b) ? (Py_INCREF(Py_True), Py_True) : (Py_INCREF(Py_False), Py_False))
|
|
static CYTHON_INLINE int __Pyx_PyObject_IsTrue(PyObject*);
|
|
static CYTHON_INLINE PyObject* __Pyx_PyNumber_Int(PyObject* x);
|
|
|
|
static CYTHON_INLINE Py_ssize_t __Pyx_PyIndex_AsSsize_t(PyObject*);
|
|
static CYTHON_INLINE PyObject * __Pyx_PyInt_FromSize_t(size_t);
|
|
static CYTHON_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[] = {
|
|
"util.py",
|
|
};
|
|
|
|
/*--- Type declarations ---*/
|
|
|
|
#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); /*proto*/
|
|
#define __Pyx_RefNannyDeclarations void *__pyx_refnanny = NULL;
|
|
#define __Pyx_RefNannySetupContext(name) __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_XINCREF(r) do { if((r) != NULL) {__Pyx_INCREF(r); }} while(0)
|
|
#define __Pyx_XDECREF(r) do { if((r) != NULL) {__Pyx_DECREF(r); }} while(0)
|
|
#define __Pyx_XGOTREF(r) do { if((r) != NULL) {__Pyx_GOTREF(r); }} while(0)
|
|
#define __Pyx_XGIVEREF(r) do { if((r) != NULL) {__Pyx_GIVEREF(r);}} while(0)
|
|
#else
|
|
#define __Pyx_RefNannyDeclarations
|
|
#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_XINCREF(r) Py_XINCREF(r)
|
|
#define __Pyx_XDECREF(r) Py_XDECREF(r)
|
|
#define __Pyx_XGOTREF(r)
|
|
#define __Pyx_XGIVEREF(r)
|
|
#endif /* CYTHON_REFNANNY */
|
|
|
|
static PyObject *__Pyx_GetName(PyObject *dict, PyObject *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 void __Pyx_RaiseDoubleKeywordsError(
|
|
const char* func_name, PyObject* kw_name); /*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 int __Pyx_GetException(PyObject **type, PyObject **value, PyObject **tb); /*proto*/
|
|
|
|
|
|
static CYTHON_INLINE PyObject *__Pyx_GetItemInt_Generic(PyObject *o, PyObject* j) {
|
|
PyObject *r;
|
|
if (!j) return NULL;
|
|
r = PyObject_GetItem(o, j);
|
|
Py_DECREF(j);
|
|
return r;
|
|
}
|
|
|
|
|
|
#define __Pyx_GetItemInt_List(o, i, size, to_py_func) (((size) <= sizeof(Py_ssize_t)) ? \
|
|
__Pyx_GetItemInt_List_Fast(o, i) : \
|
|
__Pyx_GetItemInt_Generic(o, to_py_func(i)))
|
|
|
|
static CYTHON_INLINE PyObject *__Pyx_GetItemInt_List_Fast(PyObject *o, Py_ssize_t i) {
|
|
if (likely(o != Py_None)) {
|
|
if (likely((0 <= i) & (i < PyList_GET_SIZE(o)))) {
|
|
PyObject *r = PyList_GET_ITEM(o, i);
|
|
Py_INCREF(r);
|
|
return r;
|
|
}
|
|
else if ((-PyList_GET_SIZE(o) <= i) & (i < 0)) {
|
|
PyObject *r = PyList_GET_ITEM(o, PyList_GET_SIZE(o) + i);
|
|
Py_INCREF(r);
|
|
return r;
|
|
}
|
|
}
|
|
return __Pyx_GetItemInt_Generic(o, PyInt_FromSsize_t(i));
|
|
}
|
|
|
|
#define __Pyx_GetItemInt_Tuple(o, i, size, to_py_func) (((size) <= sizeof(Py_ssize_t)) ? \
|
|
__Pyx_GetItemInt_Tuple_Fast(o, i) : \
|
|
__Pyx_GetItemInt_Generic(o, to_py_func(i)))
|
|
|
|
static CYTHON_INLINE PyObject *__Pyx_GetItemInt_Tuple_Fast(PyObject *o, Py_ssize_t i) {
|
|
if (likely(o != Py_None)) {
|
|
if (likely((0 <= i) & (i < PyTuple_GET_SIZE(o)))) {
|
|
PyObject *r = PyTuple_GET_ITEM(o, i);
|
|
Py_INCREF(r);
|
|
return r;
|
|
}
|
|
else if ((-PyTuple_GET_SIZE(o) <= i) & (i < 0)) {
|
|
PyObject *r = PyTuple_GET_ITEM(o, PyTuple_GET_SIZE(o) + i);
|
|
Py_INCREF(r);
|
|
return r;
|
|
}
|
|
}
|
|
return __Pyx_GetItemInt_Generic(o, PyInt_FromSsize_t(i));
|
|
}
|
|
|
|
|
|
#define __Pyx_GetItemInt(o, i, size, to_py_func) (((size) <= sizeof(Py_ssize_t)) ? \
|
|
__Pyx_GetItemInt_Fast(o, i) : \
|
|
__Pyx_GetItemInt_Generic(o, to_py_func(i)))
|
|
|
|
static CYTHON_INLINE PyObject *__Pyx_GetItemInt_Fast(PyObject *o, Py_ssize_t i) {
|
|
PyObject *r;
|
|
if (PyList_CheckExact(o) && ((0 <= i) & (i < PyList_GET_SIZE(o)))) {
|
|
r = PyList_GET_ITEM(o, i);
|
|
Py_INCREF(r);
|
|
}
|
|
else if (PyTuple_CheckExact(o) && ((0 <= i) & (i < PyTuple_GET_SIZE(o)))) {
|
|
r = PyTuple_GET_ITEM(o, i);
|
|
Py_INCREF(r);
|
|
}
|
|
else if (Py_TYPE(o)->tp_as_sequence && Py_TYPE(o)->tp_as_sequence->sq_item && (likely(i >= 0))) {
|
|
r = PySequence_GetItem(o, i);
|
|
}
|
|
else {
|
|
r = __Pyx_GetItemInt_Generic(o, PyInt_FromSsize_t(i));
|
|
}
|
|
return r;
|
|
}
|
|
|
|
static CYTHON_INLINE void __Pyx_RaiseNeedMoreValuesError(Py_ssize_t index);
|
|
|
|
static CYTHON_INLINE void __Pyx_RaiseTooManyValuesError(Py_ssize_t expected);
|
|
|
|
static int __Pyx_IternextUnpackEndCheck(PyObject *retval, Py_ssize_t expected); /*proto*/
|
|
|
|
static CYTHON_INLINE PyObject* __Pyx_PyObject_Append(PyObject* L, PyObject* x) {
|
|
if (likely(PyList_CheckExact(L))) {
|
|
if (PyList_Append(L, x) < 0) return NULL;
|
|
Py_INCREF(Py_None);
|
|
return Py_None; /* this is just to have an accurate signature */
|
|
}
|
|
else {
|
|
PyObject *r, *m;
|
|
m = __Pyx_GetAttrString(L, "append");
|
|
if (!m) return NULL;
|
|
r = PyObject_CallFunctionObjArgs(m, x, NULL);
|
|
Py_DECREF(m);
|
|
return r;
|
|
}
|
|
}
|
|
|
|
static CYTHON_INLINE void __Pyx_RaiseUnboundLocalError(const char *varname);
|
|
|
|
static CYTHON_INLINE void __Pyx_ExceptionSave(PyObject **type, PyObject **value, PyObject **tb); /*proto*/
|
|
static void __Pyx_ExceptionReset(PyObject *type, PyObject *value, PyObject *tb); /*proto*/
|
|
|
|
static PyObject *__Pyx_Import(PyObject *name, PyObject *from_list, long level); /*proto*/
|
|
|
|
#include <string.h>
|
|
|
|
static CYTHON_INLINE int __Pyx_PyBytes_Equals(PyObject* s1, PyObject* s2, int equals); /*proto*/
|
|
|
|
static CYTHON_INLINE int __Pyx_PyUnicode_Equals(PyObject* s1, PyObject* s2, int equals); /*proto*/
|
|
|
|
#if PY_MAJOR_VERSION >= 3
|
|
#define __Pyx_PyString_Equals __Pyx_PyUnicode_Equals
|
|
#else
|
|
#define __Pyx_PyString_Equals __Pyx_PyBytes_Equals
|
|
#endif
|
|
|
|
static int __Pyx_Print(PyObject*, PyObject *, int); /*proto*/
|
|
#if PY_MAJOR_VERSION >= 3
|
|
static PyObject* __pyx_print = 0;
|
|
static PyObject* __pyx_print_kwargs = 0;
|
|
#endif
|
|
|
|
#define __pyx_binding_PyCFunctionType_USED 1
|
|
|
|
typedef struct {
|
|
PyCFunctionObject func;
|
|
} __pyx_binding_PyCFunctionType_object;
|
|
|
|
static PyTypeObject __pyx_binding_PyCFunctionType_type;
|
|
static PyTypeObject *__pyx_binding_PyCFunctionType = NULL;
|
|
|
|
static PyObject *__pyx_binding_PyCFunctionType_NewEx(PyMethodDef *ml, PyObject *self, PyObject *module); /* proto */
|
|
#define __pyx_binding_PyCFunctionType_New(ml, self) __pyx_binding_PyCFunctionType_NewEx(ml, self, NULL)
|
|
|
|
static int __pyx_binding_PyCFunctionType_init(void); /* proto */
|
|
|
|
static CYTHON_INLINE unsigned char __Pyx_PyInt_AsUnsignedChar(PyObject *);
|
|
|
|
static CYTHON_INLINE unsigned short __Pyx_PyInt_AsUnsignedShort(PyObject *);
|
|
|
|
static CYTHON_INLINE unsigned int __Pyx_PyInt_AsUnsignedInt(PyObject *);
|
|
|
|
static CYTHON_INLINE char __Pyx_PyInt_AsChar(PyObject *);
|
|
|
|
static CYTHON_INLINE short __Pyx_PyInt_AsShort(PyObject *);
|
|
|
|
static CYTHON_INLINE int __Pyx_PyInt_AsInt(PyObject *);
|
|
|
|
static CYTHON_INLINE signed char __Pyx_PyInt_AsSignedChar(PyObject *);
|
|
|
|
static CYTHON_INLINE signed short __Pyx_PyInt_AsSignedShort(PyObject *);
|
|
|
|
static CYTHON_INLINE signed int __Pyx_PyInt_AsSignedInt(PyObject *);
|
|
|
|
static CYTHON_INLINE int __Pyx_PyInt_AsLongDouble(PyObject *);
|
|
|
|
static CYTHON_INLINE unsigned long __Pyx_PyInt_AsUnsignedLong(PyObject *);
|
|
|
|
static CYTHON_INLINE unsigned PY_LONG_LONG __Pyx_PyInt_AsUnsignedLongLong(PyObject *);
|
|
|
|
static CYTHON_INLINE long __Pyx_PyInt_AsLong(PyObject *);
|
|
|
|
static CYTHON_INLINE PY_LONG_LONG __Pyx_PyInt_AsLongLong(PyObject *);
|
|
|
|
static CYTHON_INLINE signed long __Pyx_PyInt_AsSignedLong(PyObject *);
|
|
|
|
static CYTHON_INLINE signed PY_LONG_LONG __Pyx_PyInt_AsSignedLongLong(PyObject *);
|
|
|
|
static int __Pyx_check_binary_version(void);
|
|
|
|
static void __Pyx_AddTraceback(const char *funcname, int __pyx_clineno,
|
|
int __pyx_lineno, const char *__pyx_filename); /*proto*/
|
|
|
|
static int __Pyx_InitStrings(__Pyx_StringTabEntry *t); /*proto*/
|
|
|
|
/* Module declarations from 'util' */
|
|
#define __Pyx_MODULE_NAME "util"
|
|
int __pyx_module_is_main_util = 0;
|
|
|
|
/* Implementation of 'util' */
|
|
static PyObject *__pyx_builtin_open;
|
|
static PyObject *__pyx_builtin_IOError;
|
|
static PyObject *__pyx_builtin_map;
|
|
static PyObject *__pyx_builtin_range;
|
|
static PyObject *__pyx_builtin_xrange;
|
|
static char __pyx_k_1[] = "";
|
|
static char __pyx_k_2[] = "(%s)";
|
|
static char __pyx_k_3[] = ",";
|
|
static char __pyx_k_4[] = ":";
|
|
static char __pyx_k_5[] = ")";
|
|
static char __pyx_k_7[] = "()";
|
|
static char __pyx_k_8[] = "(";
|
|
static char __pyx_k_10[] = "Syntax Error";
|
|
static char __pyx_k_12[] = "-";
|
|
static char __pyx_k_16[] = "%s - (%d)";
|
|
static char __pyx_k_18[] = "%d - %s";
|
|
static char __pyx_k_19[] = "%s - %s + 1";
|
|
static char __pyx_k_20[] = "%";
|
|
static char __pyx_k_21[] = "s ! %s:%4s";
|
|
static char __pyx_k_24[] = "0:10";
|
|
static char __pyx_k_26[] = "0:x";
|
|
static char __pyx_k_28[] = "-3:x";
|
|
static char __pyx_k_30[] = "x:y";
|
|
static char __pyx_k_32[] = "x:5";
|
|
static char __pyx_k__f[] = "f";
|
|
static char __pyx_k__i[] = "i";
|
|
static char __pyx_k__r[] = "r";
|
|
static char __pyx_k__w[] = "w";
|
|
static char __pyx_k__10[] = "10";
|
|
static char __pyx_k__os[] = "os";
|
|
static char __pyx_k__dim[] = "dim";
|
|
static char __pyx_k__map[] = "map";
|
|
static char __pyx_k__sys[] = "sys";
|
|
static char __pyx_k__txt[] = "txt";
|
|
static char __pyx_k__Line[] = "Line";
|
|
static char __pyx_k__dump[] = "dump";
|
|
static char __pyx_k__fail[] = "fail";
|
|
static char __pyx_k__fork[] = "fork";
|
|
static char __pyx_k__join[] = "join";
|
|
static char __pyx_k__load[] = "load";
|
|
static char __pyx_k__open[] = "open";
|
|
static char __pyx_k__pipe[] = "pipe";
|
|
static char __pyx_k__read[] = "read";
|
|
static char __pyx_k__sort[] = "sort";
|
|
static char __pyx_k__text[] = "text";
|
|
static char __pyx_k__util[] = "util";
|
|
static char __pyx_k___exit[] = "_exit";
|
|
static char __pyx_k__close[] = "close";
|
|
static char __pyx_k__error[] = "error";
|
|
static char __pyx_k__ljust[] = "ljust";
|
|
static char __pyx_k__lower[] = "lower";
|
|
static char __pyx_k__range[] = "range";
|
|
static char __pyx_k__split[] = "split";
|
|
static char __pyx_k__strip[] = "strip";
|
|
static char __pyx_k__fdopen[] = "fdopen";
|
|
static char __pyx_k__pickle[] = "pickle";
|
|
static char __pyx_k__source[] = "source";
|
|
static char __pyx_k__xrange[] = "xrange";
|
|
static char __pyx_k__IOError[] = "IOError";
|
|
static char __pyx_k__cPickle[] = "cPickle";
|
|
static char __pyx_k__dimsize[] = "dimsize";
|
|
static char __pyx_k__flatten[] = "flatten";
|
|
static char __pyx_k__isdigit[] = "isdigit";
|
|
static char __pyx_k__replace[] = "replace";
|
|
static char __pyx_k__waitpid[] = "waitpid";
|
|
static char __pyx_k__NTHREADS[] = "NTHREADS";
|
|
static char __pyx_k____main__[] = "__main__";
|
|
static char __pyx_k____name__[] = "__name__";
|
|
static char __pyx_k____test__[] = "__test__";
|
|
static char __pyx_k__endswith[] = "endswith";
|
|
static char __pyx_k__filename[] = "filename";
|
|
static char __pyx_k__irpf90_t[] = "irpf90_t";
|
|
static char __pyx_k__put_info[] = "put_info";
|
|
static char __pyx_k__build_dim[] = "build_dim";
|
|
static char __pyx_k__same_file[] = "same_file";
|
|
static char __pyx_k__make_single[] = "make_single";
|
|
static char __pyx_k__find_subname[] = "find_subname";
|
|
static char __pyx_k__parallel_loop[] = "parallel_loop";
|
|
static char __pyx_k__build_dim_colons[] = "build_dim_colons";
|
|
static PyObject *__pyx_kp_s_1;
|
|
static PyObject *__pyx_kp_s_10;
|
|
static PyObject *__pyx_kp_s_12;
|
|
static PyObject *__pyx_kp_s_16;
|
|
static PyObject *__pyx_kp_s_18;
|
|
static PyObject *__pyx_kp_s_19;
|
|
static PyObject *__pyx_kp_s_2;
|
|
static PyObject *__pyx_kp_s_20;
|
|
static PyObject *__pyx_kp_s_21;
|
|
static PyObject *__pyx_kp_s_24;
|
|
static PyObject *__pyx_kp_s_26;
|
|
static PyObject *__pyx_kp_s_28;
|
|
static PyObject *__pyx_kp_s_3;
|
|
static PyObject *__pyx_kp_s_30;
|
|
static PyObject *__pyx_kp_s_32;
|
|
static PyObject *__pyx_kp_s_4;
|
|
static PyObject *__pyx_kp_s_5;
|
|
static PyObject *__pyx_kp_s_7;
|
|
static PyObject *__pyx_kp_s_8;
|
|
static PyObject *__pyx_kp_s__10;
|
|
static PyObject *__pyx_n_s__IOError;
|
|
static PyObject *__pyx_n_s__Line;
|
|
static PyObject *__pyx_n_s__NTHREADS;
|
|
static PyObject *__pyx_n_s____main__;
|
|
static PyObject *__pyx_n_s____name__;
|
|
static PyObject *__pyx_n_s____test__;
|
|
static PyObject *__pyx_n_s___exit;
|
|
static PyObject *__pyx_n_s__build_dim;
|
|
static PyObject *__pyx_n_s__build_dim_colons;
|
|
static PyObject *__pyx_n_s__cPickle;
|
|
static PyObject *__pyx_n_s__close;
|
|
static PyObject *__pyx_n_s__dim;
|
|
static PyObject *__pyx_n_s__dimsize;
|
|
static PyObject *__pyx_n_s__dump;
|
|
static PyObject *__pyx_n_s__endswith;
|
|
static PyObject *__pyx_n_s__error;
|
|
static PyObject *__pyx_n_s__f;
|
|
static PyObject *__pyx_n_s__fail;
|
|
static PyObject *__pyx_n_s__fdopen;
|
|
static PyObject *__pyx_n_s__filename;
|
|
static PyObject *__pyx_n_s__find_subname;
|
|
static PyObject *__pyx_n_s__flatten;
|
|
static PyObject *__pyx_n_s__fork;
|
|
static PyObject *__pyx_n_s__i;
|
|
static PyObject *__pyx_n_s__irpf90_t;
|
|
static PyObject *__pyx_n_s__isdigit;
|
|
static PyObject *__pyx_n_s__join;
|
|
static PyObject *__pyx_n_s__ljust;
|
|
static PyObject *__pyx_n_s__load;
|
|
static PyObject *__pyx_n_s__lower;
|
|
static PyObject *__pyx_n_s__make_single;
|
|
static PyObject *__pyx_n_s__map;
|
|
static PyObject *__pyx_n_s__open;
|
|
static PyObject *__pyx_n_s__os;
|
|
static PyObject *__pyx_n_s__parallel_loop;
|
|
static PyObject *__pyx_n_s__pickle;
|
|
static PyObject *__pyx_n_s__pipe;
|
|
static PyObject *__pyx_n_s__put_info;
|
|
static PyObject *__pyx_n_s__r;
|
|
static PyObject *__pyx_n_s__range;
|
|
static PyObject *__pyx_n_s__read;
|
|
static PyObject *__pyx_n_s__replace;
|
|
static PyObject *__pyx_n_s__same_file;
|
|
static PyObject *__pyx_n_s__sort;
|
|
static PyObject *__pyx_n_s__source;
|
|
static PyObject *__pyx_n_s__split;
|
|
static PyObject *__pyx_n_s__strip;
|
|
static PyObject *__pyx_n_s__sys;
|
|
static PyObject *__pyx_n_s__text;
|
|
static PyObject *__pyx_n_s__txt;
|
|
static PyObject *__pyx_n_s__util;
|
|
static PyObject *__pyx_n_s__w;
|
|
static PyObject *__pyx_n_s__waitpid;
|
|
static PyObject *__pyx_n_s__xrange;
|
|
static PyObject *__pyx_int_0;
|
|
static PyObject *__pyx_int_1;
|
|
static PyObject *__pyx_int_neg_1;
|
|
static PyObject *__pyx_k_tuple_6;
|
|
static PyObject *__pyx_k_tuple_9;
|
|
static PyObject *__pyx_k_tuple_11;
|
|
static PyObject *__pyx_k_tuple_13;
|
|
static PyObject *__pyx_k_tuple_14;
|
|
static PyObject *__pyx_k_tuple_15;
|
|
static PyObject *__pyx_k_tuple_17;
|
|
static PyObject *__pyx_k_tuple_22;
|
|
static PyObject *__pyx_k_tuple_23;
|
|
static PyObject *__pyx_k_tuple_25;
|
|
static PyObject *__pyx_k_tuple_27;
|
|
static PyObject *__pyx_k_tuple_29;
|
|
static PyObject *__pyx_k_tuple_31;
|
|
static PyObject *__pyx_k_tuple_33;
|
|
|
|
/* "util.py":30
|
|
* NTHREADS=1 #int(os.getenv('OMP_NUM_THREADS',1))
|
|
*
|
|
* def strip(x): # <<<<<<<<<<<<<<
|
|
* return x.strip()
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4util_strip(PyObject *__pyx_self, PyObject *__pyx_v_x); /*proto*/
|
|
static PyMethodDef __pyx_mdef_4util_strip = {__Pyx_NAMESTR("strip"), (PyCFunction)__pyx_pf_4util_strip, METH_O, __Pyx_DOCSTR(0)};
|
|
static PyObject *__pyx_pf_4util_strip(PyObject *__pyx_self, PyObject *__pyx_v_x) {
|
|
PyObject *__pyx_r = NULL;
|
|
__Pyx_RefNannyDeclarations
|
|
PyObject *__pyx_t_1 = NULL;
|
|
PyObject *__pyx_t_2 = NULL;
|
|
int __pyx_lineno = 0;
|
|
const char *__pyx_filename = NULL;
|
|
int __pyx_clineno = 0;
|
|
__Pyx_RefNannySetupContext("strip");
|
|
__pyx_self = __pyx_self;
|
|
|
|
/* "util.py":31
|
|
*
|
|
* def strip(x):
|
|
* return x.strip() # <<<<<<<<<<<<<<
|
|
*
|
|
* def lower(x):
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_1 = PyObject_GetAttr(__pyx_v_x, __pyx_n_s__strip); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 31; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_2 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_empty_tuple), NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 31; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__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("util.strip", __pyx_clineno, __pyx_lineno, __pyx_filename);
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "util.py":33
|
|
* return x.strip()
|
|
*
|
|
* def lower(x): # <<<<<<<<<<<<<<
|
|
* return x.lower()
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4util_1lower(PyObject *__pyx_self, PyObject *__pyx_v_x); /*proto*/
|
|
static PyMethodDef __pyx_mdef_4util_1lower = {__Pyx_NAMESTR("lower"), (PyCFunction)__pyx_pf_4util_1lower, METH_O, __Pyx_DOCSTR(0)};
|
|
static PyObject *__pyx_pf_4util_1lower(PyObject *__pyx_self, PyObject *__pyx_v_x) {
|
|
PyObject *__pyx_r = NULL;
|
|
__Pyx_RefNannyDeclarations
|
|
PyObject *__pyx_t_1 = NULL;
|
|
PyObject *__pyx_t_2 = NULL;
|
|
int __pyx_lineno = 0;
|
|
const char *__pyx_filename = NULL;
|
|
int __pyx_clineno = 0;
|
|
__Pyx_RefNannySetupContext("lower");
|
|
__pyx_self = __pyx_self;
|
|
|
|
/* "util.py":34
|
|
*
|
|
* def lower(x):
|
|
* return x.lower() # <<<<<<<<<<<<<<
|
|
*
|
|
* def same_file(filename,txt):
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_1 = PyObject_GetAttr(__pyx_v_x, __pyx_n_s__lower); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 34; __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 = 34; __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("util.lower", __pyx_clineno, __pyx_lineno, __pyx_filename);
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "util.py":36
|
|
* return x.lower()
|
|
*
|
|
* def same_file(filename,txt): # <<<<<<<<<<<<<<
|
|
* assert isinstance(filename,str)
|
|
* assert type(txt) == list
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4util_2same_file(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
|
|
static PyMethodDef __pyx_mdef_4util_2same_file = {__Pyx_NAMESTR("same_file"), (PyCFunction)__pyx_pf_4util_2same_file, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(0)};
|
|
static PyObject *__pyx_pf_4util_2same_file(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
|
|
PyObject *__pyx_v_filename = 0;
|
|
PyObject *__pyx_v_txt = 0;
|
|
PyObject *__pyx_v_file = NULL;
|
|
PyObject *__pyx_v_stream = NULL;
|
|
PyObject *__pyx_v_buffer = NULL;
|
|
PyObject *__pyx_r = NULL;
|
|
__Pyx_RefNannyDeclarations
|
|
PyObject *__pyx_t_1 = NULL;
|
|
int __pyx_t_2;
|
|
PyObject *__pyx_t_3 = NULL;
|
|
PyObject *__pyx_t_4 = NULL;
|
|
PyObject *__pyx_t_5 = NULL;
|
|
PyObject *__pyx_t_6 = NULL;
|
|
int __pyx_t_7;
|
|
PyObject *__pyx_t_8 = NULL;
|
|
PyObject *__pyx_t_9 = NULL;
|
|
Py_ssize_t __pyx_t_10;
|
|
Py_ssize_t __pyx_t_11;
|
|
int __pyx_lineno = 0;
|
|
const char *__pyx_filename = NULL;
|
|
int __pyx_clineno = 0;
|
|
static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__filename,&__pyx_n_s__txt,0};
|
|
__Pyx_RefNannySetupContext("same_file");
|
|
__pyx_self = __pyx_self;
|
|
{
|
|
PyObject* values[2] = {0,0};
|
|
if (unlikely(__pyx_kwds)) {
|
|
Py_ssize_t kw_args;
|
|
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;
|
|
}
|
|
kw_args = PyDict_Size(__pyx_kwds);
|
|
switch (PyTuple_GET_SIZE(__pyx_args)) {
|
|
case 0:
|
|
values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__filename);
|
|
if (likely(values[0])) kw_args--;
|
|
else goto __pyx_L5_argtuple_error;
|
|
case 1:
|
|
values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__txt);
|
|
if (likely(values[1])) kw_args--;
|
|
else {
|
|
__Pyx_RaiseArgtupleInvalid("same_file", 1, 2, 2, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 36; __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), "same_file") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 36; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
} else if (PyTuple_GET_SIZE(__pyx_args) != 2) {
|
|
goto __pyx_L5_argtuple_error;
|
|
} else {
|
|
values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
|
|
values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
|
|
}
|
|
__pyx_v_filename = values[0];
|
|
__pyx_v_txt = values[1];
|
|
}
|
|
goto __pyx_L4_argument_unpacking_done;
|
|
__pyx_L5_argtuple_error:;
|
|
__Pyx_RaiseArgtupleInvalid("same_file", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 36; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
__pyx_L3_error:;
|
|
__Pyx_AddTraceback("util.same_file", __pyx_clineno, __pyx_lineno, __pyx_filename);
|
|
__Pyx_RefNannyFinishContext();
|
|
return NULL;
|
|
__pyx_L4_argument_unpacking_done:;
|
|
|
|
/* "util.py":37
|
|
*
|
|
* def same_file(filename,txt):
|
|
* assert isinstance(filename,str) # <<<<<<<<<<<<<<
|
|
* assert type(txt) == list
|
|
*
|
|
*/
|
|
#ifndef CYTHON_WITHOUT_ASSERTIONS
|
|
__pyx_t_1 = ((PyObject *)((PyObject*)(&PyString_Type)));
|
|
__Pyx_INCREF(__pyx_t_1);
|
|
__pyx_t_2 = __Pyx_TypeCheck(__pyx_v_filename, __pyx_t_1);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
if (unlikely(!__pyx_t_2)) {
|
|
PyErr_SetNone(PyExc_AssertionError);
|
|
{__pyx_filename = __pyx_f[0]; __pyx_lineno = 37; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
}
|
|
#endif
|
|
|
|
/* "util.py":38
|
|
* def same_file(filename,txt):
|
|
* assert isinstance(filename,str)
|
|
* assert type(txt) == list # <<<<<<<<<<<<<<
|
|
*
|
|
* try:
|
|
*/
|
|
#ifndef CYTHON_WITHOUT_ASSERTIONS
|
|
__pyx_t_1 = PyObject_RichCompare(((PyObject *)Py_TYPE(__pyx_v_txt)), ((PyObject *)((PyObject*)(&PyList_Type))), Py_EQ); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 38; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_2 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely(__pyx_t_2 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 38; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
if (unlikely(!__pyx_t_2)) {
|
|
PyErr_SetNone(PyExc_AssertionError);
|
|
{__pyx_filename = __pyx_f[0]; __pyx_lineno = 38; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
}
|
|
#endif
|
|
|
|
/* "util.py":40
|
|
* assert type(txt) == list
|
|
*
|
|
* try: # <<<<<<<<<<<<<<
|
|
* file = open(filename,"r")
|
|
* except IOError:
|
|
*/
|
|
{
|
|
__Pyx_ExceptionSave(&__pyx_t_3, &__pyx_t_4, &__pyx_t_5);
|
|
__Pyx_XGOTREF(__pyx_t_3);
|
|
__Pyx_XGOTREF(__pyx_t_4);
|
|
__Pyx_XGOTREF(__pyx_t_5);
|
|
/*try:*/ {
|
|
|
|
/* "util.py":41
|
|
*
|
|
* try:
|
|
* file = open(filename,"r") # <<<<<<<<<<<<<<
|
|
* except IOError:
|
|
* return False
|
|
*/
|
|
__pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 41; __pyx_clineno = __LINE__; goto __pyx_L6_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
__Pyx_INCREF(__pyx_v_filename);
|
|
PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_v_filename);
|
|
__Pyx_GIVEREF(__pyx_v_filename);
|
|
__Pyx_INCREF(((PyObject *)__pyx_n_s__r));
|
|
PyTuple_SET_ITEM(__pyx_t_1, 1, ((PyObject *)__pyx_n_s__r));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_n_s__r));
|
|
__pyx_t_6 = PyObject_Call(__pyx_builtin_open, ((PyObject *)__pyx_t_1), NULL); if (unlikely(!__pyx_t_6)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 41; __pyx_clineno = __LINE__; goto __pyx_L6_error;}
|
|
__Pyx_GOTREF(__pyx_t_6);
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0;
|
|
__pyx_v_file = __pyx_t_6;
|
|
__pyx_t_6 = 0;
|
|
}
|
|
__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;
|
|
goto __pyx_L13_try_end;
|
|
__pyx_L6_error:;
|
|
__Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
|
|
|
|
/* "util.py":42
|
|
* try:
|
|
* file = open(filename,"r")
|
|
* except IOError: # <<<<<<<<<<<<<<
|
|
* return False
|
|
* stream = file.read()
|
|
*/
|
|
__pyx_t_7 = PyErr_ExceptionMatches(__pyx_builtin_IOError);
|
|
if (__pyx_t_7) {
|
|
__Pyx_AddTraceback("util.same_file", __pyx_clineno, __pyx_lineno, __pyx_filename);
|
|
if (__Pyx_GetException(&__pyx_t_6, &__pyx_t_1, &__pyx_t_8) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 42; __pyx_clineno = __LINE__; goto __pyx_L8_except_error;}
|
|
__Pyx_GOTREF(__pyx_t_6);
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__Pyx_GOTREF(__pyx_t_8);
|
|
|
|
/* "util.py":43
|
|
* file = open(filename,"r")
|
|
* except IOError:
|
|
* return False # <<<<<<<<<<<<<<
|
|
* stream = file.read()
|
|
* file.close()
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_9 = __Pyx_PyBool_FromLong(0); if (unlikely(!__pyx_t_9)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 43; __pyx_clineno = __LINE__; goto __pyx_L8_except_error;}
|
|
__Pyx_GOTREF(__pyx_t_9);
|
|
__pyx_r = __pyx_t_9;
|
|
__pyx_t_9 = 0;
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
|
|
__Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
|
|
goto __pyx_L9_except_return;
|
|
__Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
|
|
goto __pyx_L7_exception_handled;
|
|
}
|
|
__pyx_L8_except_error:;
|
|
__Pyx_XGIVEREF(__pyx_t_3);
|
|
__Pyx_XGIVEREF(__pyx_t_4);
|
|
__Pyx_XGIVEREF(__pyx_t_5);
|
|
__Pyx_ExceptionReset(__pyx_t_3, __pyx_t_4, __pyx_t_5);
|
|
goto __pyx_L1_error;
|
|
__pyx_L9_except_return:;
|
|
__Pyx_XGIVEREF(__pyx_t_3);
|
|
__Pyx_XGIVEREF(__pyx_t_4);
|
|
__Pyx_XGIVEREF(__pyx_t_5);
|
|
__Pyx_ExceptionReset(__pyx_t_3, __pyx_t_4, __pyx_t_5);
|
|
goto __pyx_L0;
|
|
__pyx_L7_exception_handled:;
|
|
__Pyx_XGIVEREF(__pyx_t_3);
|
|
__Pyx_XGIVEREF(__pyx_t_4);
|
|
__Pyx_XGIVEREF(__pyx_t_5);
|
|
__Pyx_ExceptionReset(__pyx_t_3, __pyx_t_4, __pyx_t_5);
|
|
__pyx_L13_try_end:;
|
|
}
|
|
|
|
/* "util.py":44
|
|
* except IOError:
|
|
* return False
|
|
* stream = file.read() # <<<<<<<<<<<<<<
|
|
* file.close()
|
|
*
|
|
*/
|
|
__pyx_t_8 = PyObject_GetAttr(__pyx_v_file, __pyx_n_s__read); if (unlikely(!__pyx_t_8)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 44; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_8);
|
|
__pyx_t_1 = PyObject_Call(__pyx_t_8, ((PyObject *)__pyx_empty_tuple), NULL); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 44; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
|
|
__pyx_v_stream = __pyx_t_1;
|
|
__pyx_t_1 = 0;
|
|
|
|
/* "util.py":45
|
|
* return False
|
|
* stream = file.read()
|
|
* file.close() # <<<<<<<<<<<<<<
|
|
*
|
|
* buffer = ''.join(txt)
|
|
*/
|
|
__pyx_t_1 = PyObject_GetAttr(__pyx_v_file, __pyx_n_s__close); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 45; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_8 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_empty_tuple), NULL); if (unlikely(!__pyx_t_8)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 45; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_8);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
|
|
|
|
/* "util.py":47
|
|
* file.close()
|
|
*
|
|
* buffer = ''.join(txt) # <<<<<<<<<<<<<<
|
|
*
|
|
* if len(stream) != len(buffer):
|
|
*/
|
|
__pyx_t_8 = PyObject_GetAttr(((PyObject *)__pyx_kp_s_1), __pyx_n_s__join); if (unlikely(!__pyx_t_8)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 47; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_8);
|
|
__pyx_t_1 = PyTuple_New(1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 47; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
__Pyx_INCREF(__pyx_v_txt);
|
|
PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_v_txt);
|
|
__Pyx_GIVEREF(__pyx_v_txt);
|
|
__pyx_t_6 = PyObject_Call(__pyx_t_8, ((PyObject *)__pyx_t_1), NULL); if (unlikely(!__pyx_t_6)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 47; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_6);
|
|
__Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0;
|
|
__pyx_v_buffer = __pyx_t_6;
|
|
__pyx_t_6 = 0;
|
|
|
|
/* "util.py":49
|
|
* buffer = ''.join(txt)
|
|
*
|
|
* if len(stream) != len(buffer): # <<<<<<<<<<<<<<
|
|
* return False
|
|
* if stream != buffer:
|
|
*/
|
|
__pyx_t_10 = PyObject_Length(__pyx_v_stream); if (unlikely(__pyx_t_10 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 49; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_t_11 = PyObject_Length(__pyx_v_buffer); if (unlikely(__pyx_t_11 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 49; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_t_2 = (__pyx_t_10 != __pyx_t_11);
|
|
if (__pyx_t_2) {
|
|
|
|
/* "util.py":50
|
|
*
|
|
* if len(stream) != len(buffer):
|
|
* return False # <<<<<<<<<<<<<<
|
|
* if stream != buffer:
|
|
* return False
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_6 = __Pyx_PyBool_FromLong(0); if (unlikely(!__pyx_t_6)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 50; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_6);
|
|
__pyx_r = __pyx_t_6;
|
|
__pyx_t_6 = 0;
|
|
goto __pyx_L0;
|
|
goto __pyx_L16;
|
|
}
|
|
__pyx_L16:;
|
|
|
|
/* "util.py":51
|
|
* if len(stream) != len(buffer):
|
|
* return False
|
|
* if stream != buffer: # <<<<<<<<<<<<<<
|
|
* return False
|
|
* return True
|
|
*/
|
|
__pyx_t_6 = PyObject_RichCompare(__pyx_v_stream, __pyx_v_buffer, Py_NE); if (unlikely(!__pyx_t_6)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 51; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_6);
|
|
__pyx_t_2 = __Pyx_PyObject_IsTrue(__pyx_t_6); if (unlikely(__pyx_t_2 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 51; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
|
|
if (__pyx_t_2) {
|
|
|
|
/* "util.py":52
|
|
* return False
|
|
* if stream != buffer:
|
|
* return False # <<<<<<<<<<<<<<
|
|
* return True
|
|
*
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_6 = __Pyx_PyBool_FromLong(0); if (unlikely(!__pyx_t_6)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 52; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_6);
|
|
__pyx_r = __pyx_t_6;
|
|
__pyx_t_6 = 0;
|
|
goto __pyx_L0;
|
|
goto __pyx_L17;
|
|
}
|
|
__pyx_L17:;
|
|
|
|
/* "util.py":53
|
|
* if stream != buffer:
|
|
* return False
|
|
* return True # <<<<<<<<<<<<<<
|
|
*
|
|
* def build_dim(dim):
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_6 = __Pyx_PyBool_FromLong(1); if (unlikely(!__pyx_t_6)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 53; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_6);
|
|
__pyx_r = __pyx_t_6;
|
|
__pyx_t_6 = 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_6);
|
|
__Pyx_XDECREF(__pyx_t_8);
|
|
__Pyx_XDECREF(__pyx_t_9);
|
|
__Pyx_AddTraceback("util.same_file", __pyx_clineno, __pyx_lineno, __pyx_filename);
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XDECREF(__pyx_v_file);
|
|
__Pyx_XDECREF(__pyx_v_stream);
|
|
__Pyx_XDECREF(__pyx_v_buffer);
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "util.py":55
|
|
* return True
|
|
*
|
|
* def build_dim(dim): # <<<<<<<<<<<<<<
|
|
* if len(dim) == 0:
|
|
* return ""
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4util_3build_dim(PyObject *__pyx_self, PyObject *__pyx_v_dim); /*proto*/
|
|
static PyMethodDef __pyx_mdef_4util_3build_dim = {__Pyx_NAMESTR("build_dim"), (PyCFunction)__pyx_pf_4util_3build_dim, METH_O, __Pyx_DOCSTR(0)};
|
|
static PyObject *__pyx_pf_4util_3build_dim(PyObject *__pyx_self, PyObject *__pyx_v_dim) {
|
|
PyObject *__pyx_r = NULL;
|
|
__Pyx_RefNannyDeclarations
|
|
Py_ssize_t __pyx_t_1;
|
|
int __pyx_t_2;
|
|
PyObject *__pyx_t_3 = NULL;
|
|
PyObject *__pyx_t_4 = NULL;
|
|
PyObject *__pyx_t_5 = NULL;
|
|
int __pyx_lineno = 0;
|
|
const char *__pyx_filename = NULL;
|
|
int __pyx_clineno = 0;
|
|
__Pyx_RefNannySetupContext("build_dim");
|
|
__pyx_self = __pyx_self;
|
|
|
|
/* "util.py":56
|
|
*
|
|
* def build_dim(dim):
|
|
* if len(dim) == 0: # <<<<<<<<<<<<<<
|
|
* return ""
|
|
* else:
|
|
*/
|
|
__pyx_t_1 = PyObject_Length(__pyx_v_dim); if (unlikely(__pyx_t_1 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 56; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_t_2 = (__pyx_t_1 == 0);
|
|
if (__pyx_t_2) {
|
|
|
|
/* "util.py":57
|
|
* def build_dim(dim):
|
|
* if len(dim) == 0:
|
|
* return "" # <<<<<<<<<<<<<<
|
|
* else:
|
|
* return "(%s)"%( ",".join(dim) )
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__Pyx_INCREF(((PyObject *)__pyx_kp_s_1));
|
|
__pyx_r = ((PyObject *)__pyx_kp_s_1);
|
|
goto __pyx_L0;
|
|
goto __pyx_L5;
|
|
}
|
|
/*else*/ {
|
|
|
|
/* "util.py":59
|
|
* return ""
|
|
* else:
|
|
* return "(%s)"%( ",".join(dim) ) # <<<<<<<<<<<<<<
|
|
*
|
|
* def build_dim_colons(v):
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_3 = PyObject_GetAttr(((PyObject *)__pyx_kp_s_3), __pyx_n_s__join); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 59; __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 = 59; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_4));
|
|
__Pyx_INCREF(__pyx_v_dim);
|
|
PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_v_dim);
|
|
__Pyx_GIVEREF(__pyx_v_dim);
|
|
__pyx_t_5 = PyObject_Call(__pyx_t_3, ((PyObject *)__pyx_t_4), NULL); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 59; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_5);
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_4)); __pyx_t_4 = 0;
|
|
__pyx_t_4 = PyNumber_Remainder(((PyObject *)__pyx_kp_s_2), __pyx_t_5); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 59; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_4));
|
|
__Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
|
|
__pyx_r = ((PyObject *)__pyx_t_4);
|
|
__pyx_t_4 = 0;
|
|
goto __pyx_L0;
|
|
}
|
|
__pyx_L5:;
|
|
|
|
__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("util.build_dim", __pyx_clineno, __pyx_lineno, __pyx_filename);
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "util.py":66
|
|
* return ""
|
|
* else:
|
|
* x = map(lambda x: ":", d) # <<<<<<<<<<<<<<
|
|
* return "(%s)"%(','.join(x))
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_lambda_funcdef_lambda1(PyObject *__pyx_self, PyObject *__pyx_v_x); /*proto*/
|
|
static PyMethodDef __pyx_lambda_methdef_lambda1 = {__Pyx_NAMESTR("lambda1"), (PyCFunction)__pyx_lambda_funcdef_lambda1, METH_O, __Pyx_DOCSTR(0)};
|
|
static PyObject *__pyx_lambda_funcdef_lambda1(PyObject *__pyx_self, PyObject *__pyx_v_x) {
|
|
PyObject *__pyx_r = NULL;
|
|
__Pyx_RefNannyDeclarations
|
|
__Pyx_RefNannySetupContext("lambda1");
|
|
__pyx_self = __pyx_self;
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__Pyx_INCREF(((PyObject *)__pyx_kp_s_4));
|
|
__pyx_r = ((PyObject *)__pyx_kp_s_4);
|
|
goto __pyx_L0;
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "util.py":61
|
|
* return "(%s)"%( ",".join(dim) )
|
|
*
|
|
* def build_dim_colons(v): # <<<<<<<<<<<<<<
|
|
* d = v.dim
|
|
* if d == []:
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4util_4build_dim_colons(PyObject *__pyx_self, PyObject *__pyx_v_v); /*proto*/
|
|
static PyMethodDef __pyx_mdef_4util_4build_dim_colons = {__Pyx_NAMESTR("build_dim_colons"), (PyCFunction)__pyx_pf_4util_4build_dim_colons, METH_O, __Pyx_DOCSTR(0)};
|
|
static PyObject *__pyx_pf_4util_4build_dim_colons(PyObject *__pyx_self, PyObject *__pyx_v_v) {
|
|
PyObject *__pyx_v_d = NULL;
|
|
PyObject *__pyx_v_x = NULL;
|
|
PyObject *__pyx_r = NULL;
|
|
__Pyx_RefNannyDeclarations
|
|
PyObject *__pyx_t_1 = NULL;
|
|
PyObject *__pyx_t_2 = NULL;
|
|
int __pyx_t_3;
|
|
PyObject *__pyx_t_4 = NULL;
|
|
int __pyx_lineno = 0;
|
|
const char *__pyx_filename = NULL;
|
|
int __pyx_clineno = 0;
|
|
__Pyx_RefNannySetupContext("build_dim_colons");
|
|
__pyx_self = __pyx_self;
|
|
|
|
/* "util.py":62
|
|
*
|
|
* def build_dim_colons(v):
|
|
* d = v.dim # <<<<<<<<<<<<<<
|
|
* if d == []:
|
|
* return ""
|
|
*/
|
|
__pyx_t_1 = PyObject_GetAttr(__pyx_v_v, __pyx_n_s__dim); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 62; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_v_d = __pyx_t_1;
|
|
__pyx_t_1 = 0;
|
|
|
|
/* "util.py":63
|
|
* def build_dim_colons(v):
|
|
* d = v.dim
|
|
* if d == []: # <<<<<<<<<<<<<<
|
|
* return ""
|
|
* else:
|
|
*/
|
|
__pyx_t_1 = PyList_New(0); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 63; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
__pyx_t_2 = PyObject_RichCompare(__pyx_v_d, ((PyObject *)__pyx_t_1), Py_EQ); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 63; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0;
|
|
__pyx_t_3 = __Pyx_PyObject_IsTrue(__pyx_t_2); if (unlikely(__pyx_t_3 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 63; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
|
|
if (__pyx_t_3) {
|
|
|
|
/* "util.py":64
|
|
* d = v.dim
|
|
* if d == []:
|
|
* return "" # <<<<<<<<<<<<<<
|
|
* else:
|
|
* x = map(lambda x: ":", d)
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__Pyx_INCREF(((PyObject *)__pyx_kp_s_1));
|
|
__pyx_r = ((PyObject *)__pyx_kp_s_1);
|
|
goto __pyx_L0;
|
|
goto __pyx_L5;
|
|
}
|
|
/*else*/ {
|
|
|
|
/* "util.py":66
|
|
* return ""
|
|
* else:
|
|
* x = map(lambda x: ":", d) # <<<<<<<<<<<<<<
|
|
* return "(%s)"%(','.join(x))
|
|
*
|
|
*/
|
|
__pyx_t_2 = __pyx_binding_PyCFunctionType_NewEx(&__pyx_lambda_methdef_lambda1, NULL, __pyx_n_s__util); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 66; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 66; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_t_2);
|
|
__Pyx_GIVEREF(__pyx_t_2);
|
|
__Pyx_INCREF(__pyx_v_d);
|
|
PyTuple_SET_ITEM(__pyx_t_1, 1, __pyx_v_d);
|
|
__Pyx_GIVEREF(__pyx_v_d);
|
|
__pyx_t_2 = 0;
|
|
__pyx_t_2 = PyObject_Call(__pyx_builtin_map, ((PyObject *)__pyx_t_1), NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 66; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0;
|
|
__pyx_v_x = __pyx_t_2;
|
|
__pyx_t_2 = 0;
|
|
|
|
/* "util.py":67
|
|
* else:
|
|
* x = map(lambda x: ":", d)
|
|
* return "(%s)"%(','.join(x)) # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_2 = PyObject_GetAttr(((PyObject *)__pyx_kp_s_3), __pyx_n_s__join); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 67; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__pyx_t_1 = PyTuple_New(1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 67; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
__Pyx_INCREF(__pyx_v_x);
|
|
PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_v_x);
|
|
__Pyx_GIVEREF(__pyx_v_x);
|
|
__pyx_t_4 = PyObject_Call(__pyx_t_2, ((PyObject *)__pyx_t_1), NULL); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 67; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0;
|
|
__pyx_t_1 = PyNumber_Remainder(((PyObject *)__pyx_kp_s_2), __pyx_t_4); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 67; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
__pyx_r = ((PyObject *)__pyx_t_1);
|
|
__pyx_t_1 = 0;
|
|
goto __pyx_L0;
|
|
}
|
|
__pyx_L5:;
|
|
|
|
__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_4);
|
|
__Pyx_AddTraceback("util.build_dim_colons", __pyx_clineno, __pyx_lineno, __pyx_filename);
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XDECREF(__pyx_v_d);
|
|
__Pyx_XDECREF(__pyx_v_x);
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "util.py":71
|
|
*
|
|
* import error
|
|
* def find_subname(line): # <<<<<<<<<<<<<<
|
|
* buffer = line.lower
|
|
* if not buffer.endswith(')'):
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4util_5find_subname(PyObject *__pyx_self, PyObject *__pyx_v_line); /*proto*/
|
|
static PyMethodDef __pyx_mdef_4util_5find_subname = {__Pyx_NAMESTR("find_subname"), (PyCFunction)__pyx_pf_4util_5find_subname, METH_O, __Pyx_DOCSTR(0)};
|
|
static PyObject *__pyx_pf_4util_5find_subname(PyObject *__pyx_self, PyObject *__pyx_v_line) {
|
|
PyObject *__pyx_v_buffer = NULL;
|
|
PyObject *__pyx_r = NULL;
|
|
__Pyx_RefNannyDeclarations
|
|
PyObject *__pyx_t_1 = NULL;
|
|
PyObject *__pyx_t_2 = NULL;
|
|
int __pyx_t_3;
|
|
int __pyx_t_4;
|
|
Py_ssize_t __pyx_t_5;
|
|
PyObject *__pyx_t_6 = NULL;
|
|
int __pyx_lineno = 0;
|
|
const char *__pyx_filename = NULL;
|
|
int __pyx_clineno = 0;
|
|
__Pyx_RefNannySetupContext("find_subname");
|
|
__pyx_self = __pyx_self;
|
|
|
|
/* "util.py":72
|
|
* import error
|
|
* def find_subname(line):
|
|
* buffer = line.lower # <<<<<<<<<<<<<<
|
|
* if not buffer.endswith(')'):
|
|
* buffer += "()"
|
|
*/
|
|
__pyx_t_1 = PyObject_GetAttr(__pyx_v_line, __pyx_n_s__lower); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 72; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_v_buffer = __pyx_t_1;
|
|
__pyx_t_1 = 0;
|
|
|
|
/* "util.py":73
|
|
* def find_subname(line):
|
|
* buffer = line.lower
|
|
* if not buffer.endswith(')'): # <<<<<<<<<<<<<<
|
|
* buffer += "()"
|
|
* buffer = buffer.split('(')
|
|
*/
|
|
__pyx_t_1 = PyObject_GetAttr(__pyx_v_buffer, __pyx_n_s__endswith); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 73; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_2 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_k_tuple_6), NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 73; __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_PyObject_IsTrue(__pyx_t_2); if (unlikely(__pyx_t_3 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 73; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
|
|
__pyx_t_4 = (!__pyx_t_3);
|
|
if (__pyx_t_4) {
|
|
|
|
/* "util.py":74
|
|
* buffer = line.lower
|
|
* if not buffer.endswith(')'):
|
|
* buffer += "()" # <<<<<<<<<<<<<<
|
|
* buffer = buffer.split('(')
|
|
* buffer = buffer[0].split()
|
|
*/
|
|
__pyx_t_2 = PyNumber_InPlaceAdd(__pyx_v_buffer, ((PyObject *)__pyx_kp_s_7)); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 74; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__Pyx_DECREF(__pyx_v_buffer);
|
|
__pyx_v_buffer = __pyx_t_2;
|
|
__pyx_t_2 = 0;
|
|
goto __pyx_L5;
|
|
}
|
|
__pyx_L5:;
|
|
|
|
/* "util.py":75
|
|
* if not buffer.endswith(')'):
|
|
* buffer += "()"
|
|
* buffer = buffer.split('(') # <<<<<<<<<<<<<<
|
|
* buffer = buffer[0].split()
|
|
* if len(buffer) < 2:
|
|
*/
|
|
__pyx_t_2 = PyObject_GetAttr(__pyx_v_buffer, __pyx_n_s__split); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 75; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__pyx_t_1 = PyObject_Call(__pyx_t_2, ((PyObject *)__pyx_k_tuple_9), NULL); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 75; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
|
|
__Pyx_DECREF(__pyx_v_buffer);
|
|
__pyx_v_buffer = __pyx_t_1;
|
|
__pyx_t_1 = 0;
|
|
|
|
/* "util.py":76
|
|
* buffer += "()"
|
|
* buffer = buffer.split('(')
|
|
* buffer = buffer[0].split() # <<<<<<<<<<<<<<
|
|
* if len(buffer) < 2:
|
|
* error.fail(line,"Syntax Error")
|
|
*/
|
|
__pyx_t_1 = __Pyx_GetItemInt(__pyx_v_buffer, 0, sizeof(long), PyInt_FromLong); if (!__pyx_t_1) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 76; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_2 = PyObject_GetAttr(__pyx_t_1, __pyx_n_s__split); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 76; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_t_1 = PyObject_Call(__pyx_t_2, ((PyObject *)__pyx_empty_tuple), NULL); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 76; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
|
|
__Pyx_DECREF(__pyx_v_buffer);
|
|
__pyx_v_buffer = __pyx_t_1;
|
|
__pyx_t_1 = 0;
|
|
|
|
/* "util.py":77
|
|
* buffer = buffer.split('(')
|
|
* buffer = buffer[0].split()
|
|
* if len(buffer) < 2: # <<<<<<<<<<<<<<
|
|
* error.fail(line,"Syntax Error")
|
|
* return buffer[-1]
|
|
*/
|
|
__pyx_t_5 = PyObject_Length(__pyx_v_buffer); if (unlikely(__pyx_t_5 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 77; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_t_4 = (__pyx_t_5 < 2);
|
|
if (__pyx_t_4) {
|
|
|
|
/* "util.py":78
|
|
* buffer = buffer[0].split()
|
|
* if len(buffer) < 2:
|
|
* error.fail(line,"Syntax Error") # <<<<<<<<<<<<<<
|
|
* return buffer[-1]
|
|
*
|
|
*/
|
|
__pyx_t_1 = __Pyx_GetName(__pyx_m, __pyx_n_s__error); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 78; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_2 = PyObject_GetAttr(__pyx_t_1, __pyx_n_s__fail); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 78; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 78; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
__Pyx_INCREF(__pyx_v_line);
|
|
PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_v_line);
|
|
__Pyx_GIVEREF(__pyx_v_line);
|
|
__Pyx_INCREF(((PyObject *)__pyx_kp_s_10));
|
|
PyTuple_SET_ITEM(__pyx_t_1, 1, ((PyObject *)__pyx_kp_s_10));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_kp_s_10));
|
|
__pyx_t_6 = PyObject_Call(__pyx_t_2, ((PyObject *)__pyx_t_1), NULL); if (unlikely(!__pyx_t_6)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 78; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_6);
|
|
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0;
|
|
__Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
|
|
goto __pyx_L6;
|
|
}
|
|
__pyx_L6:;
|
|
|
|
/* "util.py":79
|
|
* if len(buffer) < 2:
|
|
* error.fail(line,"Syntax Error")
|
|
* return buffer[-1] # <<<<<<<<<<<<<<
|
|
*
|
|
* def make_single(l):
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_6 = __Pyx_GetItemInt(__pyx_v_buffer, -1, sizeof(long), PyInt_FromLong); if (!__pyx_t_6) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 79; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_6);
|
|
__pyx_r = __pyx_t_6;
|
|
__pyx_t_6 = 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_6);
|
|
__Pyx_AddTraceback("util.find_subname", __pyx_clineno, __pyx_lineno, __pyx_filename);
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XDECREF(__pyx_v_buffer);
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "util.py":81
|
|
* return buffer[-1]
|
|
*
|
|
* def make_single(l): # <<<<<<<<<<<<<<
|
|
* d = {}
|
|
* for x in l:
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4util_6make_single(PyObject *__pyx_self, PyObject *__pyx_v_l); /*proto*/
|
|
static PyMethodDef __pyx_mdef_4util_6make_single = {__Pyx_NAMESTR("make_single"), (PyCFunction)__pyx_pf_4util_6make_single, METH_O, __Pyx_DOCSTR(0)};
|
|
static PyObject *__pyx_pf_4util_6make_single(PyObject *__pyx_self, PyObject *__pyx_v_l) {
|
|
PyObject *__pyx_v_d = NULL;
|
|
PyObject *__pyx_v_x = NULL;
|
|
PyObject *__pyx_r = NULL;
|
|
__Pyx_RefNannyDeclarations
|
|
PyObject *__pyx_t_1 = NULL;
|
|
Py_ssize_t __pyx_t_2;
|
|
PyObject *(*__pyx_t_3)(PyObject *);
|
|
PyObject *__pyx_t_4 = NULL;
|
|
int __pyx_lineno = 0;
|
|
const char *__pyx_filename = NULL;
|
|
int __pyx_clineno = 0;
|
|
__Pyx_RefNannySetupContext("make_single");
|
|
__pyx_self = __pyx_self;
|
|
|
|
/* "util.py":82
|
|
*
|
|
* def make_single(l):
|
|
* d = {} # <<<<<<<<<<<<<<
|
|
* for x in l:
|
|
* d[x] = True
|
|
*/
|
|
__pyx_t_1 = PyDict_New(); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 82; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
__pyx_v_d = __pyx_t_1;
|
|
__pyx_t_1 = 0;
|
|
|
|
/* "util.py":83
|
|
* def make_single(l):
|
|
* d = {}
|
|
* for x in l: # <<<<<<<<<<<<<<
|
|
* d[x] = True
|
|
* return d.keys()
|
|
*/
|
|
if (PyList_CheckExact(__pyx_v_l) || PyTuple_CheckExact(__pyx_v_l)) {
|
|
__pyx_t_1 = __pyx_v_l; __Pyx_INCREF(__pyx_t_1); __pyx_t_2 = 0;
|
|
__pyx_t_3 = NULL;
|
|
} else {
|
|
__pyx_t_2 = -1; __pyx_t_1 = PyObject_GetIter(__pyx_v_l); 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_t_3 = Py_TYPE(__pyx_t_1)->tp_iternext;
|
|
}
|
|
for (;;) {
|
|
if (PyList_CheckExact(__pyx_t_1)) {
|
|
if (__pyx_t_2 >= PyList_GET_SIZE(__pyx_t_1)) break;
|
|
__pyx_t_4 = PyList_GET_ITEM(__pyx_t_1, __pyx_t_2); __Pyx_INCREF(__pyx_t_4); __pyx_t_2++;
|
|
} else if (PyTuple_CheckExact(__pyx_t_1)) {
|
|
if (__pyx_t_2 >= PyTuple_GET_SIZE(__pyx_t_1)) break;
|
|
__pyx_t_4 = PyTuple_GET_ITEM(__pyx_t_1, __pyx_t_2); __Pyx_INCREF(__pyx_t_4); __pyx_t_2++;
|
|
} else {
|
|
__pyx_t_4 = __pyx_t_3(__pyx_t_1);
|
|
if (unlikely(!__pyx_t_4)) {
|
|
if (PyErr_Occurred()) {
|
|
if (likely(PyErr_ExceptionMatches(PyExc_StopIteration))) PyErr_Clear();
|
|
else {__pyx_filename = __pyx_f[0]; __pyx_lineno = 83; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
}
|
|
break;
|
|
}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
}
|
|
__Pyx_XDECREF(__pyx_v_x);
|
|
__pyx_v_x = __pyx_t_4;
|
|
__pyx_t_4 = 0;
|
|
|
|
/* "util.py":84
|
|
* d = {}
|
|
* for x in l:
|
|
* d[x] = True # <<<<<<<<<<<<<<
|
|
* return d.keys()
|
|
*
|
|
*/
|
|
__pyx_t_4 = __Pyx_PyBool_FromLong(1); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 84; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
if (PyDict_SetItem(((PyObject *)__pyx_v_d), __pyx_v_x, __pyx_t_4) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 84; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
}
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
|
|
/* "util.py":85
|
|
* for x in l:
|
|
* d[x] = True
|
|
* return d.keys() # <<<<<<<<<<<<<<
|
|
*
|
|
* def flatten(l):
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
if (unlikely(((PyObject *)__pyx_v_d) == Py_None)) {
|
|
PyErr_Format(PyExc_AttributeError, "'NoneType' object has no attribute '%s'", "keys"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 85; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
}
|
|
__pyx_t_1 = PyDict_Keys(__pyx_v_d); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 85; __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_XDECREF(__pyx_t_4);
|
|
__Pyx_AddTraceback("util.make_single", __pyx_clineno, __pyx_lineno, __pyx_filename);
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XDECREF(__pyx_v_d);
|
|
__Pyx_XDECREF(__pyx_v_x);
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "util.py":87
|
|
* return d.keys()
|
|
*
|
|
* def flatten(l): # <<<<<<<<<<<<<<
|
|
* if type(l) == list:
|
|
* result = []
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4util_7flatten(PyObject *__pyx_self, PyObject *__pyx_v_l); /*proto*/
|
|
static PyMethodDef __pyx_mdef_4util_7flatten = {__Pyx_NAMESTR("flatten"), (PyCFunction)__pyx_pf_4util_7flatten, METH_O, __Pyx_DOCSTR(0)};
|
|
static PyObject *__pyx_pf_4util_7flatten(PyObject *__pyx_self, PyObject *__pyx_v_l) {
|
|
PyObject *__pyx_v_result = NULL;
|
|
Py_ssize_t __pyx_v_i;
|
|
PyObject *__pyx_v_elem = NULL;
|
|
PyObject *__pyx_r = NULL;
|
|
__Pyx_RefNannyDeclarations
|
|
PyObject *__pyx_t_1 = NULL;
|
|
int __pyx_t_2;
|
|
Py_ssize_t __pyx_t_3;
|
|
Py_ssize_t __pyx_t_4;
|
|
PyObject *__pyx_t_5 = NULL;
|
|
PyObject *__pyx_t_6 = NULL;
|
|
int __pyx_lineno = 0;
|
|
const char *__pyx_filename = NULL;
|
|
int __pyx_clineno = 0;
|
|
__Pyx_RefNannySetupContext("flatten");
|
|
__pyx_self = __pyx_self;
|
|
|
|
/* "util.py":88
|
|
*
|
|
* def flatten(l):
|
|
* if type(l) == list: # <<<<<<<<<<<<<<
|
|
* result = []
|
|
* for i in range(len(l)):
|
|
*/
|
|
__pyx_t_1 = PyObject_RichCompare(((PyObject *)Py_TYPE(__pyx_v_l)), ((PyObject *)((PyObject*)(&PyList_Type))), Py_EQ); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 88; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_2 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely(__pyx_t_2 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 88; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
if (__pyx_t_2) {
|
|
|
|
/* "util.py":89
|
|
* def flatten(l):
|
|
* if type(l) == list:
|
|
* result = [] # <<<<<<<<<<<<<<
|
|
* for i in range(len(l)):
|
|
* elem = l[i]
|
|
*/
|
|
__pyx_t_1 = PyList_New(0); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 89; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
__pyx_v_result = ((PyObject *)__pyx_t_1);
|
|
__pyx_t_1 = 0;
|
|
|
|
/* "util.py":90
|
|
* if type(l) == list:
|
|
* result = []
|
|
* for i in range(len(l)): # <<<<<<<<<<<<<<
|
|
* elem = l[i]
|
|
* result += flatten(elem)
|
|
*/
|
|
__pyx_t_3 = PyObject_Length(__pyx_v_l); if (unlikely(__pyx_t_3 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 90; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
for (__pyx_t_4 = 0; __pyx_t_4 < __pyx_t_3; __pyx_t_4+=1) {
|
|
__pyx_v_i = __pyx_t_4;
|
|
|
|
/* "util.py":91
|
|
* result = []
|
|
* for i in range(len(l)):
|
|
* elem = l[i] # <<<<<<<<<<<<<<
|
|
* result += flatten(elem)
|
|
* return result
|
|
*/
|
|
__pyx_t_1 = __Pyx_GetItemInt(__pyx_v_l, __pyx_v_i, sizeof(Py_ssize_t), PyInt_FromSsize_t); if (!__pyx_t_1) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 91; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__Pyx_XDECREF(__pyx_v_elem);
|
|
__pyx_v_elem = __pyx_t_1;
|
|
__pyx_t_1 = 0;
|
|
|
|
/* "util.py":92
|
|
* for i in range(len(l)):
|
|
* elem = l[i]
|
|
* result += flatten(elem) # <<<<<<<<<<<<<<
|
|
* return result
|
|
* else:
|
|
*/
|
|
__pyx_t_1 = __Pyx_GetName(__pyx_m, __pyx_n_s__flatten); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 92; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_5 = PyTuple_New(1); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 92; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_5));
|
|
__Pyx_INCREF(__pyx_v_elem);
|
|
PyTuple_SET_ITEM(__pyx_t_5, 0, __pyx_v_elem);
|
|
__Pyx_GIVEREF(__pyx_v_elem);
|
|
__pyx_t_6 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_t_5), NULL); if (unlikely(!__pyx_t_6)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 92; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_6);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_5)); __pyx_t_5 = 0;
|
|
__pyx_t_5 = PyNumber_InPlaceAdd(__pyx_v_result, __pyx_t_6); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 92; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_5);
|
|
__Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
|
|
__Pyx_DECREF(__pyx_v_result);
|
|
__pyx_v_result = __pyx_t_5;
|
|
__pyx_t_5 = 0;
|
|
}
|
|
|
|
/* "util.py":93
|
|
* elem = l[i]
|
|
* result += flatten(elem)
|
|
* return result # <<<<<<<<<<<<<<
|
|
* else:
|
|
* return [l]
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__Pyx_INCREF(__pyx_v_result);
|
|
__pyx_r = __pyx_v_result;
|
|
goto __pyx_L0;
|
|
goto __pyx_L5;
|
|
}
|
|
/*else*/ {
|
|
|
|
/* "util.py":95
|
|
* return result
|
|
* else:
|
|
* return [l] # <<<<<<<<<<<<<<
|
|
*
|
|
* def dimsize(x):
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_5 = PyList_New(1); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 95; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_5));
|
|
__Pyx_INCREF(__pyx_v_l);
|
|
PyList_SET_ITEM(__pyx_t_5, 0, __pyx_v_l);
|
|
__Pyx_GIVEREF(__pyx_v_l);
|
|
__pyx_r = ((PyObject *)__pyx_t_5);
|
|
__pyx_t_5 = 0;
|
|
goto __pyx_L0;
|
|
}
|
|
__pyx_L5:;
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_1);
|
|
__Pyx_XDECREF(__pyx_t_5);
|
|
__Pyx_XDECREF(__pyx_t_6);
|
|
__Pyx_AddTraceback("util.flatten", __pyx_clineno, __pyx_lineno, __pyx_filename);
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XDECREF(__pyx_v_result);
|
|
__Pyx_XDECREF(__pyx_v_elem);
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "util.py":97
|
|
* return [l]
|
|
*
|
|
* def dimsize(x): # <<<<<<<<<<<<<<
|
|
* assert isinstance(x,str)
|
|
* buffer = x.split(':')
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4util_8dimsize(PyObject *__pyx_self, PyObject *__pyx_v_x); /*proto*/
|
|
static PyMethodDef __pyx_mdef_4util_8dimsize = {__Pyx_NAMESTR("dimsize"), (PyCFunction)__pyx_pf_4util_8dimsize, METH_O, __Pyx_DOCSTR(0)};
|
|
static PyObject *__pyx_pf_4util_8dimsize(PyObject *__pyx_self, PyObject *__pyx_v_x) {
|
|
PyObject *__pyx_v_buffer = NULL;
|
|
PyObject *__pyx_v_size = NULL;
|
|
PyObject *__pyx_v_b0 = NULL;
|
|
PyObject *__pyx_v_b1 = NULL;
|
|
PyObject *__pyx_r = NULL;
|
|
__Pyx_RefNannyDeclarations
|
|
PyObject *__pyx_t_1 = NULL;
|
|
int __pyx_t_2;
|
|
PyObject *__pyx_t_3 = NULL;
|
|
Py_ssize_t __pyx_t_4;
|
|
PyObject *__pyx_t_5 = NULL;
|
|
PyObject *(*__pyx_t_6)(PyObject *);
|
|
int __pyx_t_7;
|
|
int __pyx_t_8;
|
|
int __pyx_lineno = 0;
|
|
const char *__pyx_filename = NULL;
|
|
int __pyx_clineno = 0;
|
|
__Pyx_RefNannySetupContext("dimsize");
|
|
__pyx_self = __pyx_self;
|
|
|
|
/* "util.py":98
|
|
*
|
|
* def dimsize(x):
|
|
* assert isinstance(x,str) # <<<<<<<<<<<<<<
|
|
* buffer = x.split(':')
|
|
* if len(buffer) == 1:
|
|
*/
|
|
#ifndef CYTHON_WITHOUT_ASSERTIONS
|
|
__pyx_t_1 = ((PyObject *)((PyObject*)(&PyString_Type)));
|
|
__Pyx_INCREF(__pyx_t_1);
|
|
__pyx_t_2 = __Pyx_TypeCheck(__pyx_v_x, __pyx_t_1);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
if (unlikely(!__pyx_t_2)) {
|
|
PyErr_SetNone(PyExc_AssertionError);
|
|
{__pyx_filename = __pyx_f[0]; __pyx_lineno = 98; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
}
|
|
#endif
|
|
|
|
/* "util.py":99
|
|
* def dimsize(x):
|
|
* assert isinstance(x,str)
|
|
* buffer = x.split(':') # <<<<<<<<<<<<<<
|
|
* if len(buffer) == 1:
|
|
* return x
|
|
*/
|
|
__pyx_t_1 = PyObject_GetAttr(__pyx_v_x, __pyx_n_s__split); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 99; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_3 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_k_tuple_11), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 99; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_v_buffer = __pyx_t_3;
|
|
__pyx_t_3 = 0;
|
|
|
|
/* "util.py":100
|
|
* assert isinstance(x,str)
|
|
* buffer = x.split(':')
|
|
* if len(buffer) == 1: # <<<<<<<<<<<<<<
|
|
* return x
|
|
* buffer = map(strip,buffer)
|
|
*/
|
|
__pyx_t_4 = PyObject_Length(__pyx_v_buffer); if (unlikely(__pyx_t_4 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 100; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_t_2 = (__pyx_t_4 == 1);
|
|
if (__pyx_t_2) {
|
|
|
|
/* "util.py":101
|
|
* buffer = x.split(':')
|
|
* if len(buffer) == 1:
|
|
* return x # <<<<<<<<<<<<<<
|
|
* buffer = map(strip,buffer)
|
|
* else:
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__Pyx_INCREF(__pyx_v_x);
|
|
__pyx_r = __pyx_v_x;
|
|
goto __pyx_L0;
|
|
goto __pyx_L5;
|
|
}
|
|
/*else*/ {
|
|
|
|
/* "util.py":104
|
|
* buffer = map(strip,buffer)
|
|
* else:
|
|
* assert len(buffer) == 2 # <<<<<<<<<<<<<<
|
|
* size = ""
|
|
* b0, b1 = buffer
|
|
*/
|
|
#ifndef CYTHON_WITHOUT_ASSERTIONS
|
|
__pyx_t_4 = PyObject_Length(__pyx_v_buffer); if (unlikely(__pyx_t_4 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 104; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
if (unlikely(!(__pyx_t_4 == 2))) {
|
|
PyErr_SetNone(PyExc_AssertionError);
|
|
{__pyx_filename = __pyx_f[0]; __pyx_lineno = 104; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
}
|
|
#endif
|
|
|
|
/* "util.py":105
|
|
* else:
|
|
* assert len(buffer) == 2
|
|
* size = "" # <<<<<<<<<<<<<<
|
|
* b0, b1 = buffer
|
|
* if b0.replace('-','').isdigit() and b1.replace('-','').isdigit():
|
|
*/
|
|
__Pyx_INCREF(((PyObject *)__pyx_kp_s_1));
|
|
__pyx_v_size = ((PyObject *)__pyx_kp_s_1);
|
|
|
|
/* "util.py":106
|
|
* assert len(buffer) == 2
|
|
* size = ""
|
|
* b0, b1 = buffer # <<<<<<<<<<<<<<
|
|
* if b0.replace('-','').isdigit() and b1.replace('-','').isdigit():
|
|
* size = str( int(b1) - int(b0) + 1 )
|
|
*/
|
|
if ((likely(PyTuple_CheckExact(__pyx_v_buffer))) || (PyList_CheckExact(__pyx_v_buffer))) {
|
|
PyObject* sequence = __pyx_v_buffer;
|
|
if (likely(PyTuple_CheckExact(sequence))) {
|
|
if (unlikely(PyTuple_GET_SIZE(sequence) != 2)) {
|
|
if (PyTuple_GET_SIZE(sequence) > 2) __Pyx_RaiseTooManyValuesError(2);
|
|
else __Pyx_RaiseNeedMoreValuesError(PyTuple_GET_SIZE(sequence));
|
|
{__pyx_filename = __pyx_f[0]; __pyx_lineno = 106; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
}
|
|
__pyx_t_3 = PyTuple_GET_ITEM(sequence, 0);
|
|
__pyx_t_1 = PyTuple_GET_ITEM(sequence, 1);
|
|
} else {
|
|
if (unlikely(PyList_GET_SIZE(sequence) != 2)) {
|
|
if (PyList_GET_SIZE(sequence) > 2) __Pyx_RaiseTooManyValuesError(2);
|
|
else __Pyx_RaiseNeedMoreValuesError(PyList_GET_SIZE(sequence));
|
|
{__pyx_filename = __pyx_f[0]; __pyx_lineno = 106; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
}
|
|
__pyx_t_3 = PyList_GET_ITEM(sequence, 0);
|
|
__pyx_t_1 = PyList_GET_ITEM(sequence, 1);
|
|
}
|
|
__Pyx_INCREF(__pyx_t_3);
|
|
__Pyx_INCREF(__pyx_t_1);
|
|
} else {
|
|
Py_ssize_t index = -1;
|
|
__pyx_t_5 = PyObject_GetIter(__pyx_v_buffer); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 106; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_5);
|
|
__pyx_t_6 = Py_TYPE(__pyx_t_5)->tp_iternext;
|
|
index = 0; __pyx_t_3 = __pyx_t_6(__pyx_t_5); if (unlikely(!__pyx_t_3)) goto __pyx_L6_unpacking_failed;
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
index = 1; __pyx_t_1 = __pyx_t_6(__pyx_t_5); if (unlikely(!__pyx_t_1)) goto __pyx_L6_unpacking_failed;
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
if (__Pyx_IternextUnpackEndCheck(__pyx_t_6(__pyx_t_5), 2) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 106; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
|
|
goto __pyx_L7_unpacking_done;
|
|
__pyx_L6_unpacking_failed:;
|
|
__Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
|
|
if (PyErr_Occurred() && PyErr_ExceptionMatches(PyExc_StopIteration)) PyErr_Clear();
|
|
if (!PyErr_Occurred()) __Pyx_RaiseNeedMoreValuesError(index);
|
|
{__pyx_filename = __pyx_f[0]; __pyx_lineno = 106; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_L7_unpacking_done:;
|
|
}
|
|
__pyx_v_b0 = __pyx_t_3;
|
|
__pyx_t_3 = 0;
|
|
__pyx_v_b1 = __pyx_t_1;
|
|
__pyx_t_1 = 0;
|
|
|
|
/* "util.py":107
|
|
* size = ""
|
|
* b0, b1 = buffer
|
|
* if b0.replace('-','').isdigit() and b1.replace('-','').isdigit(): # <<<<<<<<<<<<<<
|
|
* size = str( int(b1) - int(b0) + 1 )
|
|
* else:
|
|
*/
|
|
__pyx_t_1 = PyObject_GetAttr(__pyx_v_b0, __pyx_n_s__replace); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 107; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_3 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_k_tuple_13), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 107; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_t_1 = PyObject_GetAttr(__pyx_t_3, __pyx_n_s__isdigit); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 107; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
__pyx_t_3 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_empty_tuple), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 107; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_t_2 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely(__pyx_t_2 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 107; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
if (__pyx_t_2) {
|
|
__pyx_t_3 = PyObject_GetAttr(__pyx_v_b1, __pyx_n_s__replace); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 107; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__pyx_t_1 = PyObject_Call(__pyx_t_3, ((PyObject *)__pyx_k_tuple_14), NULL); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 107; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
__pyx_t_3 = PyObject_GetAttr(__pyx_t_1, __pyx_n_s__isdigit); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 107; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_t_1 = PyObject_Call(__pyx_t_3, ((PyObject *)__pyx_empty_tuple), NULL); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 107; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
__pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely(__pyx_t_7 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 107; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_t_8 = __pyx_t_7;
|
|
} else {
|
|
__pyx_t_8 = __pyx_t_2;
|
|
}
|
|
if (__pyx_t_8) {
|
|
|
|
/* "util.py":108
|
|
* b0, b1 = buffer
|
|
* if b0.replace('-','').isdigit() and b1.replace('-','').isdigit():
|
|
* size = str( int(b1) - int(b0) + 1 ) # <<<<<<<<<<<<<<
|
|
* else:
|
|
* if b0.replace('-','').isdigit():
|
|
*/
|
|
__pyx_t_1 = PyTuple_New(1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 108; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
__Pyx_INCREF(__pyx_v_b1);
|
|
PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_v_b1);
|
|
__Pyx_GIVEREF(__pyx_v_b1);
|
|
__pyx_t_3 = PyObject_Call(((PyObject *)((PyObject*)(&PyInt_Type))), ((PyObject *)__pyx_t_1), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 108; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0;
|
|
__pyx_t_1 = PyTuple_New(1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 108; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
__Pyx_INCREF(__pyx_v_b0);
|
|
PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_v_b0);
|
|
__Pyx_GIVEREF(__pyx_v_b0);
|
|
__pyx_t_5 = PyObject_Call(((PyObject *)((PyObject*)(&PyInt_Type))), ((PyObject *)__pyx_t_1), NULL); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 108; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_5);
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0;
|
|
__pyx_t_1 = PyNumber_Subtract(__pyx_t_3, __pyx_t_5); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 108; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
__Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
|
|
__pyx_t_5 = PyNumber_Add(__pyx_t_1, __pyx_int_1); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 108; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_5);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_t_1 = PyTuple_New(1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 108; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_t_5);
|
|
__Pyx_GIVEREF(__pyx_t_5);
|
|
__pyx_t_5 = 0;
|
|
__pyx_t_5 = PyObject_Call(((PyObject *)((PyObject*)(&PyString_Type))), ((PyObject *)__pyx_t_1), NULL); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 108; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_5);
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0;
|
|
__Pyx_DECREF(__pyx_v_size);
|
|
__pyx_v_size = __pyx_t_5;
|
|
__pyx_t_5 = 0;
|
|
goto __pyx_L8;
|
|
}
|
|
/*else*/ {
|
|
|
|
/* "util.py":110
|
|
* size = str( int(b1) - int(b0) + 1 )
|
|
* else:
|
|
* if b0.replace('-','').isdigit(): # <<<<<<<<<<<<<<
|
|
* size = "%s - (%d)"%(b1,int(b0)-1)
|
|
* elif b1.replace('-','').isdigit():
|
|
*/
|
|
__pyx_t_5 = PyObject_GetAttr(__pyx_v_b0, __pyx_n_s__replace); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 110; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_5);
|
|
__pyx_t_1 = PyObject_Call(__pyx_t_5, ((PyObject *)__pyx_k_tuple_15), NULL); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 110; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
|
|
__pyx_t_5 = PyObject_GetAttr(__pyx_t_1, __pyx_n_s__isdigit); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 110; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_5);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_t_1 = PyObject_Call(__pyx_t_5, ((PyObject *)__pyx_empty_tuple), NULL); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 110; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
|
|
__pyx_t_8 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely(__pyx_t_8 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 110; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
if (__pyx_t_8) {
|
|
|
|
/* "util.py":111
|
|
* else:
|
|
* if b0.replace('-','').isdigit():
|
|
* size = "%s - (%d)"%(b1,int(b0)-1) # <<<<<<<<<<<<<<
|
|
* elif b1.replace('-','').isdigit():
|
|
* size = "%d - %s"%(int(b1)+1,b0)
|
|
*/
|
|
__pyx_t_1 = PyTuple_New(1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 111; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
__Pyx_INCREF(__pyx_v_b0);
|
|
PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_v_b0);
|
|
__Pyx_GIVEREF(__pyx_v_b0);
|
|
__pyx_t_5 = PyObject_Call(((PyObject *)((PyObject*)(&PyInt_Type))), ((PyObject *)__pyx_t_1), NULL); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 111; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_5);
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0;
|
|
__pyx_t_1 = PyNumber_Subtract(__pyx_t_5, __pyx_int_1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 111; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
|
|
__pyx_t_5 = PyTuple_New(2); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 111; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_5));
|
|
__Pyx_INCREF(__pyx_v_b1);
|
|
PyTuple_SET_ITEM(__pyx_t_5, 0, __pyx_v_b1);
|
|
__Pyx_GIVEREF(__pyx_v_b1);
|
|
PyTuple_SET_ITEM(__pyx_t_5, 1, __pyx_t_1);
|
|
__Pyx_GIVEREF(__pyx_t_1);
|
|
__pyx_t_1 = 0;
|
|
__pyx_t_1 = PyNumber_Remainder(((PyObject *)__pyx_kp_s_16), ((PyObject *)__pyx_t_5)); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 111; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_5)); __pyx_t_5 = 0;
|
|
__Pyx_DECREF(__pyx_v_size);
|
|
__pyx_v_size = ((PyObject *)__pyx_t_1);
|
|
__pyx_t_1 = 0;
|
|
goto __pyx_L9;
|
|
}
|
|
|
|
/* "util.py":112
|
|
* if b0.replace('-','').isdigit():
|
|
* size = "%s - (%d)"%(b1,int(b0)-1)
|
|
* elif b1.replace('-','').isdigit(): # <<<<<<<<<<<<<<
|
|
* size = "%d - %s"%(int(b1)+1,b0)
|
|
* else:
|
|
*/
|
|
__pyx_t_1 = PyObject_GetAttr(__pyx_v_b1, __pyx_n_s__replace); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 112; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_5 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_k_tuple_17), NULL); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 112; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_5);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_t_1 = PyObject_GetAttr(__pyx_t_5, __pyx_n_s__isdigit); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 112; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
|
|
__pyx_t_5 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_empty_tuple), NULL); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 112; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_5);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_t_8 = __Pyx_PyObject_IsTrue(__pyx_t_5); if (unlikely(__pyx_t_8 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 112; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
|
|
if (__pyx_t_8) {
|
|
|
|
/* "util.py":113
|
|
* size = "%s - (%d)"%(b1,int(b0)-1)
|
|
* elif b1.replace('-','').isdigit():
|
|
* size = "%d - %s"%(int(b1)+1,b0) # <<<<<<<<<<<<<<
|
|
* else:
|
|
* size = "%s - %s + 1"%(b1,b0)
|
|
*/
|
|
__pyx_t_5 = PyTuple_New(1); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 113; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_5));
|
|
__Pyx_INCREF(__pyx_v_b1);
|
|
PyTuple_SET_ITEM(__pyx_t_5, 0, __pyx_v_b1);
|
|
__Pyx_GIVEREF(__pyx_v_b1);
|
|
__pyx_t_1 = PyObject_Call(((PyObject *)((PyObject*)(&PyInt_Type))), ((PyObject *)__pyx_t_5), NULL); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 113; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_5)); __pyx_t_5 = 0;
|
|
__pyx_t_5 = PyNumber_Add(__pyx_t_1, __pyx_int_1); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 113; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_5);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 113; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_t_5);
|
|
__Pyx_GIVEREF(__pyx_t_5);
|
|
__Pyx_INCREF(__pyx_v_b0);
|
|
PyTuple_SET_ITEM(__pyx_t_1, 1, __pyx_v_b0);
|
|
__Pyx_GIVEREF(__pyx_v_b0);
|
|
__pyx_t_5 = 0;
|
|
__pyx_t_5 = PyNumber_Remainder(((PyObject *)__pyx_kp_s_18), ((PyObject *)__pyx_t_1)); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 113; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_5));
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0;
|
|
__Pyx_DECREF(__pyx_v_size);
|
|
__pyx_v_size = ((PyObject *)__pyx_t_5);
|
|
__pyx_t_5 = 0;
|
|
goto __pyx_L9;
|
|
}
|
|
/*else*/ {
|
|
|
|
/* "util.py":115
|
|
* size = "%d - %s"%(int(b1)+1,b0)
|
|
* else:
|
|
* size = "%s - %s + 1"%(b1,b0) # <<<<<<<<<<<<<<
|
|
* return size
|
|
*
|
|
*/
|
|
__pyx_t_5 = PyTuple_New(2); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 115; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_5));
|
|
__Pyx_INCREF(__pyx_v_b1);
|
|
PyTuple_SET_ITEM(__pyx_t_5, 0, __pyx_v_b1);
|
|
__Pyx_GIVEREF(__pyx_v_b1);
|
|
__Pyx_INCREF(__pyx_v_b0);
|
|
PyTuple_SET_ITEM(__pyx_t_5, 1, __pyx_v_b0);
|
|
__Pyx_GIVEREF(__pyx_v_b0);
|
|
__pyx_t_1 = PyNumber_Remainder(((PyObject *)__pyx_kp_s_19), ((PyObject *)__pyx_t_5)); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 115; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_5)); __pyx_t_5 = 0;
|
|
__Pyx_DECREF(__pyx_v_size);
|
|
__pyx_v_size = ((PyObject *)__pyx_t_1);
|
|
__pyx_t_1 = 0;
|
|
}
|
|
__pyx_L9:;
|
|
}
|
|
__pyx_L8:;
|
|
|
|
/* "util.py":116
|
|
* else:
|
|
* size = "%s - %s + 1"%(b1,b0)
|
|
* return size # <<<<<<<<<<<<<<
|
|
*
|
|
* def put_info(text,filename):
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__Pyx_INCREF(__pyx_v_size);
|
|
__pyx_r = __pyx_v_size;
|
|
goto __pyx_L0;
|
|
}
|
|
__pyx_L5:;
|
|
|
|
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_1);
|
|
__Pyx_XDECREF(__pyx_t_3);
|
|
__Pyx_XDECREF(__pyx_t_5);
|
|
__Pyx_AddTraceback("util.dimsize", __pyx_clineno, __pyx_lineno, __pyx_filename);
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XDECREF(__pyx_v_buffer);
|
|
__Pyx_XDECREF(__pyx_v_size);
|
|
__Pyx_XDECREF(__pyx_v_b0);
|
|
__Pyx_XDECREF(__pyx_v_b1);
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "util.py":118
|
|
* return size
|
|
*
|
|
* def put_info(text,filename): # <<<<<<<<<<<<<<
|
|
* assert type(text) == list
|
|
* if len(text) > 0:
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4util_9put_info(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
|
|
static PyMethodDef __pyx_mdef_4util_9put_info = {__Pyx_NAMESTR("put_info"), (PyCFunction)__pyx_pf_4util_9put_info, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(0)};
|
|
static PyObject *__pyx_pf_4util_9put_info(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
|
|
PyObject *__pyx_v_text = 0;
|
|
PyObject *__pyx_v_filename = 0;
|
|
PyObject *__pyx_v_Line = NULL;
|
|
Py_ssize_t __pyx_v_lenmax;
|
|
PyObject *__pyx_v_format = NULL;
|
|
PyObject *__pyx_v_vars = NULL;
|
|
PyObject *__pyx_v_line = NULL;
|
|
PyObject *__pyx_r = NULL;
|
|
__Pyx_RefNannyDeclarations
|
|
PyObject *__pyx_t_1 = NULL;
|
|
int __pyx_t_2;
|
|
Py_ssize_t __pyx_t_3;
|
|
PyObject *__pyx_t_4 = NULL;
|
|
PyObject *(*__pyx_t_5)(PyObject *);
|
|
PyObject *__pyx_t_6 = NULL;
|
|
PyObject *__pyx_t_7 = NULL;
|
|
PyObject *__pyx_t_8 = NULL;
|
|
PyObject *(*__pyx_t_9)(PyObject *);
|
|
int __pyx_lineno = 0;
|
|
const char *__pyx_filename = NULL;
|
|
int __pyx_clineno = 0;
|
|
static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__text,&__pyx_n_s__filename,0};
|
|
__Pyx_RefNannySetupContext("put_info");
|
|
__pyx_self = __pyx_self;
|
|
{
|
|
PyObject* values[2] = {0,0};
|
|
if (unlikely(__pyx_kwds)) {
|
|
Py_ssize_t kw_args;
|
|
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;
|
|
}
|
|
kw_args = PyDict_Size(__pyx_kwds);
|
|
switch (PyTuple_GET_SIZE(__pyx_args)) {
|
|
case 0:
|
|
values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__text);
|
|
if (likely(values[0])) kw_args--;
|
|
else goto __pyx_L5_argtuple_error;
|
|
case 1:
|
|
values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__filename);
|
|
if (likely(values[1])) kw_args--;
|
|
else {
|
|
__Pyx_RaiseArgtupleInvalid("put_info", 1, 2, 2, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 118; __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), "put_info") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 118; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
} else if (PyTuple_GET_SIZE(__pyx_args) != 2) {
|
|
goto __pyx_L5_argtuple_error;
|
|
} else {
|
|
values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
|
|
values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
|
|
}
|
|
__pyx_v_text = values[0];
|
|
__pyx_v_filename = values[1];
|
|
}
|
|
goto __pyx_L4_argument_unpacking_done;
|
|
__pyx_L5_argtuple_error:;
|
|
__Pyx_RaiseArgtupleInvalid("put_info", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 118; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
__pyx_L3_error:;
|
|
__Pyx_AddTraceback("util.put_info", __pyx_clineno, __pyx_lineno, __pyx_filename);
|
|
__Pyx_RefNannyFinishContext();
|
|
return NULL;
|
|
__pyx_L4_argument_unpacking_done:;
|
|
|
|
/* "util.py":119
|
|
*
|
|
* def put_info(text,filename):
|
|
* assert type(text) == list # <<<<<<<<<<<<<<
|
|
* if len(text) > 0:
|
|
* assert type(text[0]) == tuple
|
|
*/
|
|
#ifndef CYTHON_WITHOUT_ASSERTIONS
|
|
__pyx_t_1 = PyObject_RichCompare(((PyObject *)Py_TYPE(__pyx_v_text)), ((PyObject *)((PyObject*)(&PyList_Type))), Py_EQ); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 119; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_2 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely(__pyx_t_2 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 119; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
if (unlikely(!__pyx_t_2)) {
|
|
PyErr_SetNone(PyExc_AssertionError);
|
|
{__pyx_filename = __pyx_f[0]; __pyx_lineno = 119; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
}
|
|
#endif
|
|
|
|
/* "util.py":120
|
|
* def put_info(text,filename):
|
|
* assert type(text) == list
|
|
* if len(text) > 0: # <<<<<<<<<<<<<<
|
|
* assert type(text[0]) == tuple
|
|
* from irpf90_t import Line
|
|
*/
|
|
__pyx_t_3 = PyObject_Length(__pyx_v_text); if (unlikely(__pyx_t_3 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 120; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_t_2 = (__pyx_t_3 > 0);
|
|
if (__pyx_t_2) {
|
|
|
|
/* "util.py":121
|
|
* assert type(text) == list
|
|
* if len(text) > 0:
|
|
* assert type(text[0]) == tuple # <<<<<<<<<<<<<<
|
|
* from irpf90_t import Line
|
|
* assert type(text[0][0]) == list
|
|
*/
|
|
#ifndef CYTHON_WITHOUT_ASSERTIONS
|
|
__pyx_t_1 = __Pyx_GetItemInt(__pyx_v_text, 0, sizeof(long), PyInt_FromLong); if (!__pyx_t_1) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 121; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_4 = PyObject_RichCompare(((PyObject *)Py_TYPE(__pyx_t_1)), ((PyObject *)((PyObject*)(&PyTuple_Type))), Py_EQ); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 121; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_t_2 = __Pyx_PyObject_IsTrue(__pyx_t_4); if (unlikely(__pyx_t_2 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 121; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
if (unlikely(!__pyx_t_2)) {
|
|
PyErr_SetNone(PyExc_AssertionError);
|
|
{__pyx_filename = __pyx_f[0]; __pyx_lineno = 121; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
}
|
|
#endif
|
|
|
|
/* "util.py":122
|
|
* if len(text) > 0:
|
|
* assert type(text[0]) == tuple
|
|
* from irpf90_t import Line # <<<<<<<<<<<<<<
|
|
* assert type(text[0][0]) == list
|
|
* assert isinstance(text[0][1], Line)
|
|
*/
|
|
__pyx_t_4 = PyList_New(1); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 122; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_4));
|
|
__Pyx_INCREF(((PyObject *)__pyx_n_s__Line));
|
|
PyList_SET_ITEM(__pyx_t_4, 0, ((PyObject *)__pyx_n_s__Line));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_n_s__Line));
|
|
__pyx_t_1 = __Pyx_Import(((PyObject *)__pyx_n_s__irpf90_t), ((PyObject *)__pyx_t_4), -1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 122; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_4)); __pyx_t_4 = 0;
|
|
__pyx_t_4 = PyObject_GetAttr(__pyx_t_1, __pyx_n_s__Line); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 122; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
__Pyx_INCREF(__pyx_t_4);
|
|
__pyx_v_Line = __pyx_t_4;
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
|
|
/* "util.py":123
|
|
* assert type(text[0]) == tuple
|
|
* from irpf90_t import Line
|
|
* assert type(text[0][0]) == list # <<<<<<<<<<<<<<
|
|
* assert isinstance(text[0][1], Line)
|
|
* lenmax = 80 - len(filename)
|
|
*/
|
|
#ifndef CYTHON_WITHOUT_ASSERTIONS
|
|
__pyx_t_1 = __Pyx_GetItemInt(__pyx_v_text, 0, sizeof(long), PyInt_FromLong); if (!__pyx_t_1) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 123; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_4 = __Pyx_GetItemInt(__pyx_t_1, 0, sizeof(long), PyInt_FromLong); if (!__pyx_t_4) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 123; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_t_1 = PyObject_RichCompare(((PyObject *)Py_TYPE(__pyx_t_4)), ((PyObject *)((PyObject*)(&PyList_Type))), Py_EQ); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 123; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
__pyx_t_2 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely(__pyx_t_2 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 123; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
if (unlikely(!__pyx_t_2)) {
|
|
PyErr_SetNone(PyExc_AssertionError);
|
|
{__pyx_filename = __pyx_f[0]; __pyx_lineno = 123; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
}
|
|
#endif
|
|
|
|
/* "util.py":124
|
|
* from irpf90_t import Line
|
|
* assert type(text[0][0]) == list
|
|
* assert isinstance(text[0][1], Line) # <<<<<<<<<<<<<<
|
|
* lenmax = 80 - len(filename)
|
|
* format = "%"+str(lenmax)+"s ! %s:%4s"
|
|
*/
|
|
#ifndef CYTHON_WITHOUT_ASSERTIONS
|
|
__pyx_t_1 = __Pyx_GetItemInt(__pyx_v_text, 0, sizeof(long), PyInt_FromLong); if (!__pyx_t_1) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 124; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_4 = __Pyx_GetItemInt(__pyx_t_1, 1, sizeof(long), PyInt_FromLong); if (!__pyx_t_4) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 124; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_t_2 = PyObject_IsInstance(__pyx_t_4, __pyx_v_Line); if (unlikely(__pyx_t_2 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 124; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
if (unlikely(!__pyx_t_2)) {
|
|
PyErr_SetNone(PyExc_AssertionError);
|
|
{__pyx_filename = __pyx_f[0]; __pyx_lineno = 124; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
}
|
|
#endif
|
|
|
|
/* "util.py":125
|
|
* assert type(text[0][0]) == list
|
|
* assert isinstance(text[0][1], Line)
|
|
* lenmax = 80 - len(filename) # <<<<<<<<<<<<<<
|
|
* format = "%"+str(lenmax)+"s ! %s:%4s"
|
|
* for vars,line in text:
|
|
*/
|
|
__pyx_t_3 = PyObject_Length(__pyx_v_filename); if (unlikely(__pyx_t_3 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 125; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_v_lenmax = (80 - __pyx_t_3);
|
|
|
|
/* "util.py":126
|
|
* assert isinstance(text[0][1], Line)
|
|
* lenmax = 80 - len(filename)
|
|
* format = "%"+str(lenmax)+"s ! %s:%4s" # <<<<<<<<<<<<<<
|
|
* for vars,line in text:
|
|
* line.text = format%(line.text.ljust(lenmax),line.filename,str(line.i))
|
|
*/
|
|
__pyx_t_4 = PyInt_FromSsize_t(__pyx_v_lenmax); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 126; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
__pyx_t_1 = PyTuple_New(1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 126; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_t_4);
|
|
__Pyx_GIVEREF(__pyx_t_4);
|
|
__pyx_t_4 = 0;
|
|
__pyx_t_4 = PyObject_Call(((PyObject *)((PyObject*)(&PyString_Type))), ((PyObject *)__pyx_t_1), NULL); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 126; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0;
|
|
__pyx_t_1 = PyNumber_Add(((PyObject *)__pyx_kp_s_20), __pyx_t_4); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 126; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
__pyx_t_4 = PyNumber_Add(__pyx_t_1, ((PyObject *)__pyx_kp_s_21)); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 126; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_v_format = __pyx_t_4;
|
|
__pyx_t_4 = 0;
|
|
|
|
/* "util.py":127
|
|
* lenmax = 80 - len(filename)
|
|
* format = "%"+str(lenmax)+"s ! %s:%4s"
|
|
* for vars,line in text: # <<<<<<<<<<<<<<
|
|
* line.text = format%(line.text.ljust(lenmax),line.filename,str(line.i))
|
|
* return text
|
|
*/
|
|
if (PyList_CheckExact(__pyx_v_text) || PyTuple_CheckExact(__pyx_v_text)) {
|
|
__pyx_t_4 = __pyx_v_text; __Pyx_INCREF(__pyx_t_4); __pyx_t_3 = 0;
|
|
__pyx_t_5 = NULL;
|
|
} else {
|
|
__pyx_t_3 = -1; __pyx_t_4 = PyObject_GetIter(__pyx_v_text); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 127; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
__pyx_t_5 = Py_TYPE(__pyx_t_4)->tp_iternext;
|
|
}
|
|
for (;;) {
|
|
if (PyList_CheckExact(__pyx_t_4)) {
|
|
if (__pyx_t_3 >= PyList_GET_SIZE(__pyx_t_4)) break;
|
|
__pyx_t_1 = PyList_GET_ITEM(__pyx_t_4, __pyx_t_3); __Pyx_INCREF(__pyx_t_1); __pyx_t_3++;
|
|
} else if (PyTuple_CheckExact(__pyx_t_4)) {
|
|
if (__pyx_t_3 >= PyTuple_GET_SIZE(__pyx_t_4)) break;
|
|
__pyx_t_1 = PyTuple_GET_ITEM(__pyx_t_4, __pyx_t_3); __Pyx_INCREF(__pyx_t_1); __pyx_t_3++;
|
|
} else {
|
|
__pyx_t_1 = __pyx_t_5(__pyx_t_4);
|
|
if (unlikely(!__pyx_t_1)) {
|
|
if (PyErr_Occurred()) {
|
|
if (likely(PyErr_ExceptionMatches(PyExc_StopIteration))) PyErr_Clear();
|
|
else {__pyx_filename = __pyx_f[0]; __pyx_lineno = 127; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
}
|
|
break;
|
|
}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
}
|
|
if ((likely(PyTuple_CheckExact(__pyx_t_1))) || (PyList_CheckExact(__pyx_t_1))) {
|
|
PyObject* sequence = __pyx_t_1;
|
|
if (likely(PyTuple_CheckExact(sequence))) {
|
|
if (unlikely(PyTuple_GET_SIZE(sequence) != 2)) {
|
|
if (PyTuple_GET_SIZE(sequence) > 2) __Pyx_RaiseTooManyValuesError(2);
|
|
else __Pyx_RaiseNeedMoreValuesError(PyTuple_GET_SIZE(sequence));
|
|
{__pyx_filename = __pyx_f[0]; __pyx_lineno = 127; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
}
|
|
__pyx_t_6 = PyTuple_GET_ITEM(sequence, 0);
|
|
__pyx_t_7 = PyTuple_GET_ITEM(sequence, 1);
|
|
} else {
|
|
if (unlikely(PyList_GET_SIZE(sequence) != 2)) {
|
|
if (PyList_GET_SIZE(sequence) > 2) __Pyx_RaiseTooManyValuesError(2);
|
|
else __Pyx_RaiseNeedMoreValuesError(PyList_GET_SIZE(sequence));
|
|
{__pyx_filename = __pyx_f[0]; __pyx_lineno = 127; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
}
|
|
__pyx_t_6 = PyList_GET_ITEM(sequence, 0);
|
|
__pyx_t_7 = PyList_GET_ITEM(sequence, 1);
|
|
}
|
|
__Pyx_INCREF(__pyx_t_6);
|
|
__Pyx_INCREF(__pyx_t_7);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
} else {
|
|
Py_ssize_t index = -1;
|
|
__pyx_t_8 = PyObject_GetIter(__pyx_t_1); if (unlikely(!__pyx_t_8)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 127; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_8);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_t_9 = Py_TYPE(__pyx_t_8)->tp_iternext;
|
|
index = 0; __pyx_t_6 = __pyx_t_9(__pyx_t_8); if (unlikely(!__pyx_t_6)) goto __pyx_L9_unpacking_failed;
|
|
__Pyx_GOTREF(__pyx_t_6);
|
|
index = 1; __pyx_t_7 = __pyx_t_9(__pyx_t_8); if (unlikely(!__pyx_t_7)) goto __pyx_L9_unpacking_failed;
|
|
__Pyx_GOTREF(__pyx_t_7);
|
|
if (__Pyx_IternextUnpackEndCheck(__pyx_t_9(__pyx_t_8), 2) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 127; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
|
|
goto __pyx_L10_unpacking_done;
|
|
__pyx_L9_unpacking_failed:;
|
|
__Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
|
|
if (PyErr_Occurred() && PyErr_ExceptionMatches(PyExc_StopIteration)) PyErr_Clear();
|
|
if (!PyErr_Occurred()) __Pyx_RaiseNeedMoreValuesError(index);
|
|
{__pyx_filename = __pyx_f[0]; __pyx_lineno = 127; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_L10_unpacking_done:;
|
|
}
|
|
__Pyx_XDECREF(__pyx_v_vars);
|
|
__pyx_v_vars = __pyx_t_6;
|
|
__pyx_t_6 = 0;
|
|
__Pyx_XDECREF(__pyx_v_line);
|
|
__pyx_v_line = __pyx_t_7;
|
|
__pyx_t_7 = 0;
|
|
|
|
/* "util.py":128
|
|
* format = "%"+str(lenmax)+"s ! %s:%4s"
|
|
* for vars,line in text:
|
|
* line.text = format%(line.text.ljust(lenmax),line.filename,str(line.i)) # <<<<<<<<<<<<<<
|
|
* return text
|
|
*
|
|
*/
|
|
__pyx_t_1 = PyObject_GetAttr(__pyx_v_line, __pyx_n_s__text); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 128; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_7 = PyObject_GetAttr(__pyx_t_1, __pyx_n_s__ljust); if (unlikely(!__pyx_t_7)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 128; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_7);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_t_1 = PyInt_FromSsize_t(__pyx_v_lenmax); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 128; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_6 = PyTuple_New(1); if (unlikely(!__pyx_t_6)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 128; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_6));
|
|
PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_1);
|
|
__Pyx_GIVEREF(__pyx_t_1);
|
|
__pyx_t_1 = 0;
|
|
__pyx_t_1 = PyObject_Call(__pyx_t_7, ((PyObject *)__pyx_t_6), NULL); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 128; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_6)); __pyx_t_6 = 0;
|
|
__pyx_t_6 = PyObject_GetAttr(__pyx_v_line, __pyx_n_s__filename); if (unlikely(!__pyx_t_6)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 128; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_6);
|
|
__pyx_t_7 = PyObject_GetAttr(__pyx_v_line, __pyx_n_s__i); if (unlikely(!__pyx_t_7)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 128; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_7);
|
|
__pyx_t_8 = PyTuple_New(1); if (unlikely(!__pyx_t_8)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 128; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_8));
|
|
PyTuple_SET_ITEM(__pyx_t_8, 0, __pyx_t_7);
|
|
__Pyx_GIVEREF(__pyx_t_7);
|
|
__pyx_t_7 = 0;
|
|
__pyx_t_7 = PyObject_Call(((PyObject *)((PyObject*)(&PyString_Type))), ((PyObject *)__pyx_t_8), NULL); if (unlikely(!__pyx_t_7)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 128; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_7);
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_8)); __pyx_t_8 = 0;
|
|
__pyx_t_8 = PyTuple_New(3); if (unlikely(!__pyx_t_8)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 128; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_8));
|
|
PyTuple_SET_ITEM(__pyx_t_8, 0, __pyx_t_1);
|
|
__Pyx_GIVEREF(__pyx_t_1);
|
|
PyTuple_SET_ITEM(__pyx_t_8, 1, __pyx_t_6);
|
|
__Pyx_GIVEREF(__pyx_t_6);
|
|
PyTuple_SET_ITEM(__pyx_t_8, 2, __pyx_t_7);
|
|
__Pyx_GIVEREF(__pyx_t_7);
|
|
__pyx_t_1 = 0;
|
|
__pyx_t_6 = 0;
|
|
__pyx_t_7 = 0;
|
|
__pyx_t_7 = PyNumber_Remainder(__pyx_v_format, ((PyObject *)__pyx_t_8)); if (unlikely(!__pyx_t_7)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 128; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_7);
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_8)); __pyx_t_8 = 0;
|
|
if (PyObject_SetAttr(__pyx_v_line, __pyx_n_s__text, __pyx_t_7) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 128; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
|
|
}
|
|
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
|
|
goto __pyx_L6;
|
|
}
|
|
__pyx_L6:;
|
|
|
|
/* "util.py":129
|
|
* for vars,line in text:
|
|
* line.text = format%(line.text.ljust(lenmax),line.filename,str(line.i))
|
|
* return text # <<<<<<<<<<<<<<
|
|
*
|
|
* import cPickle as pickle
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__Pyx_INCREF(__pyx_v_text);
|
|
__pyx_r = __pyx_v_text;
|
|
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_4);
|
|
__Pyx_XDECREF(__pyx_t_6);
|
|
__Pyx_XDECREF(__pyx_t_7);
|
|
__Pyx_XDECREF(__pyx_t_8);
|
|
__Pyx_AddTraceback("util.put_info", __pyx_clineno, __pyx_lineno, __pyx_filename);
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XDECREF(__pyx_v_Line);
|
|
__Pyx_XDECREF(__pyx_v_format);
|
|
__Pyx_XDECREF(__pyx_v_vars);
|
|
__Pyx_XDECREF(__pyx_v_line);
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "util.py":139
|
|
* index = 0
|
|
* try:
|
|
* source = map( lambda x: (len(x[1]),(x[0], x[1])), source ) # <<<<<<<<<<<<<<
|
|
* source.sort()
|
|
* source = map( lambda x: x[1], source )
|
|
*/
|
|
|
|
static PyObject *__pyx_lambda_funcdef_lambda2(PyObject *__pyx_self, PyObject *__pyx_v_x); /*proto*/
|
|
static PyMethodDef __pyx_lambda_methdef_lambda2 = {__Pyx_NAMESTR("lambda2"), (PyCFunction)__pyx_lambda_funcdef_lambda2, METH_O, __Pyx_DOCSTR(0)};
|
|
static PyObject *__pyx_lambda_funcdef_lambda2(PyObject *__pyx_self, PyObject *__pyx_v_x) {
|
|
PyObject *__pyx_r = NULL;
|
|
__Pyx_RefNannyDeclarations
|
|
PyObject *__pyx_t_1 = NULL;
|
|
Py_ssize_t __pyx_t_2;
|
|
PyObject *__pyx_t_3 = NULL;
|
|
PyObject *__pyx_t_4 = NULL;
|
|
PyObject *__pyx_t_5 = NULL;
|
|
int __pyx_lineno = 0;
|
|
const char *__pyx_filename = NULL;
|
|
int __pyx_clineno = 0;
|
|
__Pyx_RefNannySetupContext("lambda2");
|
|
__pyx_self = __pyx_self;
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_1 = __Pyx_GetItemInt(__pyx_v_x, 1, sizeof(long), PyInt_FromLong); if (!__pyx_t_1) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 139; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_2 = PyObject_Length(__pyx_t_1); if (unlikely(__pyx_t_2 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 139; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_t_1 = PyInt_FromSsize_t(__pyx_t_2); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 139; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_3 = __Pyx_GetItemInt(__pyx_v_x, 0, sizeof(long), PyInt_FromLong); if (!__pyx_t_3) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 139; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__pyx_t_4 = __Pyx_GetItemInt(__pyx_v_x, 1, sizeof(long), PyInt_FromLong); if (!__pyx_t_4) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 139; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_4);
|
|
__pyx_t_5 = PyTuple_New(2); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 139; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_5));
|
|
PyTuple_SET_ITEM(__pyx_t_5, 0, __pyx_t_3);
|
|
__Pyx_GIVEREF(__pyx_t_3);
|
|
PyTuple_SET_ITEM(__pyx_t_5, 1, __pyx_t_4);
|
|
__Pyx_GIVEREF(__pyx_t_4);
|
|
__pyx_t_3 = 0;
|
|
__pyx_t_4 = 0;
|
|
__pyx_t_4 = PyTuple_New(2); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 139; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_4));
|
|
PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_1);
|
|
__Pyx_GIVEREF(__pyx_t_1);
|
|
PyTuple_SET_ITEM(__pyx_t_4, 1, ((PyObject *)__pyx_t_5));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_t_5));
|
|
__pyx_t_1 = 0;
|
|
__pyx_t_5 = 0;
|
|
__pyx_r = ((PyObject *)__pyx_t_4);
|
|
__pyx_t_4 = 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_3);
|
|
__Pyx_XDECREF(__pyx_t_4);
|
|
__Pyx_XDECREF(__pyx_t_5);
|
|
__Pyx_AddTraceback("util.parallel_loop.lambda2", __pyx_clineno, __pyx_lineno, __pyx_filename);
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "util.py":141
|
|
* source = map( lambda x: (len(x[1]),(x[0], x[1])), source )
|
|
* source.sort()
|
|
* source = map( lambda x: x[1], source ) # <<<<<<<<<<<<<<
|
|
* except:
|
|
* pass
|
|
*/
|
|
|
|
static PyObject *__pyx_lambda_funcdef_lambda3(PyObject *__pyx_self, PyObject *__pyx_v_x); /*proto*/
|
|
static PyMethodDef __pyx_lambda_methdef_lambda3 = {__Pyx_NAMESTR("lambda3"), (PyCFunction)__pyx_lambda_funcdef_lambda3, METH_O, __Pyx_DOCSTR(0)};
|
|
static PyObject *__pyx_lambda_funcdef_lambda3(PyObject *__pyx_self, PyObject *__pyx_v_x) {
|
|
PyObject *__pyx_r = NULL;
|
|
__Pyx_RefNannyDeclarations
|
|
PyObject *__pyx_t_1 = NULL;
|
|
int __pyx_lineno = 0;
|
|
const char *__pyx_filename = NULL;
|
|
int __pyx_clineno = 0;
|
|
__Pyx_RefNannySetupContext("lambda3");
|
|
__pyx_self = __pyx_self;
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__pyx_t_1 = __Pyx_GetItemInt(__pyx_v_x, 1, sizeof(long), PyInt_FromLong); if (!__pyx_t_1) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 141; __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("util.parallel_loop.lambda3", __pyx_clineno, __pyx_lineno, __pyx_filename);
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
/* "util.py":133
|
|
* import cPickle as pickle
|
|
* import os, sys
|
|
* def parallel_loop(f,source): # <<<<<<<<<<<<<<
|
|
* pidlist = range(NTHREADS)
|
|
*
|
|
*/
|
|
|
|
static PyObject *__pyx_pf_4util_10parallel_loop(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
|
|
static PyMethodDef __pyx_mdef_4util_10parallel_loop = {__Pyx_NAMESTR("parallel_loop"), (PyCFunction)__pyx_pf_4util_10parallel_loop, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(0)};
|
|
static PyObject *__pyx_pf_4util_10parallel_loop(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
|
|
PyObject *__pyx_v_f = 0;
|
|
PyObject *__pyx_v_source = 0;
|
|
PyObject *__pyx_v_pidlist = NULL;
|
|
PyObject *__pyx_v_src = NULL;
|
|
PyObject *__pyx_v_index = NULL;
|
|
PyObject *__pyx_v_i = NULL;
|
|
PyObject *__pyx_v_thread_id = NULL;
|
|
PyObject *__pyx_v_fork = NULL;
|
|
PyObject *__pyx_v_r = NULL;
|
|
PyObject *__pyx_v_w = NULL;
|
|
PyObject *__pyx_v_result = NULL;
|
|
PyObject *__pyx_v_filename = NULL;
|
|
PyObject *__pyx_v_text = NULL;
|
|
PyObject *__pyx_r = NULL;
|
|
__Pyx_RefNannyDeclarations
|
|
PyObject *__pyx_t_1 = NULL;
|
|
PyObject *__pyx_t_2 = NULL;
|
|
PyObject *__pyx_t_3 = NULL;
|
|
Py_ssize_t __pyx_t_4;
|
|
PyObject *(*__pyx_t_5)(PyObject *);
|
|
PyObject *__pyx_t_6 = NULL;
|
|
PyObject *__pyx_t_7 = NULL;
|
|
PyObject *__pyx_t_8 = NULL;
|
|
int __pyx_t_9;
|
|
PyObject *__pyx_t_10 = NULL;
|
|
PyObject *__pyx_t_11 = NULL;
|
|
PyObject *(*__pyx_t_12)(PyObject *);
|
|
int __pyx_lineno = 0;
|
|
const char *__pyx_filename = NULL;
|
|
int __pyx_clineno = 0;
|
|
static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__f,&__pyx_n_s__source,0};
|
|
__Pyx_RefNannySetupContext("parallel_loop");
|
|
__pyx_self = __pyx_self;
|
|
{
|
|
PyObject* values[2] = {0,0};
|
|
if (unlikely(__pyx_kwds)) {
|
|
Py_ssize_t kw_args;
|
|
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;
|
|
}
|
|
kw_args = PyDict_Size(__pyx_kwds);
|
|
switch (PyTuple_GET_SIZE(__pyx_args)) {
|
|
case 0:
|
|
values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__f);
|
|
if (likely(values[0])) kw_args--;
|
|
else goto __pyx_L5_argtuple_error;
|
|
case 1:
|
|
values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__source);
|
|
if (likely(values[1])) kw_args--;
|
|
else {
|
|
__Pyx_RaiseArgtupleInvalid("parallel_loop", 1, 2, 2, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 133; __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), "parallel_loop") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 133; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
}
|
|
} else if (PyTuple_GET_SIZE(__pyx_args) != 2) {
|
|
goto __pyx_L5_argtuple_error;
|
|
} else {
|
|
values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
|
|
values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
|
|
}
|
|
__pyx_v_f = values[0];
|
|
__pyx_v_source = values[1];
|
|
}
|
|
goto __pyx_L4_argument_unpacking_done;
|
|
__pyx_L5_argtuple_error:;
|
|
__Pyx_RaiseArgtupleInvalid("parallel_loop", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 133; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
|
|
__pyx_L3_error:;
|
|
__Pyx_AddTraceback("util.parallel_loop", __pyx_clineno, __pyx_lineno, __pyx_filename);
|
|
__Pyx_RefNannyFinishContext();
|
|
return NULL;
|
|
__pyx_L4_argument_unpacking_done:;
|
|
__Pyx_INCREF(__pyx_v_source);
|
|
|
|
/* "util.py":134
|
|
* import os, sys
|
|
* def parallel_loop(f,source):
|
|
* pidlist = range(NTHREADS) # <<<<<<<<<<<<<<
|
|
*
|
|
* src = [ [] for i in xrange(NTHREADS) ]
|
|
*/
|
|
__pyx_t_1 = __Pyx_GetName(__pyx_m, __pyx_n_s__NTHREADS); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 134; __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 = 134; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__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_builtin_range, ((PyObject *)__pyx_t_2), NULL); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 134; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_2)); __pyx_t_2 = 0;
|
|
__pyx_v_pidlist = __pyx_t_1;
|
|
__pyx_t_1 = 0;
|
|
|
|
/* "util.py":136
|
|
* pidlist = range(NTHREADS)
|
|
*
|
|
* src = [ [] for i in xrange(NTHREADS) ] # <<<<<<<<<<<<<<
|
|
* index = 0
|
|
* try:
|
|
*/
|
|
__pyx_t_1 = PyList_New(0); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 136; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
__pyx_t_2 = __Pyx_GetName(__pyx_m, __pyx_n_s__NTHREADS); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 136; __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 = 136; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__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(__pyx_builtin_xrange, ((PyObject *)__pyx_t_3), NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 136; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_3)); __pyx_t_3 = 0;
|
|
if (PyList_CheckExact(__pyx_t_2) || PyTuple_CheckExact(__pyx_t_2)) {
|
|
__pyx_t_3 = __pyx_t_2; __Pyx_INCREF(__pyx_t_3); __pyx_t_4 = 0;
|
|
__pyx_t_5 = NULL;
|
|
} else {
|
|
__pyx_t_4 = -1; __pyx_t_3 = PyObject_GetIter(__pyx_t_2); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 136; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__pyx_t_5 = Py_TYPE(__pyx_t_3)->tp_iternext;
|
|
}
|
|
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
|
|
for (;;) {
|
|
if (PyList_CheckExact(__pyx_t_3)) {
|
|
if (__pyx_t_4 >= PyList_GET_SIZE(__pyx_t_3)) break;
|
|
__pyx_t_2 = PyList_GET_ITEM(__pyx_t_3, __pyx_t_4); __Pyx_INCREF(__pyx_t_2); __pyx_t_4++;
|
|
} else if (PyTuple_CheckExact(__pyx_t_3)) {
|
|
if (__pyx_t_4 >= PyTuple_GET_SIZE(__pyx_t_3)) break;
|
|
__pyx_t_2 = PyTuple_GET_ITEM(__pyx_t_3, __pyx_t_4); __Pyx_INCREF(__pyx_t_2); __pyx_t_4++;
|
|
} else {
|
|
__pyx_t_2 = __pyx_t_5(__pyx_t_3);
|
|
if (unlikely(!__pyx_t_2)) {
|
|
if (PyErr_Occurred()) {
|
|
if (likely(PyErr_ExceptionMatches(PyExc_StopIteration))) PyErr_Clear();
|
|
else {__pyx_filename = __pyx_f[0]; __pyx_lineno = 136; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
}
|
|
break;
|
|
}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
}
|
|
__Pyx_XDECREF(__pyx_v_i);
|
|
__pyx_v_i = __pyx_t_2;
|
|
__pyx_t_2 = 0;
|
|
__pyx_t_2 = PyList_New(0); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 136; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_2));
|
|
if (unlikely(PyList_Append(__pyx_t_1, (PyObject*)__pyx_t_2))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 136; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_2)); __pyx_t_2 = 0;
|
|
}
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
__Pyx_INCREF(((PyObject *)__pyx_t_1));
|
|
__pyx_v_src = __pyx_t_1;
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0;
|
|
|
|
/* "util.py":137
|
|
*
|
|
* src = [ [] for i in xrange(NTHREADS) ]
|
|
* index = 0 # <<<<<<<<<<<<<<
|
|
* try:
|
|
* source = map( lambda x: (len(x[1]),(x[0], x[1])), source )
|
|
*/
|
|
__Pyx_INCREF(__pyx_int_0);
|
|
__pyx_v_index = __pyx_int_0;
|
|
|
|
/* "util.py":138
|
|
* src = [ [] for i in xrange(NTHREADS) ]
|
|
* index = 0
|
|
* try: # <<<<<<<<<<<<<<
|
|
* source = map( lambda x: (len(x[1]),(x[0], x[1])), source )
|
|
* source.sort()
|
|
*/
|
|
{
|
|
__Pyx_ExceptionSave(&__pyx_t_6, &__pyx_t_7, &__pyx_t_8);
|
|
__Pyx_XGOTREF(__pyx_t_6);
|
|
__Pyx_XGOTREF(__pyx_t_7);
|
|
__Pyx_XGOTREF(__pyx_t_8);
|
|
/*try:*/ {
|
|
|
|
/* "util.py":139
|
|
* index = 0
|
|
* try:
|
|
* source = map( lambda x: (len(x[1]),(x[0], x[1])), source ) # <<<<<<<<<<<<<<
|
|
* source.sort()
|
|
* source = map( lambda x: x[1], source )
|
|
*/
|
|
__pyx_t_1 = __pyx_binding_PyCFunctionType_NewEx(&__pyx_lambda_methdef_lambda2, NULL, __pyx_n_s__util); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 139; __pyx_clineno = __LINE__; goto __pyx_L8_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_3 = PyTuple_New(2); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 139; __pyx_clineno = __LINE__; goto __pyx_L8_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_3));
|
|
PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_1);
|
|
__Pyx_GIVEREF(__pyx_t_1);
|
|
__Pyx_INCREF(__pyx_v_source);
|
|
PyTuple_SET_ITEM(__pyx_t_3, 1, __pyx_v_source);
|
|
__Pyx_GIVEREF(__pyx_v_source);
|
|
__pyx_t_1 = 0;
|
|
__pyx_t_1 = PyObject_Call(__pyx_builtin_map, ((PyObject *)__pyx_t_3), NULL); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 139; __pyx_clineno = __LINE__; goto __pyx_L8_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_3)); __pyx_t_3 = 0;
|
|
__Pyx_DECREF(__pyx_v_source);
|
|
__pyx_v_source = __pyx_t_1;
|
|
__pyx_t_1 = 0;
|
|
|
|
/* "util.py":140
|
|
* try:
|
|
* source = map( lambda x: (len(x[1]),(x[0], x[1])), source )
|
|
* source.sort() # <<<<<<<<<<<<<<
|
|
* source = map( lambda x: x[1], source )
|
|
* except:
|
|
*/
|
|
__pyx_t_1 = PyObject_GetAttr(__pyx_v_source, __pyx_n_s__sort); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 140; __pyx_clineno = __LINE__; goto __pyx_L8_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_3 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_empty_tuple), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 140; __pyx_clineno = __LINE__; goto __pyx_L8_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
|
|
/* "util.py":141
|
|
* source = map( lambda x: (len(x[1]),(x[0], x[1])), source )
|
|
* source.sort()
|
|
* source = map( lambda x: x[1], source ) # <<<<<<<<<<<<<<
|
|
* except:
|
|
* pass
|
|
*/
|
|
__pyx_t_3 = __pyx_binding_PyCFunctionType_NewEx(&__pyx_lambda_methdef_lambda3, NULL, __pyx_n_s__util); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 141; __pyx_clineno = __LINE__; goto __pyx_L8_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 141; __pyx_clineno = __LINE__; goto __pyx_L8_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_t_3);
|
|
__Pyx_GIVEREF(__pyx_t_3);
|
|
__Pyx_INCREF(__pyx_v_source);
|
|
PyTuple_SET_ITEM(__pyx_t_1, 1, __pyx_v_source);
|
|
__Pyx_GIVEREF(__pyx_v_source);
|
|
__pyx_t_3 = 0;
|
|
__pyx_t_3 = PyObject_Call(__pyx_builtin_map, ((PyObject *)__pyx_t_1), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 141; __pyx_clineno = __LINE__; goto __pyx_L8_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0;
|
|
__Pyx_DECREF(__pyx_v_source);
|
|
__pyx_v_source = __pyx_t_3;
|
|
__pyx_t_3 = 0;
|
|
}
|
|
__Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
|
|
__Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
|
|
__Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0;
|
|
goto __pyx_L15_try_end;
|
|
__pyx_L8_error:;
|
|
__Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
|
|
__Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
|
|
/* "util.py":142
|
|
* source.sort()
|
|
* source = map( lambda x: x[1], source )
|
|
* except: # <<<<<<<<<<<<<<
|
|
* pass
|
|
* for i in source:
|
|
*/
|
|
/*except:*/ {
|
|
PyErr_Restore(0,0,0);
|
|
goto __pyx_L9_exception_handled;
|
|
}
|
|
__pyx_L9_exception_handled:;
|
|
__Pyx_XGIVEREF(__pyx_t_6);
|
|
__Pyx_XGIVEREF(__pyx_t_7);
|
|
__Pyx_XGIVEREF(__pyx_t_8);
|
|
__Pyx_ExceptionReset(__pyx_t_6, __pyx_t_7, __pyx_t_8);
|
|
__pyx_L15_try_end:;
|
|
}
|
|
|
|
/* "util.py":144
|
|
* except:
|
|
* pass
|
|
* for i in source: # <<<<<<<<<<<<<<
|
|
* index += 1
|
|
* if index == NTHREADS:
|
|
*/
|
|
if (PyList_CheckExact(__pyx_v_source) || PyTuple_CheckExact(__pyx_v_source)) {
|
|
__pyx_t_3 = __pyx_v_source; __Pyx_INCREF(__pyx_t_3); __pyx_t_4 = 0;
|
|
__pyx_t_5 = NULL;
|
|
} else {
|
|
__pyx_t_4 = -1; __pyx_t_3 = PyObject_GetIter(__pyx_v_source); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 144; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__pyx_t_5 = Py_TYPE(__pyx_t_3)->tp_iternext;
|
|
}
|
|
for (;;) {
|
|
if (PyList_CheckExact(__pyx_t_3)) {
|
|
if (__pyx_t_4 >= PyList_GET_SIZE(__pyx_t_3)) break;
|
|
__pyx_t_1 = PyList_GET_ITEM(__pyx_t_3, __pyx_t_4); __Pyx_INCREF(__pyx_t_1); __pyx_t_4++;
|
|
} else if (PyTuple_CheckExact(__pyx_t_3)) {
|
|
if (__pyx_t_4 >= PyTuple_GET_SIZE(__pyx_t_3)) break;
|
|
__pyx_t_1 = PyTuple_GET_ITEM(__pyx_t_3, __pyx_t_4); __Pyx_INCREF(__pyx_t_1); __pyx_t_4++;
|
|
} else {
|
|
__pyx_t_1 = __pyx_t_5(__pyx_t_3);
|
|
if (unlikely(!__pyx_t_1)) {
|
|
if (PyErr_Occurred()) {
|
|
if (likely(PyErr_ExceptionMatches(PyExc_StopIteration))) PyErr_Clear();
|
|
else {__pyx_filename = __pyx_f[0]; __pyx_lineno = 144; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
}
|
|
break;
|
|
}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
}
|
|
__Pyx_XDECREF(__pyx_v_i);
|
|
__pyx_v_i = __pyx_t_1;
|
|
__pyx_t_1 = 0;
|
|
|
|
/* "util.py":145
|
|
* pass
|
|
* for i in source:
|
|
* index += 1 # <<<<<<<<<<<<<<
|
|
* if index == NTHREADS:
|
|
* index = 0
|
|
*/
|
|
__pyx_t_1 = PyNumber_InPlaceAdd(__pyx_v_index, __pyx_int_1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 145; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__Pyx_DECREF(__pyx_v_index);
|
|
__pyx_v_index = __pyx_t_1;
|
|
__pyx_t_1 = 0;
|
|
|
|
/* "util.py":146
|
|
* for i in source:
|
|
* index += 1
|
|
* if index == NTHREADS: # <<<<<<<<<<<<<<
|
|
* index = 0
|
|
* src[index].append(i)
|
|
*/
|
|
__pyx_t_1 = __Pyx_GetName(__pyx_m, __pyx_n_s__NTHREADS); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 146; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_2 = PyObject_RichCompare(__pyx_v_index, __pyx_t_1, Py_EQ); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 146; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_t_9 = __Pyx_PyObject_IsTrue(__pyx_t_2); if (unlikely(__pyx_t_9 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 146; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
|
|
if (__pyx_t_9) {
|
|
|
|
/* "util.py":147
|
|
* index += 1
|
|
* if index == NTHREADS:
|
|
* index = 0 # <<<<<<<<<<<<<<
|
|
* src[index].append(i)
|
|
*
|
|
*/
|
|
__Pyx_INCREF(__pyx_int_0);
|
|
__Pyx_DECREF(__pyx_v_index);
|
|
__pyx_v_index = __pyx_int_0;
|
|
goto __pyx_L18;
|
|
}
|
|
__pyx_L18:;
|
|
|
|
/* "util.py":148
|
|
* if index == NTHREADS:
|
|
* index = 0
|
|
* src[index].append(i) # <<<<<<<<<<<<<<
|
|
*
|
|
* thread_id = 0
|
|
*/
|
|
__pyx_t_2 = PyObject_GetItem(((PyObject *)__pyx_v_src), __pyx_v_index); if (!__pyx_t_2) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 148; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__pyx_t_1 = __Pyx_PyObject_Append(__pyx_t_2, __pyx_v_i); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 148; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
}
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
|
|
/* "util.py":150
|
|
* src[index].append(i)
|
|
*
|
|
* thread_id = 0 # <<<<<<<<<<<<<<
|
|
* fork = 1
|
|
* r = range(0,NTHREADS)
|
|
*/
|
|
__Pyx_INCREF(__pyx_int_0);
|
|
__pyx_v_thread_id = __pyx_int_0;
|
|
|
|
/* "util.py":151
|
|
*
|
|
* thread_id = 0
|
|
* fork = 1 # <<<<<<<<<<<<<<
|
|
* r = range(0,NTHREADS)
|
|
* for thread_id in xrange(1,NTHREADS):
|
|
*/
|
|
__Pyx_INCREF(__pyx_int_1);
|
|
__pyx_v_fork = __pyx_int_1;
|
|
|
|
/* "util.py":152
|
|
* thread_id = 0
|
|
* fork = 1
|
|
* r = range(0,NTHREADS) # <<<<<<<<<<<<<<
|
|
* for thread_id in xrange(1,NTHREADS):
|
|
* r[thread_id], w = os.pipe()
|
|
*/
|
|
__pyx_t_3 = __Pyx_GetName(__pyx_m, __pyx_n_s__NTHREADS); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 152; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 152; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
__Pyx_INCREF(__pyx_int_0);
|
|
PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_int_0);
|
|
__Pyx_GIVEREF(__pyx_int_0);
|
|
PyTuple_SET_ITEM(__pyx_t_1, 1, __pyx_t_3);
|
|
__Pyx_GIVEREF(__pyx_t_3);
|
|
__pyx_t_3 = 0;
|
|
__pyx_t_3 = PyObject_Call(__pyx_builtin_range, ((PyObject *)__pyx_t_1), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 152; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0;
|
|
__pyx_v_r = __pyx_t_3;
|
|
__pyx_t_3 = 0;
|
|
|
|
/* "util.py":153
|
|
* fork = 1
|
|
* r = range(0,NTHREADS)
|
|
* for thread_id in xrange(1,NTHREADS): # <<<<<<<<<<<<<<
|
|
* r[thread_id], w = os.pipe()
|
|
* fork = os.fork()
|
|
*/
|
|
__pyx_t_3 = __Pyx_GetName(__pyx_m, __pyx_n_s__NTHREADS); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 153; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 153; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
__Pyx_INCREF(__pyx_int_1);
|
|
PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_int_1);
|
|
__Pyx_GIVEREF(__pyx_int_1);
|
|
PyTuple_SET_ITEM(__pyx_t_1, 1, __pyx_t_3);
|
|
__Pyx_GIVEREF(__pyx_t_3);
|
|
__pyx_t_3 = 0;
|
|
__pyx_t_3 = PyObject_Call(__pyx_builtin_xrange, ((PyObject *)__pyx_t_1), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 153; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0;
|
|
if (PyList_CheckExact(__pyx_t_3) || PyTuple_CheckExact(__pyx_t_3)) {
|
|
__pyx_t_1 = __pyx_t_3; __Pyx_INCREF(__pyx_t_1); __pyx_t_4 = 0;
|
|
__pyx_t_5 = NULL;
|
|
} else {
|
|
__pyx_t_4 = -1; __pyx_t_1 = PyObject_GetIter(__pyx_t_3); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 153; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_5 = Py_TYPE(__pyx_t_1)->tp_iternext;
|
|
}
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
for (;;) {
|
|
if (PyList_CheckExact(__pyx_t_1)) {
|
|
if (__pyx_t_4 >= PyList_GET_SIZE(__pyx_t_1)) break;
|
|
__pyx_t_3 = PyList_GET_ITEM(__pyx_t_1, __pyx_t_4); __Pyx_INCREF(__pyx_t_3); __pyx_t_4++;
|
|
} else if (PyTuple_CheckExact(__pyx_t_1)) {
|
|
if (__pyx_t_4 >= PyTuple_GET_SIZE(__pyx_t_1)) break;
|
|
__pyx_t_3 = PyTuple_GET_ITEM(__pyx_t_1, __pyx_t_4); __Pyx_INCREF(__pyx_t_3); __pyx_t_4++;
|
|
} else {
|
|
__pyx_t_3 = __pyx_t_5(__pyx_t_1);
|
|
if (unlikely(!__pyx_t_3)) {
|
|
if (PyErr_Occurred()) {
|
|
if (likely(PyErr_ExceptionMatches(PyExc_StopIteration))) PyErr_Clear();
|
|
else {__pyx_filename = __pyx_f[0]; __pyx_lineno = 153; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
}
|
|
break;
|
|
}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
}
|
|
__Pyx_DECREF(__pyx_v_thread_id);
|
|
__pyx_v_thread_id = __pyx_t_3;
|
|
__pyx_t_3 = 0;
|
|
|
|
/* "util.py":154
|
|
* r = range(0,NTHREADS)
|
|
* for thread_id in xrange(1,NTHREADS):
|
|
* r[thread_id], w = os.pipe() # <<<<<<<<<<<<<<
|
|
* fork = os.fork()
|
|
* if fork == 0:
|
|
*/
|
|
__pyx_t_3 = __Pyx_GetName(__pyx_m, __pyx_n_s__os); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 154; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__pyx_t_2 = PyObject_GetAttr(__pyx_t_3, __pyx_n_s__pipe); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 154; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
__pyx_t_3 = PyObject_Call(__pyx_t_2, ((PyObject *)__pyx_empty_tuple), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 154; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
|
|
if ((likely(PyTuple_CheckExact(__pyx_t_3))) || (PyList_CheckExact(__pyx_t_3))) {
|
|
PyObject* sequence = __pyx_t_3;
|
|
if (likely(PyTuple_CheckExact(sequence))) {
|
|
if (unlikely(PyTuple_GET_SIZE(sequence) != 2)) {
|
|
if (PyTuple_GET_SIZE(sequence) > 2) __Pyx_RaiseTooManyValuesError(2);
|
|
else __Pyx_RaiseNeedMoreValuesError(PyTuple_GET_SIZE(sequence));
|
|
{__pyx_filename = __pyx_f[0]; __pyx_lineno = 154; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
}
|
|
__pyx_t_2 = PyTuple_GET_ITEM(sequence, 0);
|
|
__pyx_t_10 = PyTuple_GET_ITEM(sequence, 1);
|
|
} else {
|
|
if (unlikely(PyList_GET_SIZE(sequence) != 2)) {
|
|
if (PyList_GET_SIZE(sequence) > 2) __Pyx_RaiseTooManyValuesError(2);
|
|
else __Pyx_RaiseNeedMoreValuesError(PyList_GET_SIZE(sequence));
|
|
{__pyx_filename = __pyx_f[0]; __pyx_lineno = 154; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
}
|
|
__pyx_t_2 = PyList_GET_ITEM(sequence, 0);
|
|
__pyx_t_10 = PyList_GET_ITEM(sequence, 1);
|
|
}
|
|
__Pyx_INCREF(__pyx_t_2);
|
|
__Pyx_INCREF(__pyx_t_10);
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
} else {
|
|
Py_ssize_t index = -1;
|
|
__pyx_t_11 = PyObject_GetIter(__pyx_t_3); if (unlikely(!__pyx_t_11)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 154; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_11);
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
__pyx_t_12 = Py_TYPE(__pyx_t_11)->tp_iternext;
|
|
index = 0; __pyx_t_2 = __pyx_t_12(__pyx_t_11); if (unlikely(!__pyx_t_2)) goto __pyx_L21_unpacking_failed;
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
index = 1; __pyx_t_10 = __pyx_t_12(__pyx_t_11); if (unlikely(!__pyx_t_10)) goto __pyx_L21_unpacking_failed;
|
|
__Pyx_GOTREF(__pyx_t_10);
|
|
if (__Pyx_IternextUnpackEndCheck(__pyx_t_12(__pyx_t_11), 2) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 154; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
|
|
goto __pyx_L22_unpacking_done;
|
|
__pyx_L21_unpacking_failed:;
|
|
__Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
|
|
if (PyErr_Occurred() && PyErr_ExceptionMatches(PyExc_StopIteration)) PyErr_Clear();
|
|
if (!PyErr_Occurred()) __Pyx_RaiseNeedMoreValuesError(index);
|
|
{__pyx_filename = __pyx_f[0]; __pyx_lineno = 154; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_L22_unpacking_done:;
|
|
}
|
|
if (PyObject_SetItem(__pyx_v_r, __pyx_v_thread_id, __pyx_t_2) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 154; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
|
|
__Pyx_XDECREF(__pyx_v_w);
|
|
__pyx_v_w = __pyx_t_10;
|
|
__pyx_t_10 = 0;
|
|
|
|
/* "util.py":155
|
|
* for thread_id in xrange(1,NTHREADS):
|
|
* r[thread_id], w = os.pipe()
|
|
* fork = os.fork() # <<<<<<<<<<<<<<
|
|
* if fork == 0:
|
|
* os.close(r[thread_id])
|
|
*/
|
|
__pyx_t_3 = __Pyx_GetName(__pyx_m, __pyx_n_s__os); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 155; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__pyx_t_10 = PyObject_GetAttr(__pyx_t_3, __pyx_n_s__fork); if (unlikely(!__pyx_t_10)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 155; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_10);
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
__pyx_t_3 = PyObject_Call(__pyx_t_10, ((PyObject *)__pyx_empty_tuple), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 155; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
|
|
__Pyx_DECREF(__pyx_v_fork);
|
|
__pyx_v_fork = __pyx_t_3;
|
|
__pyx_t_3 = 0;
|
|
|
|
/* "util.py":156
|
|
* r[thread_id], w = os.pipe()
|
|
* fork = os.fork()
|
|
* if fork == 0: # <<<<<<<<<<<<<<
|
|
* os.close(r[thread_id])
|
|
* w = os.fdopen(w,'w')
|
|
*/
|
|
__pyx_t_3 = PyObject_RichCompare(__pyx_v_fork, __pyx_int_0, Py_EQ); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 156; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__pyx_t_9 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely(__pyx_t_9 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 156; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
if (__pyx_t_9) {
|
|
|
|
/* "util.py":157
|
|
* fork = os.fork()
|
|
* if fork == 0:
|
|
* os.close(r[thread_id]) # <<<<<<<<<<<<<<
|
|
* w = os.fdopen(w,'w')
|
|
* break
|
|
*/
|
|
__pyx_t_3 = __Pyx_GetName(__pyx_m, __pyx_n_s__os); 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);
|
|
__pyx_t_10 = PyObject_GetAttr(__pyx_t_3, __pyx_n_s__close); if (unlikely(!__pyx_t_10)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 157; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_10);
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
__pyx_t_3 = PyObject_GetItem(__pyx_v_r, __pyx_v_thread_id); if (!__pyx_t_3) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 157; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__pyx_t_2 = PyTuple_New(1); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 157; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_2));
|
|
PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_3);
|
|
__Pyx_GIVEREF(__pyx_t_3);
|
|
__pyx_t_3 = 0;
|
|
__pyx_t_3 = PyObject_Call(__pyx_t_10, ((PyObject *)__pyx_t_2), NULL); 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);
|
|
__Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_2)); __pyx_t_2 = 0;
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
|
|
/* "util.py":158
|
|
* if fork == 0:
|
|
* os.close(r[thread_id])
|
|
* w = os.fdopen(w,'w') # <<<<<<<<<<<<<<
|
|
* break
|
|
* else:
|
|
*/
|
|
__pyx_t_3 = __Pyx_GetName(__pyx_m, __pyx_n_s__os); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 158; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__pyx_t_2 = PyObject_GetAttr(__pyx_t_3, __pyx_n_s__fdopen); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 158; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
__pyx_t_3 = PyTuple_New(2); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 158; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_3));
|
|
__Pyx_INCREF(__pyx_v_w);
|
|
PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_v_w);
|
|
__Pyx_GIVEREF(__pyx_v_w);
|
|
__Pyx_INCREF(((PyObject *)__pyx_n_s__w));
|
|
PyTuple_SET_ITEM(__pyx_t_3, 1, ((PyObject *)__pyx_n_s__w));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_n_s__w));
|
|
__pyx_t_10 = PyObject_Call(__pyx_t_2, ((PyObject *)__pyx_t_3), NULL); if (unlikely(!__pyx_t_10)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 158; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_10);
|
|
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_3)); __pyx_t_3 = 0;
|
|
__Pyx_DECREF(__pyx_v_w);
|
|
__pyx_v_w = __pyx_t_10;
|
|
__pyx_t_10 = 0;
|
|
|
|
/* "util.py":159
|
|
* os.close(r[thread_id])
|
|
* w = os.fdopen(w,'w')
|
|
* break # <<<<<<<<<<<<<<
|
|
* else:
|
|
* os.close(w)
|
|
*/
|
|
goto __pyx_L20_break;
|
|
goto __pyx_L23;
|
|
}
|
|
/*else*/ {
|
|
|
|
/* "util.py":161
|
|
* break
|
|
* else:
|
|
* os.close(w) # <<<<<<<<<<<<<<
|
|
* r[thread_id] = os.fdopen(r[thread_id],'r')
|
|
* pidlist[thread_id] = fork
|
|
*/
|
|
__pyx_t_10 = __Pyx_GetName(__pyx_m, __pyx_n_s__os); if (unlikely(!__pyx_t_10)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 161; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_10);
|
|
__pyx_t_3 = PyObject_GetAttr(__pyx_t_10, __pyx_n_s__close); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 161; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
|
|
__pyx_t_10 = PyTuple_New(1); if (unlikely(!__pyx_t_10)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 161; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_10));
|
|
__Pyx_INCREF(__pyx_v_w);
|
|
PyTuple_SET_ITEM(__pyx_t_10, 0, __pyx_v_w);
|
|
__Pyx_GIVEREF(__pyx_v_w);
|
|
__pyx_t_2 = PyObject_Call(__pyx_t_3, ((PyObject *)__pyx_t_10), NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 161; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_10)); __pyx_t_10 = 0;
|
|
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
|
|
|
|
/* "util.py":162
|
|
* else:
|
|
* os.close(w)
|
|
* r[thread_id] = os.fdopen(r[thread_id],'r') # <<<<<<<<<<<<<<
|
|
* pidlist[thread_id] = fork
|
|
* thread_id = 0
|
|
*/
|
|
__pyx_t_2 = __Pyx_GetName(__pyx_m, __pyx_n_s__os); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 162; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__pyx_t_10 = PyObject_GetAttr(__pyx_t_2, __pyx_n_s__fdopen); if (unlikely(!__pyx_t_10)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 162; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_10);
|
|
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
|
|
__pyx_t_2 = PyObject_GetItem(__pyx_v_r, __pyx_v_thread_id); if (!__pyx_t_2) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 162; __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 = 162; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_3));
|
|
PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_2);
|
|
__Pyx_GIVEREF(__pyx_t_2);
|
|
__Pyx_INCREF(((PyObject *)__pyx_n_s__r));
|
|
PyTuple_SET_ITEM(__pyx_t_3, 1, ((PyObject *)__pyx_n_s__r));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_n_s__r));
|
|
__pyx_t_2 = 0;
|
|
__pyx_t_2 = PyObject_Call(__pyx_t_10, ((PyObject *)__pyx_t_3), NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 162; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_3)); __pyx_t_3 = 0;
|
|
if (PyObject_SetItem(__pyx_v_r, __pyx_v_thread_id, __pyx_t_2) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 162; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
|
|
|
|
/* "util.py":163
|
|
* os.close(w)
|
|
* r[thread_id] = os.fdopen(r[thread_id],'r')
|
|
* pidlist[thread_id] = fork # <<<<<<<<<<<<<<
|
|
* thread_id = 0
|
|
*
|
|
*/
|
|
if (PyObject_SetItem(__pyx_v_pidlist, __pyx_v_thread_id, __pyx_v_fork) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 163; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
/* "util.py":164
|
|
* r[thread_id] = os.fdopen(r[thread_id],'r')
|
|
* pidlist[thread_id] = fork
|
|
* thread_id = 0 # <<<<<<<<<<<<<<
|
|
*
|
|
* result = []
|
|
*/
|
|
__Pyx_INCREF(__pyx_int_0);
|
|
__Pyx_DECREF(__pyx_v_thread_id);
|
|
__pyx_v_thread_id = __pyx_int_0;
|
|
}
|
|
__pyx_L23:;
|
|
}
|
|
__pyx_L20_break:;
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
|
|
/* "util.py":166
|
|
* thread_id = 0
|
|
*
|
|
* result = [] # <<<<<<<<<<<<<<
|
|
* for filename, text in src[thread_id]:
|
|
* result.append( (filename, f(filename,text)) )
|
|
*/
|
|
__pyx_t_1 = PyList_New(0); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 166; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
__pyx_v_result = ((PyObject *)__pyx_t_1);
|
|
__pyx_t_1 = 0;
|
|
|
|
/* "util.py":167
|
|
*
|
|
* result = []
|
|
* for filename, text in src[thread_id]: # <<<<<<<<<<<<<<
|
|
* result.append( (filename, f(filename,text)) )
|
|
* result.sort()
|
|
*/
|
|
__pyx_t_1 = PyObject_GetItem(((PyObject *)__pyx_v_src), __pyx_v_thread_id); if (!__pyx_t_1) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 167; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
if (PyList_CheckExact(__pyx_t_1) || PyTuple_CheckExact(__pyx_t_1)) {
|
|
__pyx_t_2 = __pyx_t_1; __Pyx_INCREF(__pyx_t_2); __pyx_t_4 = 0;
|
|
__pyx_t_5 = NULL;
|
|
} else {
|
|
__pyx_t_4 = -1; __pyx_t_2 = PyObject_GetIter(__pyx_t_1); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 167; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__pyx_t_5 = Py_TYPE(__pyx_t_2)->tp_iternext;
|
|
}
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
for (;;) {
|
|
if (PyList_CheckExact(__pyx_t_2)) {
|
|
if (__pyx_t_4 >= PyList_GET_SIZE(__pyx_t_2)) break;
|
|
__pyx_t_1 = PyList_GET_ITEM(__pyx_t_2, __pyx_t_4); __Pyx_INCREF(__pyx_t_1); __pyx_t_4++;
|
|
} else if (PyTuple_CheckExact(__pyx_t_2)) {
|
|
if (__pyx_t_4 >= PyTuple_GET_SIZE(__pyx_t_2)) break;
|
|
__pyx_t_1 = PyTuple_GET_ITEM(__pyx_t_2, __pyx_t_4); __Pyx_INCREF(__pyx_t_1); __pyx_t_4++;
|
|
} else {
|
|
__pyx_t_1 = __pyx_t_5(__pyx_t_2);
|
|
if (unlikely(!__pyx_t_1)) {
|
|
if (PyErr_Occurred()) {
|
|
if (likely(PyErr_ExceptionMatches(PyExc_StopIteration))) PyErr_Clear();
|
|
else {__pyx_filename = __pyx_f[0]; __pyx_lineno = 167; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
}
|
|
break;
|
|
}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
}
|
|
if ((likely(PyTuple_CheckExact(__pyx_t_1))) || (PyList_CheckExact(__pyx_t_1))) {
|
|
PyObject* sequence = __pyx_t_1;
|
|
if (likely(PyTuple_CheckExact(sequence))) {
|
|
if (unlikely(PyTuple_GET_SIZE(sequence) != 2)) {
|
|
if (PyTuple_GET_SIZE(sequence) > 2) __Pyx_RaiseTooManyValuesError(2);
|
|
else __Pyx_RaiseNeedMoreValuesError(PyTuple_GET_SIZE(sequence));
|
|
{__pyx_filename = __pyx_f[0]; __pyx_lineno = 167; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
}
|
|
__pyx_t_3 = PyTuple_GET_ITEM(sequence, 0);
|
|
__pyx_t_10 = PyTuple_GET_ITEM(sequence, 1);
|
|
} else {
|
|
if (unlikely(PyList_GET_SIZE(sequence) != 2)) {
|
|
if (PyList_GET_SIZE(sequence) > 2) __Pyx_RaiseTooManyValuesError(2);
|
|
else __Pyx_RaiseNeedMoreValuesError(PyList_GET_SIZE(sequence));
|
|
{__pyx_filename = __pyx_f[0]; __pyx_lineno = 167; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
}
|
|
__pyx_t_3 = PyList_GET_ITEM(sequence, 0);
|
|
__pyx_t_10 = PyList_GET_ITEM(sequence, 1);
|
|
}
|
|
__Pyx_INCREF(__pyx_t_3);
|
|
__Pyx_INCREF(__pyx_t_10);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
} else {
|
|
Py_ssize_t index = -1;
|
|
__pyx_t_11 = PyObject_GetIter(__pyx_t_1); if (unlikely(!__pyx_t_11)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 167; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_11);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_t_12 = Py_TYPE(__pyx_t_11)->tp_iternext;
|
|
index = 0; __pyx_t_3 = __pyx_t_12(__pyx_t_11); if (unlikely(!__pyx_t_3)) goto __pyx_L26_unpacking_failed;
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
index = 1; __pyx_t_10 = __pyx_t_12(__pyx_t_11); if (unlikely(!__pyx_t_10)) goto __pyx_L26_unpacking_failed;
|
|
__Pyx_GOTREF(__pyx_t_10);
|
|
if (__Pyx_IternextUnpackEndCheck(__pyx_t_12(__pyx_t_11), 2) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 167; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
|
|
goto __pyx_L27_unpacking_done;
|
|
__pyx_L26_unpacking_failed:;
|
|
__Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
|
|
if (PyErr_Occurred() && PyErr_ExceptionMatches(PyExc_StopIteration)) PyErr_Clear();
|
|
if (!PyErr_Occurred()) __Pyx_RaiseNeedMoreValuesError(index);
|
|
{__pyx_filename = __pyx_f[0]; __pyx_lineno = 167; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_L27_unpacking_done:;
|
|
}
|
|
__Pyx_XDECREF(__pyx_v_filename);
|
|
__pyx_v_filename = __pyx_t_3;
|
|
__pyx_t_3 = 0;
|
|
__Pyx_XDECREF(__pyx_v_text);
|
|
__pyx_v_text = __pyx_t_10;
|
|
__pyx_t_10 = 0;
|
|
|
|
/* "util.py":168
|
|
* result = []
|
|
* for filename, text in src[thread_id]:
|
|
* result.append( (filename, f(filename,text)) ) # <<<<<<<<<<<<<<
|
|
* result.sort()
|
|
*
|
|
*/
|
|
__pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 168; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
__Pyx_INCREF(__pyx_v_filename);
|
|
PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_v_filename);
|
|
__Pyx_GIVEREF(__pyx_v_filename);
|
|
__Pyx_INCREF(__pyx_v_text);
|
|
PyTuple_SET_ITEM(__pyx_t_1, 1, __pyx_v_text);
|
|
__Pyx_GIVEREF(__pyx_v_text);
|
|
__pyx_t_10 = PyObject_Call(__pyx_v_f, ((PyObject *)__pyx_t_1), NULL); if (unlikely(!__pyx_t_10)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 168; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_10);
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0;
|
|
__pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 168; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
__Pyx_INCREF(__pyx_v_filename);
|
|
PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_v_filename);
|
|
__Pyx_GIVEREF(__pyx_v_filename);
|
|
PyTuple_SET_ITEM(__pyx_t_1, 1, __pyx_t_10);
|
|
__Pyx_GIVEREF(__pyx_t_10);
|
|
__pyx_t_10 = 0;
|
|
__pyx_t_10 = __Pyx_PyObject_Append(__pyx_v_result, ((PyObject *)__pyx_t_1)); if (unlikely(!__pyx_t_10)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 168; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_10);
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0;
|
|
__Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
|
|
}
|
|
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
|
|
|
|
/* "util.py":169
|
|
* for filename, text in src[thread_id]:
|
|
* result.append( (filename, f(filename,text)) )
|
|
* result.sort() # <<<<<<<<<<<<<<
|
|
*
|
|
* if fork == 0:
|
|
*/
|
|
__pyx_t_2 = PyObject_GetAttr(__pyx_v_result, __pyx_n_s__sort); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 169; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__pyx_t_10 = PyObject_Call(__pyx_t_2, ((PyObject *)__pyx_empty_tuple), NULL); if (unlikely(!__pyx_t_10)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 169; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_10);
|
|
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
|
|
__Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
|
|
|
|
/* "util.py":171
|
|
* result.sort()
|
|
*
|
|
* if fork == 0: # <<<<<<<<<<<<<<
|
|
* pickle.dump(result,w,-1)
|
|
* w.close()
|
|
*/
|
|
__pyx_t_10 = PyObject_RichCompare(__pyx_v_fork, __pyx_int_0, Py_EQ); if (unlikely(!__pyx_t_10)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 171; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_10);
|
|
__pyx_t_9 = __Pyx_PyObject_IsTrue(__pyx_t_10); if (unlikely(__pyx_t_9 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 171; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
|
|
if (__pyx_t_9) {
|
|
|
|
/* "util.py":172
|
|
*
|
|
* if fork == 0:
|
|
* pickle.dump(result,w,-1) # <<<<<<<<<<<<<<
|
|
* w.close()
|
|
* os._exit(0)
|
|
*/
|
|
__pyx_t_10 = __Pyx_GetName(__pyx_m, __pyx_n_s__pickle); if (unlikely(!__pyx_t_10)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 172; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_10);
|
|
__pyx_t_2 = PyObject_GetAttr(__pyx_t_10, __pyx_n_s__dump); 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);
|
|
__Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
|
|
if (unlikely(!__pyx_v_w)) { __Pyx_RaiseUnboundLocalError("w"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 172; __pyx_clineno = __LINE__; goto __pyx_L1_error;} }__pyx_t_10 = PyTuple_New(3); if (unlikely(!__pyx_t_10)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 172; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_10));
|
|
__Pyx_INCREF(__pyx_v_result);
|
|
PyTuple_SET_ITEM(__pyx_t_10, 0, __pyx_v_result);
|
|
__Pyx_GIVEREF(__pyx_v_result);
|
|
__Pyx_INCREF(__pyx_v_w);
|
|
PyTuple_SET_ITEM(__pyx_t_10, 1, __pyx_v_w);
|
|
__Pyx_GIVEREF(__pyx_v_w);
|
|
__Pyx_INCREF(__pyx_int_neg_1);
|
|
PyTuple_SET_ITEM(__pyx_t_10, 2, __pyx_int_neg_1);
|
|
__Pyx_GIVEREF(__pyx_int_neg_1);
|
|
__pyx_t_1 = PyObject_Call(__pyx_t_2, ((PyObject *)__pyx_t_10), 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_DECREF(((PyObject *)__pyx_t_10)); __pyx_t_10 = 0;
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
|
|
/* "util.py":173
|
|
* if fork == 0:
|
|
* pickle.dump(result,w,-1)
|
|
* w.close() # <<<<<<<<<<<<<<
|
|
* os._exit(0)
|
|
*
|
|
*/
|
|
__pyx_t_1 = PyObject_GetAttr(__pyx_v_w, __pyx_n_s__close); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 173; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_10 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_empty_tuple), NULL); if (unlikely(!__pyx_t_10)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 173; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_10);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
|
|
|
|
/* "util.py":174
|
|
* pickle.dump(result,w,-1)
|
|
* w.close()
|
|
* os._exit(0) # <<<<<<<<<<<<<<
|
|
*
|
|
* for i in xrange(1,NTHREADS):
|
|
*/
|
|
__pyx_t_10 = __Pyx_GetName(__pyx_m, __pyx_n_s__os); if (unlikely(!__pyx_t_10)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 174; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_10);
|
|
__pyx_t_1 = PyObject_GetAttr(__pyx_t_10, __pyx_n_s___exit); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 174; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
|
|
__pyx_t_10 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_k_tuple_22), NULL); if (unlikely(!__pyx_t_10)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 174; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_10);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
|
|
goto __pyx_L28;
|
|
}
|
|
__pyx_L28:;
|
|
|
|
/* "util.py":176
|
|
* os._exit(0)
|
|
*
|
|
* for i in xrange(1,NTHREADS): # <<<<<<<<<<<<<<
|
|
* result += pickle.load(r[i])
|
|
* r[i].close()
|
|
*/
|
|
__pyx_t_10 = __Pyx_GetName(__pyx_m, __pyx_n_s__NTHREADS); if (unlikely(!__pyx_t_10)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 176; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_10);
|
|
__pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 176; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
__Pyx_INCREF(__pyx_int_1);
|
|
PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_int_1);
|
|
__Pyx_GIVEREF(__pyx_int_1);
|
|
PyTuple_SET_ITEM(__pyx_t_1, 1, __pyx_t_10);
|
|
__Pyx_GIVEREF(__pyx_t_10);
|
|
__pyx_t_10 = 0;
|
|
__pyx_t_10 = PyObject_Call(__pyx_builtin_xrange, ((PyObject *)__pyx_t_1), NULL); if (unlikely(!__pyx_t_10)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 176; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_10);
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0;
|
|
if (PyList_CheckExact(__pyx_t_10) || PyTuple_CheckExact(__pyx_t_10)) {
|
|
__pyx_t_1 = __pyx_t_10; __Pyx_INCREF(__pyx_t_1); __pyx_t_4 = 0;
|
|
__pyx_t_5 = NULL;
|
|
} else {
|
|
__pyx_t_4 = -1; __pyx_t_1 = PyObject_GetIter(__pyx_t_10); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 176; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_5 = Py_TYPE(__pyx_t_1)->tp_iternext;
|
|
}
|
|
__Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
|
|
for (;;) {
|
|
if (PyList_CheckExact(__pyx_t_1)) {
|
|
if (__pyx_t_4 >= PyList_GET_SIZE(__pyx_t_1)) break;
|
|
__pyx_t_10 = PyList_GET_ITEM(__pyx_t_1, __pyx_t_4); __Pyx_INCREF(__pyx_t_10); __pyx_t_4++;
|
|
} else if (PyTuple_CheckExact(__pyx_t_1)) {
|
|
if (__pyx_t_4 >= PyTuple_GET_SIZE(__pyx_t_1)) break;
|
|
__pyx_t_10 = PyTuple_GET_ITEM(__pyx_t_1, __pyx_t_4); __Pyx_INCREF(__pyx_t_10); __pyx_t_4++;
|
|
} else {
|
|
__pyx_t_10 = __pyx_t_5(__pyx_t_1);
|
|
if (unlikely(!__pyx_t_10)) {
|
|
if (PyErr_Occurred()) {
|
|
if (likely(PyErr_ExceptionMatches(PyExc_StopIteration))) PyErr_Clear();
|
|
else {__pyx_filename = __pyx_f[0]; __pyx_lineno = 176; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
}
|
|
break;
|
|
}
|
|
__Pyx_GOTREF(__pyx_t_10);
|
|
}
|
|
__Pyx_XDECREF(__pyx_v_i);
|
|
__pyx_v_i = __pyx_t_10;
|
|
__pyx_t_10 = 0;
|
|
|
|
/* "util.py":177
|
|
*
|
|
* for i in xrange(1,NTHREADS):
|
|
* result += pickle.load(r[i]) # <<<<<<<<<<<<<<
|
|
* r[i].close()
|
|
* os.waitpid(pidlist[i],0)[1]
|
|
*/
|
|
__pyx_t_10 = __Pyx_GetName(__pyx_m, __pyx_n_s__pickle); if (unlikely(!__pyx_t_10)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 177; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_10);
|
|
__pyx_t_2 = PyObject_GetAttr(__pyx_t_10, __pyx_n_s__load); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 177; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
|
|
__pyx_t_10 = PyObject_GetItem(__pyx_v_r, __pyx_v_i); if (!__pyx_t_10) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 177; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_10);
|
|
__pyx_t_3 = PyTuple_New(1); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 177; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_3));
|
|
PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_10);
|
|
__Pyx_GIVEREF(__pyx_t_10);
|
|
__pyx_t_10 = 0;
|
|
__pyx_t_10 = PyObject_Call(__pyx_t_2, ((PyObject *)__pyx_t_3), NULL); if (unlikely(!__pyx_t_10)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 177; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_10);
|
|
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_3)); __pyx_t_3 = 0;
|
|
__pyx_t_3 = PyNumber_InPlaceAdd(__pyx_v_result, __pyx_t_10); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 177; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
|
|
__Pyx_DECREF(__pyx_v_result);
|
|
__pyx_v_result = __pyx_t_3;
|
|
__pyx_t_3 = 0;
|
|
|
|
/* "util.py":178
|
|
* for i in xrange(1,NTHREADS):
|
|
* result += pickle.load(r[i])
|
|
* r[i].close() # <<<<<<<<<<<<<<
|
|
* os.waitpid(pidlist[i],0)[1]
|
|
*
|
|
*/
|
|
__pyx_t_3 = PyObject_GetItem(__pyx_v_r, __pyx_v_i); if (!__pyx_t_3) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 178; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__pyx_t_10 = PyObject_GetAttr(__pyx_t_3, __pyx_n_s__close); if (unlikely(!__pyx_t_10)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 178; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_10);
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
__pyx_t_3 = PyObject_Call(__pyx_t_10, ((PyObject *)__pyx_empty_tuple), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 178; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
|
|
/* "util.py":179
|
|
* result += pickle.load(r[i])
|
|
* r[i].close()
|
|
* os.waitpid(pidlist[i],0)[1] # <<<<<<<<<<<<<<
|
|
*
|
|
* return result
|
|
*/
|
|
__pyx_t_3 = __Pyx_GetName(__pyx_m, __pyx_n_s__os); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 179; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__pyx_t_10 = PyObject_GetAttr(__pyx_t_3, __pyx_n_s__waitpid); if (unlikely(!__pyx_t_10)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 179; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_10);
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
__pyx_t_3 = PyObject_GetItem(__pyx_v_pidlist, __pyx_v_i); if (!__pyx_t_3) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 179; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__pyx_t_2 = PyTuple_New(2); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 179; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_2));
|
|
PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_3);
|
|
__Pyx_GIVEREF(__pyx_t_3);
|
|
__Pyx_INCREF(__pyx_int_0);
|
|
PyTuple_SET_ITEM(__pyx_t_2, 1, __pyx_int_0);
|
|
__Pyx_GIVEREF(__pyx_int_0);
|
|
__pyx_t_3 = 0;
|
|
__pyx_t_3 = PyObject_Call(__pyx_t_10, ((PyObject *)__pyx_t_2), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 179; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_2)); __pyx_t_2 = 0;
|
|
__pyx_t_2 = __Pyx_GetItemInt(__pyx_t_3, 1, sizeof(long), PyInt_FromLong); if (!__pyx_t_2) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 179; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_2);
|
|
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
|
|
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
|
|
}
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
|
|
/* "util.py":181
|
|
* os.waitpid(pidlist[i],0)[1]
|
|
*
|
|
* return result # <<<<<<<<<<<<<<
|
|
*
|
|
*
|
|
*/
|
|
__Pyx_XDECREF(__pyx_r);
|
|
__Pyx_INCREF(__pyx_v_result);
|
|
__pyx_r = __pyx_v_result;
|
|
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_10);
|
|
__Pyx_XDECREF(__pyx_t_11);
|
|
__Pyx_AddTraceback("util.parallel_loop", __pyx_clineno, __pyx_lineno, __pyx_filename);
|
|
__pyx_r = NULL;
|
|
__pyx_L0:;
|
|
__Pyx_XDECREF(__pyx_v_pidlist);
|
|
__Pyx_XDECREF(__pyx_v_src);
|
|
__Pyx_XDECREF(__pyx_v_index);
|
|
__Pyx_XDECREF(__pyx_v_i);
|
|
__Pyx_XDECREF(__pyx_v_thread_id);
|
|
__Pyx_XDECREF(__pyx_v_fork);
|
|
__Pyx_XDECREF(__pyx_v_r);
|
|
__Pyx_XDECREF(__pyx_v_w);
|
|
__Pyx_XDECREF(__pyx_v_result);
|
|
__Pyx_XDECREF(__pyx_v_filename);
|
|
__Pyx_XDECREF(__pyx_v_text);
|
|
__Pyx_XDECREF(__pyx_v_source);
|
|
__Pyx_XGIVEREF(__pyx_r);
|
|
__Pyx_RefNannyFinishContext();
|
|
return __pyx_r;
|
|
}
|
|
|
|
static PyMethodDef __pyx_methods[] = {
|
|
{0, 0, 0, 0}
|
|
};
|
|
|
|
#if PY_MAJOR_VERSION >= 3
|
|
static struct PyModuleDef __pyx_moduledef = {
|
|
PyModuleDef_HEAD_INIT,
|
|
__Pyx_NAMESTR("util"),
|
|
0, /* 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_10, __pyx_k_10, sizeof(__pyx_k_10), 0, 0, 1, 0},
|
|
{&__pyx_kp_s_12, __pyx_k_12, sizeof(__pyx_k_12), 0, 0, 1, 0},
|
|
{&__pyx_kp_s_16, __pyx_k_16, sizeof(__pyx_k_16), 0, 0, 1, 0},
|
|
{&__pyx_kp_s_18, __pyx_k_18, sizeof(__pyx_k_18), 0, 0, 1, 0},
|
|
{&__pyx_kp_s_19, __pyx_k_19, sizeof(__pyx_k_19), 0, 0, 1, 0},
|
|
{&__pyx_kp_s_2, __pyx_k_2, sizeof(__pyx_k_2), 0, 0, 1, 0},
|
|
{&__pyx_kp_s_20, __pyx_k_20, sizeof(__pyx_k_20), 0, 0, 1, 0},
|
|
{&__pyx_kp_s_21, __pyx_k_21, sizeof(__pyx_k_21), 0, 0, 1, 0},
|
|
{&__pyx_kp_s_24, __pyx_k_24, sizeof(__pyx_k_24), 0, 0, 1, 0},
|
|
{&__pyx_kp_s_26, __pyx_k_26, sizeof(__pyx_k_26), 0, 0, 1, 0},
|
|
{&__pyx_kp_s_28, __pyx_k_28, sizeof(__pyx_k_28), 0, 0, 1, 0},
|
|
{&__pyx_kp_s_3, __pyx_k_3, sizeof(__pyx_k_3), 0, 0, 1, 0},
|
|
{&__pyx_kp_s_30, __pyx_k_30, sizeof(__pyx_k_30), 0, 0, 1, 0},
|
|
{&__pyx_kp_s_32, __pyx_k_32, sizeof(__pyx_k_32), 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_kp_s_7, __pyx_k_7, sizeof(__pyx_k_7), 0, 0, 1, 0},
|
|
{&__pyx_kp_s_8, __pyx_k_8, sizeof(__pyx_k_8), 0, 0, 1, 0},
|
|
{&__pyx_kp_s__10, __pyx_k__10, sizeof(__pyx_k__10), 0, 0, 1, 0},
|
|
{&__pyx_n_s__IOError, __pyx_k__IOError, sizeof(__pyx_k__IOError), 0, 0, 1, 1},
|
|
{&__pyx_n_s__Line, __pyx_k__Line, sizeof(__pyx_k__Line), 0, 0, 1, 1},
|
|
{&__pyx_n_s__NTHREADS, __pyx_k__NTHREADS, sizeof(__pyx_k__NTHREADS), 0, 0, 1, 1},
|
|
{&__pyx_n_s____main__, __pyx_k____main__, sizeof(__pyx_k____main__), 0, 0, 1, 1},
|
|
{&__pyx_n_s____name__, __pyx_k____name__, sizeof(__pyx_k____name__), 0, 0, 1, 1},
|
|
{&__pyx_n_s____test__, __pyx_k____test__, sizeof(__pyx_k____test__), 0, 0, 1, 1},
|
|
{&__pyx_n_s___exit, __pyx_k___exit, sizeof(__pyx_k___exit), 0, 0, 1, 1},
|
|
{&__pyx_n_s__build_dim, __pyx_k__build_dim, sizeof(__pyx_k__build_dim), 0, 0, 1, 1},
|
|
{&__pyx_n_s__build_dim_colons, __pyx_k__build_dim_colons, sizeof(__pyx_k__build_dim_colons), 0, 0, 1, 1},
|
|
{&__pyx_n_s__cPickle, __pyx_k__cPickle, sizeof(__pyx_k__cPickle), 0, 0, 1, 1},
|
|
{&__pyx_n_s__close, __pyx_k__close, sizeof(__pyx_k__close), 0, 0, 1, 1},
|
|
{&__pyx_n_s__dim, __pyx_k__dim, sizeof(__pyx_k__dim), 0, 0, 1, 1},
|
|
{&__pyx_n_s__dimsize, __pyx_k__dimsize, sizeof(__pyx_k__dimsize), 0, 0, 1, 1},
|
|
{&__pyx_n_s__dump, __pyx_k__dump, sizeof(__pyx_k__dump), 0, 0, 1, 1},
|
|
{&__pyx_n_s__endswith, __pyx_k__endswith, sizeof(__pyx_k__endswith), 0, 0, 1, 1},
|
|
{&__pyx_n_s__error, __pyx_k__error, sizeof(__pyx_k__error), 0, 0, 1, 1},
|
|
{&__pyx_n_s__f, __pyx_k__f, sizeof(__pyx_k__f), 0, 0, 1, 1},
|
|
{&__pyx_n_s__fail, __pyx_k__fail, sizeof(__pyx_k__fail), 0, 0, 1, 1},
|
|
{&__pyx_n_s__fdopen, __pyx_k__fdopen, sizeof(__pyx_k__fdopen), 0, 0, 1, 1},
|
|
{&__pyx_n_s__filename, __pyx_k__filename, sizeof(__pyx_k__filename), 0, 0, 1, 1},
|
|
{&__pyx_n_s__find_subname, __pyx_k__find_subname, sizeof(__pyx_k__find_subname), 0, 0, 1, 1},
|
|
{&__pyx_n_s__flatten, __pyx_k__flatten, sizeof(__pyx_k__flatten), 0, 0, 1, 1},
|
|
{&__pyx_n_s__fork, __pyx_k__fork, sizeof(__pyx_k__fork), 0, 0, 1, 1},
|
|
{&__pyx_n_s__i, __pyx_k__i, sizeof(__pyx_k__i), 0, 0, 1, 1},
|
|
{&__pyx_n_s__irpf90_t, __pyx_k__irpf90_t, sizeof(__pyx_k__irpf90_t), 0, 0, 1, 1},
|
|
{&__pyx_n_s__isdigit, __pyx_k__isdigit, sizeof(__pyx_k__isdigit), 0, 0, 1, 1},
|
|
{&__pyx_n_s__join, __pyx_k__join, sizeof(__pyx_k__join), 0, 0, 1, 1},
|
|
{&__pyx_n_s__ljust, __pyx_k__ljust, sizeof(__pyx_k__ljust), 0, 0, 1, 1},
|
|
{&__pyx_n_s__load, __pyx_k__load, sizeof(__pyx_k__load), 0, 0, 1, 1},
|
|
{&__pyx_n_s__lower, __pyx_k__lower, sizeof(__pyx_k__lower), 0, 0, 1, 1},
|
|
{&__pyx_n_s__make_single, __pyx_k__make_single, sizeof(__pyx_k__make_single), 0, 0, 1, 1},
|
|
{&__pyx_n_s__map, __pyx_k__map, sizeof(__pyx_k__map), 0, 0, 1, 1},
|
|
{&__pyx_n_s__open, __pyx_k__open, sizeof(__pyx_k__open), 0, 0, 1, 1},
|
|
{&__pyx_n_s__os, __pyx_k__os, sizeof(__pyx_k__os), 0, 0, 1, 1},
|
|
{&__pyx_n_s__parallel_loop, __pyx_k__parallel_loop, sizeof(__pyx_k__parallel_loop), 0, 0, 1, 1},
|
|
{&__pyx_n_s__pickle, __pyx_k__pickle, sizeof(__pyx_k__pickle), 0, 0, 1, 1},
|
|
{&__pyx_n_s__pipe, __pyx_k__pipe, sizeof(__pyx_k__pipe), 0, 0, 1, 1},
|
|
{&__pyx_n_s__put_info, __pyx_k__put_info, sizeof(__pyx_k__put_info), 0, 0, 1, 1},
|
|
{&__pyx_n_s__r, __pyx_k__r, sizeof(__pyx_k__r), 0, 0, 1, 1},
|
|
{&__pyx_n_s__range, __pyx_k__range, sizeof(__pyx_k__range), 0, 0, 1, 1},
|
|
{&__pyx_n_s__read, __pyx_k__read, sizeof(__pyx_k__read), 0, 0, 1, 1},
|
|
{&__pyx_n_s__replace, __pyx_k__replace, sizeof(__pyx_k__replace), 0, 0, 1, 1},
|
|
{&__pyx_n_s__same_file, __pyx_k__same_file, sizeof(__pyx_k__same_file), 0, 0, 1, 1},
|
|
{&__pyx_n_s__sort, __pyx_k__sort, sizeof(__pyx_k__sort), 0, 0, 1, 1},
|
|
{&__pyx_n_s__source, __pyx_k__source, sizeof(__pyx_k__source), 0, 0, 1, 1},
|
|
{&__pyx_n_s__split, __pyx_k__split, sizeof(__pyx_k__split), 0, 0, 1, 1},
|
|
{&__pyx_n_s__strip, __pyx_k__strip, sizeof(__pyx_k__strip), 0, 0, 1, 1},
|
|
{&__pyx_n_s__sys, __pyx_k__sys, sizeof(__pyx_k__sys), 0, 0, 1, 1},
|
|
{&__pyx_n_s__text, __pyx_k__text, sizeof(__pyx_k__text), 0, 0, 1, 1},
|
|
{&__pyx_n_s__txt, __pyx_k__txt, sizeof(__pyx_k__txt), 0, 0, 1, 1},
|
|
{&__pyx_n_s__util, __pyx_k__util, sizeof(__pyx_k__util), 0, 0, 1, 1},
|
|
{&__pyx_n_s__w, __pyx_k__w, sizeof(__pyx_k__w), 0, 0, 1, 1},
|
|
{&__pyx_n_s__waitpid, __pyx_k__waitpid, sizeof(__pyx_k__waitpid), 0, 0, 1, 1},
|
|
{&__pyx_n_s__xrange, __pyx_k__xrange, sizeof(__pyx_k__xrange), 0, 0, 1, 1},
|
|
{0, 0, 0, 0, 0, 0, 0}
|
|
};
|
|
static int __Pyx_InitCachedBuiltins(void) {
|
|
__pyx_builtin_open = __Pyx_GetName(__pyx_b, __pyx_n_s__open); if (!__pyx_builtin_open) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 41; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_builtin_IOError = __Pyx_GetName(__pyx_b, __pyx_n_s__IOError); if (!__pyx_builtin_IOError) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 42; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_builtin_map = __Pyx_GetName(__pyx_b, __pyx_n_s__map); if (!__pyx_builtin_map) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 66; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__pyx_builtin_range = __Pyx_GetName(__pyx_b, __pyx_n_s__range); if (!__pyx_builtin_range) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 90; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
#if PY_MAJOR_VERSION >= 3
|
|
__pyx_builtin_xrange = __Pyx_GetName(__pyx_b, __pyx_n_s__range); if (!__pyx_builtin_xrange) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 136; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
#else
|
|
__pyx_builtin_xrange = __Pyx_GetName(__pyx_b, __pyx_n_s__xrange); if (!__pyx_builtin_xrange) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 136; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
#endif
|
|
return 0;
|
|
__pyx_L1_error:;
|
|
return -1;
|
|
}
|
|
|
|
static int __Pyx_InitCachedConstants(void) {
|
|
__Pyx_RefNannyDeclarations
|
|
__Pyx_RefNannySetupContext("__Pyx_InitCachedConstants");
|
|
|
|
/* "util.py":73
|
|
* def find_subname(line):
|
|
* buffer = line.lower
|
|
* if not buffer.endswith(')'): # <<<<<<<<<<<<<<
|
|
* buffer += "()"
|
|
* buffer = buffer.split('(')
|
|
*/
|
|
__pyx_k_tuple_6 = PyTuple_New(1); if (unlikely(!__pyx_k_tuple_6)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 73; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_k_tuple_6));
|
|
__Pyx_INCREF(((PyObject *)__pyx_kp_s_5));
|
|
PyTuple_SET_ITEM(__pyx_k_tuple_6, 0, ((PyObject *)__pyx_kp_s_5));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_kp_s_5));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_6));
|
|
|
|
/* "util.py":75
|
|
* if not buffer.endswith(')'):
|
|
* buffer += "()"
|
|
* buffer = buffer.split('(') # <<<<<<<<<<<<<<
|
|
* buffer = buffer[0].split()
|
|
* if len(buffer) < 2:
|
|
*/
|
|
__pyx_k_tuple_9 = PyTuple_New(1); if (unlikely(!__pyx_k_tuple_9)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 75; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_k_tuple_9));
|
|
__Pyx_INCREF(((PyObject *)__pyx_kp_s_8));
|
|
PyTuple_SET_ITEM(__pyx_k_tuple_9, 0, ((PyObject *)__pyx_kp_s_8));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_kp_s_8));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_9));
|
|
|
|
/* "util.py":99
|
|
* def dimsize(x):
|
|
* assert isinstance(x,str)
|
|
* buffer = x.split(':') # <<<<<<<<<<<<<<
|
|
* if len(buffer) == 1:
|
|
* return x
|
|
*/
|
|
__pyx_k_tuple_11 = PyTuple_New(1); if (unlikely(!__pyx_k_tuple_11)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 99; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_k_tuple_11));
|
|
__Pyx_INCREF(((PyObject *)__pyx_kp_s_4));
|
|
PyTuple_SET_ITEM(__pyx_k_tuple_11, 0, ((PyObject *)__pyx_kp_s_4));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_kp_s_4));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_11));
|
|
|
|
/* "util.py":107
|
|
* size = ""
|
|
* b0, b1 = buffer
|
|
* if b0.replace('-','').isdigit() and b1.replace('-','').isdigit(): # <<<<<<<<<<<<<<
|
|
* size = str( int(b1) - int(b0) + 1 )
|
|
* else:
|
|
*/
|
|
__pyx_k_tuple_13 = PyTuple_New(2); if (unlikely(!__pyx_k_tuple_13)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 107; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_k_tuple_13));
|
|
__Pyx_INCREF(((PyObject *)__pyx_kp_s_12));
|
|
PyTuple_SET_ITEM(__pyx_k_tuple_13, 0, ((PyObject *)__pyx_kp_s_12));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_kp_s_12));
|
|
__Pyx_INCREF(((PyObject *)__pyx_kp_s_1));
|
|
PyTuple_SET_ITEM(__pyx_k_tuple_13, 1, ((PyObject *)__pyx_kp_s_1));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_kp_s_1));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_13));
|
|
__pyx_k_tuple_14 = PyTuple_New(2); if (unlikely(!__pyx_k_tuple_14)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 107; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_k_tuple_14));
|
|
__Pyx_INCREF(((PyObject *)__pyx_kp_s_12));
|
|
PyTuple_SET_ITEM(__pyx_k_tuple_14, 0, ((PyObject *)__pyx_kp_s_12));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_kp_s_12));
|
|
__Pyx_INCREF(((PyObject *)__pyx_kp_s_1));
|
|
PyTuple_SET_ITEM(__pyx_k_tuple_14, 1, ((PyObject *)__pyx_kp_s_1));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_kp_s_1));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_14));
|
|
|
|
/* "util.py":110
|
|
* size = str( int(b1) - int(b0) + 1 )
|
|
* else:
|
|
* if b0.replace('-','').isdigit(): # <<<<<<<<<<<<<<
|
|
* size = "%s - (%d)"%(b1,int(b0)-1)
|
|
* elif b1.replace('-','').isdigit():
|
|
*/
|
|
__pyx_k_tuple_15 = PyTuple_New(2); if (unlikely(!__pyx_k_tuple_15)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 110; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_k_tuple_15));
|
|
__Pyx_INCREF(((PyObject *)__pyx_kp_s_12));
|
|
PyTuple_SET_ITEM(__pyx_k_tuple_15, 0, ((PyObject *)__pyx_kp_s_12));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_kp_s_12));
|
|
__Pyx_INCREF(((PyObject *)__pyx_kp_s_1));
|
|
PyTuple_SET_ITEM(__pyx_k_tuple_15, 1, ((PyObject *)__pyx_kp_s_1));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_kp_s_1));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_15));
|
|
|
|
/* "util.py":112
|
|
* if b0.replace('-','').isdigit():
|
|
* size = "%s - (%d)"%(b1,int(b0)-1)
|
|
* elif b1.replace('-','').isdigit(): # <<<<<<<<<<<<<<
|
|
* size = "%d - %s"%(int(b1)+1,b0)
|
|
* else:
|
|
*/
|
|
__pyx_k_tuple_17 = PyTuple_New(2); if (unlikely(!__pyx_k_tuple_17)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 112; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_k_tuple_17));
|
|
__Pyx_INCREF(((PyObject *)__pyx_kp_s_12));
|
|
PyTuple_SET_ITEM(__pyx_k_tuple_17, 0, ((PyObject *)__pyx_kp_s_12));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_kp_s_12));
|
|
__Pyx_INCREF(((PyObject *)__pyx_kp_s_1));
|
|
PyTuple_SET_ITEM(__pyx_k_tuple_17, 1, ((PyObject *)__pyx_kp_s_1));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_kp_s_1));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_17));
|
|
|
|
/* "util.py":174
|
|
* pickle.dump(result,w,-1)
|
|
* w.close()
|
|
* os._exit(0) # <<<<<<<<<<<<<<
|
|
*
|
|
* for i in xrange(1,NTHREADS):
|
|
*/
|
|
__pyx_k_tuple_22 = PyTuple_New(1); if (unlikely(!__pyx_k_tuple_22)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 174; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_k_tuple_22));
|
|
__Pyx_INCREF(__pyx_int_0);
|
|
PyTuple_SET_ITEM(__pyx_k_tuple_22, 0, __pyx_int_0);
|
|
__Pyx_GIVEREF(__pyx_int_0);
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_22));
|
|
|
|
/* "util.py":186
|
|
*
|
|
* if __name__ == '__main__':
|
|
* print "10",dimsize("10") #-> "10" # <<<<<<<<<<<<<<
|
|
* print "0:10",dimsize("0:10") # -> "11"
|
|
* print "0:x",dimsize("0:x") # -> "x+1"
|
|
*/
|
|
__pyx_k_tuple_23 = PyTuple_New(1); if (unlikely(!__pyx_k_tuple_23)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 186; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_k_tuple_23));
|
|
__Pyx_INCREF(((PyObject *)__pyx_kp_s__10));
|
|
PyTuple_SET_ITEM(__pyx_k_tuple_23, 0, ((PyObject *)__pyx_kp_s__10));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_kp_s__10));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_23));
|
|
|
|
/* "util.py":187
|
|
* if __name__ == '__main__':
|
|
* print "10",dimsize("10") #-> "10"
|
|
* print "0:10",dimsize("0:10") # -> "11" # <<<<<<<<<<<<<<
|
|
* print "0:x",dimsize("0:x") # -> "x+1"
|
|
* print "-3:x",dimsize("-3:x") # -> "x+1"
|
|
*/
|
|
__pyx_k_tuple_25 = PyTuple_New(1); if (unlikely(!__pyx_k_tuple_25)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 187; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_k_tuple_25));
|
|
__Pyx_INCREF(((PyObject *)__pyx_kp_s_24));
|
|
PyTuple_SET_ITEM(__pyx_k_tuple_25, 0, ((PyObject *)__pyx_kp_s_24));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_kp_s_24));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_25));
|
|
|
|
/* "util.py":188
|
|
* print "10",dimsize("10") #-> "10"
|
|
* print "0:10",dimsize("0:10") # -> "11"
|
|
* print "0:x",dimsize("0:x") # -> "x+1" # <<<<<<<<<<<<<<
|
|
* print "-3:x",dimsize("-3:x") # -> "x+1"
|
|
* print "x:y",dimsize("x:y") # -> "y-x+1"
|
|
*/
|
|
__pyx_k_tuple_27 = PyTuple_New(1); if (unlikely(!__pyx_k_tuple_27)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 188; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_k_tuple_27));
|
|
__Pyx_INCREF(((PyObject *)__pyx_kp_s_26));
|
|
PyTuple_SET_ITEM(__pyx_k_tuple_27, 0, ((PyObject *)__pyx_kp_s_26));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_kp_s_26));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_27));
|
|
|
|
/* "util.py":189
|
|
* print "0:10",dimsize("0:10") # -> "11"
|
|
* print "0:x",dimsize("0:x") # -> "x+1"
|
|
* print "-3:x",dimsize("-3:x") # -> "x+1" # <<<<<<<<<<<<<<
|
|
* print "x:y",dimsize("x:y") # -> "y-x+1"
|
|
* print "x:5",dimsize("x:5") # -> "y-x+1"
|
|
*/
|
|
__pyx_k_tuple_29 = PyTuple_New(1); if (unlikely(!__pyx_k_tuple_29)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 189; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_k_tuple_29));
|
|
__Pyx_INCREF(((PyObject *)__pyx_kp_s_28));
|
|
PyTuple_SET_ITEM(__pyx_k_tuple_29, 0, ((PyObject *)__pyx_kp_s_28));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_kp_s_28));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_29));
|
|
|
|
/* "util.py":190
|
|
* print "0:x",dimsize("0:x") # -> "x+1"
|
|
* print "-3:x",dimsize("-3:x") # -> "x+1"
|
|
* print "x:y",dimsize("x:y") # -> "y-x+1" # <<<<<<<<<<<<<<
|
|
* print "x:5",dimsize("x:5") # -> "y-x+1"
|
|
*
|
|
*/
|
|
__pyx_k_tuple_31 = PyTuple_New(1); if (unlikely(!__pyx_k_tuple_31)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 190; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_k_tuple_31));
|
|
__Pyx_INCREF(((PyObject *)__pyx_kp_s_30));
|
|
PyTuple_SET_ITEM(__pyx_k_tuple_31, 0, ((PyObject *)__pyx_kp_s_30));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_kp_s_30));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_31));
|
|
|
|
/* "util.py":191
|
|
* print "-3:x",dimsize("-3:x") # -> "x+1"
|
|
* print "x:y",dimsize("x:y") # -> "y-x+1"
|
|
* print "x:5",dimsize("x:5") # -> "y-x+1" # <<<<<<<<<<<<<<
|
|
*
|
|
*/
|
|
__pyx_k_tuple_33 = PyTuple_New(1); if (unlikely(!__pyx_k_tuple_33)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 191; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_k_tuple_33));
|
|
__Pyx_INCREF(((PyObject *)__pyx_kp_s_32));
|
|
PyTuple_SET_ITEM(__pyx_k_tuple_33, 0, ((PyObject *)__pyx_kp_s_32));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_kp_s_32));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_33));
|
|
__Pyx_RefNannyFinishContext();
|
|
return 0;
|
|
__pyx_L1_error:;
|
|
__Pyx_RefNannyFinishContext();
|
|
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_0 = PyInt_FromLong(0); if (unlikely(!__pyx_int_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;};
|
|
__pyx_int_neg_1 = PyInt_FromLong(-1); if (unlikely(!__pyx_int_neg_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 initutil(void); /*proto*/
|
|
PyMODINIT_FUNC initutil(void)
|
|
#else
|
|
PyMODINIT_FUNC PyInit_util(void); /*proto*/
|
|
PyMODINIT_FUNC PyInit_util(void)
|
|
#endif
|
|
{
|
|
PyObject *__pyx_t_1 = NULL;
|
|
int __pyx_t_2;
|
|
PyObject *__pyx_t_3 = NULL;
|
|
__Pyx_RefNannyDeclarations
|
|
#if CYTHON_REFNANNY
|
|
__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");
|
|
}
|
|
#endif
|
|
__Pyx_RefNannySetupContext("PyMODINIT_FUNC PyInit_util(void)");
|
|
if ( __Pyx_check_binary_version() < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__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;}
|
|
__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;}
|
|
#ifdef __pyx_binding_PyCFunctionType_USED
|
|
if (__pyx_binding_PyCFunctionType_init() < 0) {__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("util"), __pyx_methods, 0, 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_util) {
|
|
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;}
|
|
/*--- Constants init code ---*/
|
|
if (unlikely(__Pyx_InitCachedConstants() < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
/*--- Global init code ---*/
|
|
/*--- Variable export code ---*/
|
|
/*--- Function export code ---*/
|
|
/*--- Type init code ---*/
|
|
/*--- Type import code ---*/
|
|
/*--- Variable import code ---*/
|
|
/*--- Function import code ---*/
|
|
/*--- Execution code ---*/
|
|
|
|
/* "util.py":27
|
|
* # scemama@irsamc.ups-tlse.fr
|
|
*
|
|
* import os # <<<<<<<<<<<<<<
|
|
* NTHREADS=1 #int(os.getenv('OMP_NUM_THREADS',1))
|
|
*
|
|
*/
|
|
__pyx_t_1 = __Pyx_Import(((PyObject *)__pyx_n_s__os), 0, -1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 27; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__os, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 27; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
|
|
/* "util.py":28
|
|
*
|
|
* import os
|
|
* NTHREADS=1 #int(os.getenv('OMP_NUM_THREADS',1)) # <<<<<<<<<<<<<<
|
|
*
|
|
* def strip(x):
|
|
*/
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__NTHREADS, __pyx_int_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 28; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
|
|
/* "util.py":30
|
|
* NTHREADS=1 #int(os.getenv('OMP_NUM_THREADS',1))
|
|
*
|
|
* def strip(x): # <<<<<<<<<<<<<<
|
|
* return x.strip()
|
|
*
|
|
*/
|
|
__pyx_t_1 = PyCFunction_NewEx(&__pyx_mdef_4util_strip, NULL, __pyx_n_s__util); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 30; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__strip, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 30; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
|
|
/* "util.py":33
|
|
* return x.strip()
|
|
*
|
|
* def lower(x): # <<<<<<<<<<<<<<
|
|
* return x.lower()
|
|
*
|
|
*/
|
|
__pyx_t_1 = PyCFunction_NewEx(&__pyx_mdef_4util_1lower, NULL, __pyx_n_s__util); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 33; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__lower, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 33; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
|
|
/* "util.py":36
|
|
* return x.lower()
|
|
*
|
|
* def same_file(filename,txt): # <<<<<<<<<<<<<<
|
|
* assert isinstance(filename,str)
|
|
* assert type(txt) == list
|
|
*/
|
|
__pyx_t_1 = PyCFunction_NewEx(&__pyx_mdef_4util_2same_file, NULL, __pyx_n_s__util); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 36; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__same_file, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 36; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
|
|
/* "util.py":55
|
|
* return True
|
|
*
|
|
* def build_dim(dim): # <<<<<<<<<<<<<<
|
|
* if len(dim) == 0:
|
|
* return ""
|
|
*/
|
|
__pyx_t_1 = PyCFunction_NewEx(&__pyx_mdef_4util_3build_dim, NULL, __pyx_n_s__util); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 55; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__build_dim, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 55; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
|
|
/* "util.py":61
|
|
* return "(%s)"%( ",".join(dim) )
|
|
*
|
|
* def build_dim_colons(v): # <<<<<<<<<<<<<<
|
|
* d = v.dim
|
|
* if d == []:
|
|
*/
|
|
__pyx_t_1 = PyCFunction_NewEx(&__pyx_mdef_4util_4build_dim_colons, NULL, __pyx_n_s__util); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 61; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__build_dim_colons, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 61; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
|
|
/* "util.py":70
|
|
*
|
|
*
|
|
* import error # <<<<<<<<<<<<<<
|
|
* def find_subname(line):
|
|
* buffer = line.lower
|
|
*/
|
|
__pyx_t_1 = __Pyx_Import(((PyObject *)__pyx_n_s__error), 0, -1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 70; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__error, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 70; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
|
|
/* "util.py":71
|
|
*
|
|
* import error
|
|
* def find_subname(line): # <<<<<<<<<<<<<<
|
|
* buffer = line.lower
|
|
* if not buffer.endswith(')'):
|
|
*/
|
|
__pyx_t_1 = PyCFunction_NewEx(&__pyx_mdef_4util_5find_subname, NULL, __pyx_n_s__util); 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);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__find_subname, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 71; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
|
|
/* "util.py":81
|
|
* return buffer[-1]
|
|
*
|
|
* def make_single(l): # <<<<<<<<<<<<<<
|
|
* d = {}
|
|
* for x in l:
|
|
*/
|
|
__pyx_t_1 = PyCFunction_NewEx(&__pyx_mdef_4util_6make_single, NULL, __pyx_n_s__util); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 81; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__make_single, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 81; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
|
|
/* "util.py":87
|
|
* return d.keys()
|
|
*
|
|
* def flatten(l): # <<<<<<<<<<<<<<
|
|
* if type(l) == list:
|
|
* result = []
|
|
*/
|
|
__pyx_t_1 = PyCFunction_NewEx(&__pyx_mdef_4util_7flatten, NULL, __pyx_n_s__util); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 87; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__flatten, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 87; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
|
|
/* "util.py":97
|
|
* return [l]
|
|
*
|
|
* def dimsize(x): # <<<<<<<<<<<<<<
|
|
* assert isinstance(x,str)
|
|
* buffer = x.split(':')
|
|
*/
|
|
__pyx_t_1 = PyCFunction_NewEx(&__pyx_mdef_4util_8dimsize, NULL, __pyx_n_s__util); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 97; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__dimsize, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 97; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
|
|
/* "util.py":118
|
|
* return size
|
|
*
|
|
* def put_info(text,filename): # <<<<<<<<<<<<<<
|
|
* assert type(text) == list
|
|
* if len(text) > 0:
|
|
*/
|
|
__pyx_t_1 = PyCFunction_NewEx(&__pyx_mdef_4util_9put_info, NULL, __pyx_n_s__util); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 118; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__put_info, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 118; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
|
|
/* "util.py":131
|
|
* return text
|
|
*
|
|
* import cPickle as pickle # <<<<<<<<<<<<<<
|
|
* import os, sys
|
|
* def parallel_loop(f,source):
|
|
*/
|
|
__pyx_t_1 = __Pyx_Import(((PyObject *)__pyx_n_s__cPickle), 0, -1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 131; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__pickle, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 131; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
|
|
/* "util.py":132
|
|
*
|
|
* import cPickle as pickle
|
|
* import os, sys # <<<<<<<<<<<<<<
|
|
* def parallel_loop(f,source):
|
|
* pidlist = range(NTHREADS)
|
|
*/
|
|
__pyx_t_1 = __Pyx_Import(((PyObject *)__pyx_n_s__os), 0, -1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 132; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__os, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 132; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_t_1 = __Pyx_Import(((PyObject *)__pyx_n_s__sys), 0, -1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 132; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__sys, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 132; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
|
|
/* "util.py":133
|
|
* import cPickle as pickle
|
|
* import os, sys
|
|
* def parallel_loop(f,source): # <<<<<<<<<<<<<<
|
|
* pidlist = range(NTHREADS)
|
|
*
|
|
*/
|
|
__pyx_t_1 = PyCFunction_NewEx(&__pyx_mdef_4util_10parallel_loop, NULL, __pyx_n_s__util); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 133; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s__parallel_loop, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 133; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
|
|
/* "util.py":185
|
|
*
|
|
*
|
|
* if __name__ == '__main__': # <<<<<<<<<<<<<<
|
|
* print "10",dimsize("10") #-> "10"
|
|
* print "0:10",dimsize("0:10") # -> "11"
|
|
*/
|
|
__pyx_t_1 = __Pyx_GetName(__pyx_m, __pyx_n_s____name__); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 185; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_2 = __Pyx_PyString_Equals(__pyx_t_1, ((PyObject *)__pyx_n_s____main__), Py_EQ); if (unlikely(__pyx_t_2 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 185; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
if (__pyx_t_2) {
|
|
|
|
/* "util.py":186
|
|
*
|
|
* if __name__ == '__main__':
|
|
* print "10",dimsize("10") #-> "10" # <<<<<<<<<<<<<<
|
|
* print "0:10",dimsize("0:10") # -> "11"
|
|
* print "0:x",dimsize("0:x") # -> "x+1"
|
|
*/
|
|
__pyx_t_1 = __Pyx_GetName(__pyx_m, __pyx_n_s__dimsize); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 186; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_3 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_k_tuple_23), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 186; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 186; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
__Pyx_INCREF(((PyObject *)__pyx_kp_s__10));
|
|
PyTuple_SET_ITEM(__pyx_t_1, 0, ((PyObject *)__pyx_kp_s__10));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_kp_s__10));
|
|
PyTuple_SET_ITEM(__pyx_t_1, 1, __pyx_t_3);
|
|
__Pyx_GIVEREF(__pyx_t_3);
|
|
__pyx_t_3 = 0;
|
|
if (__Pyx_Print(0, ((PyObject *)__pyx_t_1), 1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 186; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0;
|
|
|
|
/* "util.py":187
|
|
* if __name__ == '__main__':
|
|
* print "10",dimsize("10") #-> "10"
|
|
* print "0:10",dimsize("0:10") # -> "11" # <<<<<<<<<<<<<<
|
|
* print "0:x",dimsize("0:x") # -> "x+1"
|
|
* print "-3:x",dimsize("-3:x") # -> "x+1"
|
|
*/
|
|
__pyx_t_1 = __Pyx_GetName(__pyx_m, __pyx_n_s__dimsize); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 187; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_3 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_k_tuple_25), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 187; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 187; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
__Pyx_INCREF(((PyObject *)__pyx_kp_s_24));
|
|
PyTuple_SET_ITEM(__pyx_t_1, 0, ((PyObject *)__pyx_kp_s_24));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_kp_s_24));
|
|
PyTuple_SET_ITEM(__pyx_t_1, 1, __pyx_t_3);
|
|
__Pyx_GIVEREF(__pyx_t_3);
|
|
__pyx_t_3 = 0;
|
|
if (__Pyx_Print(0, ((PyObject *)__pyx_t_1), 1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 187; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0;
|
|
|
|
/* "util.py":188
|
|
* print "10",dimsize("10") #-> "10"
|
|
* print "0:10",dimsize("0:10") # -> "11"
|
|
* print "0:x",dimsize("0:x") # -> "x+1" # <<<<<<<<<<<<<<
|
|
* print "-3:x",dimsize("-3:x") # -> "x+1"
|
|
* print "x:y",dimsize("x:y") # -> "y-x+1"
|
|
*/
|
|
__pyx_t_1 = __Pyx_GetName(__pyx_m, __pyx_n_s__dimsize); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 188; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_3 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_k_tuple_27), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 188; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 188; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
__Pyx_INCREF(((PyObject *)__pyx_kp_s_26));
|
|
PyTuple_SET_ITEM(__pyx_t_1, 0, ((PyObject *)__pyx_kp_s_26));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_kp_s_26));
|
|
PyTuple_SET_ITEM(__pyx_t_1, 1, __pyx_t_3);
|
|
__Pyx_GIVEREF(__pyx_t_3);
|
|
__pyx_t_3 = 0;
|
|
if (__Pyx_Print(0, ((PyObject *)__pyx_t_1), 1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 188; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0;
|
|
|
|
/* "util.py":189
|
|
* print "0:10",dimsize("0:10") # -> "11"
|
|
* print "0:x",dimsize("0:x") # -> "x+1"
|
|
* print "-3:x",dimsize("-3:x") # -> "x+1" # <<<<<<<<<<<<<<
|
|
* print "x:y",dimsize("x:y") # -> "y-x+1"
|
|
* print "x:5",dimsize("x:5") # -> "y-x+1"
|
|
*/
|
|
__pyx_t_1 = __Pyx_GetName(__pyx_m, __pyx_n_s__dimsize); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 189; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_3 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_k_tuple_29), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 189; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 189; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
__Pyx_INCREF(((PyObject *)__pyx_kp_s_28));
|
|
PyTuple_SET_ITEM(__pyx_t_1, 0, ((PyObject *)__pyx_kp_s_28));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_kp_s_28));
|
|
PyTuple_SET_ITEM(__pyx_t_1, 1, __pyx_t_3);
|
|
__Pyx_GIVEREF(__pyx_t_3);
|
|
__pyx_t_3 = 0;
|
|
if (__Pyx_Print(0, ((PyObject *)__pyx_t_1), 1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 189; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0;
|
|
|
|
/* "util.py":190
|
|
* print "0:x",dimsize("0:x") # -> "x+1"
|
|
* print "-3:x",dimsize("-3:x") # -> "x+1"
|
|
* print "x:y",dimsize("x:y") # -> "y-x+1" # <<<<<<<<<<<<<<
|
|
* print "x:5",dimsize("x:5") # -> "y-x+1"
|
|
*
|
|
*/
|
|
__pyx_t_1 = __Pyx_GetName(__pyx_m, __pyx_n_s__dimsize); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 190; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_3 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_k_tuple_31), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 190; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 190; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
__Pyx_INCREF(((PyObject *)__pyx_kp_s_30));
|
|
PyTuple_SET_ITEM(__pyx_t_1, 0, ((PyObject *)__pyx_kp_s_30));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_kp_s_30));
|
|
PyTuple_SET_ITEM(__pyx_t_1, 1, __pyx_t_3);
|
|
__Pyx_GIVEREF(__pyx_t_3);
|
|
__pyx_t_3 = 0;
|
|
if (__Pyx_Print(0, ((PyObject *)__pyx_t_1), 1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 190; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0;
|
|
|
|
/* "util.py":191
|
|
* print "-3:x",dimsize("-3:x") # -> "x+1"
|
|
* print "x:y",dimsize("x:y") # -> "y-x+1"
|
|
* print "x:5",dimsize("x:5") # -> "y-x+1" # <<<<<<<<<<<<<<
|
|
*
|
|
*/
|
|
__pyx_t_1 = __Pyx_GetName(__pyx_m, __pyx_n_s__dimsize); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 191; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_1);
|
|
__pyx_t_3 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_k_tuple_33), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 191; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(__pyx_t_3);
|
|
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
|
|
__pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 191; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
__Pyx_INCREF(((PyObject *)__pyx_kp_s_32));
|
|
PyTuple_SET_ITEM(__pyx_t_1, 0, ((PyObject *)__pyx_kp_s_32));
|
|
__Pyx_GIVEREF(((PyObject *)__pyx_kp_s_32));
|
|
PyTuple_SET_ITEM(__pyx_t_1, 1, __pyx_t_3);
|
|
__Pyx_GIVEREF(__pyx_t_3);
|
|
__pyx_t_3 = 0;
|
|
if (__Pyx_Print(0, ((PyObject *)__pyx_t_1), 1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 191; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0;
|
|
goto __pyx_L2;
|
|
}
|
|
__pyx_L2:;
|
|
|
|
/* "util.py":1
|
|
* #!/usr/bin/python # <<<<<<<<<<<<<<
|
|
* # IRPF90 is a Fortran90 preprocessor written in Python for programming using
|
|
* # the Implicit Reference to Parameters (IRP) method.
|
|
*/
|
|
__pyx_t_1 = PyDict_New(); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_GOTREF(((PyObject *)__pyx_t_1));
|
|
if (PyObject_SetAttr(__pyx_m, __pyx_n_s____test__, ((PyObject *)__pyx_t_1)) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
|
|
__Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0;
|
|
goto __pyx_L0;
|
|
__pyx_L1_error:;
|
|
__Pyx_XDECREF(__pyx_t_1);
|
|
__Pyx_XDECREF(__pyx_t_3);
|
|
if (__pyx_m) {
|
|
__Pyx_AddTraceback("init util", __pyx_clineno, __pyx_lineno, __pyx_filename);
|
|
Py_DECREF(__pyx_m); __pyx_m = 0;
|
|
} else if (!PyErr_Occurred()) {
|
|
PyErr_SetString(PyExc_ImportError, "init util");
|
|
}
|
|
__pyx_L0:;
|
|
__Pyx_RefNannyFinishContext();
|
|
#if PY_MAJOR_VERSION < 3
|
|
return;
|
|
#else
|
|
return __pyx_m;
|
|
#endif
|
|
}
|
|
|
|
/* Runtime support code */
|
|
|
|
#if CYTHON_REFNANNY
|
|
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;
|
|
}
|
|
#endif /* CYTHON_REFNANNY */
|
|
|
|
static PyObject *__Pyx_GetName(PyObject *dict, PyObject *name) {
|
|
PyObject *result;
|
|
result = PyObject_GetAttr(dict, name);
|
|
if (!result) {
|
|
if (dict != __pyx_b) {
|
|
PyErr_Clear();
|
|
result = PyObject_GetAttr(__pyx_b, name);
|
|
}
|
|
if (!result) {
|
|
PyErr_SetObject(PyExc_NameError, name);
|
|
}
|
|
}
|
|
return result;
|
|
}
|
|
|
|
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 *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";
|
|
}
|
|
PyErr_Format(PyExc_TypeError,
|
|
"%s() takes %s %"PY_FORMAT_SIZE_T"d positional argument%s (%"PY_FORMAT_SIZE_T"d given)",
|
|
func_name, more_or_less, num_expected,
|
|
(num_expected == 1) ? "" : "s", num_found);
|
|
}
|
|
|
|
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 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 int __Pyx_GetException(PyObject **type, PyObject **value, PyObject **tb) {
|
|
PyObject *local_type, *local_value, *local_tb;
|
|
PyObject *tmp_type, *tmp_value, *tmp_tb;
|
|
PyThreadState *tstate = PyThreadState_GET();
|
|
local_type = tstate->curexc_type;
|
|
local_value = tstate->curexc_value;
|
|
local_tb = tstate->curexc_traceback;
|
|
tstate->curexc_type = 0;
|
|
tstate->curexc_value = 0;
|
|
tstate->curexc_traceback = 0;
|
|
PyErr_NormalizeException(&local_type, &local_value, &local_tb);
|
|
if (unlikely(tstate->curexc_type))
|
|
goto bad;
|
|
#if PY_MAJOR_VERSION >= 3
|
|
if (unlikely(PyException_SetTraceback(local_value, local_tb) < 0))
|
|
goto bad;
|
|
#endif
|
|
*type = local_type;
|
|
*value = local_value;
|
|
*tb = local_tb;
|
|
Py_INCREF(local_type);
|
|
Py_INCREF(local_value);
|
|
Py_INCREF(local_tb);
|
|
tmp_type = tstate->exc_type;
|
|
tmp_value = tstate->exc_value;
|
|
tmp_tb = tstate->exc_traceback;
|
|
tstate->exc_type = local_type;
|
|
tstate->exc_value = local_value;
|
|
tstate->exc_traceback = local_tb;
|
|
/* Make sure tstate is in a consistent state when we XDECREF
|
|
these objects (XDECREF may run arbitrary code). */
|
|
Py_XDECREF(tmp_type);
|
|
Py_XDECREF(tmp_value);
|
|
Py_XDECREF(tmp_tb);
|
|
return 0;
|
|
bad:
|
|
*type = 0;
|
|
*value = 0;
|
|
*tb = 0;
|
|
Py_XDECREF(local_type);
|
|
Py_XDECREF(local_value);
|
|
Py_XDECREF(local_tb);
|
|
return -1;
|
|
}
|
|
|
|
|
|
|
|
static CYTHON_INLINE void __Pyx_RaiseNeedMoreValuesError(Py_ssize_t index) {
|
|
PyErr_Format(PyExc_ValueError,
|
|
"need more than %"PY_FORMAT_SIZE_T"d value%s to unpack",
|
|
index, (index == 1) ? "" : "s");
|
|
}
|
|
|
|
static CYTHON_INLINE void __Pyx_RaiseTooManyValuesError(Py_ssize_t expected) {
|
|
PyErr_Format(PyExc_ValueError,
|
|
"too many values to unpack (expected %"PY_FORMAT_SIZE_T"d)", expected);
|
|
}
|
|
|
|
static int __Pyx_IternextUnpackEndCheck(PyObject *retval, Py_ssize_t expected) {
|
|
if (unlikely(retval)) {
|
|
Py_DECREF(retval);
|
|
__Pyx_RaiseTooManyValuesError(expected);
|
|
return -1;
|
|
} else if (PyErr_Occurred()) {
|
|
if (likely(PyErr_ExceptionMatches(PyExc_StopIteration))) {
|
|
PyErr_Clear();
|
|
return 0;
|
|
} else {
|
|
return -1;
|
|
}
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
static CYTHON_INLINE void __Pyx_RaiseUnboundLocalError(const char *varname) {
|
|
PyErr_Format(PyExc_UnboundLocalError, "local variable '%s' referenced before assignment", varname);
|
|
}
|
|
|
|
static CYTHON_INLINE void __Pyx_ExceptionSave(PyObject **type, PyObject **value, PyObject **tb) {
|
|
PyThreadState *tstate = PyThreadState_GET();
|
|
*type = tstate->exc_type;
|
|
*value = tstate->exc_value;
|
|
*tb = tstate->exc_traceback;
|
|
Py_XINCREF(*type);
|
|
Py_XINCREF(*value);
|
|
Py_XINCREF(*tb);
|
|
}
|
|
|
|
static void __Pyx_ExceptionReset(PyObject *type, PyObject *value, PyObject *tb) {
|
|
PyObject *tmp_type, *tmp_value, *tmp_tb;
|
|
PyThreadState *tstate = PyThreadState_GET();
|
|
tmp_type = tstate->exc_type;
|
|
tmp_value = tstate->exc_value;
|
|
tmp_tb = tstate->exc_traceback;
|
|
tstate->exc_type = type;
|
|
tstate->exc_value = value;
|
|
tstate->exc_traceback = tb;
|
|
Py_XDECREF(tmp_type);
|
|
Py_XDECREF(tmp_value);
|
|
Py_XDECREF(tmp_tb);
|
|
}
|
|
|
|
static PyObject *__Pyx_Import(PyObject *name, PyObject *from_list, long level) {
|
|
PyObject *py_import = 0;
|
|
PyObject *empty_list = 0;
|
|
PyObject *module = 0;
|
|
PyObject *global_dict = 0;
|
|
PyObject *empty_dict = 0;
|
|
PyObject *list;
|
|
py_import = __Pyx_GetAttrString(__pyx_b, "__import__");
|
|
if (!py_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;
|
|
#if PY_VERSION_HEX >= 0x02050000
|
|
{
|
|
PyObject *py_level = PyInt_FromLong(level);
|
|
if (!py_level)
|
|
goto bad;
|
|
module = PyObject_CallFunctionObjArgs(py_import,
|
|
name, global_dict, empty_dict, list, py_level, NULL);
|
|
Py_DECREF(py_level);
|
|
}
|
|
#else
|
|
if (level>0) {
|
|
PyErr_SetString(PyExc_RuntimeError, "Relative import is not supported for Python <=2.4.");
|
|
goto bad;
|
|
}
|
|
module = PyObject_CallFunctionObjArgs(py_import,
|
|
name, global_dict, empty_dict, list, NULL);
|
|
#endif
|
|
bad:
|
|
Py_XDECREF(empty_list);
|
|
Py_XDECREF(py_import);
|
|
Py_XDECREF(empty_dict);
|
|
return module;
|
|
}
|
|
|
|
static CYTHON_INLINE int __Pyx_PyBytes_Equals(PyObject* s1, PyObject* s2, int equals) {
|
|
if (s1 == s2) { /* as done by PyObject_RichCompareBool(); also catches the (interned) empty string */
|
|
return (equals == Py_EQ);
|
|
} else if (PyBytes_CheckExact(s1) & PyBytes_CheckExact(s2)) {
|
|
if (PyBytes_GET_SIZE(s1) != PyBytes_GET_SIZE(s2)) {
|
|
return (equals == Py_NE);
|
|
} else if (PyBytes_GET_SIZE(s1) == 1) {
|
|
if (equals == Py_EQ)
|
|
return (PyBytes_AS_STRING(s1)[0] == PyBytes_AS_STRING(s2)[0]);
|
|
else
|
|
return (PyBytes_AS_STRING(s1)[0] != PyBytes_AS_STRING(s2)[0]);
|
|
} else {
|
|
int result = memcmp(PyBytes_AS_STRING(s1), PyBytes_AS_STRING(s2), (size_t)PyBytes_GET_SIZE(s1));
|
|
return (equals == Py_EQ) ? (result == 0) : (result != 0);
|
|
}
|
|
} else if ((s1 == Py_None) & PyBytes_CheckExact(s2)) {
|
|
return (equals == Py_NE);
|
|
} else if ((s2 == Py_None) & PyBytes_CheckExact(s1)) {
|
|
return (equals == Py_NE);
|
|
} else {
|
|
int result;
|
|
PyObject* py_result = PyObject_RichCompare(s1, s2, equals);
|
|
if (!py_result)
|
|
return -1;
|
|
result = __Pyx_PyObject_IsTrue(py_result);
|
|
Py_DECREF(py_result);
|
|
return result;
|
|
}
|
|
}
|
|
|
|
static CYTHON_INLINE int __Pyx_PyUnicode_Equals(PyObject* s1, PyObject* s2, int equals) {
|
|
if (s1 == s2) { /* as done by PyObject_RichCompareBool(); also catches the (interned) empty string */
|
|
return (equals == Py_EQ);
|
|
} else if (PyUnicode_CheckExact(s1) & PyUnicode_CheckExact(s2)) {
|
|
if (PyUnicode_GET_SIZE(s1) != PyUnicode_GET_SIZE(s2)) {
|
|
return (equals == Py_NE);
|
|
} else if (PyUnicode_GET_SIZE(s1) == 1) {
|
|
if (equals == Py_EQ)
|
|
return (PyUnicode_AS_UNICODE(s1)[0] == PyUnicode_AS_UNICODE(s2)[0]);
|
|
else
|
|
return (PyUnicode_AS_UNICODE(s1)[0] != PyUnicode_AS_UNICODE(s2)[0]);
|
|
} else {
|
|
int result = PyUnicode_Compare(s1, s2);
|
|
if ((result == -1) && unlikely(PyErr_Occurred()))
|
|
return -1;
|
|
return (equals == Py_EQ) ? (result == 0) : (result != 0);
|
|
}
|
|
} else if ((s1 == Py_None) & PyUnicode_CheckExact(s2)) {
|
|
return (equals == Py_NE);
|
|
} else if ((s2 == Py_None) & PyUnicode_CheckExact(s1)) {
|
|
return (equals == Py_NE);
|
|
} else {
|
|
int result;
|
|
PyObject* py_result = PyObject_RichCompare(s1, s2, equals);
|
|
if (!py_result)
|
|
return -1;
|
|
result = __Pyx_PyObject_IsTrue(py_result);
|
|
Py_DECREF(py_result);
|
|
return result;
|
|
}
|
|
}
|
|
|
|
#if PY_MAJOR_VERSION < 3
|
|
static PyObject *__Pyx_GetStdout(void) {
|
|
PyObject *f = PySys_GetObject((char *)"stdout");
|
|
if (!f) {
|
|
PyErr_SetString(PyExc_RuntimeError, "lost sys.stdout");
|
|
}
|
|
return f;
|
|
}
|
|
|
|
static int __Pyx_Print(PyObject* f, PyObject *arg_tuple, int newline) {
|
|
PyObject* v;
|
|
int i;
|
|
|
|
if (!f) {
|
|
if (!(f = __Pyx_GetStdout()))
|
|
return -1;
|
|
}
|
|
for (i=0; i < PyTuple_GET_SIZE(arg_tuple); i++) {
|
|
if (PyFile_SoftSpace(f, 1)) {
|
|
if (PyFile_WriteString(" ", f) < 0)
|
|
return -1;
|
|
}
|
|
v = PyTuple_GET_ITEM(arg_tuple, i);
|
|
if (PyFile_WriteObject(v, f, Py_PRINT_RAW) < 0)
|
|
return -1;
|
|
if (PyString_Check(v)) {
|
|
char *s = PyString_AsString(v);
|
|
Py_ssize_t len = PyString_Size(v);
|
|
if (len > 0 &&
|
|
isspace(Py_CHARMASK(s[len-1])) &&
|
|
s[len-1] != ' ')
|
|
PyFile_SoftSpace(f, 0);
|
|
}
|
|
}
|
|
if (newline) {
|
|
if (PyFile_WriteString("\n", f) < 0)
|
|
return -1;
|
|
PyFile_SoftSpace(f, 0);
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
#else /* Python 3 has a print function */
|
|
|
|
static int __Pyx_Print(PyObject* stream, PyObject *arg_tuple, int newline) {
|
|
PyObject* kwargs = 0;
|
|
PyObject* result = 0;
|
|
PyObject* end_string;
|
|
if (unlikely(!__pyx_print)) {
|
|
__pyx_print = __Pyx_GetAttrString(__pyx_b, "print");
|
|
if (!__pyx_print)
|
|
return -1;
|
|
}
|
|
if (stream) {
|
|
kwargs = PyDict_New();
|
|
if (unlikely(!kwargs))
|
|
return -1;
|
|
if (unlikely(PyDict_SetItemString(kwargs, "file", stream) < 0))
|
|
goto bad;
|
|
if (!newline) {
|
|
end_string = PyUnicode_FromStringAndSize(" ", 1);
|
|
if (unlikely(!end_string))
|
|
goto bad;
|
|
if (PyDict_SetItemString(kwargs, "end", end_string) < 0) {
|
|
Py_DECREF(end_string);
|
|
goto bad;
|
|
}
|
|
Py_DECREF(end_string);
|
|
}
|
|
} else if (!newline) {
|
|
if (unlikely(!__pyx_print_kwargs)) {
|
|
__pyx_print_kwargs = PyDict_New();
|
|
if (unlikely(!__pyx_print_kwargs))
|
|
return -1;
|
|
end_string = PyUnicode_FromStringAndSize(" ", 1);
|
|
if (unlikely(!end_string))
|
|
return -1;
|
|
if (PyDict_SetItemString(__pyx_print_kwargs, "end", end_string) < 0) {
|
|
Py_DECREF(end_string);
|
|
return -1;
|
|
}
|
|
Py_DECREF(end_string);
|
|
}
|
|
kwargs = __pyx_print_kwargs;
|
|
}
|
|
result = PyObject_Call(__pyx_print, arg_tuple, kwargs);
|
|
if (unlikely(kwargs) && (kwargs != __pyx_print_kwargs))
|
|
Py_DECREF(kwargs);
|
|
if (!result)
|
|
return -1;
|
|
Py_DECREF(result);
|
|
return 0;
|
|
bad:
|
|
if (kwargs != __pyx_print_kwargs)
|
|
Py_XDECREF(kwargs);
|
|
return -1;
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
static PyObject *__pyx_binding_PyCFunctionType_NewEx(PyMethodDef *ml, PyObject *self, PyObject *module) {
|
|
__pyx_binding_PyCFunctionType_object *op = PyObject_GC_New(__pyx_binding_PyCFunctionType_object, __pyx_binding_PyCFunctionType);
|
|
if (op == NULL)
|
|
return NULL;
|
|
op->func.m_ml = ml;
|
|
Py_XINCREF(self);
|
|
op->func.m_self = self;
|
|
Py_XINCREF(module);
|
|
op->func.m_module = module;
|
|
PyObject_GC_Track(op);
|
|
return (PyObject *)op;
|
|
}
|
|
|
|
static void __pyx_binding_PyCFunctionType_dealloc(__pyx_binding_PyCFunctionType_object *m) {
|
|
PyObject_GC_UnTrack(m);
|
|
Py_XDECREF(m->func.m_self);
|
|
Py_XDECREF(m->func.m_module);
|
|
PyObject_GC_Del(m);
|
|
}
|
|
|
|
static PyObject *__pyx_binding_PyCFunctionType_descr_get(PyObject *func, PyObject *obj, PyObject *type) {
|
|
if (obj == Py_None)
|
|
obj = NULL;
|
|
return PyMethod_New(func, obj, type);
|
|
}
|
|
|
|
static int __pyx_binding_PyCFunctionType_init(void) {
|
|
__pyx_binding_PyCFunctionType_type = PyCFunction_Type;
|
|
__pyx_binding_PyCFunctionType_type.tp_name = __Pyx_NAMESTR("cython_binding_builtin_function_or_method");
|
|
__pyx_binding_PyCFunctionType_type.tp_dealloc = (destructor)__pyx_binding_PyCFunctionType_dealloc;
|
|
__pyx_binding_PyCFunctionType_type.tp_descr_get = __pyx_binding_PyCFunctionType_descr_get;
|
|
if (PyType_Ready(&__pyx_binding_PyCFunctionType_type) < 0) {
|
|
return -1;
|
|
}
|
|
__pyx_binding_PyCFunctionType = &__pyx_binding_PyCFunctionType_type;
|
|
return 0;
|
|
|
|
}
|
|
|
|
static CYTHON_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 CYTHON_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 CYTHON_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 CYTHON_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 CYTHON_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 CYTHON_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 CYTHON_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 CYTHON_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 CYTHON_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 CYTHON_INLINE int __Pyx_PyInt_AsLongDouble(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 CYTHON_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 (unsigned long)PyLong_AsUnsignedLong(x);
|
|
} else {
|
|
return (unsigned long)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 CYTHON_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 (unsigned PY_LONG_LONG)PyLong_AsUnsignedLongLong(x);
|
|
} else {
|
|
return (unsigned PY_LONG_LONG)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 CYTHON_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 (long)PyLong_AsUnsignedLong(x);
|
|
} else {
|
|
return (long)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 CYTHON_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 (PY_LONG_LONG)PyLong_AsUnsignedLongLong(x);
|
|
} else {
|
|
return (PY_LONG_LONG)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 CYTHON_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 (signed long)PyLong_AsUnsignedLong(x);
|
|
} else {
|
|
return (signed long)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 CYTHON_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 (signed PY_LONG_LONG)PyLong_AsUnsignedLongLong(x);
|
|
} else {
|
|
return (signed PY_LONG_LONG)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 int __Pyx_check_binary_version(void) {
|
|
char ctversion[4], rtversion[4];
|
|
PyOS_snprintf(ctversion, 4, "%d.%d", PY_MAJOR_VERSION, PY_MINOR_VERSION);
|
|
PyOS_snprintf(rtversion, 4, "%s", Py_GetVersion());
|
|
if (ctversion[0] != rtversion[0] || ctversion[2] != rtversion[2]) {
|
|
char message[200];
|
|
PyOS_snprintf(message, sizeof(message),
|
|
"compiletime version %s of module '%.100s' "
|
|
"does not match runtime version %s",
|
|
ctversion, __Pyx_MODULE_NAME, rtversion);
|
|
#if PY_VERSION_HEX < 0x02050000
|
|
return PyErr_Warn(NULL, message);
|
|
#else
|
|
return PyErr_WarnEx(NULL, message, 1);
|
|
#endif
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
#include "compile.h"
|
|
#include "frameobject.h"
|
|
#include "traceback.h"
|
|
|
|
static void __Pyx_AddTraceback(const char *funcname, int __pyx_clineno,
|
|
int __pyx_lineno, const char *__pyx_filename) {
|
|
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 CYTHON_INLINE int __Pyx_PyObject_IsTrue(PyObject* x) {
|
|
int is_true = x == Py_True;
|
|
if (is_true | (x == Py_False) | (x == Py_None)) return is_true;
|
|
else return PyObject_IsTrue(x);
|
|
}
|
|
|
|
static CYTHON_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 CYTHON_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 CYTHON_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 CYTHON_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 */
|