From 73e1c44a25a835458cd3919f3ab58c10fb687fa0 Mon Sep 17 00:00:00 2001 From: Jiang Date: Mon, 5 Jan 2026 19:00:55 +0800 Subject: [PATCH] =?UTF-8?q?=E5=88=A0=E9=99=A4=E5=86=97=E4=BD=99=E4=BE=9D?= =?UTF-8?q?=E8=B5=96=E6=96=87=E4=BB=B6?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- epanet/__init__.c | 4829 ------- epanet/epanet.c | 21700 -------------------------------- epanet/epanet2-0.dll | Bin 649728 -> 0 bytes epanet/epanet2-2.2.0.dll | Bin 460288 -> 0 bytes epanet/epanet2-2.3.0.dll | Bin 466944 -> 0 bytes epanet/epanet2-cannot run.dll | Bin 217088 -> 0 bytes epanet/epanet2_ec.c | 6027 --------- epanet/epanet2_ec.py | 92 - epanet/epanet2_vs_3.md | 187 - epanet/vcruntime140_1.dll | Bin 44312 -> 0 bytes 10 files changed, 32835 deletions(-) delete mode 100644 epanet/__init__.c delete mode 100644 epanet/epanet.c delete mode 100644 epanet/epanet2-0.dll delete mode 100644 epanet/epanet2-2.2.0.dll delete mode 100644 epanet/epanet2-2.3.0.dll delete mode 100644 epanet/epanet2-cannot run.dll delete mode 100644 epanet/epanet2_ec.c delete mode 100644 epanet/epanet2_ec.py delete mode 100644 epanet/epanet2_vs_3.md delete mode 100644 epanet/vcruntime140_1.dll diff --git a/epanet/__init__.c b/epanet/__init__.c deleted file mode 100644 index 9d7b628..0000000 --- a/epanet/__init__.c +++ /dev/null @@ -1,4829 +0,0 @@ -/* Generated by Cython 3.1.0 */ - -/* BEGIN: Cython Metadata -{ - "distutils": { - "name": "epanet.__init__", - "sources": [ - "epanet\\__init__.py" - ] - }, - "module_name": "epanet.__init__" -} -END: Cython Metadata */ - -#ifndef PY_SSIZE_T_CLEAN -#define PY_SSIZE_T_CLEAN -#endif /* PY_SSIZE_T_CLEAN */ -/* InitLimitedAPI */ -#if defined(Py_LIMITED_API) && !defined(CYTHON_LIMITED_API) - #define CYTHON_LIMITED_API 1 -#endif - -#include "Python.h" -#ifndef Py_PYTHON_H - #error Python headers needed to compile C extensions, please install development version of Python. -#elif PY_VERSION_HEX < 0x03080000 - #error Cython requires Python 3.8+. -#else -#define __PYX_ABI_VERSION "3_1_0" -#define CYTHON_HEX_VERSION 0x030100F0 -#define CYTHON_FUTURE_DIVISION 1 -/* CModulePreamble */ -#include -#ifndef offsetof - #define offsetof(type, member) ( (size_t) & ((type*)0) -> member ) -#endif -#if !defined(_WIN32) && !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 -#define __PYX_COMMA , -#ifndef HAVE_LONG_LONG - #define HAVE_LONG_LONG -#endif -#ifndef PY_LONG_LONG - #define PY_LONG_LONG LONG_LONG -#endif -#ifndef Py_HUGE_VAL - #define Py_HUGE_VAL HUGE_VAL -#endif -#define __PYX_LIMITED_VERSION_HEX PY_VERSION_HEX -#if defined(GRAALVM_PYTHON) - /* For very preliminary testing purposes. Most variables are set the same as PyPy. - The existence of this section does not imply that anything works or is even tested */ - #define CYTHON_COMPILING_IN_PYPY 0 - #define CYTHON_COMPILING_IN_CPYTHON 0 - #define CYTHON_COMPILING_IN_LIMITED_API 0 - #define CYTHON_COMPILING_IN_GRAAL 1 - #define CYTHON_COMPILING_IN_CPYTHON_FREETHREADING 0 - #undef CYTHON_USE_TYPE_SLOTS - #define CYTHON_USE_TYPE_SLOTS 0 - #undef CYTHON_USE_TYPE_SPECS - #define CYTHON_USE_TYPE_SPECS 0 - #undef CYTHON_USE_PYTYPE_LOOKUP - #define CYTHON_USE_PYTYPE_LOOKUP 0 - #undef CYTHON_USE_PYLIST_INTERNALS - #define CYTHON_USE_PYLIST_INTERNALS 0 - #undef CYTHON_USE_UNICODE_INTERNALS - #define CYTHON_USE_UNICODE_INTERNALS 0 - #undef CYTHON_USE_UNICODE_WRITER - #define CYTHON_USE_UNICODE_WRITER 0 - #undef CYTHON_USE_PYLONG_INTERNALS - #define CYTHON_USE_PYLONG_INTERNALS 0 - #undef CYTHON_AVOID_BORROWED_REFS - #define CYTHON_AVOID_BORROWED_REFS 1 - #undef CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS - #define CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS 1 - #undef CYTHON_ASSUME_SAFE_MACROS - #define CYTHON_ASSUME_SAFE_MACROS 0 - #undef CYTHON_ASSUME_SAFE_SIZE - #define CYTHON_ASSUME_SAFE_SIZE 0 - #undef CYTHON_UNPACK_METHODS - #define CYTHON_UNPACK_METHODS 0 - #undef CYTHON_FAST_THREAD_STATE - #define CYTHON_FAST_THREAD_STATE 0 - #undef CYTHON_FAST_GIL - #define CYTHON_FAST_GIL 0 - #undef CYTHON_METH_FASTCALL - #define CYTHON_METH_FASTCALL 0 - #undef CYTHON_FAST_PYCALL - #define CYTHON_FAST_PYCALL 0 - #ifndef CYTHON_PEP487_INIT_SUBCLASS - #define CYTHON_PEP487_INIT_SUBCLASS 1 - #endif - #undef CYTHON_PEP489_MULTI_PHASE_INIT - #define CYTHON_PEP489_MULTI_PHASE_INIT 1 - #undef CYTHON_USE_MODULE_STATE - #define CYTHON_USE_MODULE_STATE 0 - #undef CYTHON_USE_SYS_MONITORING - #define CYTHON_USE_SYS_MONITORING 0 - #undef CYTHON_USE_TP_FINALIZE - #define CYTHON_USE_TP_FINALIZE 0 - #undef CYTHON_USE_AM_SEND - #define CYTHON_USE_AM_SEND 0 - #undef CYTHON_USE_DICT_VERSIONS - #define CYTHON_USE_DICT_VERSIONS 0 - #undef CYTHON_USE_EXC_INFO_STACK - #define CYTHON_USE_EXC_INFO_STACK 1 - #ifndef CYTHON_UPDATE_DESCRIPTOR_DOC - #define CYTHON_UPDATE_DESCRIPTOR_DOC 0 - #endif - #undef CYTHON_USE_FREELISTS - #define CYTHON_USE_FREELISTS 0 -#elif defined(PYPY_VERSION) - #define CYTHON_COMPILING_IN_PYPY 1 - #define CYTHON_COMPILING_IN_CPYTHON 0 - #define CYTHON_COMPILING_IN_LIMITED_API 0 - #define CYTHON_COMPILING_IN_GRAAL 0 - #define CYTHON_COMPILING_IN_CPYTHON_FREETHREADING 0 - #undef CYTHON_USE_TYPE_SLOTS - #define CYTHON_USE_TYPE_SLOTS 1 - #ifndef CYTHON_USE_TYPE_SPECS - #define CYTHON_USE_TYPE_SPECS 0 - #endif - #undef CYTHON_USE_PYTYPE_LOOKUP - #define CYTHON_USE_PYTYPE_LOOKUP 0 - #undef CYTHON_USE_PYLIST_INTERNALS - #define CYTHON_USE_PYLIST_INTERNALS 0 - #undef CYTHON_USE_UNICODE_INTERNALS - #define CYTHON_USE_UNICODE_INTERNALS 0 - #undef CYTHON_USE_UNICODE_WRITER - #define CYTHON_USE_UNICODE_WRITER 0 - #undef CYTHON_USE_PYLONG_INTERNALS - #define CYTHON_USE_PYLONG_INTERNALS 0 - #undef CYTHON_AVOID_BORROWED_REFS - #define CYTHON_AVOID_BORROWED_REFS 1 - #undef CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS - #define CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS 1 - #undef CYTHON_ASSUME_SAFE_MACROS - #define CYTHON_ASSUME_SAFE_MACROS 0 - #ifndef CYTHON_ASSUME_SAFE_SIZE - #define CYTHON_ASSUME_SAFE_SIZE 1 - #endif - #undef CYTHON_UNPACK_METHODS - #define CYTHON_UNPACK_METHODS 0 - #undef CYTHON_FAST_THREAD_STATE - #define CYTHON_FAST_THREAD_STATE 0 - #undef CYTHON_FAST_GIL - #define CYTHON_FAST_GIL 0 - #undef CYTHON_METH_FASTCALL - #define CYTHON_METH_FASTCALL 0 - #undef CYTHON_FAST_PYCALL - #define CYTHON_FAST_PYCALL 0 - #ifndef CYTHON_PEP487_INIT_SUBCLASS - #define CYTHON_PEP487_INIT_SUBCLASS 1 - #endif - #if PY_VERSION_HEX < 0x03090000 - #undef CYTHON_PEP489_MULTI_PHASE_INIT - #define CYTHON_PEP489_MULTI_PHASE_INIT 0 - #elif !defined(CYTHON_PEP489_MULTI_PHASE_INIT) - #define CYTHON_PEP489_MULTI_PHASE_INIT 1 - #endif - #undef CYTHON_USE_MODULE_STATE - #define CYTHON_USE_MODULE_STATE 0 - #undef CYTHON_USE_SYS_MONITORING - #define CYTHON_USE_SYS_MONITORING 0 - #ifndef CYTHON_USE_TP_FINALIZE - #define CYTHON_USE_TP_FINALIZE (PYPY_VERSION_NUM >= 0x07030C00) - #endif - #undef CYTHON_USE_AM_SEND - #define CYTHON_USE_AM_SEND 0 - #undef CYTHON_USE_DICT_VERSIONS - #define CYTHON_USE_DICT_VERSIONS 0 - #undef CYTHON_USE_EXC_INFO_STACK - #define CYTHON_USE_EXC_INFO_STACK 0 - #ifndef CYTHON_UPDATE_DESCRIPTOR_DOC - #define CYTHON_UPDATE_DESCRIPTOR_DOC (PYPY_VERSION_NUM >= 0x07031100) - #endif - #undef CYTHON_USE_FREELISTS - #define CYTHON_USE_FREELISTS 0 -#elif defined(CYTHON_LIMITED_API) - #ifdef Py_LIMITED_API - #undef __PYX_LIMITED_VERSION_HEX - #define __PYX_LIMITED_VERSION_HEX Py_LIMITED_API - #endif - #define CYTHON_COMPILING_IN_PYPY 0 - #define CYTHON_COMPILING_IN_CPYTHON 0 - #define CYTHON_COMPILING_IN_LIMITED_API 1 - #define CYTHON_COMPILING_IN_GRAAL 0 - #define CYTHON_COMPILING_IN_CPYTHON_FREETHREADING 0 - #undef CYTHON_CLINE_IN_TRACEBACK - #define CYTHON_CLINE_IN_TRACEBACK 0 - #undef CYTHON_USE_TYPE_SLOTS - #define CYTHON_USE_TYPE_SLOTS 0 - #undef CYTHON_USE_TYPE_SPECS - #define CYTHON_USE_TYPE_SPECS 1 - #undef CYTHON_USE_PYTYPE_LOOKUP - #define CYTHON_USE_PYTYPE_LOOKUP 0 - #undef CYTHON_USE_PYLIST_INTERNALS - #define CYTHON_USE_PYLIST_INTERNALS 0 - #undef CYTHON_USE_UNICODE_INTERNALS - #define CYTHON_USE_UNICODE_INTERNALS 0 - #ifndef CYTHON_USE_UNICODE_WRITER - #define CYTHON_USE_UNICODE_WRITER 0 - #endif - #undef CYTHON_USE_PYLONG_INTERNALS - #define CYTHON_USE_PYLONG_INTERNALS 0 - #ifndef CYTHON_AVOID_BORROWED_REFS - #define CYTHON_AVOID_BORROWED_REFS 0 - #endif - #ifndef CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS - #define CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS 0 - #endif - #undef CYTHON_ASSUME_SAFE_MACROS - #define CYTHON_ASSUME_SAFE_MACROS 0 - #undef CYTHON_ASSUME_SAFE_SIZE - #define CYTHON_ASSUME_SAFE_SIZE 0 - #undef CYTHON_UNPACK_METHODS - #define CYTHON_UNPACK_METHODS 0 - #undef CYTHON_FAST_THREAD_STATE - #define CYTHON_FAST_THREAD_STATE 0 - #undef CYTHON_FAST_GIL - #define CYTHON_FAST_GIL 0 - #undef CYTHON_METH_FASTCALL - #define CYTHON_METH_FASTCALL (__PYX_LIMITED_VERSION_HEX >= 0x030C0000) - #undef CYTHON_FAST_PYCALL - #define CYTHON_FAST_PYCALL 0 - #ifndef CYTHON_PEP487_INIT_SUBCLASS - #define CYTHON_PEP487_INIT_SUBCLASS 1 - #endif - #ifndef CYTHON_PEP489_MULTI_PHASE_INIT - #define CYTHON_PEP489_MULTI_PHASE_INIT 1 - #endif - #ifndef CYTHON_USE_MODULE_STATE - #define CYTHON_USE_MODULE_STATE 0 - #endif - #undef CYTHON_USE_SYS_MONITORING - #define CYTHON_USE_SYS_MONITORING 0 - #ifndef CYTHON_USE_TP_FINALIZE - #define CYTHON_USE_TP_FINALIZE 0 - #endif - #ifndef CYTHON_USE_AM_SEND - #define CYTHON_USE_AM_SEND (__PYX_LIMITED_VERSION_HEX >= 0x030A0000) - #endif - #undef CYTHON_USE_DICT_VERSIONS - #define CYTHON_USE_DICT_VERSIONS 0 - #undef CYTHON_USE_EXC_INFO_STACK - #define CYTHON_USE_EXC_INFO_STACK 0 - #ifndef CYTHON_UPDATE_DESCRIPTOR_DOC - #define CYTHON_UPDATE_DESCRIPTOR_DOC 0 - #endif - #undef CYTHON_USE_FREELISTS - #define CYTHON_USE_FREELISTS 0 -#else - #define CYTHON_COMPILING_IN_PYPY 0 - #define CYTHON_COMPILING_IN_CPYTHON 1 - #define CYTHON_COMPILING_IN_LIMITED_API 0 - #define CYTHON_COMPILING_IN_GRAAL 0 - #ifdef Py_GIL_DISABLED - #define CYTHON_COMPILING_IN_CPYTHON_FREETHREADING 1 - #else - #define CYTHON_COMPILING_IN_CPYTHON_FREETHREADING 0 - #endif - #if PY_VERSION_HEX < 0x030A0000 - #undef CYTHON_USE_TYPE_SLOTS - #define CYTHON_USE_TYPE_SLOTS 1 - #elif !defined(CYTHON_USE_TYPE_SLOTS) - #define CYTHON_USE_TYPE_SLOTS 1 - #endif - #ifndef CYTHON_USE_TYPE_SPECS - #define CYTHON_USE_TYPE_SPECS 0 - #endif - #ifndef CYTHON_USE_PYTYPE_LOOKUP - #define CYTHON_USE_PYTYPE_LOOKUP 1 - #endif - #ifndef CYTHON_USE_PYLONG_INTERNALS - #define CYTHON_USE_PYLONG_INTERNALS 1 - #endif - #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - #undef CYTHON_USE_PYLIST_INTERNALS - #define CYTHON_USE_PYLIST_INTERNALS 0 - #elif !defined(CYTHON_USE_PYLIST_INTERNALS) - #define CYTHON_USE_PYLIST_INTERNALS 1 - #endif - #ifndef CYTHON_USE_UNICODE_INTERNALS - #define CYTHON_USE_UNICODE_INTERNALS 1 - #endif - #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING || PY_VERSION_HEX >= 0x030B00A2 - #undef CYTHON_USE_UNICODE_WRITER - #define CYTHON_USE_UNICODE_WRITER 0 - #elif !defined(CYTHON_USE_UNICODE_WRITER) - #define CYTHON_USE_UNICODE_WRITER 1 - #endif - #ifndef CYTHON_AVOID_BORROWED_REFS - #define CYTHON_AVOID_BORROWED_REFS 0 - #endif - #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - #undef CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS - #define CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS 1 - #elif !defined(CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS) - #define CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS 0 - #endif - #ifndef CYTHON_ASSUME_SAFE_MACROS - #define CYTHON_ASSUME_SAFE_MACROS 1 - #endif - #ifndef CYTHON_ASSUME_SAFE_SIZE - #define CYTHON_ASSUME_SAFE_SIZE 1 - #endif - #ifndef CYTHON_UNPACK_METHODS - #define CYTHON_UNPACK_METHODS 1 - #endif - #ifndef CYTHON_FAST_THREAD_STATE - #define CYTHON_FAST_THREAD_STATE 1 - #endif - #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - #undef CYTHON_FAST_GIL - #define CYTHON_FAST_GIL 0 - #elif !defined(CYTHON_FAST_GIL) - #define CYTHON_FAST_GIL (PY_VERSION_HEX < 0x030C00A6) - #endif - #ifndef CYTHON_METH_FASTCALL - #define CYTHON_METH_FASTCALL 1 - #endif - #ifndef CYTHON_FAST_PYCALL - #define CYTHON_FAST_PYCALL 1 - #endif - #ifndef CYTHON_PEP487_INIT_SUBCLASS - #define CYTHON_PEP487_INIT_SUBCLASS 1 - #endif - #ifndef CYTHON_PEP489_MULTI_PHASE_INIT - #define CYTHON_PEP489_MULTI_PHASE_INIT 1 - #endif - #ifndef CYTHON_USE_MODULE_STATE - #define CYTHON_USE_MODULE_STATE 0 - #endif - #ifndef CYTHON_USE_SYS_MONITORING - #define CYTHON_USE_SYS_MONITORING (PY_VERSION_HEX >= 0x030d00B1) - #endif - #ifndef CYTHON_USE_TP_FINALIZE - #define CYTHON_USE_TP_FINALIZE 1 - #endif - #ifndef CYTHON_USE_AM_SEND - #define CYTHON_USE_AM_SEND 1 - #endif - #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - #undef CYTHON_USE_DICT_VERSIONS - #define CYTHON_USE_DICT_VERSIONS 0 - #elif !defined(CYTHON_USE_DICT_VERSIONS) - #define CYTHON_USE_DICT_VERSIONS (PY_VERSION_HEX < 0x030C00A5 && !CYTHON_USE_MODULE_STATE) - #endif - #ifndef CYTHON_USE_EXC_INFO_STACK - #define CYTHON_USE_EXC_INFO_STACK 1 - #endif - #ifndef CYTHON_UPDATE_DESCRIPTOR_DOC - #define CYTHON_UPDATE_DESCRIPTOR_DOC 1 - #endif - #ifndef CYTHON_USE_FREELISTS - #define CYTHON_USE_FREELISTS (!CYTHON_COMPILING_IN_CPYTHON_FREETHREADING) - #endif -#endif -#ifndef CYTHON_FAST_PYCCALL -#define CYTHON_FAST_PYCCALL CYTHON_FAST_PYCALL -#endif -#ifndef CYTHON_VECTORCALL -#if CYTHON_COMPILING_IN_LIMITED_API -#define CYTHON_VECTORCALL (__PYX_LIMITED_VERSION_HEX >= 0x030C0000) -#else -#define CYTHON_VECTORCALL (CYTHON_FAST_PYCCALL && PY_VERSION_HEX >= 0x030800B1) -#endif -#endif -#define CYTHON_BACKPORT_VECTORCALL (CYTHON_METH_FASTCALL && PY_VERSION_HEX < 0x030800B1) -#if CYTHON_USE_PYLONG_INTERNALS - #undef SHIFT - #undef BASE - #undef MASK - #ifdef SIZEOF_VOID_P - enum { __pyx_check_sizeof_voidp = 1 / (int)(SIZEOF_VOID_P == sizeof(void*)) }; - #endif -#endif -#ifndef __has_attribute - #define __has_attribute(x) 0 -#endif -#ifndef __has_cpp_attribute - #define __has_cpp_attribute(x) 0 -#endif -#ifndef CYTHON_RESTRICT - #if defined(__GNUC__) - #define CYTHON_RESTRICT __restrict__ - #elif defined(_MSC_VER) && _MSC_VER >= 1400 - #define CYTHON_RESTRICT __restrict - #elif defined (__STDC_VERSION__) && __STDC_VERSION__ >= 199901L - #define CYTHON_RESTRICT restrict - #else - #define CYTHON_RESTRICT - #endif -#endif -#ifndef CYTHON_UNUSED - #if defined(__cplusplus) - /* for clang __has_cpp_attribute(maybe_unused) is true even before C++17 - * but leads to warnings with -pedantic, since it is a C++17 feature */ - #if ((defined(_MSVC_LANG) && _MSVC_LANG >= 201703L) || __cplusplus >= 201703L) - #if __has_cpp_attribute(maybe_unused) - #define CYTHON_UNUSED [[maybe_unused]] - #endif - #endif - #endif -#endif -#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) && !defined(_MSC_VER)) -# define CYTHON_UNUSED __attribute__ ((__unused__)) -# else -# define CYTHON_UNUSED -# endif -#endif -#ifndef CYTHON_UNUSED_VAR -# if defined(__cplusplus) - template void CYTHON_UNUSED_VAR( const T& ) { } -# else -# define CYTHON_UNUSED_VAR(x) (void)(x) -# endif -#endif -#ifndef CYTHON_MAYBE_UNUSED_VAR - #define CYTHON_MAYBE_UNUSED_VAR(x) CYTHON_UNUSED_VAR(x) -#endif -#ifndef CYTHON_NCP_UNUSED -# if CYTHON_COMPILING_IN_CPYTHON -# define CYTHON_NCP_UNUSED -# else -# define CYTHON_NCP_UNUSED CYTHON_UNUSED -# endif -#endif -#ifndef CYTHON_USE_CPP_STD_MOVE - #if defined(__cplusplus) && (\ - __cplusplus >= 201103L || (defined(_MSC_VER) && _MSC_VER >= 1600)) - #define CYTHON_USE_CPP_STD_MOVE 1 - #else - #define CYTHON_USE_CPP_STD_MOVE 0 - #endif -#endif -#define __Pyx_void_to_None(void_result) ((void)(void_result), Py_INCREF(Py_None), Py_None) -#ifdef _MSC_VER - #ifndef _MSC_STDINT_H_ - #if _MSC_VER < 1300 - typedef unsigned char uint8_t; - typedef unsigned short uint16_t; - typedef unsigned int uint32_t; - #else - typedef unsigned __int8 uint8_t; - typedef unsigned __int16 uint16_t; - typedef unsigned __int32 uint32_t; - #endif - #endif - #if _MSC_VER < 1300 - #ifdef _WIN64 - typedef unsigned long long __pyx_uintptr_t; - #else - typedef unsigned int __pyx_uintptr_t; - #endif - #else - #ifdef _WIN64 - typedef unsigned __int64 __pyx_uintptr_t; - #else - typedef unsigned __int32 __pyx_uintptr_t; - #endif - #endif -#else - #include - typedef uintptr_t __pyx_uintptr_t; -#endif -#ifndef CYTHON_FALLTHROUGH - #if defined(__cplusplus) - /* for clang __has_cpp_attribute(fallthrough) is true even before C++17 - * but leads to warnings with -pedantic, since it is a C++17 feature */ - #if ((defined(_MSVC_LANG) && _MSVC_LANG >= 201703L) || __cplusplus >= 201703L) - #if __has_cpp_attribute(fallthrough) - #define CYTHON_FALLTHROUGH [[fallthrough]] - #endif - #endif - #ifndef CYTHON_FALLTHROUGH - #if __has_cpp_attribute(clang::fallthrough) - #define CYTHON_FALLTHROUGH [[clang::fallthrough]] - #elif __has_cpp_attribute(gnu::fallthrough) - #define CYTHON_FALLTHROUGH [[gnu::fallthrough]] - #endif - #endif - #endif - #ifndef CYTHON_FALLTHROUGH - #if __has_attribute(fallthrough) - #define CYTHON_FALLTHROUGH __attribute__((fallthrough)) - #else - #define CYTHON_FALLTHROUGH - #endif - #endif - #if defined(__clang__) && defined(__apple_build_version__) - #if __apple_build_version__ < 7000000 - #undef CYTHON_FALLTHROUGH - #define CYTHON_FALLTHROUGH - #endif - #endif -#endif -#ifndef Py_UNREACHABLE - #define Py_UNREACHABLE() assert(0); abort() -#endif -#ifdef __cplusplus - template - struct __PYX_IS_UNSIGNED_IMPL {static const bool value = T(0) < T(-1);}; - #define __PYX_IS_UNSIGNED(type) (__PYX_IS_UNSIGNED_IMPL::value) -#else - #define __PYX_IS_UNSIGNED(type) (((type)-1) > 0) -#endif -#if CYTHON_COMPILING_IN_PYPY == 1 - #define __PYX_NEED_TP_PRINT_SLOT (PY_VERSION_HEX >= 0x030800b4 && PY_VERSION_HEX < 0x030A0000) -#else - #define __PYX_NEED_TP_PRINT_SLOT (PY_VERSION_HEX >= 0x030800b4 && PY_VERSION_HEX < 0x03090000) -#endif -#define __PYX_REINTERPRET_FUNCION(func_pointer, other_pointer) ((func_pointer)(void(*)(void))(other_pointer)) - -/* CInitCode */ -#ifndef CYTHON_INLINE - #if defined(__clang__) - #define CYTHON_INLINE __inline__ __attribute__ ((__unused__)) - #elif 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 - -/* PythonCompatibility */ -#define __PYX_BUILD_PY_SSIZE_T "n" -#define CYTHON_FORMAT_SSIZE_T "z" -#define __Pyx_BUILTIN_MODULE_NAME "builtins" -#define __Pyx_DefaultClassType PyType_Type -#if CYTHON_COMPILING_IN_LIMITED_API - #ifndef CO_OPTIMIZED - static int CO_OPTIMIZED; - #endif - #ifndef CO_NEWLOCALS - static int CO_NEWLOCALS; - #endif - #ifndef CO_VARARGS - static int CO_VARARGS; - #endif - #ifndef CO_VARKEYWORDS - static int CO_VARKEYWORDS; - #endif - #ifndef CO_ASYNC_GENERATOR - static int CO_ASYNC_GENERATOR; - #endif - #ifndef CO_GENERATOR - static int CO_GENERATOR; - #endif - #ifndef CO_COROUTINE - static int CO_COROUTINE; - #endif -#else - #ifndef CO_COROUTINE - #define CO_COROUTINE 0x80 - #endif - #ifndef CO_ASYNC_GENERATOR - #define CO_ASYNC_GENERATOR 0x200 - #endif -#endif -static int __Pyx_init_co_variables(void); -#if PY_VERSION_HEX >= 0x030900A4 || defined(Py_IS_TYPE) - #define __Pyx_IS_TYPE(ob, type) Py_IS_TYPE(ob, type) -#else - #define __Pyx_IS_TYPE(ob, type) (((const PyObject*)ob)->ob_type == (type)) -#endif -#if PY_VERSION_HEX >= 0x030A00B1 || defined(Py_Is) - #define __Pyx_Py_Is(x, y) Py_Is(x, y) -#else - #define __Pyx_Py_Is(x, y) ((x) == (y)) -#endif -#if PY_VERSION_HEX >= 0x030A00B1 || defined(Py_IsNone) - #define __Pyx_Py_IsNone(ob) Py_IsNone(ob) -#else - #define __Pyx_Py_IsNone(ob) __Pyx_Py_Is((ob), Py_None) -#endif -#if PY_VERSION_HEX >= 0x030A00B1 || defined(Py_IsTrue) - #define __Pyx_Py_IsTrue(ob) Py_IsTrue(ob) -#else - #define __Pyx_Py_IsTrue(ob) __Pyx_Py_Is((ob), Py_True) -#endif -#if PY_VERSION_HEX >= 0x030A00B1 || defined(Py_IsFalse) - #define __Pyx_Py_IsFalse(ob) Py_IsFalse(ob) -#else - #define __Pyx_Py_IsFalse(ob) __Pyx_Py_Is((ob), Py_False) -#endif -#define __Pyx_NoneAsNull(obj) (__Pyx_Py_IsNone(obj) ? NULL : (obj)) -#if PY_VERSION_HEX >= 0x030900F0 && !CYTHON_COMPILING_IN_PYPY - #define __Pyx_PyObject_GC_IsFinalized(o) PyObject_GC_IsFinalized(o) -#else - #define __Pyx_PyObject_GC_IsFinalized(o) _PyGC_FINALIZED(o) -#endif -#ifndef Py_TPFLAGS_CHECKTYPES - #define Py_TPFLAGS_CHECKTYPES 0 -#endif -#ifndef Py_TPFLAGS_HAVE_INDEX - #define Py_TPFLAGS_HAVE_INDEX 0 -#endif -#ifndef Py_TPFLAGS_HAVE_NEWBUFFER - #define Py_TPFLAGS_HAVE_NEWBUFFER 0 -#endif -#ifndef Py_TPFLAGS_HAVE_FINALIZE - #define Py_TPFLAGS_HAVE_FINALIZE 0 -#endif -#ifndef Py_TPFLAGS_SEQUENCE - #define Py_TPFLAGS_SEQUENCE 0 -#endif -#ifndef Py_TPFLAGS_MAPPING - #define Py_TPFLAGS_MAPPING 0 -#endif -#ifndef METH_STACKLESS - #define METH_STACKLESS 0 -#endif -#ifndef METH_FASTCALL - #ifndef METH_FASTCALL - #define METH_FASTCALL 0x80 - #endif - typedef PyObject *(*__Pyx_PyCFunctionFast) (PyObject *self, PyObject *const *args, Py_ssize_t nargs); - typedef PyObject *(*__Pyx_PyCFunctionFastWithKeywords) (PyObject *self, PyObject *const *args, - Py_ssize_t nargs, PyObject *kwnames); -#else - #if PY_VERSION_HEX >= 0x030d00A4 - # define __Pyx_PyCFunctionFast PyCFunctionFast - # define __Pyx_PyCFunctionFastWithKeywords PyCFunctionFastWithKeywords - #else - # define __Pyx_PyCFunctionFast _PyCFunctionFast - # define __Pyx_PyCFunctionFastWithKeywords _PyCFunctionFastWithKeywords - #endif -#endif -#if CYTHON_METH_FASTCALL - #define __Pyx_METH_FASTCALL METH_FASTCALL - #define __Pyx_PyCFunction_FastCall __Pyx_PyCFunctionFast - #define __Pyx_PyCFunction_FastCallWithKeywords __Pyx_PyCFunctionFastWithKeywords -#else - #define __Pyx_METH_FASTCALL METH_VARARGS - #define __Pyx_PyCFunction_FastCall PyCFunction - #define __Pyx_PyCFunction_FastCallWithKeywords PyCFunctionWithKeywords -#endif -#if CYTHON_VECTORCALL - #define __pyx_vectorcallfunc vectorcallfunc - #define __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET PY_VECTORCALL_ARGUMENTS_OFFSET - #define __Pyx_PyVectorcall_NARGS(n) PyVectorcall_NARGS((size_t)(n)) -#elif CYTHON_BACKPORT_VECTORCALL - typedef PyObject *(*__pyx_vectorcallfunc)(PyObject *callable, PyObject *const *args, - size_t nargsf, PyObject *kwnames); - #define __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET ((size_t)1 << (8 * sizeof(size_t) - 1)) - #define __Pyx_PyVectorcall_NARGS(n) ((Py_ssize_t)(((size_t)(n)) & ~__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)) -#else - #define __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET 0 - #define __Pyx_PyVectorcall_NARGS(n) ((Py_ssize_t)(n)) -#endif -#if PY_VERSION_HEX >= 0x030900B1 -#define __Pyx_PyCFunction_CheckExact(func) PyCFunction_CheckExact(func) -#else -#define __Pyx_PyCFunction_CheckExact(func) PyCFunction_Check(func) -#endif -#define __Pyx_CyOrPyCFunction_Check(func) PyCFunction_Check(func) -#if CYTHON_COMPILING_IN_CPYTHON -#define __Pyx_CyOrPyCFunction_GET_FUNCTION(func) (((PyCFunctionObject*)(func))->m_ml->ml_meth) -#elif !CYTHON_COMPILING_IN_LIMITED_API -#define __Pyx_CyOrPyCFunction_GET_FUNCTION(func) PyCFunction_GET_FUNCTION(func) -#endif -#if CYTHON_COMPILING_IN_CPYTHON -#define __Pyx_CyOrPyCFunction_GET_FLAGS(func) (((PyCFunctionObject*)(func))->m_ml->ml_flags) -static CYTHON_INLINE PyObject* __Pyx_CyOrPyCFunction_GET_SELF(PyObject *func) { - return (__Pyx_CyOrPyCFunction_GET_FLAGS(func) & METH_STATIC) ? NULL : ((PyCFunctionObject*)func)->m_self; -} -#endif -static CYTHON_INLINE int __Pyx__IsSameCFunction(PyObject *func, void (*cfunc)(void)) { -#if CYTHON_COMPILING_IN_LIMITED_API - return PyCFunction_Check(func) && PyCFunction_GetFunction(func) == (PyCFunction) cfunc; -#else - return PyCFunction_Check(func) && PyCFunction_GET_FUNCTION(func) == (PyCFunction) cfunc; -#endif -} -#define __Pyx_IsSameCFunction(func, cfunc) __Pyx__IsSameCFunction(func, cfunc) -#if __PYX_LIMITED_VERSION_HEX < 0x03090000 - #define __Pyx_PyType_FromModuleAndSpec(m, s, b) ((void)m, PyType_FromSpecWithBases(s, b)) - typedef PyObject *(*__Pyx_PyCMethod)(PyObject *, PyTypeObject *, PyObject *const *, size_t, PyObject *); -#else - #define __Pyx_PyType_FromModuleAndSpec(m, s, b) PyType_FromModuleAndSpec(m, s, b) - #define __Pyx_PyCMethod PyCMethod -#endif -#ifndef METH_METHOD - #define METH_METHOD 0x200 -#endif -#if CYTHON_COMPILING_IN_PYPY && !defined(PyObject_Malloc) - #define PyObject_Malloc(s) PyMem_Malloc(s) - #define PyObject_Free(p) PyMem_Free(p) - #define PyObject_Realloc(p) PyMem_Realloc(p) -#endif -#if CYTHON_COMPILING_IN_LIMITED_API - #define __Pyx_PyFrame_SetLineNumber(frame, lineno) -#elif CYTHON_COMPILING_IN_GRAAL - #define __Pyx_PyCode_HasFreeVars(co) (PyCode_GetNumFree(co) > 0) - #define __Pyx_PyFrame_SetLineNumber(frame, lineno) _PyFrame_SetLineNumber((frame), (lineno)) -#else - #define __Pyx_PyCode_HasFreeVars(co) (PyCode_GetNumFree(co) > 0) - #define __Pyx_PyFrame_SetLineNumber(frame, lineno) (frame)->f_lineno = (lineno) -#endif -#if CYTHON_COMPILING_IN_LIMITED_API - #define __Pyx_PyThreadState_Current PyThreadState_Get() -#elif !CYTHON_FAST_THREAD_STATE - #define __Pyx_PyThreadState_Current PyThreadState_GET() -#elif PY_VERSION_HEX >= 0x030d00A1 - #define __Pyx_PyThreadState_Current PyThreadState_GetUnchecked() -#else - #define __Pyx_PyThreadState_Current _PyThreadState_UncheckedGet() -#endif -#if CYTHON_USE_MODULE_STATE -static CYTHON_INLINE void *__Pyx__PyModule_GetState(PyObject *op) -{ - void *result; - result = PyModule_GetState(op); - if (!result) - Py_FatalError("Couldn't find the module state"); - return result; -} -#define __Pyx_PyModule_GetState(o) (__pyx_mstatetype *)__Pyx__PyModule_GetState(o) -#else -#define __Pyx_PyModule_GetState(op) ((void)op,__pyx_mstate_global) -#endif -#define __Pyx_PyObject_GetSlot(obj, name, func_ctype) __Pyx_PyType_GetSlot(Py_TYPE((PyObject *) obj), name, func_ctype) -#define __Pyx_PyObject_TryGetSlot(obj, name, func_ctype) __Pyx_PyType_TryGetSlot(Py_TYPE(obj), name, func_ctype) -#define __Pyx_PyObject_GetSubSlot(obj, sub, name, func_ctype) __Pyx_PyType_GetSubSlot(Py_TYPE(obj), sub, name, func_ctype) -#define __Pyx_PyObject_TryGetSubSlot(obj, sub, name, func_ctype) __Pyx_PyType_TryGetSubSlot(Py_TYPE(obj), sub, name, func_ctype) -#if CYTHON_USE_TYPE_SLOTS - #define __Pyx_PyType_GetSlot(type, name, func_ctype) ((type)->name) - #define __Pyx_PyType_TryGetSlot(type, name, func_ctype) __Pyx_PyType_GetSlot(type, name, func_ctype) - #define __Pyx_PyType_GetSubSlot(type, sub, name, func_ctype) (((type)->sub) ? ((type)->sub->name) : NULL) - #define __Pyx_PyType_TryGetSubSlot(type, sub, name, func_ctype) __Pyx_PyType_GetSubSlot(type, sub, name, func_ctype) -#else - #define __Pyx_PyType_GetSlot(type, name, func_ctype) ((func_ctype) PyType_GetSlot((type), Py_##name)) - #define __Pyx_PyType_TryGetSlot(type, name, func_ctype)\ - ((__PYX_LIMITED_VERSION_HEX >= 0x030A0000 ||\ - (PyType_GetFlags(type) & Py_TPFLAGS_HEAPTYPE) || __Pyx_get_runtime_version() >= 0x030A0000) ?\ - __Pyx_PyType_GetSlot(type, name, func_ctype) : NULL) - #define __Pyx_PyType_GetSubSlot(obj, sub, name, func_ctype) __Pyx_PyType_GetSlot(obj, name, func_ctype) - #define __Pyx_PyType_TryGetSubSlot(obj, sub, name, func_ctype) __Pyx_PyType_TryGetSlot(obj, name, func_ctype) -#endif -#if CYTHON_COMPILING_IN_CPYTHON || defined(_PyDict_NewPresized) -#define __Pyx_PyDict_NewPresized(n) ((n <= 8) ? PyDict_New() : _PyDict_NewPresized(n)) -#else -#define __Pyx_PyDict_NewPresized(n) PyDict_New() -#endif -#define __Pyx_PyNumber_Divide(x,y) PyNumber_TrueDivide(x,y) -#define __Pyx_PyNumber_InPlaceDivide(x,y) PyNumber_InPlaceTrueDivide(x,y) -#if CYTHON_COMPILING_IN_CPYTHON && CYTHON_USE_UNICODE_INTERNALS -#define __Pyx_PyDict_GetItemStrWithError(dict, name) _PyDict_GetItem_KnownHash(dict, name, ((PyASCIIObject *) name)->hash) -static CYTHON_INLINE PyObject * __Pyx_PyDict_GetItemStr(PyObject *dict, PyObject *name) { - PyObject *res = __Pyx_PyDict_GetItemStrWithError(dict, name); - if (res == NULL) PyErr_Clear(); - return res; -} -#elif !CYTHON_COMPILING_IN_PYPY || PYPY_VERSION_NUM >= 0x07020000 -#define __Pyx_PyDict_GetItemStrWithError PyDict_GetItemWithError -#define __Pyx_PyDict_GetItemStr PyDict_GetItem -#else -static CYTHON_INLINE PyObject * __Pyx_PyDict_GetItemStrWithError(PyObject *dict, PyObject *name) { -#if CYTHON_COMPILING_IN_PYPY - return PyDict_GetItem(dict, name); -#else - PyDictEntry *ep; - PyDictObject *mp = (PyDictObject*) dict; - long hash = ((PyStringObject *) name)->ob_shash; - assert(hash != -1); - ep = (mp->ma_lookup)(mp, name, hash); - if (ep == NULL) { - return NULL; - } - return ep->me_value; -#endif -} -#define __Pyx_PyDict_GetItemStr PyDict_GetItem -#endif -#if CYTHON_USE_TYPE_SLOTS - #define __Pyx_PyType_GetFlags(tp) (((PyTypeObject *)tp)->tp_flags) - #define __Pyx_PyType_HasFeature(type, feature) ((__Pyx_PyType_GetFlags(type) & (feature)) != 0) -#else - #define __Pyx_PyType_GetFlags(tp) (PyType_GetFlags((PyTypeObject *)tp)) - #define __Pyx_PyType_HasFeature(type, feature) PyType_HasFeature(type, feature) -#endif -#define __Pyx_PyObject_GetIterNextFunc(iterator) __Pyx_PyObject_GetSlot(iterator, tp_iternext, iternextfunc) -#if CYTHON_USE_TYPE_SPECS && PY_VERSION_HEX >= 0x03080000 -#define __Pyx_PyHeapTypeObject_GC_Del(obj) {\ - PyTypeObject *type = Py_TYPE((PyObject*)obj);\ - assert(__Pyx_PyType_HasFeature(type, Py_TPFLAGS_HEAPTYPE));\ - PyObject_GC_Del(obj);\ - Py_DECREF(type);\ -} -#else -#define __Pyx_PyHeapTypeObject_GC_Del(obj) PyObject_GC_Del(obj) -#endif -#if CYTHON_COMPILING_IN_LIMITED_API - #define __Pyx_PyUnicode_READY(op) (0) - #define __Pyx_PyUnicode_READ_CHAR(u, i) PyUnicode_ReadChar(u, i) - #define __Pyx_PyUnicode_MAX_CHAR_VALUE(u) ((void)u, 1114111U) - #define __Pyx_PyUnicode_KIND(u) ((void)u, (0)) - #define __Pyx_PyUnicode_DATA(u) ((void*)u) - #define __Pyx_PyUnicode_READ(k, d, i) ((void)k, PyUnicode_ReadChar((PyObject*)(d), i)) - #define __Pyx_PyUnicode_IS_TRUE(u) (0 != PyUnicode_GetLength(u)) -#else - #if PY_VERSION_HEX >= 0x030C0000 - #define __Pyx_PyUnicode_READY(op) (0) - #else - #define __Pyx_PyUnicode_READY(op) (likely(PyUnicode_IS_READY(op)) ?\ - 0 : _PyUnicode_Ready((PyObject *)(op))) - #endif - #define __Pyx_PyUnicode_READ_CHAR(u, i) PyUnicode_READ_CHAR(u, i) - #define __Pyx_PyUnicode_MAX_CHAR_VALUE(u) PyUnicode_MAX_CHAR_VALUE(u) - #define __Pyx_PyUnicode_KIND(u) ((int)PyUnicode_KIND(u)) - #define __Pyx_PyUnicode_DATA(u) PyUnicode_DATA(u) - #define __Pyx_PyUnicode_READ(k, d, i) PyUnicode_READ(k, d, i) - #define __Pyx_PyUnicode_WRITE(k, d, i, ch) PyUnicode_WRITE(k, d, i, (Py_UCS4) ch) - #if PY_VERSION_HEX >= 0x030C0000 - #define __Pyx_PyUnicode_IS_TRUE(u) (0 != PyUnicode_GET_LENGTH(u)) - #else - #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x03090000 - #define __Pyx_PyUnicode_IS_TRUE(u) (0 != (likely(PyUnicode_IS_READY(u)) ? PyUnicode_GET_LENGTH(u) : ((PyCompactUnicodeObject *)(u))->wstr_length)) - #else - #define __Pyx_PyUnicode_IS_TRUE(u) (0 != (likely(PyUnicode_IS_READY(u)) ? PyUnicode_GET_LENGTH(u) : PyUnicode_GET_SIZE(u))) - #endif - #endif -#endif -#if CYTHON_COMPILING_IN_PYPY - #define __Pyx_PyUnicode_Concat(a, b) PyNumber_Add(a, b) - #define __Pyx_PyUnicode_ConcatSafe(a, b) PyNumber_Add(a, b) -#else - #define __Pyx_PyUnicode_Concat(a, b) PyUnicode_Concat(a, b) - #define __Pyx_PyUnicode_ConcatSafe(a, b) ((unlikely((a) == Py_None) || unlikely((b) == Py_None)) ?\ - PyNumber_Add(a, b) : __Pyx_PyUnicode_Concat(a, b)) -#endif -#if CYTHON_COMPILING_IN_PYPY - #if !defined(PyUnicode_DecodeUnicodeEscape) - #define PyUnicode_DecodeUnicodeEscape(s, size, errors) PyUnicode_Decode(s, size, "unicode_escape", errors) - #endif - #if !defined(PyUnicode_Contains) - #define PyUnicode_Contains(u, s) PySequence_Contains(u, s) - #endif - #if !defined(PyByteArray_Check) - #define PyByteArray_Check(obj) PyObject_TypeCheck(obj, &PyByteArray_Type) - #endif - #if !defined(PyObject_Format) - #define PyObject_Format(obj, fmt) PyObject_CallMethod(obj, "__format__", "O", fmt) - #endif -#endif -#define __Pyx_PyUnicode_FormatSafe(a, b) ((unlikely((a) == Py_None || (PyUnicode_Check(b) && !PyUnicode_CheckExact(b)))) ? PyNumber_Remainder(a, b) : PyUnicode_Format(a, b)) -#if CYTHON_COMPILING_IN_CPYTHON - #define __Pyx_PySequence_ListKeepNew(obj)\ - (likely(PyList_CheckExact(obj) && Py_REFCNT(obj) == 1) ? __Pyx_NewRef(obj) : PySequence_List(obj)) -#else - #define __Pyx_PySequence_ListKeepNew(obj) PySequence_List(obj) -#endif -#ifndef PySet_CheckExact - #define PySet_CheckExact(obj) __Pyx_IS_TYPE(obj, &PySet_Type) -#endif -#if PY_VERSION_HEX >= 0x030900A4 - #define __Pyx_SET_REFCNT(obj, refcnt) Py_SET_REFCNT(obj, refcnt) - #define __Pyx_SET_SIZE(obj, size) Py_SET_SIZE(obj, size) -#else - #define __Pyx_SET_REFCNT(obj, refcnt) Py_REFCNT(obj) = (refcnt) - #define __Pyx_SET_SIZE(obj, size) Py_SIZE(obj) = (size) -#endif -#if CYTHON_COMPILING_IN_LIMITED_API || CYTHON_AVOID_BORROWED_REFS || CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS || !CYTHON_ASSUME_SAFE_MACROS - #if __PYX_LIMITED_VERSION_HEX >= 0x030d0000 - #define __Pyx_PyList_GetItemRef(o, i) PyList_GetItemRef(o, i) - #else - #define __Pyx_PyList_GetItemRef(o, i) PySequence_GetItem(o, i) - #endif -#else - #define __Pyx_PyList_GetItemRef(o, i) __Pyx_NewRef(PyList_GET_ITEM(o, i)) -#endif -#if __PYX_LIMITED_VERSION_HEX >= 0x030d0000 -#define __Pyx_PyDict_GetItemRef(dict, key, result) PyDict_GetItemRef(dict, key, result) -#elif CYTHON_AVOID_BORROWED_REFS || CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS -static CYTHON_INLINE int __Pyx_PyDict_GetItemRef(PyObject *dict, PyObject *key, PyObject **result) { - *result = PyObject_GetItem(dict, key); - if (*result == NULL) { - if (PyErr_ExceptionMatches(PyExc_KeyError)) { - PyErr_Clear(); - return 0; - } - return -1; - } - return 1; -} -#else -static CYTHON_INLINE int __Pyx_PyDict_GetItemRef(PyObject *dict, PyObject *key, PyObject **result) { - *result = PyDict_GetItemWithError(dict, key); - if (*result == NULL) { - return PyErr_Occurred() ? -1 : 0; - } - Py_INCREF(*result); - return 1; -} -#endif -#if defined(CYTHON_DEBUG_VISIT_CONST) && CYTHON_DEBUG_VISIT_CONST - #define __Pyx_VISIT_CONST(obj) Py_VISIT(obj) -#else - #define __Pyx_VISIT_CONST(obj) -#endif -#if CYTHON_ASSUME_SAFE_MACROS - #define __Pyx_PySequence_ITEM(o, i) PySequence_ITEM(o, i) - #define __Pyx_PySequence_SIZE(seq) Py_SIZE(seq) - #define __Pyx_PyTuple_SET_ITEM(o, i, v) (PyTuple_SET_ITEM(o, i, v), (0)) - #define __Pyx_PyTuple_GET_ITEM(o, i) PyTuple_GET_ITEM(o, i) - #define __Pyx_PyList_SET_ITEM(o, i, v) (PyList_SET_ITEM(o, i, v), (0)) - #define __Pyx_PyList_GET_ITEM(o, i) PyList_GET_ITEM(o, i) -#else - #define __Pyx_PySequence_ITEM(o, i) PySequence_GetItem(o, i) - #define __Pyx_PySequence_SIZE(seq) PySequence_Size(seq) - #define __Pyx_PyTuple_SET_ITEM(o, i, v) PyTuple_SetItem(o, i, v) - #define __Pyx_PyTuple_GET_ITEM(o, i) PyTuple_GetItem(o, i) - #define __Pyx_PyList_SET_ITEM(o, i, v) PyList_SetItem(o, i, v) - #define __Pyx_PyList_GET_ITEM(o, i) PyList_GetItem(o, i) -#endif -#if CYTHON_ASSUME_SAFE_SIZE - #define __Pyx_PyTuple_GET_SIZE(o) PyTuple_GET_SIZE(o) - #define __Pyx_PyList_GET_SIZE(o) PyList_GET_SIZE(o) - #define __Pyx_PySet_GET_SIZE(o) PySet_GET_SIZE(o) - #define __Pyx_PyBytes_GET_SIZE(o) PyBytes_GET_SIZE(o) - #define __Pyx_PyByteArray_GET_SIZE(o) PyByteArray_GET_SIZE(o) - #define __Pyx_PyUnicode_GET_LENGTH(o) PyUnicode_GET_LENGTH(o) -#else - #define __Pyx_PyTuple_GET_SIZE(o) PyTuple_Size(o) - #define __Pyx_PyList_GET_SIZE(o) PyList_Size(o) - #define __Pyx_PySet_GET_SIZE(o) PySet_Size(o) - #define __Pyx_PyBytes_GET_SIZE(o) PyBytes_Size(o) - #define __Pyx_PyByteArray_GET_SIZE(o) PyByteArray_Size(o) - #define __Pyx_PyUnicode_GET_LENGTH(o) PyUnicode_GetLength(o) -#endif -#if __PYX_LIMITED_VERSION_HEX >= 0x030d0000 - #define __Pyx_PyImport_AddModuleRef(name) PyImport_AddModuleRef(name) -#else - static CYTHON_INLINE PyObject *__Pyx_PyImport_AddModuleRef(const char *name) { - PyObject *module = PyImport_AddModule(name); - Py_XINCREF(module); - return module; - } -#endif -#if CYTHON_COMPILING_IN_PYPY && !defined(PyUnicode_InternFromString) - #define PyUnicode_InternFromString(s) PyUnicode_FromString(s) -#endif -#define __Pyx_PyLong_FromHash_t PyLong_FromSsize_t -#define __Pyx_PyLong_AsHash_t __Pyx_PyIndex_AsSsize_t -#if __PYX_LIMITED_VERSION_HEX >= 0x030A0000 - #define __Pyx_PySendResult PySendResult -#else - typedef enum { - PYGEN_RETURN = 0, - PYGEN_ERROR = -1, - PYGEN_NEXT = 1, - } __Pyx_PySendResult; -#endif -#if CYTHON_COMPILING_IN_LIMITED_API || PY_VERSION_HEX < 0x030A00A3 - typedef __Pyx_PySendResult (*__Pyx_pyiter_sendfunc)(PyObject *iter, PyObject *value, PyObject **result); -#else - #define __Pyx_pyiter_sendfunc sendfunc -#endif -#if !CYTHON_USE_AM_SEND -#define __PYX_HAS_PY_AM_SEND 0 -#elif __PYX_LIMITED_VERSION_HEX >= 0x030A0000 -#define __PYX_HAS_PY_AM_SEND 1 -#else -#define __PYX_HAS_PY_AM_SEND 2 // our own backported implementation -#endif -#if __PYX_HAS_PY_AM_SEND < 2 - #define __Pyx_PyAsyncMethodsStruct PyAsyncMethods -#else - typedef struct { - unaryfunc am_await; - unaryfunc am_aiter; - unaryfunc am_anext; - __Pyx_pyiter_sendfunc am_send; - } __Pyx_PyAsyncMethodsStruct; - #define __Pyx_SlotTpAsAsync(s) ((PyAsyncMethods*)(s)) -#endif -#if CYTHON_USE_AM_SEND && PY_VERSION_HEX < 0x030A00F0 - #define __Pyx_TPFLAGS_HAVE_AM_SEND (1UL << 21) -#else - #define __Pyx_TPFLAGS_HAVE_AM_SEND (0) -#endif -#if PY_VERSION_HEX >= 0x03090000 -#define __Pyx_PyInterpreterState_Get() PyInterpreterState_Get() -#else -#define __Pyx_PyInterpreterState_Get() PyThreadState_Get()->interp -#endif -#if CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX < 0x030A0000 -#ifdef __cplusplus -extern "C" -#endif -PyAPI_FUNC(void *) PyMem_Calloc(size_t nelem, size_t elsize); -#endif -#if CYTHON_COMPILING_IN_LIMITED_API -static int __Pyx_init_co_variable(PyObject *inspect, const char* name, int *write_to) { - int value; - PyObject *py_value = PyObject_GetAttrString(inspect, name); - if (!py_value) return 0; - value = (int) PyLong_AsLong(py_value); - Py_DECREF(py_value); - *write_to = value; - return value != -1 || !PyErr_Occurred(); -} -static int __Pyx_init_co_variables(void) { - PyObject *inspect; - int result; - inspect = PyImport_ImportModule("inspect"); - result = -#if !defined(CO_OPTIMIZED) - __Pyx_init_co_variable(inspect, "CO_OPTIMIZED", &CO_OPTIMIZED) && -#endif -#if !defined(CO_NEWLOCALS) - __Pyx_init_co_variable(inspect, "CO_NEWLOCALS", &CO_NEWLOCALS) && -#endif -#if !defined(CO_VARARGS) - __Pyx_init_co_variable(inspect, "CO_VARARGS", &CO_VARARGS) && -#endif -#if !defined(CO_VARKEYWORDS) - __Pyx_init_co_variable(inspect, "CO_VARKEYWORDS", &CO_VARKEYWORDS) && -#endif -#if !defined(CO_ASYNC_GENERATOR) - __Pyx_init_co_variable(inspect, "CO_ASYNC_GENERATOR", &CO_ASYNC_GENERATOR) && -#endif -#if !defined(CO_GENERATOR) - __Pyx_init_co_variable(inspect, "CO_GENERATOR", &CO_GENERATOR) && -#endif -#if !defined(CO_COROUTINE) - __Pyx_init_co_variable(inspect, "CO_COROUTINE", &CO_COROUTINE) && -#endif - 1; - Py_DECREF(inspect); - return result ? 0 : -1; -} -#else -static int __Pyx_init_co_variables(void) { - return 0; // It's a limited API-only feature -} -#endif - -/* MathInitCode */ -#if defined(_WIN32) || defined(WIN32) || defined(MS_WINDOWS) - #ifndef _USE_MATH_DEFINES - #define _USE_MATH_DEFINES - #endif -#endif -#include -#ifdef NAN -#define __PYX_NAN() ((float) NAN) -#else -static CYTHON_INLINE float __PYX_NAN() { - float value; - memset(&value, 0xFF, sizeof(value)); - return value; -} -#endif -#if defined(__CYGWIN__) && defined(_LDBL_EQ_DBL) -#define __Pyx_truncl trunc -#else -#define __Pyx_truncl truncl -#endif - -#ifndef CYTHON_CLINE_IN_TRACEBACK_RUNTIME -#define CYTHON_CLINE_IN_TRACEBACK_RUNTIME 0 -#endif -#ifndef CYTHON_CLINE_IN_TRACEBACK -#define CYTHON_CLINE_IN_TRACEBACK CYTHON_CLINE_IN_TRACEBACK_RUNTIME -#endif -#if CYTHON_CLINE_IN_TRACEBACK -#define __PYX_MARK_ERR_POS(f_index, lineno) { __pyx_filename = __pyx_f[f_index]; (void) __pyx_filename; __pyx_lineno = lineno; (void) __pyx_lineno; __pyx_clineno = __LINE__; (void) __pyx_clineno; } -#else -#define __PYX_MARK_ERR_POS(f_index, lineno) { __pyx_filename = __pyx_f[f_index]; (void) __pyx_filename; __pyx_lineno = lineno; (void) __pyx_lineno; (void) __pyx_clineno; } -#endif -#define __PYX_ERR(f_index, lineno, Ln_error) \ - { __PYX_MARK_ERR_POS(f_index, lineno) goto Ln_error; } - -#ifdef CYTHON_EXTERN_C - #undef __PYX_EXTERN_C - #define __PYX_EXTERN_C CYTHON_EXTERN_C -#elif defined(__PYX_EXTERN_C) - #ifdef _MSC_VER - #pragma message ("Please do not define the '__PYX_EXTERN_C' macro externally. Use 'CYTHON_EXTERN_C' instead.") - #else - #warning Please do not define the '__PYX_EXTERN_C' macro externally. Use 'CYTHON_EXTERN_C' instead. - #endif -#else - #ifdef __cplusplus - #define __PYX_EXTERN_C extern "C" - #else - #define __PYX_EXTERN_C extern - #endif -#endif - -#define __PYX_HAVE__epanet -#define __PYX_HAVE_API__epanet -/* Early includes */ -#ifdef _OPENMP -#include -#endif /* _OPENMP */ - -#if defined(PYREX_WITHOUT_ASSERTIONS) && !defined(CYTHON_WITHOUT_ASSERTIONS) -#define CYTHON_WITHOUT_ASSERTIONS -#endif - -#define __PYX_DEFAULT_STRING_ENCODING_IS_ASCII 0 -#define __PYX_DEFAULT_STRING_ENCODING_IS_UTF8 0 -#define __PYX_DEFAULT_STRING_ENCODING "" -#define __Pyx_PyObject_FromString __Pyx_PyBytes_FromString -#define __Pyx_PyObject_FromStringAndSize __Pyx_PyBytes_FromStringAndSize -#define __Pyx_uchar_cast(c) ((unsigned char)c) -#define __Pyx_long_cast(x) ((long)x) -#define __Pyx_fits_Py_ssize_t(v, type, is_signed) (\ - (sizeof(type) < sizeof(Py_ssize_t)) ||\ - (sizeof(type) > sizeof(Py_ssize_t) &&\ - likely(v < (type)PY_SSIZE_T_MAX ||\ - v == (type)PY_SSIZE_T_MAX) &&\ - (!is_signed || likely(v > (type)PY_SSIZE_T_MIN ||\ - v == (type)PY_SSIZE_T_MIN))) ||\ - (sizeof(type) == sizeof(Py_ssize_t) &&\ - (is_signed || likely(v < (type)PY_SSIZE_T_MAX ||\ - v == (type)PY_SSIZE_T_MAX))) ) -static CYTHON_INLINE int __Pyx_is_valid_index(Py_ssize_t i, Py_ssize_t limit) { - return (size_t) i < (size_t) limit; -} -#if defined (__cplusplus) && __cplusplus >= 201103L - #include - #define __Pyx_sst_abs(value) std::abs(value) -#elif SIZEOF_INT >= SIZEOF_SIZE_T - #define __Pyx_sst_abs(value) abs(value) -#elif SIZEOF_LONG >= SIZEOF_SIZE_T - #define __Pyx_sst_abs(value) labs(value) -#elif defined (_MSC_VER) - #define __Pyx_sst_abs(value) ((Py_ssize_t)_abs64(value)) -#elif defined (__STDC_VERSION__) && __STDC_VERSION__ >= 199901L - #define __Pyx_sst_abs(value) llabs(value) -#elif defined (__GNUC__) - #define __Pyx_sst_abs(value) __builtin_llabs(value) -#else - #define __Pyx_sst_abs(value) ((value<0) ? -value : value) -#endif -static CYTHON_INLINE Py_ssize_t __Pyx_ssize_strlen(const char *s); -static CYTHON_INLINE const char* __Pyx_PyObject_AsString(PyObject*); -static CYTHON_INLINE const char* __Pyx_PyObject_AsStringAndSize(PyObject*, Py_ssize_t* length); -static CYTHON_INLINE PyObject* __Pyx_PyByteArray_FromString(const char*); -#define __Pyx_PyByteArray_FromStringAndSize(s, l) PyByteArray_FromStringAndSize((const char*)s, l) -#define __Pyx_PyBytes_FromString PyBytes_FromString -#define __Pyx_PyBytes_FromStringAndSize PyBytes_FromStringAndSize -static CYTHON_INLINE PyObject* __Pyx_PyUnicode_FromString(const char*); -#if CYTHON_ASSUME_SAFE_MACROS - #define __Pyx_PyBytes_AsWritableString(s) ((char*) PyBytes_AS_STRING(s)) - #define __Pyx_PyBytes_AsWritableSString(s) ((signed char*) PyBytes_AS_STRING(s)) - #define __Pyx_PyBytes_AsWritableUString(s) ((unsigned char*) PyBytes_AS_STRING(s)) - #define __Pyx_PyBytes_AsString(s) ((const char*) PyBytes_AS_STRING(s)) - #define __Pyx_PyBytes_AsSString(s) ((const signed char*) PyBytes_AS_STRING(s)) - #define __Pyx_PyBytes_AsUString(s) ((const unsigned char*) PyBytes_AS_STRING(s)) - #define __Pyx_PyByteArray_AsString(s) PyByteArray_AS_STRING(s) -#else - #define __Pyx_PyBytes_AsWritableString(s) ((char*) PyBytes_AsString(s)) - #define __Pyx_PyBytes_AsWritableSString(s) ((signed char*) PyBytes_AsString(s)) - #define __Pyx_PyBytes_AsWritableUString(s) ((unsigned char*) PyBytes_AsString(s)) - #define __Pyx_PyBytes_AsString(s) ((const char*) PyBytes_AsString(s)) - #define __Pyx_PyBytes_AsSString(s) ((const signed char*) PyBytes_AsString(s)) - #define __Pyx_PyBytes_AsUString(s) ((const unsigned char*) PyBytes_AsString(s)) - #define __Pyx_PyByteArray_AsString(s) PyByteArray_AsString(s) -#endif -#define __Pyx_PyObject_AsWritableString(s) ((char*)(__pyx_uintptr_t) __Pyx_PyObject_AsString(s)) -#define __Pyx_PyObject_AsWritableSString(s) ((signed char*)(__pyx_uintptr_t) __Pyx_PyObject_AsString(s)) -#define __Pyx_PyObject_AsWritableUString(s) ((unsigned char*)(__pyx_uintptr_t) __Pyx_PyObject_AsString(s)) -#define __Pyx_PyObject_AsSString(s) ((const signed char*) __Pyx_PyObject_AsString(s)) -#define __Pyx_PyObject_AsUString(s) ((const unsigned char*) __Pyx_PyObject_AsString(s)) -#define __Pyx_PyObject_FromCString(s) __Pyx_PyObject_FromString((const char*)s) -#define __Pyx_PyBytes_FromCString(s) __Pyx_PyBytes_FromString((const char*)s) -#define __Pyx_PyByteArray_FromCString(s) __Pyx_PyByteArray_FromString((const char*)s) -#define __Pyx_PyUnicode_FromCString(s) __Pyx_PyUnicode_FromString((const char*)s) -#define __Pyx_PyUnicode_FromOrdinal(o) PyUnicode_FromOrdinal((int)o) -#define __Pyx_PyUnicode_AsUnicode PyUnicode_AsUnicode -static CYTHON_INLINE PyObject *__Pyx_NewRef(PyObject *obj) { -#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030a0000 || defined(Py_NewRef) - return Py_NewRef(obj); -#else - Py_INCREF(obj); - return obj; -#endif -} -static CYTHON_INLINE PyObject *__Pyx_XNewRef(PyObject *obj) { -#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030a0000 || defined(Py_XNewRef) - return Py_XNewRef(obj); -#else - Py_XINCREF(obj); - return obj; -#endif -} -static CYTHON_INLINE PyObject *__Pyx_Owned_Py_None(int b); -static CYTHON_INLINE PyObject * __Pyx_PyBool_FromLong(long b); -static CYTHON_INLINE int __Pyx_PyObject_IsTrue(PyObject*); -static CYTHON_INLINE int __Pyx_PyObject_IsTrueAndDecref(PyObject*); -static CYTHON_INLINE PyObject* __Pyx_PyNumber_Long(PyObject* x); -#define __Pyx_PySequence_Tuple(obj)\ - (likely(PyTuple_CheckExact(obj)) ? __Pyx_NewRef(obj) : PySequence_Tuple(obj)) -static CYTHON_INLINE Py_ssize_t __Pyx_PyIndex_AsSsize_t(PyObject*); -static CYTHON_INLINE PyObject * __Pyx_PyLong_FromSize_t(size_t); -static CYTHON_INLINE Py_hash_t __Pyx_PyIndex_AsHash_t(PyObject*); -#if CYTHON_ASSUME_SAFE_MACROS -#define __Pyx_PyFloat_AsDouble(x) (PyFloat_CheckExact(x) ? PyFloat_AS_DOUBLE(x) : PyFloat_AsDouble(x)) -#define __Pyx_PyFloat_AS_DOUBLE(x) PyFloat_AS_DOUBLE(x) -#else -#define __Pyx_PyFloat_AsDouble(x) PyFloat_AsDouble(x) -#define __Pyx_PyFloat_AS_DOUBLE(x) PyFloat_AsDouble(x) -#endif -#define __Pyx_PyFloat_AsFloat(x) ((float) __Pyx_PyFloat_AsDouble(x)) -#define __Pyx_PyNumber_Int(x) (PyLong_CheckExact(x) ? __Pyx_NewRef(x) : PyNumber_Long(x)) -#if CYTHON_USE_PYLONG_INTERNALS - #if PY_VERSION_HEX >= 0x030C00A7 - #ifndef _PyLong_SIGN_MASK - #define _PyLong_SIGN_MASK 3 - #endif - #ifndef _PyLong_NON_SIZE_BITS - #define _PyLong_NON_SIZE_BITS 3 - #endif - #define __Pyx_PyLong_Sign(x) (((PyLongObject*)x)->long_value.lv_tag & _PyLong_SIGN_MASK) - #define __Pyx_PyLong_IsNeg(x) ((__Pyx_PyLong_Sign(x) & 2) != 0) - #define __Pyx_PyLong_IsNonNeg(x) (!__Pyx_PyLong_IsNeg(x)) - #define __Pyx_PyLong_IsZero(x) (__Pyx_PyLong_Sign(x) & 1) - #define __Pyx_PyLong_IsPos(x) (__Pyx_PyLong_Sign(x) == 0) - #define __Pyx_PyLong_CompactValueUnsigned(x) (__Pyx_PyLong_Digits(x)[0]) - #define __Pyx_PyLong_DigitCount(x) ((Py_ssize_t) (((PyLongObject*)x)->long_value.lv_tag >> _PyLong_NON_SIZE_BITS)) - #define __Pyx_PyLong_SignedDigitCount(x)\ - ((1 - (Py_ssize_t) __Pyx_PyLong_Sign(x)) * __Pyx_PyLong_DigitCount(x)) - #if defined(PyUnstable_Long_IsCompact) && defined(PyUnstable_Long_CompactValue) - #define __Pyx_PyLong_IsCompact(x) PyUnstable_Long_IsCompact((PyLongObject*) x) - #define __Pyx_PyLong_CompactValue(x) PyUnstable_Long_CompactValue((PyLongObject*) x) - #else - #define __Pyx_PyLong_IsCompact(x) (((PyLongObject*)x)->long_value.lv_tag < (2 << _PyLong_NON_SIZE_BITS)) - #define __Pyx_PyLong_CompactValue(x) ((1 - (Py_ssize_t) __Pyx_PyLong_Sign(x)) * (Py_ssize_t) __Pyx_PyLong_Digits(x)[0]) - #endif - typedef Py_ssize_t __Pyx_compact_pylong; - typedef size_t __Pyx_compact_upylong; - #else - #define __Pyx_PyLong_IsNeg(x) (Py_SIZE(x) < 0) - #define __Pyx_PyLong_IsNonNeg(x) (Py_SIZE(x) >= 0) - #define __Pyx_PyLong_IsZero(x) (Py_SIZE(x) == 0) - #define __Pyx_PyLong_IsPos(x) (Py_SIZE(x) > 0) - #define __Pyx_PyLong_CompactValueUnsigned(x) ((Py_SIZE(x) == 0) ? 0 : __Pyx_PyLong_Digits(x)[0]) - #define __Pyx_PyLong_DigitCount(x) __Pyx_sst_abs(Py_SIZE(x)) - #define __Pyx_PyLong_SignedDigitCount(x) Py_SIZE(x) - #define __Pyx_PyLong_IsCompact(x) (Py_SIZE(x) == 0 || Py_SIZE(x) == 1 || Py_SIZE(x) == -1) - #define __Pyx_PyLong_CompactValue(x)\ - ((Py_SIZE(x) == 0) ? (sdigit) 0 : ((Py_SIZE(x) < 0) ? -(sdigit)__Pyx_PyLong_Digits(x)[0] : (sdigit)__Pyx_PyLong_Digits(x)[0])) - typedef sdigit __Pyx_compact_pylong; - typedef digit __Pyx_compact_upylong; - #endif - #if PY_VERSION_HEX >= 0x030C00A5 - #define __Pyx_PyLong_Digits(x) (((PyLongObject*)x)->long_value.ob_digit) - #else - #define __Pyx_PyLong_Digits(x) (((PyLongObject*)x)->ob_digit) - #endif -#endif -#if __PYX_DEFAULT_STRING_ENCODING_IS_UTF8 - #define __Pyx_PyUnicode_FromStringAndSize(c_str, size) PyUnicode_DecodeUTF8(c_str, size, NULL) -#elif __PYX_DEFAULT_STRING_ENCODING_IS_ASCII - #define __Pyx_PyUnicode_FromStringAndSize(c_str, size) PyUnicode_DecodeASCII(c_str, size, NULL) -#else - #define __Pyx_PyUnicode_FromStringAndSize(c_str, size) PyUnicode_Decode(c_str, size, __PYX_DEFAULT_STRING_ENCODING, NULL) -#endif - - -/* Test for GCC > 2.95 */ -#if defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95))) - #define likely(x) __builtin_expect(!!(x), 1) - #define unlikely(x) __builtin_expect(!!(x), 0) -#else /* !__GNUC__ or GCC < 2.95 */ - #define likely(x) (x) - #define unlikely(x) (x) -#endif /* __GNUC__ */ -/* PretendToInitialize */ -#ifdef __cplusplus -#include -template -static void __Pyx_pretend_to_initialize(T* ptr) { -#if __cplusplus > 201103L - if ((std::is_trivially_default_constructible::value)) -#endif - *ptr = T(); - (void)ptr; -} -#else -static CYTHON_INLINE void __Pyx_pretend_to_initialize(void* ptr) { (void)ptr; } -#endif - - -#if !CYTHON_USE_MODULE_STATE -static PyObject *__pyx_m = NULL; -#endif -static int __pyx_lineno; -static int __pyx_clineno = 0; -static const char * const __pyx_cfilenm = __FILE__; -static const char *__pyx_filename; - -/* #### Code section: filename_table ### */ - -static const char* const __pyx_f[] = { - "epanet/__init__.py", -}; -/* #### Code section: utility_code_proto_before_types ### */ -/* CriticalSections.proto */ -#if !CYTHON_COMPILING_IN_CPYTHON_FREETHREADING -#define __Pyx_PyCriticalSection void* -#define __Pyx_PyCriticalSection2 void* -#define __Pyx_PyCriticalSection_Begin1(cs, arg) (void)cs -#define __Pyx_PyCriticalSection_Begin2(cs, arg1, arg2) (void)cs -#define __Pyx_PyCriticalSection_End1(cs) -#define __Pyx_PyCriticalSection_End2(cs) -#else -#define __Pyx_PyCriticalSection PyCriticalSection -#define __Pyx_PyCriticalSection2 PyCriticalSection2 -#define __Pyx_PyCriticalSection_Begin1 PyCriticalSection_Begin -#define __Pyx_PyCriticalSection_Begin2 PyCriticalSection2_Begin -#define __Pyx_PyCriticalSection_End1 PyCriticalSection_End -#define __Pyx_PyCriticalSection_End2 PyCriticalSection2_End -#endif -#if PY_VERSION_HEX < 0x030d0000 || CYTHON_COMPILING_IN_LIMITED_API -#define __Pyx_BEGIN_CRITICAL_SECTION(o) { -#define __Pyx_END_CRITICAL_SECTION() } -#else -#define __Pyx_BEGIN_CRITICAL_SECTION Py_BEGIN_CRITICAL_SECTION -#define __Pyx_END_CRITICAL_SECTION Py_END_CRITICAL_SECTION -#endif - -/* Atomics.proto */ -#include -#ifndef CYTHON_ATOMICS - #define CYTHON_ATOMICS 1 -#endif -#define __PYX_CYTHON_ATOMICS_ENABLED() CYTHON_ATOMICS -#define __PYX_GET_CYTHON_COMPILING_IN_CPYTHON_FREETHREADING() CYTHON_COMPILING_IN_CPYTHON_FREETHREADING -#define __pyx_atomic_int_type int -#define __pyx_nonatomic_int_type int -#if CYTHON_ATOMICS && (defined(__STDC_VERSION__) &&\ - (__STDC_VERSION__ >= 201112L) &&\ - !defined(__STDC_NO_ATOMICS__)) - #include -#elif CYTHON_ATOMICS && (defined(__cplusplus) && (\ - (__cplusplus >= 201103L) ||\ - (defined(_MSC_VER) && _MSC_VER >= 1700))) - #include -#endif -#if CYTHON_ATOMICS && (defined(__STDC_VERSION__) &&\ - (__STDC_VERSION__ >= 201112L) &&\ - !defined(__STDC_NO_ATOMICS__) &&\ - ATOMIC_INT_LOCK_FREE == 2) - #undef __pyx_atomic_int_type - #define __pyx_atomic_int_type atomic_int - #define __pyx_atomic_ptr_type atomic_uintptr_t - #define __pyx_nonatomic_ptr_type uintptr_t - #define __pyx_atomic_incr_relaxed(value) atomic_fetch_add_explicit(value, 1, memory_order_relaxed) - #define __pyx_atomic_incr_acq_rel(value) atomic_fetch_add_explicit(value, 1, memory_order_acq_rel) - #define __pyx_atomic_decr_acq_rel(value) atomic_fetch_sub_explicit(value, 1, memory_order_acq_rel) - #define __pyx_atomic_sub(value, arg) atomic_fetch_sub(value, arg) - #define __pyx_atomic_int_cmp_exchange(value, expected, desired) atomic_compare_exchange_strong(value, expected, desired) - #define __pyx_atomic_load(value) atomic_load(value) - #define __pyx_atomic_store(value, new_value) atomic_store(value, new_value) - #define __pyx_atomic_pointer_load_relaxed(value) atomic_load_explicit(value, memory_order_relaxed) - #define __pyx_atomic_pointer_load_acquire(value) atomic_load_explicit(value, memory_order_acquire) - #define __pyx_atomic_pointer_exchange(value, new_value) atomic_exchange(value, (__pyx_nonatomic_ptr_type)new_value) - #if defined(__PYX_DEBUG_ATOMICS) && defined(_MSC_VER) - #pragma message ("Using standard C atomics") - #elif defined(__PYX_DEBUG_ATOMICS) - #warning "Using standard C atomics" - #endif -#elif CYTHON_ATOMICS && (defined(__cplusplus) && (\ - (__cplusplus >= 201103L) ||\ -\ - (defined(_MSC_VER) && _MSC_VER >= 1700)) &&\ - ATOMIC_INT_LOCK_FREE == 2) - #undef __pyx_atomic_int_type - #define __pyx_atomic_int_type std::atomic_int - #define __pyx_atomic_ptr_type std::atomic_uintptr_t - #define __pyx_nonatomic_ptr_type uintptr_t - #define __pyx_atomic_incr_relaxed(value) std::atomic_fetch_add_explicit(value, 1, std::memory_order_relaxed) - #define __pyx_atomic_incr_acq_rel(value) std::atomic_fetch_add_explicit(value, 1, std::memory_order_acq_rel) - #define __pyx_atomic_decr_acq_rel(value) std::atomic_fetch_sub_explicit(value, 1, std::memory_order_acq_rel) - #define __pyx_atomic_sub(value, arg) std::atomic_fetch_sub(value, arg) - #define __pyx_atomic_int_cmp_exchange(value, expected, desired) std::atomic_compare_exchange_strong(value, expected, desired) - #define __pyx_atomic_load(value) std::atomic_load(value) - #define __pyx_atomic_store(value, new_value) std::atomic_store(value, new_value) - #define __pyx_atomic_pointer_load_relaxed(value) std::atomic_load_explicit(value, std::memory_order_relaxed) - #define __pyx_atomic_pointer_load_acquire(value) std::atomic_load_explicit(value, std::memory_order_acquire) - #define __pyx_atomic_pointer_exchange(value, new_value) std::atomic_exchange(value, (__pyx_nonatomic_ptr_type)new_value) - #if defined(__PYX_DEBUG_ATOMICS) && defined(_MSC_VER) - #pragma message ("Using standard C++ atomics") - #elif defined(__PYX_DEBUG_ATOMICS) - #warning "Using standard C++ atomics" - #endif -#elif CYTHON_ATOMICS && (__GNUC__ >= 5 || (__GNUC__ == 4 &&\ - (__GNUC_MINOR__ > 1 ||\ - (__GNUC_MINOR__ == 1 && __GNUC_PATCHLEVEL__ >= 2)))) - #define __pyx_atomic_ptr_type void* - #define __pyx_atomic_incr_relaxed(value) __sync_fetch_and_add(value, 1) - #define __pyx_atomic_incr_acq_rel(value) __sync_fetch_and_add(value, 1) - #define __pyx_atomic_decr_acq_rel(value) __sync_fetch_and_sub(value, 1) - #define __pyx_atomic_sub(value, arg) __sync_fetch_and_sub(value, arg) - static CYTHON_INLINE int __pyx_atomic_int_cmp_exchange(__pyx_atomic_int_type* value, __pyx_nonatomic_int_type* expected, __pyx_nonatomic_int_type desired) { - __pyx_nonatomic_int_type old = __sync_val_compare_and_swap(value, *expected, desired); - int result = old == *expected; - *expected = old; - return result; - } - #define __pyx_atomic_load(value) __sync_fetch_and_add(value, 0) - #define __pyx_atomic_store(value, new_value) __sync_lock_test_and_set(value, new_value) - #define __pyx_atomic_pointer_load_relaxed(value) __sync_fetch_and_add(value, 0) - #define __pyx_atomic_pointer_load_acquire(value) __sync_fetch_and_add(value, 0) - #define __pyx_atomic_pointer_exchange(value, new_value) __sync_lock_test_and_set(value, (__pyx_atomic_ptr_type)new_value) - #ifdef __PYX_DEBUG_ATOMICS - #warning "Using GNU atomics" - #endif -#elif CYTHON_ATOMICS && defined(_MSC_VER) - #include - #undef __pyx_atomic_int_type - #define __pyx_atomic_int_type long - #define __pyx_atomic_ptr_type void* - #undef __pyx_nonatomic_int_type - #define __pyx_nonatomic_int_type long - #pragma intrinsic (_InterlockedExchangeAdd, _InterlockedExchange, _InterlockedCompareExchange, _InterlockedCompareExchangePointer, _InterlockedExchangePointer) - #define __pyx_atomic_incr_relaxed(value) _InterlockedExchangeAdd(value, 1) - #define __pyx_atomic_incr_acq_rel(value) _InterlockedExchangeAdd(value, 1) - #define __pyx_atomic_decr_acq_rel(value) _InterlockedExchangeAdd(value, -1) - #define __pyx_atomic_sub(value, arg) _InterlockedExchangeAdd(value, -arg) - static CYTHON_INLINE int __pyx_atomic_int_cmp_exchange(__pyx_atomic_int_type* value, __pyx_nonatomic_int_type* expected, __pyx_nonatomic_int_type desired) { - __pyx_nonatomic_int_type old = _InterlockedCompareExchange(value, desired, *expected); - int result = old == *expected; - *expected = old; - return result; - } - #define __pyx_atomic_load(value) _InterlockedExchangeAdd(value, 0) - #define __pyx_atomic_store(value, new_value) _InterlockedExchange(value, new_value) - #define __pyx_atomic_pointer_load_relaxed(value) *(void * volatile *)value - #define __pyx_atomic_pointer_load_acquire(value) _InterlockedCompareExchangePointer(value, 0, 0) - #define __pyx_atomic_pointer_exchange(value, new_value) _InterlockedExchangePointer(value, (__pyx_atomic_ptr_type)new_value) - #ifdef __PYX_DEBUG_ATOMICS - #pragma message ("Using MSVC atomics") - #endif -#else - #undef CYTHON_ATOMICS - #define CYTHON_ATOMICS 0 - #ifdef __PYX_DEBUG_ATOMICS - #warning "Not using atomics" - #endif -#endif -#if CYTHON_ATOMICS - #define __pyx_add_acquisition_count(memview)\ - __pyx_atomic_incr_relaxed(__pyx_get_slice_count_pointer(memview)) - #define __pyx_sub_acquisition_count(memview)\ - __pyx_atomic_decr_acq_rel(__pyx_get_slice_count_pointer(memview)) -#else - #define __pyx_add_acquisition_count(memview)\ - __pyx_add_acquisition_count_locked(__pyx_get_slice_count_pointer(memview), memview->lock) - #define __pyx_sub_acquisition_count(memview)\ - __pyx_sub_acquisition_count_locked(__pyx_get_slice_count_pointer(memview), memview->lock) -#endif - -/* #### Code section: numeric_typedefs ### */ -/* #### Code section: complex_type_declarations ### */ -/* #### Code section: type_declarations ### */ - -/*--- Type declarations ---*/ -/* #### Code section: utility_code_proto ### */ - -/* --- Runtime support code (head) --- */ -/* Refnanny.proto */ -#ifndef CYTHON_REFNANNY - #define CYTHON_REFNANNY 0 -#endif -#if CYTHON_REFNANNY - typedef struct { - void (*INCREF)(void*, PyObject*, Py_ssize_t); - void (*DECREF)(void*, PyObject*, Py_ssize_t); - void (*GOTREF)(void*, PyObject*, Py_ssize_t); - void (*GIVEREF)(void*, PyObject*, Py_ssize_t); - void* (*SetupContext)(const char*, Py_ssize_t, const char*); - void (*FinishContext)(void**); - } __Pyx_RefNannyAPIStruct; - static __Pyx_RefNannyAPIStruct *__Pyx_RefNanny = NULL; - static __Pyx_RefNannyAPIStruct *__Pyx_RefNannyImportAPI(const char *modname); - #define __Pyx_RefNannyDeclarations void *__pyx_refnanny = NULL; - #define __Pyx_RefNannySetupContext(name, acquire_gil)\ - if (acquire_gil) {\ - PyGILState_STATE __pyx_gilstate_save = PyGILState_Ensure();\ - __pyx_refnanny = __Pyx_RefNanny->SetupContext((name), (__LINE__), (__FILE__));\ - PyGILState_Release(__pyx_gilstate_save);\ - } else {\ - __pyx_refnanny = __Pyx_RefNanny->SetupContext((name), (__LINE__), (__FILE__));\ - } - #define __Pyx_RefNannyFinishContextNogil() {\ - PyGILState_STATE __pyx_gilstate_save = PyGILState_Ensure();\ - __Pyx_RefNannyFinishContext();\ - PyGILState_Release(__pyx_gilstate_save);\ - } - #define __Pyx_RefNannyFinishContextNogil() {\ - PyGILState_STATE __pyx_gilstate_save = PyGILState_Ensure();\ - __Pyx_RefNannyFinishContext();\ - PyGILState_Release(__pyx_gilstate_save);\ - } - #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); else {__Pyx_INCREF(r); }} while(0) - #define __Pyx_XDECREF(r) do { if((r) == NULL); else {__Pyx_DECREF(r); }} while(0) - #define __Pyx_XGOTREF(r) do { if((r) == NULL); else {__Pyx_GOTREF(r); }} while(0) - #define __Pyx_XGIVEREF(r) do { if((r) == NULL); else {__Pyx_GIVEREF(r);}} while(0) -#else - #define __Pyx_RefNannyDeclarations - #define __Pyx_RefNannySetupContext(name, acquire_gil) - #define __Pyx_RefNannyFinishContextNogil() - #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 -#define __Pyx_Py_XDECREF_SET(r, v) do {\ - PyObject *tmp = (PyObject *) r;\ - r = v; Py_XDECREF(tmp);\ - } while (0) -#define __Pyx_XDECREF_SET(r, v) do {\ - PyObject *tmp = (PyObject *) r;\ - r = v; __Pyx_XDECREF(tmp);\ - } while (0) -#define __Pyx_DECREF_SET(r, v) do {\ - PyObject *tmp = (PyObject *) r;\ - r = v; __Pyx_DECREF(tmp);\ - } while (0) -#define __Pyx_CLEAR(r) do { PyObject* tmp = ((PyObject*)(r)); r = NULL; __Pyx_DECREF(tmp);} while(0) -#define __Pyx_XCLEAR(r) do { if((r) != NULL) {PyObject* tmp = ((PyObject*)(r)); r = NULL; __Pyx_DECREF(tmp);}} while(0) - -/* SetPackagePathFromImportLib.proto */ -#if !CYTHON_PEP489_MULTI_PHASE_INIT -static int __Pyx_SetPackagePathFromImportLib(PyObject *module_name); -#else -#define __Pyx_SetPackagePathFromImportLib(a) 0 -#endif - -/* ListPack.proto */ -static PyObject *__Pyx_PyList_Pack(Py_ssize_t n, ...); - -/* PyObjectGetAttrStr.proto */ -#if CYTHON_USE_TYPE_SLOTS -static CYTHON_INLINE PyObject* __Pyx_PyObject_GetAttrStr(PyObject* obj, PyObject* attr_name); -#else -#define __Pyx_PyObject_GetAttrStr(o,n) PyObject_GetAttr(o,n) -#endif - -/* IncludeStringH.proto */ -#include - -/* Import.proto */ -static PyObject *__Pyx_Import(PyObject *name, PyObject *from_list, int level); - -/* ImportFrom.proto */ -static PyObject* __Pyx_ImportFrom(PyObject* module, PyObject* name); - -/* PyDictVersioning.proto */ -#if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_TYPE_SLOTS -#define __PYX_DICT_VERSION_INIT ((PY_UINT64_T) -1) -#define __PYX_GET_DICT_VERSION(dict) (((PyDictObject*)(dict))->ma_version_tag) -#define __PYX_UPDATE_DICT_CACHE(dict, value, cache_var, version_var)\ - (version_var) = __PYX_GET_DICT_VERSION(dict);\ - (cache_var) = (value); -#define __PYX_PY_DICT_LOOKUP_IF_MODIFIED(VAR, DICT, LOOKUP) {\ - static PY_UINT64_T __pyx_dict_version = 0;\ - static PyObject *__pyx_dict_cached_value = NULL;\ - if (likely(__PYX_GET_DICT_VERSION(DICT) == __pyx_dict_version)) {\ - (VAR) = __pyx_dict_cached_value;\ - } else {\ - (VAR) = __pyx_dict_cached_value = (LOOKUP);\ - __pyx_dict_version = __PYX_GET_DICT_VERSION(DICT);\ - }\ -} -static CYTHON_INLINE PY_UINT64_T __Pyx_get_tp_dict_version(PyObject *obj); -static CYTHON_INLINE PY_UINT64_T __Pyx_get_object_dict_version(PyObject *obj); -static CYTHON_INLINE int __Pyx_object_dict_version_matches(PyObject* obj, PY_UINT64_T tp_dict_version, PY_UINT64_T obj_dict_version); -#else -#define __PYX_GET_DICT_VERSION(dict) (0) -#define __PYX_UPDATE_DICT_CACHE(dict, value, cache_var, version_var) -#define __PYX_PY_DICT_LOOKUP_IF_MODIFIED(VAR, DICT, LOOKUP) (VAR) = (LOOKUP); -#endif - -/* PyErrExceptionMatches.proto */ -#if CYTHON_FAST_THREAD_STATE -#define __Pyx_PyErr_ExceptionMatches(err) __Pyx_PyErr_ExceptionMatchesInState(__pyx_tstate, err) -static CYTHON_INLINE int __Pyx_PyErr_ExceptionMatchesInState(PyThreadState* tstate, PyObject* err); -#else -#define __Pyx_PyErr_ExceptionMatches(err) PyErr_ExceptionMatches(err) -#endif - -/* PyThreadStateGet.proto */ -#if CYTHON_FAST_THREAD_STATE -#define __Pyx_PyThreadState_declare PyThreadState *__pyx_tstate; -#define __Pyx_PyThreadState_assign __pyx_tstate = __Pyx_PyThreadState_Current; -#if PY_VERSION_HEX >= 0x030C00A6 -#define __Pyx_PyErr_Occurred() (__pyx_tstate->current_exception != NULL) -#define __Pyx_PyErr_CurrentExceptionType() (__pyx_tstate->current_exception ? (PyObject*) Py_TYPE(__pyx_tstate->current_exception) : (PyObject*) NULL) -#else -#define __Pyx_PyErr_Occurred() (__pyx_tstate->curexc_type != NULL) -#define __Pyx_PyErr_CurrentExceptionType() (__pyx_tstate->curexc_type) -#endif -#else -#define __Pyx_PyThreadState_declare -#define __Pyx_PyThreadState_assign -#define __Pyx_PyErr_Occurred() (PyErr_Occurred() != NULL) -#define __Pyx_PyErr_CurrentExceptionType() PyErr_Occurred() -#endif - -/* PyErrFetchRestore.proto */ -#if CYTHON_FAST_THREAD_STATE -#define __Pyx_PyErr_Clear() __Pyx_ErrRestore(NULL, NULL, NULL) -#define __Pyx_ErrRestoreWithState(type, value, tb) __Pyx_ErrRestoreInState(PyThreadState_GET(), type, value, tb) -#define __Pyx_ErrFetchWithState(type, value, tb) __Pyx_ErrFetchInState(PyThreadState_GET(), type, value, tb) -#define __Pyx_ErrRestore(type, value, tb) __Pyx_ErrRestoreInState(__pyx_tstate, type, value, tb) -#define __Pyx_ErrFetch(type, value, tb) __Pyx_ErrFetchInState(__pyx_tstate, type, value, tb) -static CYTHON_INLINE void __Pyx_ErrRestoreInState(PyThreadState *tstate, PyObject *type, PyObject *value, PyObject *tb); -static CYTHON_INLINE void __Pyx_ErrFetchInState(PyThreadState *tstate, PyObject **type, PyObject **value, PyObject **tb); -#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX < 0x030C00A6 -#define __Pyx_PyErr_SetNone(exc) (Py_INCREF(exc), __Pyx_ErrRestore((exc), NULL, NULL)) -#else -#define __Pyx_PyErr_SetNone(exc) PyErr_SetNone(exc) -#endif -#else -#define __Pyx_PyErr_Clear() PyErr_Clear() -#define __Pyx_PyErr_SetNone(exc) PyErr_SetNone(exc) -#define __Pyx_ErrRestoreWithState(type, value, tb) PyErr_Restore(type, value, tb) -#define __Pyx_ErrFetchWithState(type, value, tb) PyErr_Fetch(type, value, tb) -#define __Pyx_ErrRestoreInState(tstate, type, value, tb) PyErr_Restore(type, value, tb) -#define __Pyx_ErrFetchInState(tstate, type, value, tb) PyErr_Fetch(type, value, tb) -#define __Pyx_ErrRestore(type, value, tb) PyErr_Restore(type, value, tb) -#define __Pyx_ErrFetch(type, value, tb) PyErr_Fetch(type, value, tb) -#endif - -/* PyObjectGetAttrStrNoError.proto */ -static CYTHON_INLINE PyObject* __Pyx_PyObject_GetAttrStrNoError(PyObject* obj, PyObject* attr_name); - -/* CLineInTraceback.proto */ -#if CYTHON_CLINE_IN_TRACEBACK && CYTHON_CLINE_IN_TRACEBACK_RUNTIME -static int __Pyx_CLineForTraceback(PyThreadState *tstate, int c_line); -#else -#define __Pyx_CLineForTraceback(tstate, c_line) (((CYTHON_CLINE_IN_TRACEBACK)) ? c_line : 0) -#endif - -/* CodeObjectCache.proto */ -#if CYTHON_COMPILING_IN_LIMITED_API -typedef PyObject __Pyx_CachedCodeObjectType; -#else -typedef PyCodeObject __Pyx_CachedCodeObjectType; -#endif -typedef struct { - __Pyx_CachedCodeObjectType* code_object; - int code_line; -} __Pyx_CodeObjectCacheEntry; -struct __Pyx_CodeObjectCache { - int count; - int max_count; - __Pyx_CodeObjectCacheEntry* entries; - #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - __pyx_atomic_int_type accessor_count; - #endif -}; -static int __pyx_bisect_code_objects(__Pyx_CodeObjectCacheEntry* entries, int count, int code_line); -static __Pyx_CachedCodeObjectType *__pyx_find_code_object(int code_line); -static void __pyx_insert_code_object(int code_line, __Pyx_CachedCodeObjectType* code_object); - -/* AddTraceback.proto */ -static void __Pyx_AddTraceback(const char *funcname, int c_line, - int py_line, const char *filename); - -/* FormatTypeName.proto */ -#if CYTHON_COMPILING_IN_LIMITED_API -typedef PyObject *__Pyx_TypeName; -#define __Pyx_FMT_TYPENAME "%U" -#define __Pyx_DECREF_TypeName(obj) Py_XDECREF(obj) -#if __PYX_LIMITED_VERSION_HEX >= 0x030d0000 -#define __Pyx_PyType_GetFullyQualifiedName PyType_GetFullyQualifiedName -#else -static __Pyx_TypeName __Pyx_PyType_GetFullyQualifiedName(PyTypeObject* tp); -#endif -#else // !LIMITED_API -typedef const char *__Pyx_TypeName; -#define __Pyx_FMT_TYPENAME "%.200s" -#define __Pyx_PyType_GetFullyQualifiedName(tp) ((tp)->tp_name) -#define __Pyx_DECREF_TypeName(obj) -#endif - -/* GCCDiagnostics.proto */ -#if !defined(__INTEL_COMPILER) && defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 6)) -#define __Pyx_HAS_GCC_DIAGNOSTIC -#endif - -/* PyFunctionFastCall.proto */ -#if CYTHON_FAST_PYCALL -#if !CYTHON_VECTORCALL -#define __Pyx_PyFunction_FastCall(func, args, nargs)\ - __Pyx_PyFunction_FastCallDict((func), (args), (nargs), NULL) -static PyObject *__Pyx_PyFunction_FastCallDict(PyObject *func, PyObject *const *args, Py_ssize_t nargs, PyObject *kwargs); -#endif -#define __Pyx_BUILD_ASSERT_EXPR(cond)\ - (sizeof(char [1 - 2*!(cond)]) - 1) -#ifndef Py_MEMBER_SIZE -#define Py_MEMBER_SIZE(type, member) sizeof(((type *)0)->member) -#endif -#if !CYTHON_VECTORCALL -#if PY_VERSION_HEX >= 0x03080000 - #include "frameobject.h" - #define __Pxy_PyFrame_Initialize_Offsets() - #define __Pyx_PyFrame_GetLocalsplus(frame) ((frame)->f_localsplus) -#else - static size_t __pyx_pyframe_localsplus_offset = 0; - #include "frameobject.h" - #define __Pxy_PyFrame_Initialize_Offsets()\ - ((void)__Pyx_BUILD_ASSERT_EXPR(sizeof(PyFrameObject) == offsetof(PyFrameObject, f_localsplus) + Py_MEMBER_SIZE(PyFrameObject, f_localsplus)),\ - (void)(__pyx_pyframe_localsplus_offset = ((size_t)PyFrame_Type.tp_basicsize) - Py_MEMBER_SIZE(PyFrameObject, f_localsplus))) - #define __Pyx_PyFrame_GetLocalsplus(frame)\ - (assert(__pyx_pyframe_localsplus_offset), (PyObject **)(((char *)(frame)) + __pyx_pyframe_localsplus_offset)) -#endif -#endif -#endif - -/* PyObjectCall.proto */ -#if CYTHON_COMPILING_IN_CPYTHON -static CYTHON_INLINE PyObject* __Pyx_PyObject_Call(PyObject *func, PyObject *arg, PyObject *kw); -#else -#define __Pyx_PyObject_Call(func, arg, kw) PyObject_Call(func, arg, kw) -#endif - -/* PyObjectCallMethO.proto */ -#if CYTHON_COMPILING_IN_CPYTHON -static CYTHON_INLINE PyObject* __Pyx_PyObject_CallMethO(PyObject *func, PyObject *arg); -#endif - -/* PyObjectFastCall.proto */ -#define __Pyx_PyObject_FastCall(func, args, nargs) __Pyx_PyObject_FastCallDict(func, args, (size_t)(nargs), NULL) -static CYTHON_INLINE PyObject* __Pyx_PyObject_FastCallDict(PyObject *func, PyObject * const*args, size_t nargs, PyObject *kwargs); - -/* PyObjectVectorCallKwBuilder.proto */ -CYTHON_UNUSED static int __Pyx_VectorcallBuilder_AddArg_Check(PyObject *key, PyObject *value, PyObject *builder, PyObject **args, int n); -#if CYTHON_VECTORCALL -#if PY_VERSION_HEX >= 0x03090000 -#define __Pyx_Object_Vectorcall_CallFromBuilder PyObject_Vectorcall -#else -#define __Pyx_Object_Vectorcall_CallFromBuilder _PyObject_Vectorcall -#endif -#define __Pyx_MakeVectorcallBuilderKwds(n) PyTuple_New(n) -static int __Pyx_VectorcallBuilder_AddArg(PyObject *key, PyObject *value, PyObject *builder, PyObject **args, int n); -static int __Pyx_VectorcallBuilder_AddArgStr(const char *key, PyObject *value, PyObject *builder, PyObject **args, int n); -#else -#define __Pyx_Object_Vectorcall_CallFromBuilder __Pyx_PyObject_FastCallDict -#define __Pyx_MakeVectorcallBuilderKwds(n) __Pyx_PyDict_NewPresized(n) -#define __Pyx_VectorcallBuilder_AddArg(key, value, builder, args, n) PyDict_SetItem(builder, key, value) -#define __Pyx_VectorcallBuilder_AddArgStr(key, value, builder, args, n) PyDict_SetItemString(builder, key, value) -#endif - -/* CIntToPy.proto */ -static CYTHON_INLINE PyObject* __Pyx_PyLong_From_long(long value); - -/* CIntFromPy.proto */ -static CYTHON_INLINE long __Pyx_PyLong_As_long(PyObject *); - -/* CIntFromPy.proto */ -static CYTHON_INLINE int __Pyx_PyLong_As_int(PyObject *); - -/* FastTypeChecks.proto */ -#if CYTHON_COMPILING_IN_CPYTHON -#define __Pyx_TypeCheck(obj, type) __Pyx_IsSubtype(Py_TYPE(obj), (PyTypeObject *)type) -#define __Pyx_TypeCheck2(obj, type1, type2) __Pyx_IsAnySubtype2(Py_TYPE(obj), (PyTypeObject *)type1, (PyTypeObject *)type2) -static CYTHON_INLINE int __Pyx_IsSubtype(PyTypeObject *a, PyTypeObject *b); -static CYTHON_INLINE int __Pyx_IsAnySubtype2(PyTypeObject *cls, PyTypeObject *a, PyTypeObject *b); -static CYTHON_INLINE int __Pyx_PyErr_GivenExceptionMatches(PyObject *err, PyObject *type); -static CYTHON_INLINE int __Pyx_PyErr_GivenExceptionMatches2(PyObject *err, PyObject *type1, PyObject *type2); -#else -#define __Pyx_TypeCheck(obj, type) PyObject_TypeCheck(obj, (PyTypeObject *)type) -#define __Pyx_TypeCheck2(obj, type1, type2) (PyObject_TypeCheck(obj, (PyTypeObject *)type1) || PyObject_TypeCheck(obj, (PyTypeObject *)type2)) -#define __Pyx_PyErr_GivenExceptionMatches(err, type) PyErr_GivenExceptionMatches(err, type) -static CYTHON_INLINE int __Pyx_PyErr_GivenExceptionMatches2(PyObject *err, PyObject *type1, PyObject *type2) { - return PyErr_GivenExceptionMatches(err, type1) || PyErr_GivenExceptionMatches(err, type2); -} -#endif -#define __Pyx_PyErr_ExceptionMatches2(err1, err2) __Pyx_PyErr_GivenExceptionMatches2(__Pyx_PyErr_CurrentExceptionType(), err1, err2) -#define __Pyx_PyException_Check(obj) __Pyx_TypeCheck(obj, PyExc_Exception) -#ifdef PyExceptionInstance_Check - #define __Pyx_PyBaseException_Check(obj) PyExceptionInstance_Check(obj) -#else - #define __Pyx_PyBaseException_Check(obj) __Pyx_TypeCheck(obj, PyExc_BaseException) -#endif - -/* GetRuntimeVersion.proto */ -static unsigned long __Pyx_get_runtime_version(void); - -/* CheckBinaryVersion.proto */ -static int __Pyx_check_binary_version(unsigned long ct_version, unsigned long rt_version, int allow_newer); - -/* MultiPhaseInitModuleState.proto */ -#if CYTHON_PEP489_MULTI_PHASE_INIT && CYTHON_USE_MODULE_STATE -static PyObject *__Pyx_State_FindModule(void*); -static int __Pyx_State_AddModule(PyObject* module, void*); -static int __Pyx_State_RemoveModule(void*); -#elif CYTHON_USE_MODULE_STATE -#define __Pyx_State_FindModule PyState_FindModule -#define __Pyx_State_AddModule PyState_AddModule -#define __Pyx_State_RemoveModule PyState_RemoveModule -#endif - -/* #### Code section: module_declarations ### */ -/* CythonABIVersion.proto */ -#if CYTHON_COMPILING_IN_LIMITED_API - #if CYTHON_METH_FASTCALL - #define __PYX_FASTCALL_ABI_SUFFIX "_fastcall" - #else - #define __PYX_FASTCALL_ABI_SUFFIX - #endif - #define __PYX_LIMITED_ABI_SUFFIX "limited" __PYX_FASTCALL_ABI_SUFFIX __PYX_AM_SEND_ABI_SUFFIX -#else - #define __PYX_LIMITED_ABI_SUFFIX -#endif -#if __PYX_HAS_PY_AM_SEND == 1 - #define __PYX_AM_SEND_ABI_SUFFIX -#elif __PYX_HAS_PY_AM_SEND == 2 - #define __PYX_AM_SEND_ABI_SUFFIX "amsendbackport" -#else - #define __PYX_AM_SEND_ABI_SUFFIX "noamsend" -#endif -#ifndef __PYX_MONITORING_ABI_SUFFIX - #define __PYX_MONITORING_ABI_SUFFIX -#endif -#if CYTHON_USE_TP_FINALIZE - #define __PYX_TP_FINALIZE_ABI_SUFFIX -#else - #define __PYX_TP_FINALIZE_ABI_SUFFIX "nofinalize" -#endif -#if CYTHON_USE_FREELISTS || !defined(__Pyx_AsyncGen_USED) - #define __PYX_FREELISTS_ABI_SUFFIX -#else - #define __PYX_FREELISTS_ABI_SUFFIX "nofreelists" -#endif -#define CYTHON_ABI __PYX_ABI_VERSION __PYX_LIMITED_ABI_SUFFIX __PYX_MONITORING_ABI_SUFFIX __PYX_TP_FINALIZE_ABI_SUFFIX __PYX_FREELISTS_ABI_SUFFIX __PYX_AM_SEND_ABI_SUFFIX -#define __PYX_ABI_MODULE_NAME "_cython_" CYTHON_ABI -#define __PYX_TYPE_MODULE_PREFIX __PYX_ABI_MODULE_NAME "." - - -/* Module declarations from "epanet" */ -/* #### Code section: typeinfo ### */ -/* #### Code section: before_global_var ### */ -#define __Pyx_MODULE_NAME "epanet.__init__" -extern int __pyx_module_is_main_epanet____init__; -int __pyx_module_is_main_epanet____init__ = 0; - -/* Implementation of "epanet" */ -/* #### Code section: global_var ### */ -/* #### Code section: string_decls ### */ -static const char __pyx_k_[] = "."; -static const char __pyx_k__2[] = "?"; -static const char __pyx_k_main[] = "__main__"; -static const char __pyx_k_name[] = "__name__"; -static const char __pyx_k_test[] = "__test__"; -static const char __pyx_k_epanet[] = "epanet"; -static const char __pyx_k_module[] = "__module__"; -static const char __pyx_k_run_inp[] = "run_inp"; -static const char __pyx_k_qualname[] = "__qualname__"; -static const char __pyx_k_dump_output[] = "dump_output"; -static const char __pyx_k_run_project[] = "run_project"; -static const char __pyx_k_epanet___init[] = "epanet.__init__"; -static const char __pyx_k_cline_in_traceback[] = "cline_in_traceback"; -static const char __pyx_k_run_project_return_dict[] = "run_project_return_dict"; -/* #### Code section: decls ### */ -/* #### Code section: late_includes ### */ -/* #### Code section: module_state ### */ -/* SmallCodeConfig */ -#ifndef CYTHON_SMALL_CODE -#if defined(__clang__) - #define CYTHON_SMALL_CODE -#elif defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 3)) - #define CYTHON_SMALL_CODE __attribute__((cold)) -#else - #define CYTHON_SMALL_CODE -#endif -#endif - -typedef struct { - PyObject *__pyx_d; - PyObject *__pyx_b; - PyObject *__pyx_cython_runtime; - PyObject *__pyx_empty_tuple; - PyObject *__pyx_empty_bytes; - PyObject *__pyx_empty_unicode; - #ifdef __Pyx_CyFunction_USED - PyTypeObject *__pyx_CyFunctionType; - #endif - #ifdef __Pyx_FusedFunction_USED - PyTypeObject *__pyx_FusedFunctionType; - #endif - #ifdef __Pyx_Generator_USED - PyTypeObject *__pyx_GeneratorType; - #endif - #ifdef __Pyx_IterableCoroutine_USED - PyTypeObject *__pyx_IterableCoroutineType; - #endif - #ifdef __Pyx_Coroutine_USED - PyTypeObject *__pyx_CoroutineAwaitType; - #endif - #ifdef __Pyx_Coroutine_USED - PyTypeObject *__pyx_CoroutineType; - #endif - PyObject *__pyx_string_tab[14]; -/* #### Code section: module_state_contents ### */ -/* CodeObjectCache.module_state_decls */ -struct __Pyx_CodeObjectCache __pyx_code_cache; - -/* #### Code section: module_state_end ### */ -} __pyx_mstatetype; - -#if CYTHON_USE_MODULE_STATE -#ifdef __cplusplus -namespace { -extern struct PyModuleDef __pyx_moduledef; -} /* anonymous namespace */ -#else -static struct PyModuleDef __pyx_moduledef; -#endif - -#define __pyx_mstate_global (__Pyx_PyModule_GetState(__Pyx_State_FindModule(&__pyx_moduledef))) - -#define __pyx_m (__Pyx_State_FindModule(&__pyx_moduledef)) -#else -static __pyx_mstatetype __pyx_mstate_global_static = -#ifdef __cplusplus - {}; -#else - {0}; -#endif -static __pyx_mstatetype * const __pyx_mstate_global = &__pyx_mstate_global_static; -#endif -/* #### Code section: constant_name_defines ### */ -#define __pyx_kp_u_ __pyx_string_tab[0] -#define __pyx_kp_u__2 __pyx_string_tab[1] -#define __pyx_n_u_cline_in_traceback __pyx_string_tab[2] -#define __pyx_n_u_dump_output __pyx_string_tab[3] -#define __pyx_n_u_epanet __pyx_string_tab[4] -#define __pyx_kp_u_epanet___init __pyx_string_tab[5] -#define __pyx_n_u_main __pyx_string_tab[6] -#define __pyx_n_u_module __pyx_string_tab[7] -#define __pyx_n_u_name __pyx_string_tab[8] -#define __pyx_n_u_qualname __pyx_string_tab[9] -#define __pyx_n_u_run_inp __pyx_string_tab[10] -#define __pyx_n_u_run_project __pyx_string_tab[11] -#define __pyx_n_u_run_project_return_dict __pyx_string_tab[12] -#define __pyx_n_u_test __pyx_string_tab[13] -/* #### Code section: module_state_clear ### */ -#if CYTHON_USE_MODULE_STATE -static CYTHON_SMALL_CODE int __pyx_m_clear(PyObject *m) { - __pyx_mstatetype *clear_module_state = __Pyx_PyModule_GetState(m); - if (!clear_module_state) return 0; - Py_CLEAR(clear_module_state->__pyx_d); - Py_CLEAR(clear_module_state->__pyx_b); - Py_CLEAR(clear_module_state->__pyx_cython_runtime); - Py_CLEAR(clear_module_state->__pyx_empty_tuple); - Py_CLEAR(clear_module_state->__pyx_empty_bytes); - Py_CLEAR(clear_module_state->__pyx_empty_unicode); - #ifdef __Pyx_CyFunction_USED - Py_CLEAR(clear_module_state->__pyx_CyFunctionType); - #endif - #ifdef __Pyx_FusedFunction_USED - Py_CLEAR(clear_module_state->__pyx_FusedFunctionType); - #endif - #if CYTHON_PEP489_MULTI_PHASE_INIT - __Pyx_State_RemoveModule(NULL); - #endif - for (int i=0; i<14; ++i) { Py_CLEAR(clear_module_state->__pyx_string_tab[i]); } - return 0; -} -#endif -/* #### Code section: module_state_traverse ### */ -#if CYTHON_USE_MODULE_STATE -static CYTHON_SMALL_CODE int __pyx_m_traverse(PyObject *m, visitproc visit, void *arg) { - __pyx_mstatetype *traverse_module_state = __Pyx_PyModule_GetState(m); - if (!traverse_module_state) return 0; - Py_VISIT(traverse_module_state->__pyx_d); - Py_VISIT(traverse_module_state->__pyx_b); - Py_VISIT(traverse_module_state->__pyx_cython_runtime); - __Pyx_VISIT_CONST(traverse_module_state->__pyx_empty_tuple); - __Pyx_VISIT_CONST(traverse_module_state->__pyx_empty_bytes); - __Pyx_VISIT_CONST(traverse_module_state->__pyx_empty_unicode); - #ifdef __Pyx_CyFunction_USED - Py_VISIT(traverse_module_state->__pyx_CyFunctionType); - #endif - #ifdef __Pyx_FusedFunction_USED - Py_VISIT(traverse_module_state->__pyx_FusedFunctionType); - #endif - for (int i=0; i<14; ++i) { __Pyx_VISIT_CONST(traverse_module_state->__pyx_string_tab[i]); } - return 0; -} -#endif -/* #### Code section: module_code ### */ -/* #### Code section: module_exttypes ### */ - -static PyMethodDef __pyx_methods[] = { - {0, 0, 0, 0} -}; -/* #### Code section: initfunc_declarations ### */ -static CYTHON_SMALL_CODE int __Pyx_InitCachedBuiltins(__pyx_mstatetype *__pyx_mstate); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_InitCachedConstants(__pyx_mstatetype *__pyx_mstate); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_InitGlobals(void); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_InitConstants(__pyx_mstatetype *__pyx_mstate); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_modinit_global_init_code(__pyx_mstatetype *__pyx_mstate); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_modinit_variable_export_code(__pyx_mstatetype *__pyx_mstate); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_modinit_function_export_code(__pyx_mstatetype *__pyx_mstate); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_modinit_type_init_code(__pyx_mstatetype *__pyx_mstate); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_modinit_type_import_code(__pyx_mstatetype *__pyx_mstate); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_modinit_variable_import_code(__pyx_mstatetype *__pyx_mstate); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_modinit_function_import_code(__pyx_mstatetype *__pyx_mstate); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_CreateCodeObjects(__pyx_mstatetype *__pyx_mstate); /*proto*/ -/* #### Code section: init_module ### */ - -static int __Pyx_modinit_global_init_code(__pyx_mstatetype *__pyx_mstate) { - __Pyx_RefNannyDeclarations - CYTHON_UNUSED_VAR(__pyx_mstate); - __Pyx_RefNannySetupContext("__Pyx_modinit_global_init_code", 0); - /*--- Global init code ---*/ - __Pyx_RefNannyFinishContext(); - return 0; -} - -static int __Pyx_modinit_variable_export_code(__pyx_mstatetype *__pyx_mstate) { - __Pyx_RefNannyDeclarations - CYTHON_UNUSED_VAR(__pyx_mstate); - __Pyx_RefNannySetupContext("__Pyx_modinit_variable_export_code", 0); - /*--- Variable export code ---*/ - __Pyx_RefNannyFinishContext(); - return 0; -} - -static int __Pyx_modinit_function_export_code(__pyx_mstatetype *__pyx_mstate) { - __Pyx_RefNannyDeclarations - CYTHON_UNUSED_VAR(__pyx_mstate); - __Pyx_RefNannySetupContext("__Pyx_modinit_function_export_code", 0); - /*--- Function export code ---*/ - __Pyx_RefNannyFinishContext(); - return 0; -} - -static int __Pyx_modinit_type_init_code(__pyx_mstatetype *__pyx_mstate) { - __Pyx_RefNannyDeclarations - CYTHON_UNUSED_VAR(__pyx_mstate); - __Pyx_RefNannySetupContext("__Pyx_modinit_type_init_code", 0); - /*--- Type init code ---*/ - __Pyx_RefNannyFinishContext(); - return 0; -} - -static int __Pyx_modinit_type_import_code(__pyx_mstatetype *__pyx_mstate) { - __Pyx_RefNannyDeclarations - CYTHON_UNUSED_VAR(__pyx_mstate); - __Pyx_RefNannySetupContext("__Pyx_modinit_type_import_code", 0); - /*--- Type import code ---*/ - __Pyx_RefNannyFinishContext(); - return 0; -} - -static int __Pyx_modinit_variable_import_code(__pyx_mstatetype *__pyx_mstate) { - __Pyx_RefNannyDeclarations - CYTHON_UNUSED_VAR(__pyx_mstate); - __Pyx_RefNannySetupContext("__Pyx_modinit_variable_import_code", 0); - /*--- Variable import code ---*/ - __Pyx_RefNannyFinishContext(); - return 0; -} - -static int __Pyx_modinit_function_import_code(__pyx_mstatetype *__pyx_mstate) { - __Pyx_RefNannyDeclarations - CYTHON_UNUSED_VAR(__pyx_mstate); - __Pyx_RefNannySetupContext("__Pyx_modinit_function_import_code", 0); - /*--- Function import code ---*/ - __Pyx_RefNannyFinishContext(); - return 0; -} - -#if CYTHON_PEP489_MULTI_PHASE_INIT -static PyObject* __pyx_pymod_create(PyObject *spec, PyModuleDef *def); /*proto*/ -static int __pyx_pymod_exec_epanet(PyObject* module); /*proto*/ -static PyModuleDef_Slot __pyx_moduledef_slots[] = { - {Py_mod_create, (void*)__pyx_pymod_create}, - {Py_mod_exec, (void*)__pyx_pymod_exec_epanet}, - #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - {Py_mod_gil, Py_MOD_GIL_USED}, - #endif - #if PY_VERSION_HEX >= 0x030C0000 && CYTHON_USE_MODULE_STATE - {Py_mod_multiple_interpreters, Py_MOD_MULTIPLE_INTERPRETERS_NOT_SUPPORTED}, - #endif - {0, NULL} -}; -#endif - -#ifdef __cplusplus -namespace { - struct PyModuleDef __pyx_moduledef = - #else - static struct PyModuleDef __pyx_moduledef = - #endif - { - PyModuleDef_HEAD_INIT, - "epanet", - 0, /* m_doc */ - #if CYTHON_USE_MODULE_STATE - sizeof(__pyx_mstatetype), /* m_size */ - #else - (CYTHON_PEP489_MULTI_PHASE_INIT) ? 0 : -1, /* m_size */ - #endif - __pyx_methods /* m_methods */, - #if CYTHON_PEP489_MULTI_PHASE_INIT - __pyx_moduledef_slots, /* m_slots */ - #else - NULL, /* m_reload */ - #endif - #if CYTHON_USE_MODULE_STATE - __pyx_m_traverse, /* m_traverse */ - __pyx_m_clear, /* m_clear */ - NULL /* m_free */ - #else - NULL, /* m_traverse */ - NULL, /* m_clear */ - NULL /* m_free */ - #endif - }; - #ifdef __cplusplus -} /* anonymous namespace */ -#endif - -/* PyModInitFuncType */ -#ifndef CYTHON_NO_PYINIT_EXPORT - #define __Pyx_PyMODINIT_FUNC PyMODINIT_FUNC -#else - #ifdef __cplusplus - #define __Pyx_PyMODINIT_FUNC extern "C" PyObject * - #else - #define __Pyx_PyMODINIT_FUNC PyObject * - #endif -#endif - -__Pyx_PyMODINIT_FUNC PyInit_epanet(void) CYTHON_SMALL_CODE; /*proto*/ -#if !defined(CYTHON_NO_PYINIT_EXPORT) && (defined(_WIN32) || defined(WIN32) || defined(MS_WINDOWS)) -__Pyx_PyMODINIT_FUNC PyInit___init__(void) { return PyInit_epanet(); } -#endif -__Pyx_PyMODINIT_FUNC PyInit_epanet(void) -#if CYTHON_PEP489_MULTI_PHASE_INIT -{ - return PyModuleDef_Init(&__pyx_moduledef); -} -/* ModuleCreationPEP489 */ -#if CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX < 0x03090000 -static PY_INT64_T __Pyx_GetCurrentInterpreterId(void) { - { - PyObject *module = PyImport_ImportModule("_interpreters"); // 3.13+ I think - if (!module) { - PyErr_Clear(); // just try the 3.8-3.12 version - module = PyImport_ImportModule("_xxsubinterpreters"); - if (!module) goto bad; - } - PyObject *current = PyObject_CallMethod(module, "get_current", NULL); - Py_DECREF(module); - if (!current) goto bad; - if (PyTuple_Check(current)) { - PyObject *new_current = PySequence_GetItem(current, 0); - Py_DECREF(current); - current = new_current; - if (!new_current) goto bad; - } - long long as_c_int = PyLong_AsLongLong(current); - Py_DECREF(current); - return as_c_int; - } - bad: - PySys_WriteStderr("__Pyx_GetCurrentInterpreterId failed. Try setting the C define CYTHON_PEP489_MULTI_PHASE_INIT=0\n"); - return -1; -} -#endif -#if !CYTHON_USE_MODULE_STATE -static CYTHON_SMALL_CODE int __Pyx_check_single_interpreter(void) { - static PY_INT64_T main_interpreter_id = -1; -#if CYTHON_COMPILING_IN_GRAAL - PY_INT64_T current_id = PyInterpreterState_GetIDFromThreadState(PyThreadState_Get()); -#elif CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX >= 0x03090000 - PY_INT64_T current_id = PyInterpreterState_GetID(PyInterpreterState_Get()); -#elif CYTHON_COMPILING_IN_LIMITED_API - PY_INT64_T current_id = __Pyx_GetCurrentInterpreterId(); -#else - PY_INT64_T current_id = PyInterpreterState_GetID(PyThreadState_Get()->interp); -#endif - if (unlikely(current_id == -1)) { - return -1; - } - if (main_interpreter_id == -1) { - main_interpreter_id = current_id; - return 0; - } else if (unlikely(main_interpreter_id != current_id)) { - PyErr_SetString( - PyExc_ImportError, - "Interpreter change detected - this module can only be loaded into one interpreter per process."); - return -1; - } - return 0; -} -#endif -static CYTHON_SMALL_CODE int __Pyx_copy_spec_to_module(PyObject *spec, PyObject *moddict, const char* from_name, const char* to_name, int allow_none) -{ - PyObject *value = PyObject_GetAttrString(spec, from_name); - int result = 0; - if (likely(value)) { - if (allow_none || value != Py_None) { - result = PyDict_SetItemString(moddict, to_name, value); - } - Py_DECREF(value); - } else if (PyErr_ExceptionMatches(PyExc_AttributeError)) { - PyErr_Clear(); - } else { - result = -1; - } - return result; -} -static CYTHON_SMALL_CODE PyObject* __pyx_pymod_create(PyObject *spec, PyModuleDef *def) { - PyObject *module = NULL, *moddict, *modname; - CYTHON_UNUSED_VAR(def); - #if !CYTHON_USE_MODULE_STATE - if (__Pyx_check_single_interpreter()) - return NULL; - #endif - if (__pyx_m) - return __Pyx_NewRef(__pyx_m); - modname = PyObject_GetAttrString(spec, "name"); - if (unlikely(!modname)) goto bad; - module = PyModule_NewObject(modname); - Py_DECREF(modname); - if (unlikely(!module)) goto bad; - moddict = PyModule_GetDict(module); - if (unlikely(!moddict)) goto bad; - if (unlikely(__Pyx_copy_spec_to_module(spec, moddict, "loader", "__loader__", 1) < 0)) goto bad; - if (unlikely(__Pyx_copy_spec_to_module(spec, moddict, "origin", "__file__", 1) < 0)) goto bad; - if (unlikely(__Pyx_copy_spec_to_module(spec, moddict, "parent", "__package__", 1) < 0)) goto bad; - if (unlikely(__Pyx_copy_spec_to_module(spec, moddict, "submodule_search_locations", "__path__", 0) < 0)) goto bad; - return module; -bad: - Py_XDECREF(module); - return NULL; -} - - -static CYTHON_SMALL_CODE int __pyx_pymod_exec_epanet(PyObject *__pyx_pyinit_module) -#endif -{ - int stringtab_initialized = 0; - #if CYTHON_USE_MODULE_STATE - int pystate_addmodule_run = 0; - #endif - __pyx_mstatetype *__pyx_mstate = NULL; - PyObject *__pyx_t_1 = NULL; - PyObject *__pyx_t_2 = NULL; - PyObject *__pyx_t_3 = NULL; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - __Pyx_RefNannyDeclarations - #if CYTHON_PEP489_MULTI_PHASE_INIT - if (__pyx_m) { - if (__pyx_m == __pyx_pyinit_module) return 0; - PyErr_SetString(PyExc_RuntimeError, "Module 'epanet' has already been imported. Re-initialisation is not supported."); - return -1; - } - #else - if (__pyx_m) return __Pyx_NewRef(__pyx_m); - #endif - /*--- Module creation code ---*/ - #if CYTHON_PEP489_MULTI_PHASE_INIT - __pyx_t_1 = __pyx_pyinit_module; - Py_INCREF(__pyx_t_1); - #else - __pyx_t_1 = PyModule_Create(&__pyx_moduledef); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1, __pyx_L1_error) - #endif - #if CYTHON_USE_MODULE_STATE - { - int add_module_result = __Pyx_State_AddModule(__pyx_t_1, &__pyx_moduledef); - __pyx_t_1 = 0; /* transfer ownership from __pyx_t_1 to "epanet" pseudovariable */ - if (unlikely((add_module_result < 0))) __PYX_ERR(0, 1, __pyx_L1_error) - pystate_addmodule_run = 1; - } - #else - __pyx_m = __pyx_t_1; - #endif - #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - PyUnstable_Module_SetGIL(__pyx_m, Py_MOD_GIL_USED); - #endif - __pyx_mstate = __pyx_mstate_global; - CYTHON_UNUSED_VAR(__pyx_t_1); - __pyx_mstate->__pyx_d = PyModule_GetDict(__pyx_m); if (unlikely(!__pyx_mstate->__pyx_d)) __PYX_ERR(0, 1, __pyx_L1_error) - Py_INCREF(__pyx_mstate->__pyx_d); - __pyx_mstate->__pyx_b = __Pyx_PyImport_AddModuleRef(__Pyx_BUILTIN_MODULE_NAME); if (unlikely(!__pyx_mstate->__pyx_b)) __PYX_ERR(0, 1, __pyx_L1_error) - __pyx_mstate->__pyx_cython_runtime = __Pyx_PyImport_AddModuleRef("cython_runtime"); if (unlikely(!__pyx_mstate->__pyx_cython_runtime)) __PYX_ERR(0, 1, __pyx_L1_error) - if (PyObject_SetAttrString(__pyx_m, "__builtins__", __pyx_mstate->__pyx_b) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - /* ImportRefnannyAPI */ - #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("PyInit_epanet", 0); - if (__Pyx_check_binary_version(__PYX_LIMITED_VERSION_HEX, __Pyx_get_runtime_version(), CYTHON_COMPILING_IN_LIMITED_API) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - #ifdef __Pxy_PyFrame_Initialize_Offsets - __Pxy_PyFrame_Initialize_Offsets(); - #endif - __pyx_mstate->__pyx_empty_tuple = PyTuple_New(0); if (unlikely(!__pyx_mstate->__pyx_empty_tuple)) __PYX_ERR(0, 1, __pyx_L1_error) - __pyx_mstate->__pyx_empty_bytes = PyBytes_FromStringAndSize("", 0); if (unlikely(!__pyx_mstate->__pyx_empty_bytes)) __PYX_ERR(0, 1, __pyx_L1_error) - __pyx_mstate->__pyx_empty_unicode = PyUnicode_FromStringAndSize("", 0); if (unlikely(!__pyx_mstate->__pyx_empty_unicode)) __PYX_ERR(0, 1, __pyx_L1_error) - #ifdef __Pyx_CyFunction_USED - if (__pyx_CyFunction_init(__pyx_m) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - #endif - #ifdef __Pyx_FusedFunction_USED - if (__pyx_FusedFunction_init(__pyx_m) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - #endif - #ifdef __Pyx_Coroutine_USED - if (__pyx_Coroutine_init(__pyx_m) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - #endif - #ifdef __Pyx_Generator_USED - if (__pyx_Generator_init(__pyx_m) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - #endif - #ifdef __Pyx_AsyncGen_USED - if (__pyx_AsyncGen_init(__pyx_m) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - #endif - /*--- Library function declarations ---*/ - /*--- Initialize various global constants etc. ---*/ - if (__Pyx_InitConstants(__pyx_mstate) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - stringtab_initialized = 1; - if (__Pyx_InitGlobals() < 0) __PYX_ERR(0, 1, __pyx_L1_error) - if (__pyx_module_is_main_epanet____init__) { - if (PyObject_SetAttr(__pyx_m, __pyx_mstate_global->__pyx_n_u_name, __pyx_mstate_global->__pyx_n_u_main) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - } - if (!CYTHON_PEP489_MULTI_PHASE_INIT) { - if (unlikely((__Pyx_SetPackagePathFromImportLib(__pyx_mstate_global->__pyx_kp_u_epanet___init) < 0))) __PYX_ERR(0, 1, __pyx_L1_error) - } - { - PyObject *modules = PyImport_GetModuleDict(); if (unlikely(!modules)) __PYX_ERR(0, 1, __pyx_L1_error) - if (!PyDict_GetItemString(modules, "epanet")) { - if (unlikely((PyDict_SetItemString(modules, "epanet", __pyx_m) < 0))) __PYX_ERR(0, 1, __pyx_L1_error) - } - } - /*--- Builtin init code ---*/ - if (__Pyx_InitCachedBuiltins(__pyx_mstate) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - /*--- Constants init code ---*/ - if (__Pyx_InitCachedConstants(__pyx_mstate) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - if (__Pyx_CreateCodeObjects(__pyx_mstate) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - /*--- Global type/function init code ---*/ - (void)__Pyx_modinit_global_init_code(__pyx_mstate); - (void)__Pyx_modinit_variable_export_code(__pyx_mstate); - (void)__Pyx_modinit_function_export_code(__pyx_mstate); - (void)__Pyx_modinit_type_init_code(__pyx_mstate); - (void)__Pyx_modinit_type_import_code(__pyx_mstate); - (void)__Pyx_modinit_variable_import_code(__pyx_mstate); - (void)__Pyx_modinit_function_import_code(__pyx_mstate); - /*--- Execution code ---*/ - - /* "epanet/__init__.py":1 - * from .epanet import run_project, run_project_return_dict, run_inp, dump_output # <<<<<<<<<<<<<< -*/ - __pyx_t_2 = __Pyx_PyList_Pack(4, __pyx_mstate_global->__pyx_n_u_run_project, __pyx_mstate_global->__pyx_n_u_run_project_return_dict, __pyx_mstate_global->__pyx_n_u_run_inp, __pyx_mstate_global->__pyx_n_u_dump_output); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_t_3 = __Pyx_Import(__pyx_mstate_global->__pyx_n_u_epanet, __pyx_t_2, 1); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __pyx_t_2 = __Pyx_ImportFrom(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_run_project); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_run_project, __pyx_t_2) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __pyx_t_2 = __Pyx_ImportFrom(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_run_project_return_dict); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_run_project_return_dict, __pyx_t_2) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __pyx_t_2 = __Pyx_ImportFrom(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_run_inp); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_run_inp, __pyx_t_2) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __pyx_t_2 = __Pyx_ImportFrom(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_dump_output); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_dump_output, __pyx_t_2) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __pyx_t_3 = __Pyx_PyDict_NewPresized(0); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_test, __pyx_t_3) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - - /*--- Wrapped vars code ---*/ - - goto __pyx_L0; - __pyx_L1_error:; - __Pyx_XDECREF(__pyx_t_2); - __Pyx_XDECREF(__pyx_t_3); - if (__pyx_m) { - if (__pyx_mstate->__pyx_d && stringtab_initialized) { - __Pyx_AddTraceback("init epanet", __pyx_clineno, __pyx_lineno, __pyx_filename); - } - #if !CYTHON_USE_MODULE_STATE - Py_CLEAR(__pyx_m); - #else - Py_DECREF(__pyx_m); - if (pystate_addmodule_run) { - PyObject *tp, *value, *tb; - PyErr_Fetch(&tp, &value, &tb); - PyState_RemoveModule(&__pyx_moduledef); - PyErr_Restore(tp, value, tb); - } - #endif - } else if (!PyErr_Occurred()) { - PyErr_SetString(PyExc_ImportError, "init epanet"); - } - __pyx_L0:; - __Pyx_RefNannyFinishContext(); - #if CYTHON_PEP489_MULTI_PHASE_INIT - return (__pyx_m != NULL) ? 0 : -1; - #else - return __pyx_m; - #endif -} -/* #### Code section: pystring_table ### */ - -typedef struct { - const char *s; -#if 23 <= 65535 - const unsigned short n; -#elif 23 / 2 < INT_MAX - const unsigned int n; -#elif 23 / 2 < LONG_MAX - const unsigned long n; -#else - const Py_ssize_t n; -#endif -#if 1 <= 31 - const unsigned int encoding : 5; -#elif 1 <= 255 - const unsigned char encoding; -#elif 1 <= 65535 - const unsigned short encoding; -#else - const Py_ssize_t encoding; -#endif - const unsigned int is_unicode : 1; - const unsigned int intern : 1; -} __Pyx_StringTabEntry; -static const char * const __pyx_string_tab_encodings[] = { 0 }; -static const __Pyx_StringTabEntry __pyx_string_tab[] = { - {__pyx_k_, sizeof(__pyx_k_), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_ */ - {__pyx_k__2, sizeof(__pyx_k__2), 0, 1, 0}, /* PyObject cname: __pyx_kp_u__2 */ - {__pyx_k_cline_in_traceback, sizeof(__pyx_k_cline_in_traceback), 0, 1, 1}, /* PyObject cname: __pyx_n_u_cline_in_traceback */ - {__pyx_k_dump_output, sizeof(__pyx_k_dump_output), 0, 1, 1}, /* PyObject cname: __pyx_n_u_dump_output */ - {__pyx_k_epanet, sizeof(__pyx_k_epanet), 0, 1, 1}, /* PyObject cname: __pyx_n_u_epanet */ - {__pyx_k_epanet___init, sizeof(__pyx_k_epanet___init), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_epanet___init */ - {__pyx_k_main, sizeof(__pyx_k_main), 0, 1, 1}, /* PyObject cname: __pyx_n_u_main */ - {__pyx_k_module, sizeof(__pyx_k_module), 0, 1, 1}, /* PyObject cname: __pyx_n_u_module */ - {__pyx_k_name, sizeof(__pyx_k_name), 0, 1, 1}, /* PyObject cname: __pyx_n_u_name */ - {__pyx_k_qualname, sizeof(__pyx_k_qualname), 0, 1, 1}, /* PyObject cname: __pyx_n_u_qualname */ - {__pyx_k_run_inp, sizeof(__pyx_k_run_inp), 0, 1, 1}, /* PyObject cname: __pyx_n_u_run_inp */ - {__pyx_k_run_project, sizeof(__pyx_k_run_project), 0, 1, 1}, /* PyObject cname: __pyx_n_u_run_project */ - {__pyx_k_run_project_return_dict, sizeof(__pyx_k_run_project_return_dict), 0, 1, 1}, /* PyObject cname: __pyx_n_u_run_project_return_dict */ - {__pyx_k_test, sizeof(__pyx_k_test), 0, 1, 1}, /* PyObject cname: __pyx_n_u_test */ - {0, 0, 0, 0, 0} -}; -/* InitStrings.proto */ -static int __Pyx_InitStrings(__Pyx_StringTabEntry const *t, PyObject **target, const char* const* encoding_names); - -/* #### Code section: cached_builtins ### */ - -static int __Pyx_InitCachedBuiltins(__pyx_mstatetype *__pyx_mstate) { - CYTHON_UNUSED_VAR(__pyx_mstate); - return 0; -} -/* #### Code section: cached_constants ### */ - -static int __Pyx_InitCachedConstants(__pyx_mstatetype *__pyx_mstate) { - __Pyx_RefNannyDeclarations - CYTHON_UNUSED_VAR(__pyx_mstate); - __Pyx_RefNannySetupContext("__Pyx_InitCachedConstants", 0); - __Pyx_RefNannyFinishContext(); - return 0; -} -/* #### Code section: init_constants ### */ - -static int __Pyx_InitConstants(__pyx_mstatetype *__pyx_mstate) { - CYTHON_UNUSED_VAR(__pyx_mstate); - if (__Pyx_InitStrings(__pyx_string_tab, __pyx_mstate->__pyx_string_tab, __pyx_string_tab_encodings) < 0) __PYX_ERR(0, 1, __pyx_L1_error); - return 0; - __pyx_L1_error:; - return -1; -} -/* #### Code section: init_codeobjects ### */ - -static int __Pyx_CreateCodeObjects(__pyx_mstatetype *__pyx_mstate) { - CYTHON_UNUSED_VAR(__pyx_mstate); - return 0; -} -/* #### Code section: init_globals ### */ - -static int __Pyx_InitGlobals(void) { - /* PythonCompatibility.init */ - if (likely(__Pyx_init_co_variables() == 0)); else - -if (unlikely(PyErr_Occurred())) __PYX_ERR(0, 1, __pyx_L1_error) - - return 0; - __pyx_L1_error:; - return -1; -} -/* #### Code section: cleanup_globals ### */ -/* #### Code section: cleanup_module ### */ -/* #### Code section: main_method ### */ -/* #### Code section: utility_code_pragmas ### */ -#ifdef _MSC_VER -#pragma warning( push ) -/* Warning 4127: conditional expression is constant - * Cython uses constant conditional expressions to allow in inline functions to be optimized at - * compile-time, so this warning is not useful - */ -#pragma warning( disable : 4127 ) -#endif - - - -/* #### Code section: utility_code_def ### */ - -/* --- Runtime support code --- */ -/* Refnanny */ -#if CYTHON_REFNANNY -static __Pyx_RefNannyAPIStruct *__Pyx_RefNannyImportAPI(const char *modname) { - PyObject *m = NULL, *p = NULL; - void *r = NULL; - m = PyImport_ImportModule(modname); - if (!m) goto end; - p = PyObject_GetAttrString(m, "RefNannyAPI"); - if (!p) goto end; - r = PyLong_AsVoidPtr(p); -end: - Py_XDECREF(p); - Py_XDECREF(m); - return (__Pyx_RefNannyAPIStruct *)r; -} -#endif - -/* SetPackagePathFromImportLib */ -#if !CYTHON_PEP489_MULTI_PHASE_INIT -static int __Pyx_SetPackagePathFromImportLib(PyObject *module_name) { - PyObject *importlib, *osmod, *ossep, *parts, *package_path; - PyObject *file_path = NULL; - PyObject *item; - int result; - PyObject *spec; - importlib = PyImport_ImportModule("importlib.util"); - if (unlikely(!importlib)) - goto bad; - spec = PyObject_CallMethod(importlib, "find_spec", "(O)", module_name); - Py_DECREF(importlib); - if (unlikely(!spec)) - goto bad; - file_path = PyObject_GetAttrString(spec, "origin"); - Py_DECREF(spec); - if (unlikely(!file_path)) - goto bad; - if (unlikely(PyObject_SetAttrString(__pyx_m, "__file__", file_path) < 0)) - goto bad; - osmod = PyImport_ImportModule("os"); - if (unlikely(!osmod)) - goto bad; - ossep = PyObject_GetAttrString(osmod, "sep"); - Py_DECREF(osmod); - if (unlikely(!ossep)) - goto bad; - parts = PyObject_CallMethod(file_path, "rsplit", "(Oi)", ossep, 1); - Py_DECREF(file_path); file_path = NULL; - Py_DECREF(ossep); - if (unlikely(!parts)) - goto bad; -#if CYTHON_ASSUME_SAFE_MACROS - package_path = Py_BuildValue("[O]", PyList_GET_ITEM(parts, 0)); -#else - item = PyList_GetItem(parts, 0); - if (unlikely(!item)) - goto bad; - package_path = Py_BuildValue("[O]", item); -#endif - Py_DECREF(parts); - if (unlikely(!package_path)) - goto bad; - goto set_path; -bad: - PyErr_WriteUnraisable(module_name); - Py_XDECREF(file_path); - PyErr_Clear(); - package_path = PyList_New(0); - if (unlikely(!package_path)) - return -1; -set_path: - result = PyObject_SetAttrString(__pyx_m, "__path__", package_path); - Py_DECREF(package_path); - return result; -} -#endif - -/* ListPack */ -static PyObject *__Pyx_PyList_Pack(Py_ssize_t n, ...) { - va_list va; - PyObject *l = PyList_New(n); - va_start(va, n); - if (unlikely(!l)) goto end; - for (Py_ssize_t i=0; itp_getattro)) - return tp->tp_getattro(obj, attr_name); - return PyObject_GetAttr(obj, attr_name); -} -#endif - -/* Import */ -static PyObject *__Pyx_Import(PyObject *name, PyObject *from_list, int level) { - PyObject *module = 0; - PyObject *empty_dict = 0; - PyObject *empty_list = 0; - empty_dict = PyDict_New(); - if (unlikely(!empty_dict)) - goto bad; - if (level == -1) { - if (strchr(__Pyx_MODULE_NAME, '.') != (0)) { - module = PyImport_ImportModuleLevelObject( - name, __pyx_mstate_global->__pyx_d, empty_dict, from_list, 1); - if (unlikely(!module)) { - if (unlikely(!PyErr_ExceptionMatches(PyExc_ImportError))) - goto bad; - PyErr_Clear(); - } - } - level = 0; - } - if (!module) { - module = PyImport_ImportModuleLevelObject( - name, __pyx_mstate_global->__pyx_d, empty_dict, from_list, level); - } -bad: - Py_XDECREF(empty_dict); - Py_XDECREF(empty_list); - return module; -} - -/* ImportFrom */ -static PyObject* __Pyx_ImportFrom(PyObject* module, PyObject* name) { - PyObject* value = __Pyx_PyObject_GetAttrStr(module, name); - if (unlikely(!value) && PyErr_ExceptionMatches(PyExc_AttributeError)) { - const char* module_name_str = 0; - PyObject* module_name = 0; - PyObject* module_dot = 0; - PyObject* full_name = 0; - PyErr_Clear(); - module_name_str = PyModule_GetName(module); - if (unlikely(!module_name_str)) { goto modbad; } - module_name = PyUnicode_FromString(module_name_str); - if (unlikely(!module_name)) { goto modbad; } - module_dot = PyUnicode_Concat(module_name, __pyx_mstate_global->__pyx_kp_u_); - if (unlikely(!module_dot)) { goto modbad; } - full_name = PyUnicode_Concat(module_dot, name); - if (unlikely(!full_name)) { goto modbad; } - #if (CYTHON_COMPILING_IN_PYPY && PYPY_VERSION_NUM < 0x07030400) ||\ - CYTHON_COMPILING_IN_GRAAL - { - PyObject *modules = PyImport_GetModuleDict(); - if (unlikely(!modules)) - goto modbad; - value = PyObject_GetItem(modules, full_name); - } - #else - value = PyImport_GetModule(full_name); - #endif - modbad: - Py_XDECREF(full_name); - Py_XDECREF(module_dot); - Py_XDECREF(module_name); - } - if (unlikely(!value)) { - PyErr_Format(PyExc_ImportError, "cannot import name %S", name); - } - return value; -} - -/* PyDictVersioning */ -#if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_TYPE_SLOTS -static CYTHON_INLINE PY_UINT64_T __Pyx_get_tp_dict_version(PyObject *obj) { - PyObject *dict = Py_TYPE(obj)->tp_dict; - return likely(dict) ? __PYX_GET_DICT_VERSION(dict) : 0; -} -static CYTHON_INLINE PY_UINT64_T __Pyx_get_object_dict_version(PyObject *obj) { - PyObject **dictptr = NULL; - Py_ssize_t offset = Py_TYPE(obj)->tp_dictoffset; - if (offset) { -#if CYTHON_COMPILING_IN_CPYTHON - dictptr = (likely(offset > 0)) ? (PyObject **) ((char *)obj + offset) : _PyObject_GetDictPtr(obj); -#else - dictptr = _PyObject_GetDictPtr(obj); -#endif - } - return (dictptr && *dictptr) ? __PYX_GET_DICT_VERSION(*dictptr) : 0; -} -static CYTHON_INLINE int __Pyx_object_dict_version_matches(PyObject* obj, PY_UINT64_T tp_dict_version, PY_UINT64_T obj_dict_version) { - PyObject *dict = Py_TYPE(obj)->tp_dict; - if (unlikely(!dict) || unlikely(tp_dict_version != __PYX_GET_DICT_VERSION(dict))) - return 0; - return obj_dict_version == __Pyx_get_object_dict_version(obj); -} -#endif - -/* PyErrExceptionMatches */ -#if CYTHON_FAST_THREAD_STATE -static int __Pyx_PyErr_ExceptionMatchesTuple(PyObject *exc_type, PyObject *tuple) { - Py_ssize_t i, n; - n = PyTuple_GET_SIZE(tuple); - for (i=0; i= 0x030C00A6 - PyObject *current_exception = tstate->current_exception; - if (unlikely(!current_exception)) return 0; - exc_type = (PyObject*) Py_TYPE(current_exception); - if (exc_type == err) return 1; -#else - exc_type = tstate->curexc_type; - if (exc_type == err) return 1; - if (unlikely(!exc_type)) return 0; -#endif - #if CYTHON_AVOID_BORROWED_REFS - Py_INCREF(exc_type); - #endif - if (unlikely(PyTuple_Check(err))) { - result = __Pyx_PyErr_ExceptionMatchesTuple(exc_type, err); - } else { - result = __Pyx_PyErr_GivenExceptionMatches(exc_type, err); - } - #if CYTHON_AVOID_BORROWED_REFS - Py_DECREF(exc_type); - #endif - return result; -} -#endif - -/* PyErrFetchRestore */ -#if CYTHON_FAST_THREAD_STATE -static CYTHON_INLINE void __Pyx_ErrRestoreInState(PyThreadState *tstate, PyObject *type, PyObject *value, PyObject *tb) { -#if PY_VERSION_HEX >= 0x030C00A6 - PyObject *tmp_value; - assert(type == NULL || (value != NULL && type == (PyObject*) Py_TYPE(value))); - if (value) { - #if CYTHON_COMPILING_IN_CPYTHON - if (unlikely(((PyBaseExceptionObject*) value)->traceback != tb)) - #endif - PyException_SetTraceback(value, tb); - } - tmp_value = tstate->current_exception; - tstate->current_exception = value; - Py_XDECREF(tmp_value); - Py_XDECREF(type); - Py_XDECREF(tb); -#else - PyObject *tmp_type, *tmp_value, *tmp_tb; - tmp_type = tstate->curexc_type; - tmp_value = tstate->curexc_value; - tmp_tb = tstate->curexc_traceback; - tstate->curexc_type = type; - tstate->curexc_value = value; - tstate->curexc_traceback = tb; - Py_XDECREF(tmp_type); - Py_XDECREF(tmp_value); - Py_XDECREF(tmp_tb); -#endif -} -static CYTHON_INLINE void __Pyx_ErrFetchInState(PyThreadState *tstate, PyObject **type, PyObject **value, PyObject **tb) { -#if PY_VERSION_HEX >= 0x030C00A6 - PyObject* exc_value; - exc_value = tstate->current_exception; - tstate->current_exception = 0; - *value = exc_value; - *type = NULL; - *tb = NULL; - if (exc_value) { - *type = (PyObject*) Py_TYPE(exc_value); - Py_INCREF(*type); - #if CYTHON_COMPILING_IN_CPYTHON - *tb = ((PyBaseExceptionObject*) exc_value)->traceback; - Py_XINCREF(*tb); - #else - *tb = PyException_GetTraceback(exc_value); - #endif - } -#else - *type = tstate->curexc_type; - *value = tstate->curexc_value; - *tb = tstate->curexc_traceback; - tstate->curexc_type = 0; - tstate->curexc_value = 0; - tstate->curexc_traceback = 0; -#endif -} -#endif - -/* PyObjectGetAttrStrNoError */ -#if __PYX_LIMITED_VERSION_HEX < 0x030d0000 -static void __Pyx_PyObject_GetAttrStr_ClearAttributeError(void) { - __Pyx_PyThreadState_declare - __Pyx_PyThreadState_assign - if (likely(__Pyx_PyErr_ExceptionMatches(PyExc_AttributeError))) - __Pyx_PyErr_Clear(); -} -#endif -static CYTHON_INLINE PyObject* __Pyx_PyObject_GetAttrStrNoError(PyObject* obj, PyObject* attr_name) { - PyObject *result; -#if __PYX_LIMITED_VERSION_HEX >= 0x030d0000 - (void) PyObject_GetOptionalAttr(obj, attr_name, &result); - return result; -#else -#if CYTHON_COMPILING_IN_CPYTHON && CYTHON_USE_TYPE_SLOTS - PyTypeObject* tp = Py_TYPE(obj); - if (likely(tp->tp_getattro == PyObject_GenericGetAttr)) { - return _PyObject_GenericGetAttrWithDict(obj, attr_name, NULL, 1); - } -#endif - result = __Pyx_PyObject_GetAttrStr(obj, attr_name); - if (unlikely(!result)) { - __Pyx_PyObject_GetAttrStr_ClearAttributeError(); - } - return result; -#endif -} - -/* CLineInTraceback */ -#if CYTHON_CLINE_IN_TRACEBACK && CYTHON_CLINE_IN_TRACEBACK_RUNTIME -static int __Pyx_CLineForTraceback(PyThreadState *tstate, int c_line) { - PyObject *use_cline; - PyObject *ptype, *pvalue, *ptraceback; -#if CYTHON_COMPILING_IN_CPYTHON - PyObject **cython_runtime_dict; -#endif - CYTHON_MAYBE_UNUSED_VAR(tstate); - if (unlikely(!__pyx_mstate_global->__pyx_cython_runtime)) { - return c_line; - } - __Pyx_ErrFetchInState(tstate, &ptype, &pvalue, &ptraceback); -#if CYTHON_COMPILING_IN_CPYTHON - cython_runtime_dict = _PyObject_GetDictPtr(__pyx_mstate_global->__pyx_cython_runtime); - if (likely(cython_runtime_dict)) { - __Pyx_BEGIN_CRITICAL_SECTION(*cython_runtime_dict); - __PYX_PY_DICT_LOOKUP_IF_MODIFIED( - use_cline, *cython_runtime_dict, - __Pyx_PyDict_GetItemStr(*cython_runtime_dict, __pyx_mstate_global->__pyx_n_u_cline_in_traceback)) - Py_XINCREF(use_cline); - __Pyx_END_CRITICAL_SECTION(); - } else -#endif - { - PyObject *use_cline_obj = __Pyx_PyObject_GetAttrStrNoError(__pyx_mstate_global->__pyx_cython_runtime, __pyx_mstate_global->__pyx_n_u_cline_in_traceback); - if (use_cline_obj) { - use_cline = PyObject_Not(use_cline_obj) ? Py_False : Py_True; - Py_INCREF(use_cline); - Py_DECREF(use_cline_obj); - } else { - PyErr_Clear(); - use_cline = NULL; - } - } - if (!use_cline) { - c_line = 0; - (void) PyObject_SetAttr(__pyx_mstate_global->__pyx_cython_runtime, __pyx_mstate_global->__pyx_n_u_cline_in_traceback, Py_False); - } - else if (use_cline == Py_False || (use_cline != Py_True && PyObject_Not(use_cline) != 0)) { - c_line = 0; - } - Py_XDECREF(use_cline); - __Pyx_ErrRestoreInState(tstate, ptype, pvalue, ptraceback); - return c_line; -} -#endif - -/* CodeObjectCache */ -static int __pyx_bisect_code_objects(__Pyx_CodeObjectCacheEntry* entries, int count, int code_line) { - int start = 0, mid = 0, end = count - 1; - if (end >= 0 && code_line > entries[end].code_line) { - return count; - } - while (start < end) { - mid = start + (end - start) / 2; - if (code_line < entries[mid].code_line) { - end = mid; - } else if (code_line > entries[mid].code_line) { - start = mid + 1; - } else { - return mid; - } - } - if (code_line <= entries[mid].code_line) { - return mid; - } else { - return mid + 1; - } -} -static __Pyx_CachedCodeObjectType *__pyx__find_code_object(struct __Pyx_CodeObjectCache *code_cache, int code_line) { - __Pyx_CachedCodeObjectType* code_object; - int pos; - if (unlikely(!code_line) || unlikely(!code_cache->entries)) { - return NULL; - } - pos = __pyx_bisect_code_objects(code_cache->entries, code_cache->count, code_line); - if (unlikely(pos >= code_cache->count) || unlikely(code_cache->entries[pos].code_line != code_line)) { - return NULL; - } - code_object = code_cache->entries[pos].code_object; - Py_INCREF(code_object); - return code_object; -} -static __Pyx_CachedCodeObjectType *__pyx_find_code_object(int code_line) { -#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING && !CYTHON_ATOMICS - (void)__pyx__find_code_object; - return NULL; // Most implementation should have atomics. But otherwise, don't make it thread-safe, just miss. -#else - struct __Pyx_CodeObjectCache *code_cache = &__pyx_mstate_global->__pyx_code_cache; -#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - __pyx_nonatomic_int_type old_count = __pyx_atomic_incr_acq_rel(&code_cache->accessor_count); - if (old_count < 0) { - __pyx_atomic_decr_acq_rel(&code_cache->accessor_count); - return NULL; - } -#endif - __Pyx_CachedCodeObjectType *result = __pyx__find_code_object(code_cache, code_line); -#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - __pyx_atomic_decr_acq_rel(&code_cache->accessor_count); -#endif - return result; -#endif -} -static void __pyx__insert_code_object(struct __Pyx_CodeObjectCache *code_cache, int code_line, __Pyx_CachedCodeObjectType* code_object) -{ - int pos, i; - __Pyx_CodeObjectCacheEntry* entries = code_cache->entries; - if (unlikely(!code_line)) { - return; - } - if (unlikely(!entries)) { - entries = (__Pyx_CodeObjectCacheEntry*)PyMem_Malloc(64*sizeof(__Pyx_CodeObjectCacheEntry)); - if (likely(entries)) { - code_cache->entries = entries; - code_cache->max_count = 64; - code_cache->count = 1; - entries[0].code_line = code_line; - entries[0].code_object = code_object; - Py_INCREF(code_object); - } - return; - } - pos = __pyx_bisect_code_objects(code_cache->entries, code_cache->count, code_line); - if ((pos < code_cache->count) && unlikely(code_cache->entries[pos].code_line == code_line)) { - __Pyx_CachedCodeObjectType* tmp = entries[pos].code_object; - entries[pos].code_object = code_object; - Py_INCREF(code_object); - Py_DECREF(tmp); - return; - } - if (code_cache->count == code_cache->max_count) { - int new_max = code_cache->max_count + 64; - entries = (__Pyx_CodeObjectCacheEntry*)PyMem_Realloc( - code_cache->entries, ((size_t)new_max) * sizeof(__Pyx_CodeObjectCacheEntry)); - if (unlikely(!entries)) { - return; - } - code_cache->entries = entries; - code_cache->max_count = new_max; - } - for (i=code_cache->count; i>pos; i--) { - entries[i] = entries[i-1]; - } - entries[pos].code_line = code_line; - entries[pos].code_object = code_object; - code_cache->count++; - Py_INCREF(code_object); -} -static void __pyx_insert_code_object(int code_line, __Pyx_CachedCodeObjectType* code_object) { -#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING && !CYTHON_ATOMICS - (void)__pyx__insert_code_object; - return; // Most implementation should have atomics. But otherwise, don't make it thread-safe, just fail. -#else - struct __Pyx_CodeObjectCache *code_cache = &__pyx_mstate_global->__pyx_code_cache; -#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - __pyx_nonatomic_int_type expected = 0; - if (!__pyx_atomic_int_cmp_exchange(&code_cache->accessor_count, &expected, INT_MIN)) { - return; - } -#endif - __pyx__insert_code_object(code_cache, code_line, code_object); -#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - __pyx_atomic_sub(&code_cache->accessor_count, INT_MIN); -#endif -#endif -} - -/* AddTraceback */ -#include "compile.h" -#include "frameobject.h" -#include "traceback.h" -#if PY_VERSION_HEX >= 0x030b00a6 && !CYTHON_COMPILING_IN_LIMITED_API && !defined(PYPY_VERSION) - #ifndef Py_BUILD_CORE - #define Py_BUILD_CORE 1 - #endif - #include "internal/pycore_frame.h" -#endif -#if CYTHON_COMPILING_IN_LIMITED_API -static PyObject *__Pyx_PyCode_Replace_For_AddTraceback(PyObject *code, PyObject *scratch_dict, - PyObject *firstlineno, PyObject *name) { - PyObject *replace = NULL; - if (unlikely(PyDict_SetItemString(scratch_dict, "co_firstlineno", firstlineno))) return NULL; - if (unlikely(PyDict_SetItemString(scratch_dict, "co_name", name))) return NULL; - replace = PyObject_GetAttrString(code, "replace"); - if (likely(replace)) { - PyObject *result = PyObject_Call(replace, __pyx_mstate_global->__pyx_empty_tuple, scratch_dict); - Py_DECREF(replace); - return result; - } - PyErr_Clear(); - return NULL; -} -static void __Pyx_AddTraceback(const char *funcname, int c_line, - int py_line, const char *filename) { - PyObject *code_object = NULL, *py_py_line = NULL, *py_funcname = NULL, *dict = NULL; - PyObject *replace = NULL, *getframe = NULL, *frame = NULL; - PyObject *exc_type, *exc_value, *exc_traceback; - int success = 0; - if (c_line) { - (void) __pyx_cfilenm; - (void) __Pyx_CLineForTraceback(__Pyx_PyThreadState_Current, c_line); - } - PyErr_Fetch(&exc_type, &exc_value, &exc_traceback); - code_object = __pyx_find_code_object(c_line ? -c_line : py_line); - if (!code_object) { - code_object = Py_CompileString("_getframe()", filename, Py_eval_input); - if (unlikely(!code_object)) goto bad; - py_py_line = PyLong_FromLong(py_line); - if (unlikely(!py_py_line)) goto bad; - py_funcname = PyUnicode_FromString(funcname); - if (unlikely(!py_funcname)) goto bad; - dict = PyDict_New(); - if (unlikely(!dict)) goto bad; - { - PyObject *old_code_object = code_object; - code_object = __Pyx_PyCode_Replace_For_AddTraceback(code_object, dict, py_py_line, py_funcname); - Py_DECREF(old_code_object); - } - if (unlikely(!code_object)) goto bad; - __pyx_insert_code_object(c_line ? -c_line : py_line, code_object); - } else { - dict = PyDict_New(); - } - getframe = PySys_GetObject("_getframe"); - if (unlikely(!getframe)) goto bad; - if (unlikely(PyDict_SetItemString(dict, "_getframe", getframe))) goto bad; - frame = PyEval_EvalCode(code_object, dict, dict); - if (unlikely(!frame) || frame == Py_None) goto bad; - success = 1; - bad: - PyErr_Restore(exc_type, exc_value, exc_traceback); - Py_XDECREF(code_object); - Py_XDECREF(py_py_line); - Py_XDECREF(py_funcname); - Py_XDECREF(dict); - Py_XDECREF(replace); - if (success) { - PyTraceBack_Here( - (struct _frame*)frame); - } - Py_XDECREF(frame); -} -#else -static PyCodeObject* __Pyx_CreateCodeObjectForTraceback( - const char *funcname, int c_line, - int py_line, const char *filename) { - PyCodeObject *py_code = NULL; - PyObject *py_funcname = NULL; - if (c_line) { - py_funcname = PyUnicode_FromFormat( "%s (%s:%d)", funcname, __pyx_cfilenm, c_line); - if (!py_funcname) goto bad; - funcname = PyUnicode_AsUTF8(py_funcname); - if (!funcname) goto bad; - } - py_code = PyCode_NewEmpty(filename, funcname, py_line); - Py_XDECREF(py_funcname); - return py_code; -bad: - Py_XDECREF(py_funcname); - return NULL; -} -static void __Pyx_AddTraceback(const char *funcname, int c_line, - int py_line, const char *filename) { - PyCodeObject *py_code = 0; - PyFrameObject *py_frame = 0; - PyThreadState *tstate = __Pyx_PyThreadState_Current; - PyObject *ptype, *pvalue, *ptraceback; - if (c_line) { - c_line = __Pyx_CLineForTraceback(tstate, c_line); - } - py_code = __pyx_find_code_object(c_line ? -c_line : py_line); - if (!py_code) { - __Pyx_ErrFetchInState(tstate, &ptype, &pvalue, &ptraceback); - py_code = __Pyx_CreateCodeObjectForTraceback( - funcname, c_line, py_line, filename); - if (!py_code) { - /* If the code object creation fails, then we should clear the - fetched exception references and propagate the new exception */ - Py_XDECREF(ptype); - Py_XDECREF(pvalue); - Py_XDECREF(ptraceback); - goto bad; - } - __Pyx_ErrRestoreInState(tstate, ptype, pvalue, ptraceback); - __pyx_insert_code_object(c_line ? -c_line : py_line, py_code); - } - py_frame = PyFrame_New( - tstate, /*PyThreadState *tstate,*/ - py_code, /*PyCodeObject *code,*/ - __pyx_mstate_global->__pyx_d, /*PyObject *globals,*/ - 0 /*PyObject *locals*/ - ); - if (!py_frame) goto bad; - __Pyx_PyFrame_SetLineNumber(py_frame, py_line); - PyTraceBack_Here(py_frame); -bad: - Py_XDECREF(py_code); - Py_XDECREF(py_frame); -} -#endif - -/* FormatTypeName */ -#if CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX < 0x030d0000 -static __Pyx_TypeName -__Pyx_PyType_GetFullyQualifiedName(PyTypeObject* tp) -{ - PyObject *module = NULL, *name = NULL, *result = NULL; - #if __PYX_LIMITED_VERSION_HEX < 0x030b0000 - name = __Pyx_PyObject_GetAttrStr((PyObject *)tp, - __pyx_mstate_global->__pyx_n_u_qualname); - #else - name = PyType_GetQualName(tp); - #endif - if (unlikely(name == NULL) || unlikely(!PyUnicode_Check(name))) goto bad; - module = __Pyx_PyObject_GetAttrStr((PyObject *)tp, - __pyx_mstate_global->__pyx_n_u_module); - if (unlikely(module == NULL) || unlikely(!PyUnicode_Check(module))) goto bad; - if (PyUnicode_CompareWithASCIIString(module, "builtins") == 0) { - result = name; - name = NULL; - goto done; - } - result = PyUnicode_FromFormat("%U.%U", module, name); - if (unlikely(result == NULL)) goto bad; - done: - Py_XDECREF(name); - Py_XDECREF(module); - return result; - bad: - PyErr_Clear(); - if (name) { - result = name; - name = NULL; - } else { - result = __Pyx_NewRef(__pyx_mstate_global->__pyx_kp_u__2); - } - goto done; -} -#endif - -/* PyFunctionFastCall */ -#if CYTHON_FAST_PYCALL && !CYTHON_VECTORCALL -static PyObject* __Pyx_PyFunction_FastCallNoKw(PyCodeObject *co, PyObject *const *args, Py_ssize_t na, - PyObject *globals) { - PyFrameObject *f; - PyThreadState *tstate = __Pyx_PyThreadState_Current; - PyObject **fastlocals; - Py_ssize_t i; - PyObject *result; - assert(globals != NULL); - /* XXX Perhaps we should create a specialized - PyFrame_New() that doesn't take locals, but does - take builtins without sanity checking them. - */ - assert(tstate != NULL); - f = PyFrame_New(tstate, co, globals, NULL); - if (f == NULL) { - return NULL; - } - fastlocals = __Pyx_PyFrame_GetLocalsplus(f); - for (i = 0; i < na; i++) { - Py_INCREF(*args); - fastlocals[i] = *args++; - } - result = PyEval_EvalFrameEx(f,0); - ++tstate->recursion_depth; - Py_DECREF(f); - --tstate->recursion_depth; - return result; -} -static PyObject *__Pyx_PyFunction_FastCallDict(PyObject *func, PyObject *const *args, Py_ssize_t nargs, PyObject *kwargs) { - PyCodeObject *co = (PyCodeObject *)PyFunction_GET_CODE(func); - PyObject *globals = PyFunction_GET_GLOBALS(func); - PyObject *argdefs = PyFunction_GET_DEFAULTS(func); - PyObject *closure; - PyObject *kwdefs; - PyObject *kwtuple, **k; - PyObject **d; - Py_ssize_t nd; - Py_ssize_t nk; - PyObject *result; - assert(kwargs == NULL || PyDict_Check(kwargs)); - nk = kwargs ? PyDict_Size(kwargs) : 0; - if (unlikely(Py_EnterRecursiveCall(" while calling a Python object"))) { - return NULL; - } - if ( - co->co_kwonlyargcount == 0 && - likely(kwargs == NULL || nk == 0) && - co->co_flags == (CO_OPTIMIZED | CO_NEWLOCALS | CO_NOFREE)) { - if (argdefs == NULL && co->co_argcount == nargs) { - result = __Pyx_PyFunction_FastCallNoKw(co, args, nargs, globals); - goto done; - } - else if (nargs == 0 && argdefs != NULL - && co->co_argcount == Py_SIZE(argdefs)) { - /* function called with no arguments, but all parameters have - a default value: use default values as arguments .*/ - args = &PyTuple_GET_ITEM(argdefs, 0); - result =__Pyx_PyFunction_FastCallNoKw(co, args, Py_SIZE(argdefs), globals); - goto done; - } - } - if (kwargs != NULL) { - Py_ssize_t pos, i; - kwtuple = PyTuple_New(2 * nk); - if (kwtuple == NULL) { - result = NULL; - goto done; - } - k = &PyTuple_GET_ITEM(kwtuple, 0); - pos = i = 0; - while (PyDict_Next(kwargs, &pos, &k[i], &k[i+1])) { - Py_INCREF(k[i]); - Py_INCREF(k[i+1]); - i += 2; - } - nk = i / 2; - } - else { - kwtuple = NULL; - k = NULL; - } - closure = PyFunction_GET_CLOSURE(func); - kwdefs = PyFunction_GET_KW_DEFAULTS(func); - if (argdefs != NULL) { - d = &PyTuple_GET_ITEM(argdefs, 0); - nd = Py_SIZE(argdefs); - } - else { - d = NULL; - nd = 0; - } - result = PyEval_EvalCodeEx((PyObject*)co, globals, (PyObject *)NULL, - args, (int)nargs, - k, (int)nk, - d, (int)nd, kwdefs, closure); - Py_XDECREF(kwtuple); -done: - Py_LeaveRecursiveCall(); - return result; -} -#endif - -/* PyObjectCall */ -#if CYTHON_COMPILING_IN_CPYTHON -static CYTHON_INLINE PyObject* __Pyx_PyObject_Call(PyObject *func, PyObject *arg, PyObject *kw) { - PyObject *result; - ternaryfunc call = Py_TYPE(func)->tp_call; - if (unlikely(!call)) - return PyObject_Call(func, arg, kw); - if (unlikely(Py_EnterRecursiveCall(" while calling a Python object"))) - return NULL; - result = (*call)(func, arg, kw); - Py_LeaveRecursiveCall(); - if (unlikely(!result) && unlikely(!PyErr_Occurred())) { - PyErr_SetString( - PyExc_SystemError, - "NULL result without error in PyObject_Call"); - } - return result; -} -#endif - -/* PyObjectCallMethO */ -#if CYTHON_COMPILING_IN_CPYTHON -static CYTHON_INLINE PyObject* __Pyx_PyObject_CallMethO(PyObject *func, PyObject *arg) { - PyObject *self, *result; - PyCFunction cfunc; - cfunc = __Pyx_CyOrPyCFunction_GET_FUNCTION(func); - self = __Pyx_CyOrPyCFunction_GET_SELF(func); - if (unlikely(Py_EnterRecursiveCall(" while calling a Python object"))) - return NULL; - result = cfunc(self, arg); - Py_LeaveRecursiveCall(); - if (unlikely(!result) && unlikely(!PyErr_Occurred())) { - PyErr_SetString( - PyExc_SystemError, - "NULL result without error in PyObject_Call"); - } - return result; -} -#endif - -/* PyObjectFastCall */ -#if PY_VERSION_HEX < 0x03090000 || CYTHON_COMPILING_IN_LIMITED_API -static PyObject* __Pyx_PyObject_FastCall_fallback(PyObject *func, PyObject * const*args, size_t nargs, PyObject *kwargs) { - PyObject *argstuple; - PyObject *result = 0; - size_t i; - argstuple = PyTuple_New((Py_ssize_t)nargs); - if (unlikely(!argstuple)) return NULL; - for (i = 0; i < nargs; i++) { - Py_INCREF(args[i]); - if (__Pyx_PyTuple_SET_ITEM(argstuple, (Py_ssize_t)i, args[i]) != (0)) goto bad; - } - result = __Pyx_PyObject_Call(func, argstuple, kwargs); - bad: - Py_DECREF(argstuple); - return result; -} -#endif -#if CYTHON_VECTORCALL && !CYTHON_COMPILING_IN_LIMITED_API - #if PY_VERSION_HEX < 0x03090000 - #define __Pyx_PyVectorcall_Function(callable) _PyVectorcall_Function(callable) - #elif CYTHON_COMPILING_IN_CPYTHON -static CYTHON_INLINE vectorcallfunc __Pyx_PyVectorcall_Function(PyObject *callable) { - PyTypeObject *tp = Py_TYPE(callable); - #if defined(__Pyx_CyFunction_USED) - if (__Pyx_CyFunction_CheckExact(callable)) { - return __Pyx_CyFunction_func_vectorcall(callable); - } - #endif - if (!PyType_HasFeature(tp, Py_TPFLAGS_HAVE_VECTORCALL)) { - return NULL; - } - assert(PyCallable_Check(callable)); - Py_ssize_t offset = tp->tp_vectorcall_offset; - assert(offset > 0); - vectorcallfunc ptr; - memcpy(&ptr, (char *) callable + offset, sizeof(ptr)); - return ptr; -} - #else - #define __Pyx_PyVectorcall_Function(callable) PyVectorcall_Function(callable) - #endif -#endif -static CYTHON_INLINE PyObject* __Pyx_PyObject_FastCallDict(PyObject *func, PyObject *const *args, size_t _nargs, PyObject *kwargs) { - Py_ssize_t nargs = __Pyx_PyVectorcall_NARGS(_nargs); -#if CYTHON_COMPILING_IN_CPYTHON - if (nargs == 0 && kwargs == NULL) { - if (__Pyx_CyOrPyCFunction_Check(func) && likely( __Pyx_CyOrPyCFunction_GET_FLAGS(func) & METH_NOARGS)) - return __Pyx_PyObject_CallMethO(func, NULL); - } - else if (nargs == 1 && kwargs == NULL) { - if (__Pyx_CyOrPyCFunction_Check(func) && likely( __Pyx_CyOrPyCFunction_GET_FLAGS(func) & METH_O)) - return __Pyx_PyObject_CallMethO(func, args[0]); - } -#endif - #if PY_VERSION_HEX < 0x030800B1 - #if CYTHON_FAST_PYCCALL - if (PyCFunction_Check(func)) { - if (kwargs) { - return _PyCFunction_FastCallDict(func, args, nargs, kwargs); - } else { - return _PyCFunction_FastCallKeywords(func, args, nargs, NULL); - } - } - if (!kwargs && __Pyx_IS_TYPE(func, &PyMethodDescr_Type)) { - return _PyMethodDescr_FastCallKeywords(func, args, nargs, NULL); - } - #endif - #if CYTHON_FAST_PYCALL - if (PyFunction_Check(func)) { - return __Pyx_PyFunction_FastCallDict(func, args, nargs, kwargs); - } - #endif - #endif - if (kwargs == NULL) { - #if CYTHON_VECTORCALL && !CYTHON_COMPILING_IN_LIMITED_API - vectorcallfunc f = __Pyx_PyVectorcall_Function(func); - if (f) { - return f(func, args, _nargs, NULL); - } - #elif defined(__Pyx_CyFunction_USED) && CYTHON_BACKPORT_VECTORCALL - if (__Pyx_CyFunction_CheckExact(func)) { - __pyx_vectorcallfunc f = __Pyx_CyFunction_func_vectorcall(func); - if (f) return f(func, args, _nargs, NULL); - } - #elif CYTHON_COMPILING_IN_LIMITED_API && CYTHON_VECTORCALL - return PyObject_Vectorcall(func, args, _nargs, NULL); - #endif - } - if (nargs == 0) { - return __Pyx_PyObject_Call(func, __pyx_mstate_global->__pyx_empty_tuple, kwargs); - } - #if PY_VERSION_HEX >= 0x03090000 && !CYTHON_COMPILING_IN_LIMITED_API - return PyObject_VectorcallDict(func, args, (size_t)nargs, kwargs); - #else - return __Pyx_PyObject_FastCall_fallback(func, args, (size_t)nargs, kwargs); - #endif -} - -/* PyObjectVectorCallKwBuilder */ -#if CYTHON_VECTORCALL -static int __Pyx_VectorcallBuilder_AddArg(PyObject *key, PyObject *value, PyObject *builder, PyObject **args, int n) { - (void)__Pyx_PyObject_FastCallDict; - if (__Pyx_PyTuple_SET_ITEM(builder, n, key) != (0)) return -1; - Py_INCREF(key); - args[n] = value; - return 0; -} -CYTHON_UNUSED static int __Pyx_VectorcallBuilder_AddArg_Check(PyObject *key, PyObject *value, PyObject *builder, PyObject **args, int n) { - (void)__Pyx_VectorcallBuilder_AddArgStr; - if (unlikely(!PyUnicode_Check(key))) { - PyErr_SetString(PyExc_TypeError, "keywords must be strings"); - return -1; - } - return __Pyx_VectorcallBuilder_AddArg(key, value, builder, args, n); -} -static int __Pyx_VectorcallBuilder_AddArgStr(const char *key, PyObject *value, PyObject *builder, PyObject **args, int n) { - PyObject *pyKey = PyUnicode_FromString(key); - if (!pyKey) return -1; - return __Pyx_VectorcallBuilder_AddArg(pyKey, value, builder, args, n); -} -#else // CYTHON_VECTORCALL -CYTHON_UNUSED static int __Pyx_VectorcallBuilder_AddArg_Check(PyObject *key, PyObject *value, PyObject *builder, CYTHON_UNUSED PyObject **args, CYTHON_UNUSED int n) { - if (unlikely(!PyUnicode_Check(key))) { - PyErr_SetString(PyExc_TypeError, "keywords must be strings"); - return -1; - } - return PyDict_SetItem(builder, key, value); -} -#endif - -/* CIntToPy */ -static CYTHON_INLINE PyObject* __Pyx_PyLong_From_long(long value) { -#ifdef __Pyx_HAS_GCC_DIAGNOSTIC -#pragma GCC diagnostic push -#pragma GCC diagnostic ignored "-Wconversion" -#endif - const long neg_one = (long) -1, const_zero = (long) 0; -#ifdef __Pyx_HAS_GCC_DIAGNOSTIC -#pragma GCC diagnostic pop -#endif - const int is_unsigned = neg_one > const_zero; - if (is_unsigned) { - if (sizeof(long) < sizeof(long)) { - return PyLong_FromLong((long) value); - } else if (sizeof(long) <= sizeof(unsigned long)) { - return PyLong_FromUnsignedLong((unsigned long) value); -#ifdef HAVE_LONG_LONG - } else if (sizeof(long) <= sizeof(unsigned PY_LONG_LONG)) { - return PyLong_FromUnsignedLongLong((unsigned PY_LONG_LONG) value); -#endif - } - } else { - if (sizeof(long) <= sizeof(long)) { - return PyLong_FromLong((long) value); -#ifdef HAVE_LONG_LONG - } else if (sizeof(long) <= sizeof(PY_LONG_LONG)) { - return PyLong_FromLongLong((PY_LONG_LONG) value); -#endif - } - } - { - unsigned char *bytes = (unsigned char *)&value; -#if !CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX >= 0x030d00A4 - if (is_unsigned) { - return PyLong_FromUnsignedNativeBytes(bytes, sizeof(value), -1); - } else { - return PyLong_FromNativeBytes(bytes, sizeof(value), -1); - } -#elif !CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX < 0x030d0000 - int one = 1; int little = (int)*(unsigned char *)&one; - return _PyLong_FromByteArray(bytes, sizeof(long), - little, !is_unsigned); -#else - int one = 1; int little = (int)*(unsigned char *)&one; - PyObject *from_bytes, *result = NULL, *kwds = NULL; - PyObject *py_bytes = NULL, *order_str = NULL; - from_bytes = PyObject_GetAttrString((PyObject*)&PyLong_Type, "from_bytes"); - if (!from_bytes) return NULL; - py_bytes = PyBytes_FromStringAndSize((char*)bytes, sizeof(long)); - if (!py_bytes) goto limited_bad; - order_str = PyUnicode_FromString(little ? "little" : "big"); - if (!order_str) goto limited_bad; - { - PyObject *args[3+(CYTHON_VECTORCALL ? 1 : 0)] = { NULL, py_bytes, order_str }; - if (!is_unsigned) { - kwds = __Pyx_MakeVectorcallBuilderKwds(1); - if (!kwds) goto limited_bad; - if (__Pyx_VectorcallBuilder_AddArgStr("signed", __Pyx_NewRef(Py_True), kwds, args+3, 0) < 0) goto limited_bad; - } - result = __Pyx_Object_Vectorcall_CallFromBuilder(from_bytes, args+1, 2 | __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET, kwds); - } - limited_bad: - Py_XDECREF(kwds); - Py_XDECREF(order_str); - Py_XDECREF(py_bytes); - Py_XDECREF(from_bytes); - return result; -#endif - } -} - -/* CIntFromPyVerify */ -#define __PYX_VERIFY_RETURN_INT(target_type, func_type, func_value)\ - __PYX__VERIFY_RETURN_INT(target_type, func_type, func_value, 0) -#define __PYX_VERIFY_RETURN_INT_EXC(target_type, func_type, func_value)\ - __PYX__VERIFY_RETURN_INT(target_type, func_type, func_value, 1) -#define __PYX__VERIFY_RETURN_INT(target_type, func_type, func_value, exc)\ - {\ - func_type value = func_value;\ - if (sizeof(target_type) < sizeof(func_type)) {\ - if (unlikely(value != (func_type) (target_type) value)) {\ - func_type zero = 0;\ - if (exc && unlikely(value == (func_type)-1 && PyErr_Occurred()))\ - return (target_type) -1;\ - if (is_unsigned && unlikely(value < zero))\ - goto raise_neg_overflow;\ - else\ - goto raise_overflow;\ - }\ - }\ - return (target_type) value;\ - } - -/* CIntFromPy */ -static CYTHON_INLINE long __Pyx_PyLong_As_long(PyObject *x) { -#ifdef __Pyx_HAS_GCC_DIAGNOSTIC -#pragma GCC diagnostic push -#pragma GCC diagnostic ignored "-Wconversion" -#endif - const long neg_one = (long) -1, const_zero = (long) 0; -#ifdef __Pyx_HAS_GCC_DIAGNOSTIC -#pragma GCC diagnostic pop -#endif - const int is_unsigned = neg_one > const_zero; - if (unlikely(!PyLong_Check(x))) { - long val; - PyObject *tmp = __Pyx_PyNumber_Long(x); - if (!tmp) return (long) -1; - val = __Pyx_PyLong_As_long(tmp); - Py_DECREF(tmp); - return val; - } - if (is_unsigned) { -#if CYTHON_USE_PYLONG_INTERNALS - if (unlikely(__Pyx_PyLong_IsNeg(x))) { - goto raise_neg_overflow; - } else if (__Pyx_PyLong_IsCompact(x)) { - __PYX_VERIFY_RETURN_INT(long, __Pyx_compact_upylong, __Pyx_PyLong_CompactValueUnsigned(x)) - } else { - const digit* digits = __Pyx_PyLong_Digits(x); - assert(__Pyx_PyLong_DigitCount(x) > 1); - switch (__Pyx_PyLong_DigitCount(x)) { - case 2: - if ((8 * sizeof(long) > 1 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 2 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(long, unsigned long, (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(long) >= 2 * PyLong_SHIFT)) { - return (long) (((((long)digits[1]) << PyLong_SHIFT) | (long)digits[0])); - } - } - break; - case 3: - if ((8 * sizeof(long) > 2 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 3 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(long, unsigned long, (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(long) >= 3 * PyLong_SHIFT)) { - return (long) (((((((long)digits[2]) << PyLong_SHIFT) | (long)digits[1]) << PyLong_SHIFT) | (long)digits[0])); - } - } - break; - case 4: - if ((8 * sizeof(long) > 3 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 4 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(long, unsigned long, (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(long) >= 4 * PyLong_SHIFT)) { - return (long) (((((((((long)digits[3]) << PyLong_SHIFT) | (long)digits[2]) << PyLong_SHIFT) | (long)digits[1]) << PyLong_SHIFT) | (long)digits[0])); - } - } - break; - } - } -#endif -#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX < 0x030C00A7 - if (unlikely(Py_SIZE(x) < 0)) { - goto raise_neg_overflow; - } -#else - { - int result = PyObject_RichCompareBool(x, Py_False, Py_LT); - if (unlikely(result < 0)) - return (long) -1; - if (unlikely(result == 1)) - goto raise_neg_overflow; - } -#endif - if ((sizeof(long) <= sizeof(unsigned long))) { - __PYX_VERIFY_RETURN_INT_EXC(long, unsigned long, PyLong_AsUnsignedLong(x)) -#ifdef HAVE_LONG_LONG - } else if ((sizeof(long) <= sizeof(unsigned PY_LONG_LONG))) { - __PYX_VERIFY_RETURN_INT_EXC(long, unsigned PY_LONG_LONG, PyLong_AsUnsignedLongLong(x)) -#endif - } - } else { -#if CYTHON_USE_PYLONG_INTERNALS - if (__Pyx_PyLong_IsCompact(x)) { - __PYX_VERIFY_RETURN_INT(long, __Pyx_compact_pylong, __Pyx_PyLong_CompactValue(x)) - } else { - const digit* digits = __Pyx_PyLong_Digits(x); - assert(__Pyx_PyLong_DigitCount(x) > 1); - switch (__Pyx_PyLong_SignedDigitCount(x)) { - case -2: - if ((8 * sizeof(long) - 1 > 1 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 2 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(long, long, -(long) (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(long) - 1 > 2 * PyLong_SHIFT)) { - return (long) (((long)-1)*(((((long)digits[1]) << PyLong_SHIFT) | (long)digits[0]))); - } - } - break; - case 2: - if ((8 * sizeof(long) > 1 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 2 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(long, unsigned long, (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(long) - 1 > 2 * PyLong_SHIFT)) { - return (long) ((((((long)digits[1]) << PyLong_SHIFT) | (long)digits[0]))); - } - } - break; - case -3: - if ((8 * sizeof(long) - 1 > 2 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 3 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(long, long, -(long) (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(long) - 1 > 3 * PyLong_SHIFT)) { - return (long) (((long)-1)*(((((((long)digits[2]) << PyLong_SHIFT) | (long)digits[1]) << PyLong_SHIFT) | (long)digits[0]))); - } - } - break; - case 3: - if ((8 * sizeof(long) > 2 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 3 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(long, unsigned long, (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(long) - 1 > 3 * PyLong_SHIFT)) { - return (long) ((((((((long)digits[2]) << PyLong_SHIFT) | (long)digits[1]) << PyLong_SHIFT) | (long)digits[0]))); - } - } - break; - case -4: - if ((8 * sizeof(long) - 1 > 3 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 4 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(long, long, -(long) (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(long) - 1 > 4 * PyLong_SHIFT)) { - return (long) (((long)-1)*(((((((((long)digits[3]) << PyLong_SHIFT) | (long)digits[2]) << PyLong_SHIFT) | (long)digits[1]) << PyLong_SHIFT) | (long)digits[0]))); - } - } - break; - case 4: - if ((8 * sizeof(long) > 3 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 4 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(long, unsigned long, (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(long) - 1 > 4 * PyLong_SHIFT)) { - return (long) ((((((((((long)digits[3]) << PyLong_SHIFT) | (long)digits[2]) << PyLong_SHIFT) | (long)digits[1]) << PyLong_SHIFT) | (long)digits[0]))); - } - } - break; - } - } -#endif - if ((sizeof(long) <= sizeof(long))) { - __PYX_VERIFY_RETURN_INT_EXC(long, long, PyLong_AsLong(x)) -#ifdef HAVE_LONG_LONG - } else if ((sizeof(long) <= sizeof(PY_LONG_LONG))) { - __PYX_VERIFY_RETURN_INT_EXC(long, PY_LONG_LONG, PyLong_AsLongLong(x)) -#endif - } - } - { - long val; - int ret = -1; -#if PY_VERSION_HEX >= 0x030d00A6 && !CYTHON_COMPILING_IN_LIMITED_API - Py_ssize_t bytes_copied = PyLong_AsNativeBytes( - x, &val, sizeof(val), Py_ASNATIVEBYTES_NATIVE_ENDIAN | (is_unsigned ? Py_ASNATIVEBYTES_UNSIGNED_BUFFER | Py_ASNATIVEBYTES_REJECT_NEGATIVE : 0)); - if (unlikely(bytes_copied == -1)) { - } else if (unlikely(bytes_copied > (Py_ssize_t) sizeof(val))) { - goto raise_overflow; - } else { - ret = 0; - } -#elif PY_VERSION_HEX < 0x030d0000 && !(CYTHON_COMPILING_IN_PYPY || CYTHON_COMPILING_IN_LIMITED_API) || defined(_PyLong_AsByteArray) - int one = 1; int is_little = (int)*(unsigned char *)&one; - unsigned char *bytes = (unsigned char *)&val; - ret = _PyLong_AsByteArray((PyLongObject *)x, - bytes, sizeof(val), - is_little, !is_unsigned); -#else - PyObject *v; - PyObject *stepval = NULL, *mask = NULL, *shift = NULL; - int bits, remaining_bits, is_negative = 0; - int chunk_size = (sizeof(long) < 8) ? 30 : 62; - if (likely(PyLong_CheckExact(x))) { - v = __Pyx_NewRef(x); - } else { - v = PyNumber_Long(x); - if (unlikely(!v)) return (long) -1; - assert(PyLong_CheckExact(v)); - } - { - int result = PyObject_RichCompareBool(v, Py_False, Py_LT); - if (unlikely(result < 0)) { - Py_DECREF(v); - return (long) -1; - } - is_negative = result == 1; - } - if (is_unsigned && unlikely(is_negative)) { - Py_DECREF(v); - goto raise_neg_overflow; - } else if (is_negative) { - stepval = PyNumber_Invert(v); - Py_DECREF(v); - if (unlikely(!stepval)) - return (long) -1; - } else { - stepval = v; - } - v = NULL; - val = (long) 0; - mask = PyLong_FromLong((1L << chunk_size) - 1); if (unlikely(!mask)) goto done; - shift = PyLong_FromLong(chunk_size); if (unlikely(!shift)) goto done; - for (bits = 0; bits < (int) sizeof(long) * 8 - chunk_size; bits += chunk_size) { - PyObject *tmp, *digit; - long idigit; - digit = PyNumber_And(stepval, mask); - if (unlikely(!digit)) goto done; - idigit = PyLong_AsLong(digit); - Py_DECREF(digit); - if (unlikely(idigit < 0)) goto done; - val |= ((long) idigit) << bits; - tmp = PyNumber_Rshift(stepval, shift); - if (unlikely(!tmp)) goto done; - Py_DECREF(stepval); stepval = tmp; - } - Py_DECREF(shift); shift = NULL; - Py_DECREF(mask); mask = NULL; - { - long idigit = PyLong_AsLong(stepval); - if (unlikely(idigit < 0)) goto done; - remaining_bits = ((int) sizeof(long) * 8) - bits - (is_unsigned ? 0 : 1); - if (unlikely(idigit >= (1L << remaining_bits))) - goto raise_overflow; - val |= ((long) idigit) << bits; - } - if (!is_unsigned) { - if (unlikely(val & (((long) 1) << (sizeof(long) * 8 - 1)))) - goto raise_overflow; - if (is_negative) - val = ~val; - } - ret = 0; - done: - Py_XDECREF(shift); - Py_XDECREF(mask); - Py_XDECREF(stepval); -#endif - if (unlikely(ret)) - return (long) -1; - return val; - } -raise_overflow: - PyErr_SetString(PyExc_OverflowError, - "value too large to convert to long"); - return (long) -1; -raise_neg_overflow: - PyErr_SetString(PyExc_OverflowError, - "can't convert negative value to long"); - return (long) -1; -} - -/* CIntFromPy */ -static CYTHON_INLINE int __Pyx_PyLong_As_int(PyObject *x) { -#ifdef __Pyx_HAS_GCC_DIAGNOSTIC -#pragma GCC diagnostic push -#pragma GCC diagnostic ignored "-Wconversion" -#endif - const int neg_one = (int) -1, const_zero = (int) 0; -#ifdef __Pyx_HAS_GCC_DIAGNOSTIC -#pragma GCC diagnostic pop -#endif - const int is_unsigned = neg_one > const_zero; - if (unlikely(!PyLong_Check(x))) { - int val; - PyObject *tmp = __Pyx_PyNumber_Long(x); - if (!tmp) return (int) -1; - val = __Pyx_PyLong_As_int(tmp); - Py_DECREF(tmp); - return val; - } - if (is_unsigned) { -#if CYTHON_USE_PYLONG_INTERNALS - if (unlikely(__Pyx_PyLong_IsNeg(x))) { - goto raise_neg_overflow; - } else if (__Pyx_PyLong_IsCompact(x)) { - __PYX_VERIFY_RETURN_INT(int, __Pyx_compact_upylong, __Pyx_PyLong_CompactValueUnsigned(x)) - } else { - const digit* digits = __Pyx_PyLong_Digits(x); - assert(__Pyx_PyLong_DigitCount(x) > 1); - switch (__Pyx_PyLong_DigitCount(x)) { - case 2: - if ((8 * sizeof(int) > 1 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 2 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(int, unsigned long, (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(int) >= 2 * PyLong_SHIFT)) { - return (int) (((((int)digits[1]) << PyLong_SHIFT) | (int)digits[0])); - } - } - break; - case 3: - if ((8 * sizeof(int) > 2 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 3 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(int, unsigned long, (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(int) >= 3 * PyLong_SHIFT)) { - return (int) (((((((int)digits[2]) << PyLong_SHIFT) | (int)digits[1]) << PyLong_SHIFT) | (int)digits[0])); - } - } - break; - case 4: - if ((8 * sizeof(int) > 3 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 4 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(int, unsigned long, (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(int) >= 4 * PyLong_SHIFT)) { - return (int) (((((((((int)digits[3]) << PyLong_SHIFT) | (int)digits[2]) << PyLong_SHIFT) | (int)digits[1]) << PyLong_SHIFT) | (int)digits[0])); - } - } - break; - } - } -#endif -#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX < 0x030C00A7 - if (unlikely(Py_SIZE(x) < 0)) { - goto raise_neg_overflow; - } -#else - { - int result = PyObject_RichCompareBool(x, Py_False, Py_LT); - if (unlikely(result < 0)) - return (int) -1; - if (unlikely(result == 1)) - goto raise_neg_overflow; - } -#endif - if ((sizeof(int) <= sizeof(unsigned long))) { - __PYX_VERIFY_RETURN_INT_EXC(int, unsigned long, PyLong_AsUnsignedLong(x)) -#ifdef HAVE_LONG_LONG - } else if ((sizeof(int) <= sizeof(unsigned PY_LONG_LONG))) { - __PYX_VERIFY_RETURN_INT_EXC(int, unsigned PY_LONG_LONG, PyLong_AsUnsignedLongLong(x)) -#endif - } - } else { -#if CYTHON_USE_PYLONG_INTERNALS - if (__Pyx_PyLong_IsCompact(x)) { - __PYX_VERIFY_RETURN_INT(int, __Pyx_compact_pylong, __Pyx_PyLong_CompactValue(x)) - } else { - const digit* digits = __Pyx_PyLong_Digits(x); - assert(__Pyx_PyLong_DigitCount(x) > 1); - switch (__Pyx_PyLong_SignedDigitCount(x)) { - case -2: - if ((8 * sizeof(int) - 1 > 1 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 2 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(int, long, -(long) (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(int) - 1 > 2 * PyLong_SHIFT)) { - return (int) (((int)-1)*(((((int)digits[1]) << PyLong_SHIFT) | (int)digits[0]))); - } - } - break; - case 2: - if ((8 * sizeof(int) > 1 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 2 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(int, unsigned long, (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(int) - 1 > 2 * PyLong_SHIFT)) { - return (int) ((((((int)digits[1]) << PyLong_SHIFT) | (int)digits[0]))); - } - } - break; - case -3: - if ((8 * sizeof(int) - 1 > 2 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 3 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(int, long, -(long) (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(int) - 1 > 3 * PyLong_SHIFT)) { - return (int) (((int)-1)*(((((((int)digits[2]) << PyLong_SHIFT) | (int)digits[1]) << PyLong_SHIFT) | (int)digits[0]))); - } - } - break; - case 3: - if ((8 * sizeof(int) > 2 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 3 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(int, unsigned long, (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(int) - 1 > 3 * PyLong_SHIFT)) { - return (int) ((((((((int)digits[2]) << PyLong_SHIFT) | (int)digits[1]) << PyLong_SHIFT) | (int)digits[0]))); - } - } - break; - case -4: - if ((8 * sizeof(int) - 1 > 3 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 4 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(int, long, -(long) (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(int) - 1 > 4 * PyLong_SHIFT)) { - return (int) (((int)-1)*(((((((((int)digits[3]) << PyLong_SHIFT) | (int)digits[2]) << PyLong_SHIFT) | (int)digits[1]) << PyLong_SHIFT) | (int)digits[0]))); - } - } - break; - case 4: - if ((8 * sizeof(int) > 3 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 4 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(int, unsigned long, (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(int) - 1 > 4 * PyLong_SHIFT)) { - return (int) ((((((((((int)digits[3]) << PyLong_SHIFT) | (int)digits[2]) << PyLong_SHIFT) | (int)digits[1]) << PyLong_SHIFT) | (int)digits[0]))); - } - } - break; - } - } -#endif - if ((sizeof(int) <= sizeof(long))) { - __PYX_VERIFY_RETURN_INT_EXC(int, long, PyLong_AsLong(x)) -#ifdef HAVE_LONG_LONG - } else if ((sizeof(int) <= sizeof(PY_LONG_LONG))) { - __PYX_VERIFY_RETURN_INT_EXC(int, PY_LONG_LONG, PyLong_AsLongLong(x)) -#endif - } - } - { - int val; - int ret = -1; -#if PY_VERSION_HEX >= 0x030d00A6 && !CYTHON_COMPILING_IN_LIMITED_API - Py_ssize_t bytes_copied = PyLong_AsNativeBytes( - x, &val, sizeof(val), Py_ASNATIVEBYTES_NATIVE_ENDIAN | (is_unsigned ? Py_ASNATIVEBYTES_UNSIGNED_BUFFER | Py_ASNATIVEBYTES_REJECT_NEGATIVE : 0)); - if (unlikely(bytes_copied == -1)) { - } else if (unlikely(bytes_copied > (Py_ssize_t) sizeof(val))) { - goto raise_overflow; - } else { - ret = 0; - } -#elif PY_VERSION_HEX < 0x030d0000 && !(CYTHON_COMPILING_IN_PYPY || CYTHON_COMPILING_IN_LIMITED_API) || defined(_PyLong_AsByteArray) - int one = 1; int is_little = (int)*(unsigned char *)&one; - unsigned char *bytes = (unsigned char *)&val; - ret = _PyLong_AsByteArray((PyLongObject *)x, - bytes, sizeof(val), - is_little, !is_unsigned); -#else - PyObject *v; - PyObject *stepval = NULL, *mask = NULL, *shift = NULL; - int bits, remaining_bits, is_negative = 0; - int chunk_size = (sizeof(long) < 8) ? 30 : 62; - if (likely(PyLong_CheckExact(x))) { - v = __Pyx_NewRef(x); - } else { - v = PyNumber_Long(x); - if (unlikely(!v)) return (int) -1; - assert(PyLong_CheckExact(v)); - } - { - int result = PyObject_RichCompareBool(v, Py_False, Py_LT); - if (unlikely(result < 0)) { - Py_DECREF(v); - return (int) -1; - } - is_negative = result == 1; - } - if (is_unsigned && unlikely(is_negative)) { - Py_DECREF(v); - goto raise_neg_overflow; - } else if (is_negative) { - stepval = PyNumber_Invert(v); - Py_DECREF(v); - if (unlikely(!stepval)) - return (int) -1; - } else { - stepval = v; - } - v = NULL; - val = (int) 0; - mask = PyLong_FromLong((1L << chunk_size) - 1); if (unlikely(!mask)) goto done; - shift = PyLong_FromLong(chunk_size); if (unlikely(!shift)) goto done; - for (bits = 0; bits < (int) sizeof(int) * 8 - chunk_size; bits += chunk_size) { - PyObject *tmp, *digit; - long idigit; - digit = PyNumber_And(stepval, mask); - if (unlikely(!digit)) goto done; - idigit = PyLong_AsLong(digit); - Py_DECREF(digit); - if (unlikely(idigit < 0)) goto done; - val |= ((int) idigit) << bits; - tmp = PyNumber_Rshift(stepval, shift); - if (unlikely(!tmp)) goto done; - Py_DECREF(stepval); stepval = tmp; - } - Py_DECREF(shift); shift = NULL; - Py_DECREF(mask); mask = NULL; - { - long idigit = PyLong_AsLong(stepval); - if (unlikely(idigit < 0)) goto done; - remaining_bits = ((int) sizeof(int) * 8) - bits - (is_unsigned ? 0 : 1); - if (unlikely(idigit >= (1L << remaining_bits))) - goto raise_overflow; - val |= ((int) idigit) << bits; - } - if (!is_unsigned) { - if (unlikely(val & (((int) 1) << (sizeof(int) * 8 - 1)))) - goto raise_overflow; - if (is_negative) - val = ~val; - } - ret = 0; - done: - Py_XDECREF(shift); - Py_XDECREF(mask); - Py_XDECREF(stepval); -#endif - if (unlikely(ret)) - return (int) -1; - return val; - } -raise_overflow: - PyErr_SetString(PyExc_OverflowError, - "value too large to convert to int"); - return (int) -1; -raise_neg_overflow: - PyErr_SetString(PyExc_OverflowError, - "can't convert negative value to int"); - return (int) -1; -} - -/* FastTypeChecks */ -#if CYTHON_COMPILING_IN_CPYTHON -static int __Pyx_InBases(PyTypeObject *a, PyTypeObject *b) { - while (a) { - a = __Pyx_PyType_GetSlot(a, tp_base, PyTypeObject*); - if (a == b) - return 1; - } - return b == &PyBaseObject_Type; -} -static CYTHON_INLINE int __Pyx_IsSubtype(PyTypeObject *a, PyTypeObject *b) { - PyObject *mro; - if (a == b) return 1; - mro = a->tp_mro; - if (likely(mro)) { - Py_ssize_t i, n; - n = PyTuple_GET_SIZE(mro); - for (i = 0; i < n; i++) { - if (PyTuple_GET_ITEM(mro, i) == (PyObject *)b) - return 1; - } - return 0; - } - return __Pyx_InBases(a, b); -} -static CYTHON_INLINE int __Pyx_IsAnySubtype2(PyTypeObject *cls, PyTypeObject *a, PyTypeObject *b) { - PyObject *mro; - if (cls == a || cls == b) return 1; - mro = cls->tp_mro; - if (likely(mro)) { - Py_ssize_t i, n; - n = PyTuple_GET_SIZE(mro); - for (i = 0; i < n; i++) { - PyObject *base = PyTuple_GET_ITEM(mro, i); - if (base == (PyObject *)a || base == (PyObject *)b) - return 1; - } - return 0; - } - return __Pyx_InBases(cls, a) || __Pyx_InBases(cls, b); -} -static CYTHON_INLINE int __Pyx_inner_PyErr_GivenExceptionMatches2(PyObject *err, PyObject* exc_type1, PyObject *exc_type2) { - if (exc_type1) { - return __Pyx_IsAnySubtype2((PyTypeObject*)err, (PyTypeObject*)exc_type1, (PyTypeObject*)exc_type2); - } else { - return __Pyx_IsSubtype((PyTypeObject*)err, (PyTypeObject*)exc_type2); - } -} -static int __Pyx_PyErr_GivenExceptionMatchesTuple(PyObject *exc_type, PyObject *tuple) { - Py_ssize_t i, n; - assert(PyExceptionClass_Check(exc_type)); - n = PyTuple_GET_SIZE(tuple); - for (i=0; i= 0x030b0000 - return Py_Version & ~0xFFUL; -#else - static unsigned long __Pyx_cached_runtime_version = 0; - if (__Pyx_cached_runtime_version == 0) { - const char* rt_version = Py_GetVersion(); - unsigned long version = 0; - unsigned long factor = 0x01000000UL; - unsigned int digit = 0; - int i = 0; - while (factor) { - while ('0' <= rt_version[i] && rt_version[i] <= '9') { - digit = digit * 10 + (unsigned int) (rt_version[i] - '0'); - ++i; - } - version += factor * digit; - if (rt_version[i] != '.') - break; - digit = 0; - factor >>= 8; - ++i; - } - __Pyx_cached_runtime_version = version; - } - return __Pyx_cached_runtime_version; -#endif -} - -/* CheckBinaryVersion */ -static int __Pyx_check_binary_version(unsigned long ct_version, unsigned long rt_version, int allow_newer) { - const unsigned long MAJOR_MINOR = 0xFFFF0000UL; - if ((rt_version & MAJOR_MINOR) == (ct_version & MAJOR_MINOR)) - return 0; - if (likely(allow_newer && (rt_version & MAJOR_MINOR) > (ct_version & MAJOR_MINOR))) - return 1; - { - char message[200]; - PyOS_snprintf(message, sizeof(message), - "compile time Python version %d.%d " - "of module '%.100s' " - "%s " - "runtime version %d.%d", - (int) (ct_version >> 24), (int) ((ct_version >> 16) & 0xFF), - __Pyx_MODULE_NAME, - (allow_newer) ? "was newer than" : "does not match", - (int) (rt_version >> 24), (int) ((rt_version >> 16) & 0xFF) - ); - return PyErr_WarnEx(NULL, message, 1); - } -} - -/* InitStrings */ -static int __Pyx_InitStrings(__Pyx_StringTabEntry const *t, PyObject **target, const char* const* encoding_names) { - while (t->s) { - PyObject *str; - if (t->is_unicode) { - if (t->intern) { - str = PyUnicode_InternFromString(t->s); - } else if (t->encoding) { - str = PyUnicode_Decode(t->s, t->n - 1, encoding_names[t->encoding], NULL); - } else { - str = PyUnicode_FromStringAndSize(t->s, t->n - 1); - } - } else { - str = PyBytes_FromStringAndSize(t->s, t->n - 1); - } - if (!str) - return -1; - *target = str; - if (PyObject_Hash(str) == -1) - return -1; - ++t; - ++target; - } - return 0; -} - -#include -static CYTHON_INLINE Py_ssize_t __Pyx_ssize_strlen(const char *s) { - size_t len = strlen(s); - if (unlikely(len > (size_t) PY_SSIZE_T_MAX)) { - PyErr_SetString(PyExc_OverflowError, "byte string is too long"); - return -1; - } - return (Py_ssize_t) len; -} -static CYTHON_INLINE PyObject* __Pyx_PyUnicode_FromString(const char* c_str) { - Py_ssize_t len = __Pyx_ssize_strlen(c_str); - if (unlikely(len < 0)) return NULL; - return __Pyx_PyUnicode_FromStringAndSize(c_str, len); -} -static CYTHON_INLINE PyObject* __Pyx_PyByteArray_FromString(const char* c_str) { - Py_ssize_t len = __Pyx_ssize_strlen(c_str); - if (unlikely(len < 0)) return NULL; - return PyByteArray_FromStringAndSize(c_str, len); -} -static CYTHON_INLINE const char* __Pyx_PyObject_AsString(PyObject* o) { - Py_ssize_t ignore; - return __Pyx_PyObject_AsStringAndSize(o, &ignore); -} -#if __PYX_DEFAULT_STRING_ENCODING_IS_ASCII || __PYX_DEFAULT_STRING_ENCODING_IS_UTF8 -static CYTHON_INLINE const char* __Pyx_PyUnicode_AsStringAndSize(PyObject* o, Py_ssize_t *length) { - if (unlikely(__Pyx_PyUnicode_READY(o) == -1)) return NULL; -#if CYTHON_COMPILING_IN_LIMITED_API - { - const char* result; - Py_ssize_t unicode_length; - CYTHON_MAYBE_UNUSED_VAR(unicode_length); // only for __PYX_DEFAULT_STRING_ENCODING_IS_ASCII - #if __PYX_LIMITED_VERSION_HEX < 0x030A0000 - if (unlikely(PyArg_Parse(o, "s#", &result, length) < 0)) return NULL; - #else - result = PyUnicode_AsUTF8AndSize(o, length); - #endif - #if __PYX_DEFAULT_STRING_ENCODING_IS_ASCII - unicode_length = PyUnicode_GetLength(o); - if (unlikely(unicode_length < 0)) return NULL; - if (unlikely(unicode_length != *length)) { - PyUnicode_AsASCIIString(o); - return NULL; - } - #endif - return result; - } -#else -#if __PYX_DEFAULT_STRING_ENCODING_IS_ASCII - if (likely(PyUnicode_IS_ASCII(o))) { - *length = PyUnicode_GET_LENGTH(o); - return PyUnicode_AsUTF8(o); - } else { - PyUnicode_AsASCIIString(o); - return NULL; - } -#else - return PyUnicode_AsUTF8AndSize(o, length); -#endif -#endif -} -#endif -static CYTHON_INLINE const char* __Pyx_PyObject_AsStringAndSize(PyObject* o, Py_ssize_t *length) { -#if __PYX_DEFAULT_STRING_ENCODING_IS_ASCII || __PYX_DEFAULT_STRING_ENCODING_IS_UTF8 - if (PyUnicode_Check(o)) { - return __Pyx_PyUnicode_AsStringAndSize(o, length); - } else -#endif - if (PyByteArray_Check(o)) { -#if (CYTHON_ASSUME_SAFE_SIZE && CYTHON_ASSUME_SAFE_MACROS) || (CYTHON_COMPILING_IN_PYPY && (defined(PyByteArray_AS_STRING) && defined(PyByteArray_GET_SIZE))) - *length = PyByteArray_GET_SIZE(o); - return PyByteArray_AS_STRING(o); -#else - *length = PyByteArray_Size(o); - if (*length == -1) return NULL; - return PyByteArray_AsString(o); -#endif - } else - { - char* result; - int r = PyBytes_AsStringAndSize(o, &result, length); - if (unlikely(r < 0)) { - return NULL; - } else { - return result; - } - } -} -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 int __Pyx_PyObject_IsTrueAndDecref(PyObject* x) { - int retval; - if (unlikely(!x)) return -1; - retval = __Pyx_PyObject_IsTrue(x); - Py_DECREF(x); - return retval; -} -static PyObject* __Pyx_PyNumber_LongWrongResultType(PyObject* result) { - __Pyx_TypeName result_type_name = __Pyx_PyType_GetFullyQualifiedName(Py_TYPE(result)); - if (PyLong_Check(result)) { - if (PyErr_WarnFormat(PyExc_DeprecationWarning, 1, - "__int__ returned non-int (type " __Pyx_FMT_TYPENAME "). " - "The ability to return an instance of a strict subclass of int is deprecated, " - "and may be removed in a future version of Python.", - result_type_name)) { - __Pyx_DECREF_TypeName(result_type_name); - Py_DECREF(result); - return NULL; - } - __Pyx_DECREF_TypeName(result_type_name); - return result; - } - PyErr_Format(PyExc_TypeError, - "__int__ returned non-int (type " __Pyx_FMT_TYPENAME ")", - result_type_name); - __Pyx_DECREF_TypeName(result_type_name); - Py_DECREF(result); - return NULL; -} -static CYTHON_INLINE PyObject* __Pyx_PyNumber_Long(PyObject* x) { -#if CYTHON_USE_TYPE_SLOTS - PyNumberMethods *m; -#endif - PyObject *res = NULL; - if (likely(PyLong_Check(x))) - return __Pyx_NewRef(x); -#if CYTHON_USE_TYPE_SLOTS - m = Py_TYPE(x)->tp_as_number; - if (likely(m && m->nb_int)) { - res = m->nb_int(x); - } -#else - if (!PyBytes_CheckExact(x) && !PyUnicode_CheckExact(x)) { - res = PyNumber_Long(x); - } -#endif - if (likely(res)) { - if (unlikely(!PyLong_CheckExact(res))) { - return __Pyx_PyNumber_LongWrongResultType(res); - } - } - 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; - if (likely(PyLong_CheckExact(b))) { - #if CYTHON_USE_PYLONG_INTERNALS - if (likely(__Pyx_PyLong_IsCompact(b))) { - return __Pyx_PyLong_CompactValue(b); - } else { - const digit* digits = __Pyx_PyLong_Digits(b); - const Py_ssize_t size = __Pyx_PyLong_SignedDigitCount(b); - switch (size) { - case 2: - if (8 * sizeof(Py_ssize_t) > 2 * PyLong_SHIFT) { - return (Py_ssize_t) (((((size_t)digits[1]) << PyLong_SHIFT) | (size_t)digits[0])); - } - break; - case -2: - if (8 * sizeof(Py_ssize_t) > 2 * PyLong_SHIFT) { - return -(Py_ssize_t) (((((size_t)digits[1]) << PyLong_SHIFT) | (size_t)digits[0])); - } - break; - case 3: - if (8 * sizeof(Py_ssize_t) > 3 * PyLong_SHIFT) { - return (Py_ssize_t) (((((((size_t)digits[2]) << PyLong_SHIFT) | (size_t)digits[1]) << PyLong_SHIFT) | (size_t)digits[0])); - } - break; - case -3: - if (8 * sizeof(Py_ssize_t) > 3 * PyLong_SHIFT) { - return -(Py_ssize_t) (((((((size_t)digits[2]) << PyLong_SHIFT) | (size_t)digits[1]) << PyLong_SHIFT) | (size_t)digits[0])); - } - break; - case 4: - if (8 * sizeof(Py_ssize_t) > 4 * PyLong_SHIFT) { - return (Py_ssize_t) (((((((((size_t)digits[3]) << PyLong_SHIFT) | (size_t)digits[2]) << PyLong_SHIFT) | (size_t)digits[1]) << PyLong_SHIFT) | (size_t)digits[0])); - } - break; - case -4: - if (8 * sizeof(Py_ssize_t) > 4 * PyLong_SHIFT) { - return -(Py_ssize_t) (((((((((size_t)digits[3]) << PyLong_SHIFT) | (size_t)digits[2]) << PyLong_SHIFT) | (size_t)digits[1]) << PyLong_SHIFT) | (size_t)digits[0])); - } - break; - } - } - #endif - return PyLong_AsSsize_t(b); - } - x = PyNumber_Index(b); - if (!x) return -1; - ival = PyLong_AsSsize_t(x); - Py_DECREF(x); - return ival; -} -static CYTHON_INLINE Py_hash_t __Pyx_PyIndex_AsHash_t(PyObject* o) { - if (sizeof(Py_hash_t) == sizeof(Py_ssize_t)) { - return (Py_hash_t) __Pyx_PyIndex_AsSsize_t(o); - } else { - Py_ssize_t ival; - PyObject *x; - x = PyNumber_Index(o); - if (!x) return -1; - ival = PyLong_AsLong(x); - Py_DECREF(x); - return ival; - } -} -static CYTHON_INLINE PyObject *__Pyx_Owned_Py_None(int b) { - CYTHON_UNUSED_VAR(b); - return __Pyx_NewRef(Py_None); -} -static CYTHON_INLINE PyObject * __Pyx_PyBool_FromLong(long b) { - return b ? __Pyx_NewRef(Py_True) : __Pyx_NewRef(Py_False); -} -static CYTHON_INLINE PyObject * __Pyx_PyLong_FromSize_t(size_t ival) { - return PyLong_FromSize_t(ival); -} - - -/* MultiPhaseInitModuleState */ -#if CYTHON_PEP489_MULTI_PHASE_INIT && CYTHON_USE_MODULE_STATE -#ifndef CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE -#if (CYTHON_COMPILING_IN_LIMITED_API || PY_VERSION_HEX >= 0x030C0000) - #define CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE 1 -#else - #define CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE 0 -#endif -#endif -#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE && !CYTHON_ATOMICS -#error "Module state with PEP489 requires atomics. Currently that's one of\ - C11, C++11, gcc atomic intrinsics or MSVC atomic intrinsics" -#endif -#if !CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE -#define __Pyx_ModuleStateLookup_Lock() -#define __Pyx_ModuleStateLookup_Unlock() -#elif !CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX >= 0x030d0000 -static PyMutex __Pyx_ModuleStateLookup_mutex = {0}; -#define __Pyx_ModuleStateLookup_Lock() PyMutex_Lock(&__Pyx_ModuleStateLookup_mutex) -#define __Pyx_ModuleStateLookup_Unlock() PyMutex_Unlock(&__Pyx_ModuleStateLookup_mutex) -#elif defined(__cplusplus) && __cplusplus >= 201103L -#include -static std::mutex __Pyx_ModuleStateLookup_mutex; -#define __Pyx_ModuleStateLookup_Lock() __Pyx_ModuleStateLookup_mutex.lock() -#define __Pyx_ModuleStateLookup_Unlock() __Pyx_ModuleStateLookup_mutex.unlock() -#elif defined(__STDC_VERSION__) && (__STDC_VERSION__ > 201112L) && !defined(__STDC_NO_THREADS__) -#include -static mtx_t __Pyx_ModuleStateLookup_mutex; -static once_flag __Pyx_ModuleStateLookup_mutex_once_flag = ONCE_FLAG_INIT; -static void __Pyx_ModuleStateLookup_initialize_mutex(void) { - mtx_init(&__Pyx_ModuleStateLookup_mutex, mtx_plain); -} -#define __Pyx_ModuleStateLookup_Lock()\ - call_once(&__Pyx_ModuleStateLookup_mutex_once_flag, __Pyx_ModuleStateLookup_initialize_mutex);\ - mtx_lock(&__Pyx_ModuleStateLookup_mutex) -#define __Pyx_ModuleStateLookup_Unlock() mtx_unlock(&__Pyx_ModuleStateLookup_mutex) -#elif defined(HAVE_PTHREAD_H) -#include -static pthread_mutex_t __Pyx_ModuleStateLookup_mutex = PTHREAD_MUTEX_INITIALIZER; -#define __Pyx_ModuleStateLookup_Lock() pthread_mutex_lock(&__Pyx_ModuleStateLookup_mutex) -#define __Pyx_ModuleStateLookup_Unlock() pthread_mutex_unlock(&__Pyx_ModuleStateLookup_mutex) -#elif defined(_WIN32) -#include // synchapi.h on its own doesn't work -static SRWLOCK __Pyx_ModuleStateLookup_mutex = SRWLOCK_INIT; -#define __Pyx_ModuleStateLookup_Lock() AcquireSRWLockExclusive(&__Pyx_ModuleStateLookup_mutex) -#define __Pyx_ModuleStateLookup_Unlock() ReleaseSRWLockExclusive(&__Pyx_ModuleStateLookup_mutex) -#else -#error "No suitable lock available for CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE.\ - Requires C standard >= C11, or C++ standard >= C++11,\ - or pthreads, or the Windows 32 API, or Python >= 3.13." -#endif -typedef struct { - int64_t id; - PyObject *module; -} __Pyx_InterpreterIdAndModule; -typedef struct { - char interpreter_id_as_index; - Py_ssize_t count; - Py_ssize_t allocated; - __Pyx_InterpreterIdAndModule table[1]; -} __Pyx_ModuleStateLookupData; -#define __PYX_MODULE_STATE_LOOKUP_SMALL_SIZE 32 -#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE -static __pyx_atomic_int_type __Pyx_ModuleStateLookup_read_counter = 0; -#endif -#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE -static __pyx_atomic_ptr_type __Pyx_ModuleStateLookup_data = 0; -#else -static __Pyx_ModuleStateLookupData* __Pyx_ModuleStateLookup_data = NULL; -#endif -static __Pyx_InterpreterIdAndModule* __Pyx_State_FindModuleStateLookupTableLowerBound( - __Pyx_InterpreterIdAndModule* table, - Py_ssize_t count, - int64_t interpreterId) { - __Pyx_InterpreterIdAndModule* begin = table; - __Pyx_InterpreterIdAndModule* end = begin + count; - if (begin->id == interpreterId) { - return begin; - } - while ((end - begin) > __PYX_MODULE_STATE_LOOKUP_SMALL_SIZE) { - __Pyx_InterpreterIdAndModule* halfway = begin + (end - begin)/2; - if (halfway->id == interpreterId) { - return halfway; - } - if (halfway->id < interpreterId) { - begin = halfway; - } else { - end = halfway; - } - } - for (; begin < end; ++begin) { - if (begin->id >= interpreterId) return begin; - } - return begin; -} -static PyObject *__Pyx_State_FindModule(CYTHON_UNUSED void* dummy) { - int64_t interpreter_id = PyInterpreterState_GetID(__Pyx_PyInterpreterState_Get()); - if (interpreter_id == -1) return NULL; -#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE - __Pyx_ModuleStateLookupData* data = (__Pyx_ModuleStateLookupData*)__pyx_atomic_pointer_load_relaxed(&__Pyx_ModuleStateLookup_data); - { - __pyx_atomic_incr_acq_rel(&__Pyx_ModuleStateLookup_read_counter); - if (likely(data)) { - __Pyx_ModuleStateLookupData* new_data = (__Pyx_ModuleStateLookupData*)__pyx_atomic_pointer_load_acquire(&__Pyx_ModuleStateLookup_data); - if (likely(data == new_data)) { - goto read_finished; - } - } - __pyx_atomic_decr_acq_rel(&__Pyx_ModuleStateLookup_read_counter); - __Pyx_ModuleStateLookup_Lock(); - __pyx_atomic_incr_relaxed(&__Pyx_ModuleStateLookup_read_counter); - data = (__Pyx_ModuleStateLookupData*)__pyx_atomic_pointer_load_relaxed(&__Pyx_ModuleStateLookup_data); - __Pyx_ModuleStateLookup_Unlock(); - } - read_finished:; -#else - __Pyx_ModuleStateLookupData* data = __Pyx_ModuleStateLookup_data; -#endif - __Pyx_InterpreterIdAndModule* found = NULL; - if (unlikely(!data)) goto end; - if (data->interpreter_id_as_index) { - if (interpreter_id < data->count) { - found = data->table+interpreter_id; - } - } else { - found = __Pyx_State_FindModuleStateLookupTableLowerBound( - data->table, data->count, interpreter_id); - } - end: - { - PyObject *result=NULL; - if (found && found->id == interpreter_id) { - result = found->module; - } -#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE - __pyx_atomic_decr_acq_rel(&__Pyx_ModuleStateLookup_read_counter); -#endif - return result; - } -} -#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE -static void __Pyx_ModuleStateLookup_wait_until_no_readers(void) { - while (__pyx_atomic_load(&__Pyx_ModuleStateLookup_read_counter) != 0); -} -#else -#define __Pyx_ModuleStateLookup_wait_until_no_readers() -#endif -static int __Pyx_State_AddModuleInterpIdAsIndex(__Pyx_ModuleStateLookupData **old_data, PyObject* module, int64_t interpreter_id) { - Py_ssize_t to_allocate = (*old_data)->allocated; - while (to_allocate <= interpreter_id) { - if (to_allocate == 0) to_allocate = 1; - else to_allocate *= 2; - } - __Pyx_ModuleStateLookupData *new_data = *old_data; - if (to_allocate != (*old_data)->allocated) { - new_data = (__Pyx_ModuleStateLookupData *)realloc( - *old_data, - sizeof(__Pyx_ModuleStateLookupData)+(to_allocate-1)*sizeof(__Pyx_InterpreterIdAndModule)); - if (!new_data) { - PyErr_NoMemory(); - return -1; - } - for (Py_ssize_t i = new_data->allocated; i < to_allocate; ++i) { - new_data->table[i].id = i; - new_data->table[i].module = NULL; - } - new_data->allocated = to_allocate; - } - new_data->table[interpreter_id].module = module; - if (new_data->count < interpreter_id+1) { - new_data->count = interpreter_id+1; - } - *old_data = new_data; - return 0; -} -static void __Pyx_State_ConvertFromInterpIdAsIndex(__Pyx_ModuleStateLookupData *data) { - __Pyx_InterpreterIdAndModule *read = data->table; - __Pyx_InterpreterIdAndModule *write = data->table; - __Pyx_InterpreterIdAndModule *end = read + data->count; - for (; readmodule) { - write->id = read->id; - write->module = read->module; - ++write; - } - } - data->count = write - data->table; - for (; writeid = 0; - write->module = NULL; - } - data->interpreter_id_as_index = 0; -} -static int __Pyx_State_AddModule(PyObject* module, CYTHON_UNUSED void* dummy) { - int64_t interpreter_id = PyInterpreterState_GetID(__Pyx_PyInterpreterState_Get()); - if (interpreter_id == -1) return -1; - int result = 0; - __Pyx_ModuleStateLookup_Lock(); -#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE - __Pyx_ModuleStateLookupData *old_data = (__Pyx_ModuleStateLookupData *) - __pyx_atomic_pointer_exchange(&__Pyx_ModuleStateLookup_data, 0); -#else - __Pyx_ModuleStateLookupData *old_data = __Pyx_ModuleStateLookup_data; -#endif - __Pyx_ModuleStateLookupData *new_data = old_data; - if (!new_data) { - new_data = (__Pyx_ModuleStateLookupData *)calloc(1, sizeof(__Pyx_ModuleStateLookupData)); - if (!new_data) { - result = -1; - PyErr_NoMemory(); - goto end; - } - new_data->allocated = 1; - new_data->interpreter_id_as_index = 1; - } - __Pyx_ModuleStateLookup_wait_until_no_readers(); - if (new_data->interpreter_id_as_index) { - if (interpreter_id < __PYX_MODULE_STATE_LOOKUP_SMALL_SIZE) { - result = __Pyx_State_AddModuleInterpIdAsIndex(&new_data, module, interpreter_id); - goto end; - } - __Pyx_State_ConvertFromInterpIdAsIndex(new_data); - } - { - Py_ssize_t insert_at = 0; - { - __Pyx_InterpreterIdAndModule* lower_bound = __Pyx_State_FindModuleStateLookupTableLowerBound( - new_data->table, new_data->count, interpreter_id); - assert(lower_bound); - insert_at = lower_bound - new_data->table; - if (unlikely(insert_at < new_data->count && lower_bound->id == interpreter_id)) { - lower_bound->module = module; - goto end; // already in table, nothing more to do - } - } - if (new_data->count+1 >= new_data->allocated) { - Py_ssize_t to_allocate = (new_data->count+1)*2; - new_data = - (__Pyx_ModuleStateLookupData*)realloc( - new_data, - sizeof(__Pyx_ModuleStateLookupData) + - (to_allocate-1)*sizeof(__Pyx_InterpreterIdAndModule)); - if (!new_data) { - result = -1; - new_data = old_data; - PyErr_NoMemory(); - goto end; - } - new_data->allocated = to_allocate; - } - ++new_data->count; - int64_t last_id = interpreter_id; - PyObject *last_module = module; - for (Py_ssize_t i=insert_at; icount; ++i) { - int64_t current_id = new_data->table[i].id; - new_data->table[i].id = last_id; - last_id = current_id; - PyObject *current_module = new_data->table[i].module; - new_data->table[i].module = last_module; - last_module = current_module; - } - } - end: -#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE - __pyx_atomic_pointer_exchange(&__Pyx_ModuleStateLookup_data, new_data); -#else - __Pyx_ModuleStateLookup_data = new_data; -#endif - __Pyx_ModuleStateLookup_Unlock(); - return result; -} -static int __Pyx_State_RemoveModule(CYTHON_UNUSED void* dummy) { - int64_t interpreter_id = PyInterpreterState_GetID(__Pyx_PyInterpreterState_Get()); - if (interpreter_id == -1) return -1; - __Pyx_ModuleStateLookup_Lock(); -#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE - __Pyx_ModuleStateLookupData *data = (__Pyx_ModuleStateLookupData *) - __pyx_atomic_pointer_exchange(&__Pyx_ModuleStateLookup_data, 0); -#else - __Pyx_ModuleStateLookupData *data = __Pyx_ModuleStateLookup_data; -#endif - if (data->interpreter_id_as_index) { - if (interpreter_id < data->count) { - data->table[interpreter_id].module = NULL; - } - goto done; - } - { - __Pyx_ModuleStateLookup_wait_until_no_readers(); - __Pyx_InterpreterIdAndModule* lower_bound = __Pyx_State_FindModuleStateLookupTableLowerBound( - data->table, data->count, interpreter_id); - if (!lower_bound) goto done; - if (lower_bound->id != interpreter_id) goto done; - __Pyx_InterpreterIdAndModule *end = data->table+data->count; - for (;lower_boundid = (lower_bound+1)->id; - lower_bound->module = (lower_bound+1)->module; - } - } - --data->count; - if (data->count == 0) { - free(data); - data = NULL; - } - done: -#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE - __pyx_atomic_pointer_exchange(&__Pyx_ModuleStateLookup_data, data); -#else - __Pyx_ModuleStateLookup_data = data; -#endif - __Pyx_ModuleStateLookup_Unlock(); - return 0; -} -#endif - -/* #### Code section: utility_code_pragmas_end ### */ -#ifdef _MSC_VER -#pragma warning( pop ) -#endif - - - -/* #### Code section: end ### */ -#endif /* Py_PYTHON_H */ diff --git a/epanet/epanet.c b/epanet/epanet.c deleted file mode 100644 index 0ef378b..0000000 --- a/epanet/epanet.c +++ /dev/null @@ -1,21700 +0,0 @@ -/* Generated by Cython 3.1.0 */ - -/* BEGIN: Cython Metadata -{ - "distutils": { - "name": "epanet.epanet", - "sources": [ - "epanet\\epanet.py" - ] - }, - "module_name": "epanet.epanet" -} -END: Cython Metadata */ - -#ifndef PY_SSIZE_T_CLEAN -#define PY_SSIZE_T_CLEAN -#endif /* PY_SSIZE_T_CLEAN */ -/* InitLimitedAPI */ -#if defined(Py_LIMITED_API) && !defined(CYTHON_LIMITED_API) - #define CYTHON_LIMITED_API 1 -#endif - -#include "Python.h" -#ifndef Py_PYTHON_H - #error Python headers needed to compile C extensions, please install development version of Python. -#elif PY_VERSION_HEX < 0x03080000 - #error Cython requires Python 3.8+. -#else -#define __PYX_ABI_VERSION "3_1_0" -#define CYTHON_HEX_VERSION 0x030100F0 -#define CYTHON_FUTURE_DIVISION 1 -/* CModulePreamble */ -#include -#ifndef offsetof - #define offsetof(type, member) ( (size_t) & ((type*)0) -> member ) -#endif -#if !defined(_WIN32) && !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 -#define __PYX_COMMA , -#ifndef HAVE_LONG_LONG - #define HAVE_LONG_LONG -#endif -#ifndef PY_LONG_LONG - #define PY_LONG_LONG LONG_LONG -#endif -#ifndef Py_HUGE_VAL - #define Py_HUGE_VAL HUGE_VAL -#endif -#define __PYX_LIMITED_VERSION_HEX PY_VERSION_HEX -#if defined(GRAALVM_PYTHON) - /* For very preliminary testing purposes. Most variables are set the same as PyPy. - The existence of this section does not imply that anything works or is even tested */ - #define CYTHON_COMPILING_IN_PYPY 0 - #define CYTHON_COMPILING_IN_CPYTHON 0 - #define CYTHON_COMPILING_IN_LIMITED_API 0 - #define CYTHON_COMPILING_IN_GRAAL 1 - #define CYTHON_COMPILING_IN_CPYTHON_FREETHREADING 0 - #undef CYTHON_USE_TYPE_SLOTS - #define CYTHON_USE_TYPE_SLOTS 0 - #undef CYTHON_USE_TYPE_SPECS - #define CYTHON_USE_TYPE_SPECS 0 - #undef CYTHON_USE_PYTYPE_LOOKUP - #define CYTHON_USE_PYTYPE_LOOKUP 0 - #undef CYTHON_USE_PYLIST_INTERNALS - #define CYTHON_USE_PYLIST_INTERNALS 0 - #undef CYTHON_USE_UNICODE_INTERNALS - #define CYTHON_USE_UNICODE_INTERNALS 0 - #undef CYTHON_USE_UNICODE_WRITER - #define CYTHON_USE_UNICODE_WRITER 0 - #undef CYTHON_USE_PYLONG_INTERNALS - #define CYTHON_USE_PYLONG_INTERNALS 0 - #undef CYTHON_AVOID_BORROWED_REFS - #define CYTHON_AVOID_BORROWED_REFS 1 - #undef CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS - #define CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS 1 - #undef CYTHON_ASSUME_SAFE_MACROS - #define CYTHON_ASSUME_SAFE_MACROS 0 - #undef CYTHON_ASSUME_SAFE_SIZE - #define CYTHON_ASSUME_SAFE_SIZE 0 - #undef CYTHON_UNPACK_METHODS - #define CYTHON_UNPACK_METHODS 0 - #undef CYTHON_FAST_THREAD_STATE - #define CYTHON_FAST_THREAD_STATE 0 - #undef CYTHON_FAST_GIL - #define CYTHON_FAST_GIL 0 - #undef CYTHON_METH_FASTCALL - #define CYTHON_METH_FASTCALL 0 - #undef CYTHON_FAST_PYCALL - #define CYTHON_FAST_PYCALL 0 - #ifndef CYTHON_PEP487_INIT_SUBCLASS - #define CYTHON_PEP487_INIT_SUBCLASS 1 - #endif - #undef CYTHON_PEP489_MULTI_PHASE_INIT - #define CYTHON_PEP489_MULTI_PHASE_INIT 1 - #undef CYTHON_USE_MODULE_STATE - #define CYTHON_USE_MODULE_STATE 0 - #undef CYTHON_USE_SYS_MONITORING - #define CYTHON_USE_SYS_MONITORING 0 - #undef CYTHON_USE_TP_FINALIZE - #define CYTHON_USE_TP_FINALIZE 0 - #undef CYTHON_USE_AM_SEND - #define CYTHON_USE_AM_SEND 0 - #undef CYTHON_USE_DICT_VERSIONS - #define CYTHON_USE_DICT_VERSIONS 0 - #undef CYTHON_USE_EXC_INFO_STACK - #define CYTHON_USE_EXC_INFO_STACK 1 - #ifndef CYTHON_UPDATE_DESCRIPTOR_DOC - #define CYTHON_UPDATE_DESCRIPTOR_DOC 0 - #endif - #undef CYTHON_USE_FREELISTS - #define CYTHON_USE_FREELISTS 0 -#elif defined(PYPY_VERSION) - #define CYTHON_COMPILING_IN_PYPY 1 - #define CYTHON_COMPILING_IN_CPYTHON 0 - #define CYTHON_COMPILING_IN_LIMITED_API 0 - #define CYTHON_COMPILING_IN_GRAAL 0 - #define CYTHON_COMPILING_IN_CPYTHON_FREETHREADING 0 - #undef CYTHON_USE_TYPE_SLOTS - #define CYTHON_USE_TYPE_SLOTS 1 - #ifndef CYTHON_USE_TYPE_SPECS - #define CYTHON_USE_TYPE_SPECS 0 - #endif - #undef CYTHON_USE_PYTYPE_LOOKUP - #define CYTHON_USE_PYTYPE_LOOKUP 0 - #undef CYTHON_USE_PYLIST_INTERNALS - #define CYTHON_USE_PYLIST_INTERNALS 0 - #undef CYTHON_USE_UNICODE_INTERNALS - #define CYTHON_USE_UNICODE_INTERNALS 0 - #undef CYTHON_USE_UNICODE_WRITER - #define CYTHON_USE_UNICODE_WRITER 0 - #undef CYTHON_USE_PYLONG_INTERNALS - #define CYTHON_USE_PYLONG_INTERNALS 0 - #undef CYTHON_AVOID_BORROWED_REFS - #define CYTHON_AVOID_BORROWED_REFS 1 - #undef CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS - #define CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS 1 - #undef CYTHON_ASSUME_SAFE_MACROS - #define CYTHON_ASSUME_SAFE_MACROS 0 - #ifndef CYTHON_ASSUME_SAFE_SIZE - #define CYTHON_ASSUME_SAFE_SIZE 1 - #endif - #undef CYTHON_UNPACK_METHODS - #define CYTHON_UNPACK_METHODS 0 - #undef CYTHON_FAST_THREAD_STATE - #define CYTHON_FAST_THREAD_STATE 0 - #undef CYTHON_FAST_GIL - #define CYTHON_FAST_GIL 0 - #undef CYTHON_METH_FASTCALL - #define CYTHON_METH_FASTCALL 0 - #undef CYTHON_FAST_PYCALL - #define CYTHON_FAST_PYCALL 0 - #ifndef CYTHON_PEP487_INIT_SUBCLASS - #define CYTHON_PEP487_INIT_SUBCLASS 1 - #endif - #if PY_VERSION_HEX < 0x03090000 - #undef CYTHON_PEP489_MULTI_PHASE_INIT - #define CYTHON_PEP489_MULTI_PHASE_INIT 0 - #elif !defined(CYTHON_PEP489_MULTI_PHASE_INIT) - #define CYTHON_PEP489_MULTI_PHASE_INIT 1 - #endif - #undef CYTHON_USE_MODULE_STATE - #define CYTHON_USE_MODULE_STATE 0 - #undef CYTHON_USE_SYS_MONITORING - #define CYTHON_USE_SYS_MONITORING 0 - #ifndef CYTHON_USE_TP_FINALIZE - #define CYTHON_USE_TP_FINALIZE (PYPY_VERSION_NUM >= 0x07030C00) - #endif - #undef CYTHON_USE_AM_SEND - #define CYTHON_USE_AM_SEND 0 - #undef CYTHON_USE_DICT_VERSIONS - #define CYTHON_USE_DICT_VERSIONS 0 - #undef CYTHON_USE_EXC_INFO_STACK - #define CYTHON_USE_EXC_INFO_STACK 0 - #ifndef CYTHON_UPDATE_DESCRIPTOR_DOC - #define CYTHON_UPDATE_DESCRIPTOR_DOC (PYPY_VERSION_NUM >= 0x07031100) - #endif - #undef CYTHON_USE_FREELISTS - #define CYTHON_USE_FREELISTS 0 -#elif defined(CYTHON_LIMITED_API) - #ifdef Py_LIMITED_API - #undef __PYX_LIMITED_VERSION_HEX - #define __PYX_LIMITED_VERSION_HEX Py_LIMITED_API - #endif - #define CYTHON_COMPILING_IN_PYPY 0 - #define CYTHON_COMPILING_IN_CPYTHON 0 - #define CYTHON_COMPILING_IN_LIMITED_API 1 - #define CYTHON_COMPILING_IN_GRAAL 0 - #define CYTHON_COMPILING_IN_CPYTHON_FREETHREADING 0 - #undef CYTHON_CLINE_IN_TRACEBACK - #define CYTHON_CLINE_IN_TRACEBACK 0 - #undef CYTHON_USE_TYPE_SLOTS - #define CYTHON_USE_TYPE_SLOTS 0 - #undef CYTHON_USE_TYPE_SPECS - #define CYTHON_USE_TYPE_SPECS 1 - #undef CYTHON_USE_PYTYPE_LOOKUP - #define CYTHON_USE_PYTYPE_LOOKUP 0 - #undef CYTHON_USE_PYLIST_INTERNALS - #define CYTHON_USE_PYLIST_INTERNALS 0 - #undef CYTHON_USE_UNICODE_INTERNALS - #define CYTHON_USE_UNICODE_INTERNALS 0 - #ifndef CYTHON_USE_UNICODE_WRITER - #define CYTHON_USE_UNICODE_WRITER 0 - #endif - #undef CYTHON_USE_PYLONG_INTERNALS - #define CYTHON_USE_PYLONG_INTERNALS 0 - #ifndef CYTHON_AVOID_BORROWED_REFS - #define CYTHON_AVOID_BORROWED_REFS 0 - #endif - #ifndef CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS - #define CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS 0 - #endif - #undef CYTHON_ASSUME_SAFE_MACROS - #define CYTHON_ASSUME_SAFE_MACROS 0 - #undef CYTHON_ASSUME_SAFE_SIZE - #define CYTHON_ASSUME_SAFE_SIZE 0 - #undef CYTHON_UNPACK_METHODS - #define CYTHON_UNPACK_METHODS 0 - #undef CYTHON_FAST_THREAD_STATE - #define CYTHON_FAST_THREAD_STATE 0 - #undef CYTHON_FAST_GIL - #define CYTHON_FAST_GIL 0 - #undef CYTHON_METH_FASTCALL - #define CYTHON_METH_FASTCALL (__PYX_LIMITED_VERSION_HEX >= 0x030C0000) - #undef CYTHON_FAST_PYCALL - #define CYTHON_FAST_PYCALL 0 - #ifndef CYTHON_PEP487_INIT_SUBCLASS - #define CYTHON_PEP487_INIT_SUBCLASS 1 - #endif - #ifndef CYTHON_PEP489_MULTI_PHASE_INIT - #define CYTHON_PEP489_MULTI_PHASE_INIT 1 - #endif - #ifndef CYTHON_USE_MODULE_STATE - #define CYTHON_USE_MODULE_STATE 0 - #endif - #undef CYTHON_USE_SYS_MONITORING - #define CYTHON_USE_SYS_MONITORING 0 - #ifndef CYTHON_USE_TP_FINALIZE - #define CYTHON_USE_TP_FINALIZE 0 - #endif - #ifndef CYTHON_USE_AM_SEND - #define CYTHON_USE_AM_SEND (__PYX_LIMITED_VERSION_HEX >= 0x030A0000) - #endif - #undef CYTHON_USE_DICT_VERSIONS - #define CYTHON_USE_DICT_VERSIONS 0 - #undef CYTHON_USE_EXC_INFO_STACK - #define CYTHON_USE_EXC_INFO_STACK 0 - #ifndef CYTHON_UPDATE_DESCRIPTOR_DOC - #define CYTHON_UPDATE_DESCRIPTOR_DOC 0 - #endif - #undef CYTHON_USE_FREELISTS - #define CYTHON_USE_FREELISTS 0 -#else - #define CYTHON_COMPILING_IN_PYPY 0 - #define CYTHON_COMPILING_IN_CPYTHON 1 - #define CYTHON_COMPILING_IN_LIMITED_API 0 - #define CYTHON_COMPILING_IN_GRAAL 0 - #ifdef Py_GIL_DISABLED - #define CYTHON_COMPILING_IN_CPYTHON_FREETHREADING 1 - #else - #define CYTHON_COMPILING_IN_CPYTHON_FREETHREADING 0 - #endif - #if PY_VERSION_HEX < 0x030A0000 - #undef CYTHON_USE_TYPE_SLOTS - #define CYTHON_USE_TYPE_SLOTS 1 - #elif !defined(CYTHON_USE_TYPE_SLOTS) - #define CYTHON_USE_TYPE_SLOTS 1 - #endif - #ifndef CYTHON_USE_TYPE_SPECS - #define CYTHON_USE_TYPE_SPECS 0 - #endif - #ifndef CYTHON_USE_PYTYPE_LOOKUP - #define CYTHON_USE_PYTYPE_LOOKUP 1 - #endif - #ifndef CYTHON_USE_PYLONG_INTERNALS - #define CYTHON_USE_PYLONG_INTERNALS 1 - #endif - #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - #undef CYTHON_USE_PYLIST_INTERNALS - #define CYTHON_USE_PYLIST_INTERNALS 0 - #elif !defined(CYTHON_USE_PYLIST_INTERNALS) - #define CYTHON_USE_PYLIST_INTERNALS 1 - #endif - #ifndef CYTHON_USE_UNICODE_INTERNALS - #define CYTHON_USE_UNICODE_INTERNALS 1 - #endif - #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING || PY_VERSION_HEX >= 0x030B00A2 - #undef CYTHON_USE_UNICODE_WRITER - #define CYTHON_USE_UNICODE_WRITER 0 - #elif !defined(CYTHON_USE_UNICODE_WRITER) - #define CYTHON_USE_UNICODE_WRITER 1 - #endif - #ifndef CYTHON_AVOID_BORROWED_REFS - #define CYTHON_AVOID_BORROWED_REFS 0 - #endif - #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - #undef CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS - #define CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS 1 - #elif !defined(CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS) - #define CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS 0 - #endif - #ifndef CYTHON_ASSUME_SAFE_MACROS - #define CYTHON_ASSUME_SAFE_MACROS 1 - #endif - #ifndef CYTHON_ASSUME_SAFE_SIZE - #define CYTHON_ASSUME_SAFE_SIZE 1 - #endif - #ifndef CYTHON_UNPACK_METHODS - #define CYTHON_UNPACK_METHODS 1 - #endif - #ifndef CYTHON_FAST_THREAD_STATE - #define CYTHON_FAST_THREAD_STATE 1 - #endif - #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - #undef CYTHON_FAST_GIL - #define CYTHON_FAST_GIL 0 - #elif !defined(CYTHON_FAST_GIL) - #define CYTHON_FAST_GIL (PY_VERSION_HEX < 0x030C00A6) - #endif - #ifndef CYTHON_METH_FASTCALL - #define CYTHON_METH_FASTCALL 1 - #endif - #ifndef CYTHON_FAST_PYCALL - #define CYTHON_FAST_PYCALL 1 - #endif - #ifndef CYTHON_PEP487_INIT_SUBCLASS - #define CYTHON_PEP487_INIT_SUBCLASS 1 - #endif - #ifndef CYTHON_PEP489_MULTI_PHASE_INIT - #define CYTHON_PEP489_MULTI_PHASE_INIT 1 - #endif - #ifndef CYTHON_USE_MODULE_STATE - #define CYTHON_USE_MODULE_STATE 0 - #endif - #ifndef CYTHON_USE_SYS_MONITORING - #define CYTHON_USE_SYS_MONITORING (PY_VERSION_HEX >= 0x030d00B1) - #endif - #ifndef CYTHON_USE_TP_FINALIZE - #define CYTHON_USE_TP_FINALIZE 1 - #endif - #ifndef CYTHON_USE_AM_SEND - #define CYTHON_USE_AM_SEND 1 - #endif - #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - #undef CYTHON_USE_DICT_VERSIONS - #define CYTHON_USE_DICT_VERSIONS 0 - #elif !defined(CYTHON_USE_DICT_VERSIONS) - #define CYTHON_USE_DICT_VERSIONS (PY_VERSION_HEX < 0x030C00A5 && !CYTHON_USE_MODULE_STATE) - #endif - #ifndef CYTHON_USE_EXC_INFO_STACK - #define CYTHON_USE_EXC_INFO_STACK 1 - #endif - #ifndef CYTHON_UPDATE_DESCRIPTOR_DOC - #define CYTHON_UPDATE_DESCRIPTOR_DOC 1 - #endif - #ifndef CYTHON_USE_FREELISTS - #define CYTHON_USE_FREELISTS (!CYTHON_COMPILING_IN_CPYTHON_FREETHREADING) - #endif -#endif -#ifndef CYTHON_FAST_PYCCALL -#define CYTHON_FAST_PYCCALL CYTHON_FAST_PYCALL -#endif -#ifndef CYTHON_VECTORCALL -#if CYTHON_COMPILING_IN_LIMITED_API -#define CYTHON_VECTORCALL (__PYX_LIMITED_VERSION_HEX >= 0x030C0000) -#else -#define CYTHON_VECTORCALL (CYTHON_FAST_PYCCALL && PY_VERSION_HEX >= 0x030800B1) -#endif -#endif -#define CYTHON_BACKPORT_VECTORCALL (CYTHON_METH_FASTCALL && PY_VERSION_HEX < 0x030800B1) -#if CYTHON_USE_PYLONG_INTERNALS - #undef SHIFT - #undef BASE - #undef MASK - #ifdef SIZEOF_VOID_P - enum { __pyx_check_sizeof_voidp = 1 / (int)(SIZEOF_VOID_P == sizeof(void*)) }; - #endif -#endif -#ifndef __has_attribute - #define __has_attribute(x) 0 -#endif -#ifndef __has_cpp_attribute - #define __has_cpp_attribute(x) 0 -#endif -#ifndef CYTHON_RESTRICT - #if defined(__GNUC__) - #define CYTHON_RESTRICT __restrict__ - #elif defined(_MSC_VER) && _MSC_VER >= 1400 - #define CYTHON_RESTRICT __restrict - #elif defined (__STDC_VERSION__) && __STDC_VERSION__ >= 199901L - #define CYTHON_RESTRICT restrict - #else - #define CYTHON_RESTRICT - #endif -#endif -#ifndef CYTHON_UNUSED - #if defined(__cplusplus) - /* for clang __has_cpp_attribute(maybe_unused) is true even before C++17 - * but leads to warnings with -pedantic, since it is a C++17 feature */ - #if ((defined(_MSVC_LANG) && _MSVC_LANG >= 201703L) || __cplusplus >= 201703L) - #if __has_cpp_attribute(maybe_unused) - #define CYTHON_UNUSED [[maybe_unused]] - #endif - #endif - #endif -#endif -#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) && !defined(_MSC_VER)) -# define CYTHON_UNUSED __attribute__ ((__unused__)) -# else -# define CYTHON_UNUSED -# endif -#endif -#ifndef CYTHON_UNUSED_VAR -# if defined(__cplusplus) - template void CYTHON_UNUSED_VAR( const T& ) { } -# else -# define CYTHON_UNUSED_VAR(x) (void)(x) -# endif -#endif -#ifndef CYTHON_MAYBE_UNUSED_VAR - #define CYTHON_MAYBE_UNUSED_VAR(x) CYTHON_UNUSED_VAR(x) -#endif -#ifndef CYTHON_NCP_UNUSED -# if CYTHON_COMPILING_IN_CPYTHON -# define CYTHON_NCP_UNUSED -# else -# define CYTHON_NCP_UNUSED CYTHON_UNUSED -# endif -#endif -#ifndef CYTHON_USE_CPP_STD_MOVE - #if defined(__cplusplus) && (\ - __cplusplus >= 201103L || (defined(_MSC_VER) && _MSC_VER >= 1600)) - #define CYTHON_USE_CPP_STD_MOVE 1 - #else - #define CYTHON_USE_CPP_STD_MOVE 0 - #endif -#endif -#define __Pyx_void_to_None(void_result) ((void)(void_result), Py_INCREF(Py_None), Py_None) -#ifdef _MSC_VER - #ifndef _MSC_STDINT_H_ - #if _MSC_VER < 1300 - typedef unsigned char uint8_t; - typedef unsigned short uint16_t; - typedef unsigned int uint32_t; - #else - typedef unsigned __int8 uint8_t; - typedef unsigned __int16 uint16_t; - typedef unsigned __int32 uint32_t; - #endif - #endif - #if _MSC_VER < 1300 - #ifdef _WIN64 - typedef unsigned long long __pyx_uintptr_t; - #else - typedef unsigned int __pyx_uintptr_t; - #endif - #else - #ifdef _WIN64 - typedef unsigned __int64 __pyx_uintptr_t; - #else - typedef unsigned __int32 __pyx_uintptr_t; - #endif - #endif -#else - #include - typedef uintptr_t __pyx_uintptr_t; -#endif -#ifndef CYTHON_FALLTHROUGH - #if defined(__cplusplus) - /* for clang __has_cpp_attribute(fallthrough) is true even before C++17 - * but leads to warnings with -pedantic, since it is a C++17 feature */ - #if ((defined(_MSVC_LANG) && _MSVC_LANG >= 201703L) || __cplusplus >= 201703L) - #if __has_cpp_attribute(fallthrough) - #define CYTHON_FALLTHROUGH [[fallthrough]] - #endif - #endif - #ifndef CYTHON_FALLTHROUGH - #if __has_cpp_attribute(clang::fallthrough) - #define CYTHON_FALLTHROUGH [[clang::fallthrough]] - #elif __has_cpp_attribute(gnu::fallthrough) - #define CYTHON_FALLTHROUGH [[gnu::fallthrough]] - #endif - #endif - #endif - #ifndef CYTHON_FALLTHROUGH - #if __has_attribute(fallthrough) - #define CYTHON_FALLTHROUGH __attribute__((fallthrough)) - #else - #define CYTHON_FALLTHROUGH - #endif - #endif - #if defined(__clang__) && defined(__apple_build_version__) - #if __apple_build_version__ < 7000000 - #undef CYTHON_FALLTHROUGH - #define CYTHON_FALLTHROUGH - #endif - #endif -#endif -#ifndef Py_UNREACHABLE - #define Py_UNREACHABLE() assert(0); abort() -#endif -#ifdef __cplusplus - template - struct __PYX_IS_UNSIGNED_IMPL {static const bool value = T(0) < T(-1);}; - #define __PYX_IS_UNSIGNED(type) (__PYX_IS_UNSIGNED_IMPL::value) -#else - #define __PYX_IS_UNSIGNED(type) (((type)-1) > 0) -#endif -#if CYTHON_COMPILING_IN_PYPY == 1 - #define __PYX_NEED_TP_PRINT_SLOT (PY_VERSION_HEX >= 0x030800b4 && PY_VERSION_HEX < 0x030A0000) -#else - #define __PYX_NEED_TP_PRINT_SLOT (PY_VERSION_HEX >= 0x030800b4 && PY_VERSION_HEX < 0x03090000) -#endif -#define __PYX_REINTERPRET_FUNCION(func_pointer, other_pointer) ((func_pointer)(void(*)(void))(other_pointer)) - -/* CInitCode */ -#ifndef CYTHON_INLINE - #if defined(__clang__) - #define CYTHON_INLINE __inline__ __attribute__ ((__unused__)) - #elif 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 - -/* PythonCompatibility */ -#define __PYX_BUILD_PY_SSIZE_T "n" -#define CYTHON_FORMAT_SSIZE_T "z" -#define __Pyx_BUILTIN_MODULE_NAME "builtins" -#define __Pyx_DefaultClassType PyType_Type -#if CYTHON_COMPILING_IN_LIMITED_API - #ifndef CO_OPTIMIZED - static int CO_OPTIMIZED; - #endif - #ifndef CO_NEWLOCALS - static int CO_NEWLOCALS; - #endif - #ifndef CO_VARARGS - static int CO_VARARGS; - #endif - #ifndef CO_VARKEYWORDS - static int CO_VARKEYWORDS; - #endif - #ifndef CO_ASYNC_GENERATOR - static int CO_ASYNC_GENERATOR; - #endif - #ifndef CO_GENERATOR - static int CO_GENERATOR; - #endif - #ifndef CO_COROUTINE - static int CO_COROUTINE; - #endif -#else - #ifndef CO_COROUTINE - #define CO_COROUTINE 0x80 - #endif - #ifndef CO_ASYNC_GENERATOR - #define CO_ASYNC_GENERATOR 0x200 - #endif -#endif -static int __Pyx_init_co_variables(void); -#if PY_VERSION_HEX >= 0x030900A4 || defined(Py_IS_TYPE) - #define __Pyx_IS_TYPE(ob, type) Py_IS_TYPE(ob, type) -#else - #define __Pyx_IS_TYPE(ob, type) (((const PyObject*)ob)->ob_type == (type)) -#endif -#if PY_VERSION_HEX >= 0x030A00B1 || defined(Py_Is) - #define __Pyx_Py_Is(x, y) Py_Is(x, y) -#else - #define __Pyx_Py_Is(x, y) ((x) == (y)) -#endif -#if PY_VERSION_HEX >= 0x030A00B1 || defined(Py_IsNone) - #define __Pyx_Py_IsNone(ob) Py_IsNone(ob) -#else - #define __Pyx_Py_IsNone(ob) __Pyx_Py_Is((ob), Py_None) -#endif -#if PY_VERSION_HEX >= 0x030A00B1 || defined(Py_IsTrue) - #define __Pyx_Py_IsTrue(ob) Py_IsTrue(ob) -#else - #define __Pyx_Py_IsTrue(ob) __Pyx_Py_Is((ob), Py_True) -#endif -#if PY_VERSION_HEX >= 0x030A00B1 || defined(Py_IsFalse) - #define __Pyx_Py_IsFalse(ob) Py_IsFalse(ob) -#else - #define __Pyx_Py_IsFalse(ob) __Pyx_Py_Is((ob), Py_False) -#endif -#define __Pyx_NoneAsNull(obj) (__Pyx_Py_IsNone(obj) ? NULL : (obj)) -#if PY_VERSION_HEX >= 0x030900F0 && !CYTHON_COMPILING_IN_PYPY - #define __Pyx_PyObject_GC_IsFinalized(o) PyObject_GC_IsFinalized(o) -#else - #define __Pyx_PyObject_GC_IsFinalized(o) _PyGC_FINALIZED(o) -#endif -#ifndef Py_TPFLAGS_CHECKTYPES - #define Py_TPFLAGS_CHECKTYPES 0 -#endif -#ifndef Py_TPFLAGS_HAVE_INDEX - #define Py_TPFLAGS_HAVE_INDEX 0 -#endif -#ifndef Py_TPFLAGS_HAVE_NEWBUFFER - #define Py_TPFLAGS_HAVE_NEWBUFFER 0 -#endif -#ifndef Py_TPFLAGS_HAVE_FINALIZE - #define Py_TPFLAGS_HAVE_FINALIZE 0 -#endif -#ifndef Py_TPFLAGS_SEQUENCE - #define Py_TPFLAGS_SEQUENCE 0 -#endif -#ifndef Py_TPFLAGS_MAPPING - #define Py_TPFLAGS_MAPPING 0 -#endif -#ifndef METH_STACKLESS - #define METH_STACKLESS 0 -#endif -#ifndef METH_FASTCALL - #ifndef METH_FASTCALL - #define METH_FASTCALL 0x80 - #endif - typedef PyObject *(*__Pyx_PyCFunctionFast) (PyObject *self, PyObject *const *args, Py_ssize_t nargs); - typedef PyObject *(*__Pyx_PyCFunctionFastWithKeywords) (PyObject *self, PyObject *const *args, - Py_ssize_t nargs, PyObject *kwnames); -#else - #if PY_VERSION_HEX >= 0x030d00A4 - # define __Pyx_PyCFunctionFast PyCFunctionFast - # define __Pyx_PyCFunctionFastWithKeywords PyCFunctionFastWithKeywords - #else - # define __Pyx_PyCFunctionFast _PyCFunctionFast - # define __Pyx_PyCFunctionFastWithKeywords _PyCFunctionFastWithKeywords - #endif -#endif -#if CYTHON_METH_FASTCALL - #define __Pyx_METH_FASTCALL METH_FASTCALL - #define __Pyx_PyCFunction_FastCall __Pyx_PyCFunctionFast - #define __Pyx_PyCFunction_FastCallWithKeywords __Pyx_PyCFunctionFastWithKeywords -#else - #define __Pyx_METH_FASTCALL METH_VARARGS - #define __Pyx_PyCFunction_FastCall PyCFunction - #define __Pyx_PyCFunction_FastCallWithKeywords PyCFunctionWithKeywords -#endif -#if CYTHON_VECTORCALL - #define __pyx_vectorcallfunc vectorcallfunc - #define __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET PY_VECTORCALL_ARGUMENTS_OFFSET - #define __Pyx_PyVectorcall_NARGS(n) PyVectorcall_NARGS((size_t)(n)) -#elif CYTHON_BACKPORT_VECTORCALL - typedef PyObject *(*__pyx_vectorcallfunc)(PyObject *callable, PyObject *const *args, - size_t nargsf, PyObject *kwnames); - #define __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET ((size_t)1 << (8 * sizeof(size_t) - 1)) - #define __Pyx_PyVectorcall_NARGS(n) ((Py_ssize_t)(((size_t)(n)) & ~__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)) -#else - #define __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET 0 - #define __Pyx_PyVectorcall_NARGS(n) ((Py_ssize_t)(n)) -#endif -#if PY_VERSION_HEX >= 0x030900B1 -#define __Pyx_PyCFunction_CheckExact(func) PyCFunction_CheckExact(func) -#else -#define __Pyx_PyCFunction_CheckExact(func) PyCFunction_Check(func) -#endif -#define __Pyx_CyOrPyCFunction_Check(func) PyCFunction_Check(func) -#if CYTHON_COMPILING_IN_CPYTHON -#define __Pyx_CyOrPyCFunction_GET_FUNCTION(func) (((PyCFunctionObject*)(func))->m_ml->ml_meth) -#elif !CYTHON_COMPILING_IN_LIMITED_API -#define __Pyx_CyOrPyCFunction_GET_FUNCTION(func) PyCFunction_GET_FUNCTION(func) -#endif -#if CYTHON_COMPILING_IN_CPYTHON -#define __Pyx_CyOrPyCFunction_GET_FLAGS(func) (((PyCFunctionObject*)(func))->m_ml->ml_flags) -static CYTHON_INLINE PyObject* __Pyx_CyOrPyCFunction_GET_SELF(PyObject *func) { - return (__Pyx_CyOrPyCFunction_GET_FLAGS(func) & METH_STATIC) ? NULL : ((PyCFunctionObject*)func)->m_self; -} -#endif -static CYTHON_INLINE int __Pyx__IsSameCFunction(PyObject *func, void (*cfunc)(void)) { -#if CYTHON_COMPILING_IN_LIMITED_API - return PyCFunction_Check(func) && PyCFunction_GetFunction(func) == (PyCFunction) cfunc; -#else - return PyCFunction_Check(func) && PyCFunction_GET_FUNCTION(func) == (PyCFunction) cfunc; -#endif -} -#define __Pyx_IsSameCFunction(func, cfunc) __Pyx__IsSameCFunction(func, cfunc) -#if __PYX_LIMITED_VERSION_HEX < 0x03090000 - #define __Pyx_PyType_FromModuleAndSpec(m, s, b) ((void)m, PyType_FromSpecWithBases(s, b)) - typedef PyObject *(*__Pyx_PyCMethod)(PyObject *, PyTypeObject *, PyObject *const *, size_t, PyObject *); -#else - #define __Pyx_PyType_FromModuleAndSpec(m, s, b) PyType_FromModuleAndSpec(m, s, b) - #define __Pyx_PyCMethod PyCMethod -#endif -#ifndef METH_METHOD - #define METH_METHOD 0x200 -#endif -#if CYTHON_COMPILING_IN_PYPY && !defined(PyObject_Malloc) - #define PyObject_Malloc(s) PyMem_Malloc(s) - #define PyObject_Free(p) PyMem_Free(p) - #define PyObject_Realloc(p) PyMem_Realloc(p) -#endif -#if CYTHON_COMPILING_IN_LIMITED_API - #define __Pyx_PyFrame_SetLineNumber(frame, lineno) -#elif CYTHON_COMPILING_IN_GRAAL - #define __Pyx_PyCode_HasFreeVars(co) (PyCode_GetNumFree(co) > 0) - #define __Pyx_PyFrame_SetLineNumber(frame, lineno) _PyFrame_SetLineNumber((frame), (lineno)) -#else - #define __Pyx_PyCode_HasFreeVars(co) (PyCode_GetNumFree(co) > 0) - #define __Pyx_PyFrame_SetLineNumber(frame, lineno) (frame)->f_lineno = (lineno) -#endif -#if CYTHON_COMPILING_IN_LIMITED_API - #define __Pyx_PyThreadState_Current PyThreadState_Get() -#elif !CYTHON_FAST_THREAD_STATE - #define __Pyx_PyThreadState_Current PyThreadState_GET() -#elif PY_VERSION_HEX >= 0x030d00A1 - #define __Pyx_PyThreadState_Current PyThreadState_GetUnchecked() -#else - #define __Pyx_PyThreadState_Current _PyThreadState_UncheckedGet() -#endif -#if CYTHON_USE_MODULE_STATE -static CYTHON_INLINE void *__Pyx__PyModule_GetState(PyObject *op) -{ - void *result; - result = PyModule_GetState(op); - if (!result) - Py_FatalError("Couldn't find the module state"); - return result; -} -#define __Pyx_PyModule_GetState(o) (__pyx_mstatetype *)__Pyx__PyModule_GetState(o) -#else -#define __Pyx_PyModule_GetState(op) ((void)op,__pyx_mstate_global) -#endif -#define __Pyx_PyObject_GetSlot(obj, name, func_ctype) __Pyx_PyType_GetSlot(Py_TYPE((PyObject *) obj), name, func_ctype) -#define __Pyx_PyObject_TryGetSlot(obj, name, func_ctype) __Pyx_PyType_TryGetSlot(Py_TYPE(obj), name, func_ctype) -#define __Pyx_PyObject_GetSubSlot(obj, sub, name, func_ctype) __Pyx_PyType_GetSubSlot(Py_TYPE(obj), sub, name, func_ctype) -#define __Pyx_PyObject_TryGetSubSlot(obj, sub, name, func_ctype) __Pyx_PyType_TryGetSubSlot(Py_TYPE(obj), sub, name, func_ctype) -#if CYTHON_USE_TYPE_SLOTS - #define __Pyx_PyType_GetSlot(type, name, func_ctype) ((type)->name) - #define __Pyx_PyType_TryGetSlot(type, name, func_ctype) __Pyx_PyType_GetSlot(type, name, func_ctype) - #define __Pyx_PyType_GetSubSlot(type, sub, name, func_ctype) (((type)->sub) ? ((type)->sub->name) : NULL) - #define __Pyx_PyType_TryGetSubSlot(type, sub, name, func_ctype) __Pyx_PyType_GetSubSlot(type, sub, name, func_ctype) -#else - #define __Pyx_PyType_GetSlot(type, name, func_ctype) ((func_ctype) PyType_GetSlot((type), Py_##name)) - #define __Pyx_PyType_TryGetSlot(type, name, func_ctype)\ - ((__PYX_LIMITED_VERSION_HEX >= 0x030A0000 ||\ - (PyType_GetFlags(type) & Py_TPFLAGS_HEAPTYPE) || __Pyx_get_runtime_version() >= 0x030A0000) ?\ - __Pyx_PyType_GetSlot(type, name, func_ctype) : NULL) - #define __Pyx_PyType_GetSubSlot(obj, sub, name, func_ctype) __Pyx_PyType_GetSlot(obj, name, func_ctype) - #define __Pyx_PyType_TryGetSubSlot(obj, sub, name, func_ctype) __Pyx_PyType_TryGetSlot(obj, name, func_ctype) -#endif -#if CYTHON_COMPILING_IN_CPYTHON || defined(_PyDict_NewPresized) -#define __Pyx_PyDict_NewPresized(n) ((n <= 8) ? PyDict_New() : _PyDict_NewPresized(n)) -#else -#define __Pyx_PyDict_NewPresized(n) PyDict_New() -#endif -#define __Pyx_PyNumber_Divide(x,y) PyNumber_TrueDivide(x,y) -#define __Pyx_PyNumber_InPlaceDivide(x,y) PyNumber_InPlaceTrueDivide(x,y) -#if CYTHON_COMPILING_IN_CPYTHON && CYTHON_USE_UNICODE_INTERNALS -#define __Pyx_PyDict_GetItemStrWithError(dict, name) _PyDict_GetItem_KnownHash(dict, name, ((PyASCIIObject *) name)->hash) -static CYTHON_INLINE PyObject * __Pyx_PyDict_GetItemStr(PyObject *dict, PyObject *name) { - PyObject *res = __Pyx_PyDict_GetItemStrWithError(dict, name); - if (res == NULL) PyErr_Clear(); - return res; -} -#elif !CYTHON_COMPILING_IN_PYPY || PYPY_VERSION_NUM >= 0x07020000 -#define __Pyx_PyDict_GetItemStrWithError PyDict_GetItemWithError -#define __Pyx_PyDict_GetItemStr PyDict_GetItem -#else -static CYTHON_INLINE PyObject * __Pyx_PyDict_GetItemStrWithError(PyObject *dict, PyObject *name) { -#if CYTHON_COMPILING_IN_PYPY - return PyDict_GetItem(dict, name); -#else - PyDictEntry *ep; - PyDictObject *mp = (PyDictObject*) dict; - long hash = ((PyStringObject *) name)->ob_shash; - assert(hash != -1); - ep = (mp->ma_lookup)(mp, name, hash); - if (ep == NULL) { - return NULL; - } - return ep->me_value; -#endif -} -#define __Pyx_PyDict_GetItemStr PyDict_GetItem -#endif -#if CYTHON_USE_TYPE_SLOTS - #define __Pyx_PyType_GetFlags(tp) (((PyTypeObject *)tp)->tp_flags) - #define __Pyx_PyType_HasFeature(type, feature) ((__Pyx_PyType_GetFlags(type) & (feature)) != 0) -#else - #define __Pyx_PyType_GetFlags(tp) (PyType_GetFlags((PyTypeObject *)tp)) - #define __Pyx_PyType_HasFeature(type, feature) PyType_HasFeature(type, feature) -#endif -#define __Pyx_PyObject_GetIterNextFunc(iterator) __Pyx_PyObject_GetSlot(iterator, tp_iternext, iternextfunc) -#if CYTHON_USE_TYPE_SPECS && PY_VERSION_HEX >= 0x03080000 -#define __Pyx_PyHeapTypeObject_GC_Del(obj) {\ - PyTypeObject *type = Py_TYPE((PyObject*)obj);\ - assert(__Pyx_PyType_HasFeature(type, Py_TPFLAGS_HEAPTYPE));\ - PyObject_GC_Del(obj);\ - Py_DECREF(type);\ -} -#else -#define __Pyx_PyHeapTypeObject_GC_Del(obj) PyObject_GC_Del(obj) -#endif -#if CYTHON_COMPILING_IN_LIMITED_API - #define __Pyx_PyUnicode_READY(op) (0) - #define __Pyx_PyUnicode_READ_CHAR(u, i) PyUnicode_ReadChar(u, i) - #define __Pyx_PyUnicode_MAX_CHAR_VALUE(u) ((void)u, 1114111U) - #define __Pyx_PyUnicode_KIND(u) ((void)u, (0)) - #define __Pyx_PyUnicode_DATA(u) ((void*)u) - #define __Pyx_PyUnicode_READ(k, d, i) ((void)k, PyUnicode_ReadChar((PyObject*)(d), i)) - #define __Pyx_PyUnicode_IS_TRUE(u) (0 != PyUnicode_GetLength(u)) -#else - #if PY_VERSION_HEX >= 0x030C0000 - #define __Pyx_PyUnicode_READY(op) (0) - #else - #define __Pyx_PyUnicode_READY(op) (likely(PyUnicode_IS_READY(op)) ?\ - 0 : _PyUnicode_Ready((PyObject *)(op))) - #endif - #define __Pyx_PyUnicode_READ_CHAR(u, i) PyUnicode_READ_CHAR(u, i) - #define __Pyx_PyUnicode_MAX_CHAR_VALUE(u) PyUnicode_MAX_CHAR_VALUE(u) - #define __Pyx_PyUnicode_KIND(u) ((int)PyUnicode_KIND(u)) - #define __Pyx_PyUnicode_DATA(u) PyUnicode_DATA(u) - #define __Pyx_PyUnicode_READ(k, d, i) PyUnicode_READ(k, d, i) - #define __Pyx_PyUnicode_WRITE(k, d, i, ch) PyUnicode_WRITE(k, d, i, (Py_UCS4) ch) - #if PY_VERSION_HEX >= 0x030C0000 - #define __Pyx_PyUnicode_IS_TRUE(u) (0 != PyUnicode_GET_LENGTH(u)) - #else - #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x03090000 - #define __Pyx_PyUnicode_IS_TRUE(u) (0 != (likely(PyUnicode_IS_READY(u)) ? PyUnicode_GET_LENGTH(u) : ((PyCompactUnicodeObject *)(u))->wstr_length)) - #else - #define __Pyx_PyUnicode_IS_TRUE(u) (0 != (likely(PyUnicode_IS_READY(u)) ? PyUnicode_GET_LENGTH(u) : PyUnicode_GET_SIZE(u))) - #endif - #endif -#endif -#if CYTHON_COMPILING_IN_PYPY - #define __Pyx_PyUnicode_Concat(a, b) PyNumber_Add(a, b) - #define __Pyx_PyUnicode_ConcatSafe(a, b) PyNumber_Add(a, b) -#else - #define __Pyx_PyUnicode_Concat(a, b) PyUnicode_Concat(a, b) - #define __Pyx_PyUnicode_ConcatSafe(a, b) ((unlikely((a) == Py_None) || unlikely((b) == Py_None)) ?\ - PyNumber_Add(a, b) : __Pyx_PyUnicode_Concat(a, b)) -#endif -#if CYTHON_COMPILING_IN_PYPY - #if !defined(PyUnicode_DecodeUnicodeEscape) - #define PyUnicode_DecodeUnicodeEscape(s, size, errors) PyUnicode_Decode(s, size, "unicode_escape", errors) - #endif - #if !defined(PyUnicode_Contains) - #define PyUnicode_Contains(u, s) PySequence_Contains(u, s) - #endif - #if !defined(PyByteArray_Check) - #define PyByteArray_Check(obj) PyObject_TypeCheck(obj, &PyByteArray_Type) - #endif - #if !defined(PyObject_Format) - #define PyObject_Format(obj, fmt) PyObject_CallMethod(obj, "__format__", "O", fmt) - #endif -#endif -#define __Pyx_PyUnicode_FormatSafe(a, b) ((unlikely((a) == Py_None || (PyUnicode_Check(b) && !PyUnicode_CheckExact(b)))) ? PyNumber_Remainder(a, b) : PyUnicode_Format(a, b)) -#if CYTHON_COMPILING_IN_CPYTHON - #define __Pyx_PySequence_ListKeepNew(obj)\ - (likely(PyList_CheckExact(obj) && Py_REFCNT(obj) == 1) ? __Pyx_NewRef(obj) : PySequence_List(obj)) -#else - #define __Pyx_PySequence_ListKeepNew(obj) PySequence_List(obj) -#endif -#ifndef PySet_CheckExact - #define PySet_CheckExact(obj) __Pyx_IS_TYPE(obj, &PySet_Type) -#endif -#if PY_VERSION_HEX >= 0x030900A4 - #define __Pyx_SET_REFCNT(obj, refcnt) Py_SET_REFCNT(obj, refcnt) - #define __Pyx_SET_SIZE(obj, size) Py_SET_SIZE(obj, size) -#else - #define __Pyx_SET_REFCNT(obj, refcnt) Py_REFCNT(obj) = (refcnt) - #define __Pyx_SET_SIZE(obj, size) Py_SIZE(obj) = (size) -#endif -#if CYTHON_COMPILING_IN_LIMITED_API || CYTHON_AVOID_BORROWED_REFS || CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS || !CYTHON_ASSUME_SAFE_MACROS - #if __PYX_LIMITED_VERSION_HEX >= 0x030d0000 - #define __Pyx_PyList_GetItemRef(o, i) PyList_GetItemRef(o, i) - #else - #define __Pyx_PyList_GetItemRef(o, i) PySequence_GetItem(o, i) - #endif -#else - #define __Pyx_PyList_GetItemRef(o, i) __Pyx_NewRef(PyList_GET_ITEM(o, i)) -#endif -#if __PYX_LIMITED_VERSION_HEX >= 0x030d0000 -#define __Pyx_PyDict_GetItemRef(dict, key, result) PyDict_GetItemRef(dict, key, result) -#elif CYTHON_AVOID_BORROWED_REFS || CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS -static CYTHON_INLINE int __Pyx_PyDict_GetItemRef(PyObject *dict, PyObject *key, PyObject **result) { - *result = PyObject_GetItem(dict, key); - if (*result == NULL) { - if (PyErr_ExceptionMatches(PyExc_KeyError)) { - PyErr_Clear(); - return 0; - } - return -1; - } - return 1; -} -#else -static CYTHON_INLINE int __Pyx_PyDict_GetItemRef(PyObject *dict, PyObject *key, PyObject **result) { - *result = PyDict_GetItemWithError(dict, key); - if (*result == NULL) { - return PyErr_Occurred() ? -1 : 0; - } - Py_INCREF(*result); - return 1; -} -#endif -#if defined(CYTHON_DEBUG_VISIT_CONST) && CYTHON_DEBUG_VISIT_CONST - #define __Pyx_VISIT_CONST(obj) Py_VISIT(obj) -#else - #define __Pyx_VISIT_CONST(obj) -#endif -#if CYTHON_ASSUME_SAFE_MACROS - #define __Pyx_PySequence_ITEM(o, i) PySequence_ITEM(o, i) - #define __Pyx_PySequence_SIZE(seq) Py_SIZE(seq) - #define __Pyx_PyTuple_SET_ITEM(o, i, v) (PyTuple_SET_ITEM(o, i, v), (0)) - #define __Pyx_PyTuple_GET_ITEM(o, i) PyTuple_GET_ITEM(o, i) - #define __Pyx_PyList_SET_ITEM(o, i, v) (PyList_SET_ITEM(o, i, v), (0)) - #define __Pyx_PyList_GET_ITEM(o, i) PyList_GET_ITEM(o, i) -#else - #define __Pyx_PySequence_ITEM(o, i) PySequence_GetItem(o, i) - #define __Pyx_PySequence_SIZE(seq) PySequence_Size(seq) - #define __Pyx_PyTuple_SET_ITEM(o, i, v) PyTuple_SetItem(o, i, v) - #define __Pyx_PyTuple_GET_ITEM(o, i) PyTuple_GetItem(o, i) - #define __Pyx_PyList_SET_ITEM(o, i, v) PyList_SetItem(o, i, v) - #define __Pyx_PyList_GET_ITEM(o, i) PyList_GetItem(o, i) -#endif -#if CYTHON_ASSUME_SAFE_SIZE - #define __Pyx_PyTuple_GET_SIZE(o) PyTuple_GET_SIZE(o) - #define __Pyx_PyList_GET_SIZE(o) PyList_GET_SIZE(o) - #define __Pyx_PySet_GET_SIZE(o) PySet_GET_SIZE(o) - #define __Pyx_PyBytes_GET_SIZE(o) PyBytes_GET_SIZE(o) - #define __Pyx_PyByteArray_GET_SIZE(o) PyByteArray_GET_SIZE(o) - #define __Pyx_PyUnicode_GET_LENGTH(o) PyUnicode_GET_LENGTH(o) -#else - #define __Pyx_PyTuple_GET_SIZE(o) PyTuple_Size(o) - #define __Pyx_PyList_GET_SIZE(o) PyList_Size(o) - #define __Pyx_PySet_GET_SIZE(o) PySet_Size(o) - #define __Pyx_PyBytes_GET_SIZE(o) PyBytes_Size(o) - #define __Pyx_PyByteArray_GET_SIZE(o) PyByteArray_Size(o) - #define __Pyx_PyUnicode_GET_LENGTH(o) PyUnicode_GetLength(o) -#endif -#if __PYX_LIMITED_VERSION_HEX >= 0x030d0000 - #define __Pyx_PyImport_AddModuleRef(name) PyImport_AddModuleRef(name) -#else - static CYTHON_INLINE PyObject *__Pyx_PyImport_AddModuleRef(const char *name) { - PyObject *module = PyImport_AddModule(name); - Py_XINCREF(module); - return module; - } -#endif -#if CYTHON_COMPILING_IN_PYPY && !defined(PyUnicode_InternFromString) - #define PyUnicode_InternFromString(s) PyUnicode_FromString(s) -#endif -#define __Pyx_PyLong_FromHash_t PyLong_FromSsize_t -#define __Pyx_PyLong_AsHash_t __Pyx_PyIndex_AsSsize_t -#if __PYX_LIMITED_VERSION_HEX >= 0x030A0000 - #define __Pyx_PySendResult PySendResult -#else - typedef enum { - PYGEN_RETURN = 0, - PYGEN_ERROR = -1, - PYGEN_NEXT = 1, - } __Pyx_PySendResult; -#endif -#if CYTHON_COMPILING_IN_LIMITED_API || PY_VERSION_HEX < 0x030A00A3 - typedef __Pyx_PySendResult (*__Pyx_pyiter_sendfunc)(PyObject *iter, PyObject *value, PyObject **result); -#else - #define __Pyx_pyiter_sendfunc sendfunc -#endif -#if !CYTHON_USE_AM_SEND -#define __PYX_HAS_PY_AM_SEND 0 -#elif __PYX_LIMITED_VERSION_HEX >= 0x030A0000 -#define __PYX_HAS_PY_AM_SEND 1 -#else -#define __PYX_HAS_PY_AM_SEND 2 // our own backported implementation -#endif -#if __PYX_HAS_PY_AM_SEND < 2 - #define __Pyx_PyAsyncMethodsStruct PyAsyncMethods -#else - typedef struct { - unaryfunc am_await; - unaryfunc am_aiter; - unaryfunc am_anext; - __Pyx_pyiter_sendfunc am_send; - } __Pyx_PyAsyncMethodsStruct; - #define __Pyx_SlotTpAsAsync(s) ((PyAsyncMethods*)(s)) -#endif -#if CYTHON_USE_AM_SEND && PY_VERSION_HEX < 0x030A00F0 - #define __Pyx_TPFLAGS_HAVE_AM_SEND (1UL << 21) -#else - #define __Pyx_TPFLAGS_HAVE_AM_SEND (0) -#endif -#if PY_VERSION_HEX >= 0x03090000 -#define __Pyx_PyInterpreterState_Get() PyInterpreterState_Get() -#else -#define __Pyx_PyInterpreterState_Get() PyThreadState_Get()->interp -#endif -#if CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX < 0x030A0000 -#ifdef __cplusplus -extern "C" -#endif -PyAPI_FUNC(void *) PyMem_Calloc(size_t nelem, size_t elsize); -#endif -#if CYTHON_COMPILING_IN_LIMITED_API -static int __Pyx_init_co_variable(PyObject *inspect, const char* name, int *write_to) { - int value; - PyObject *py_value = PyObject_GetAttrString(inspect, name); - if (!py_value) return 0; - value = (int) PyLong_AsLong(py_value); - Py_DECREF(py_value); - *write_to = value; - return value != -1 || !PyErr_Occurred(); -} -static int __Pyx_init_co_variables(void) { - PyObject *inspect; - int result; - inspect = PyImport_ImportModule("inspect"); - result = -#if !defined(CO_OPTIMIZED) - __Pyx_init_co_variable(inspect, "CO_OPTIMIZED", &CO_OPTIMIZED) && -#endif -#if !defined(CO_NEWLOCALS) - __Pyx_init_co_variable(inspect, "CO_NEWLOCALS", &CO_NEWLOCALS) && -#endif -#if !defined(CO_VARARGS) - __Pyx_init_co_variable(inspect, "CO_VARARGS", &CO_VARARGS) && -#endif -#if !defined(CO_VARKEYWORDS) - __Pyx_init_co_variable(inspect, "CO_VARKEYWORDS", &CO_VARKEYWORDS) && -#endif -#if !defined(CO_ASYNC_GENERATOR) - __Pyx_init_co_variable(inspect, "CO_ASYNC_GENERATOR", &CO_ASYNC_GENERATOR) && -#endif -#if !defined(CO_GENERATOR) - __Pyx_init_co_variable(inspect, "CO_GENERATOR", &CO_GENERATOR) && -#endif -#if !defined(CO_COROUTINE) - __Pyx_init_co_variable(inspect, "CO_COROUTINE", &CO_COROUTINE) && -#endif - 1; - Py_DECREF(inspect); - return result ? 0 : -1; -} -#else -static int __Pyx_init_co_variables(void) { - return 0; // It's a limited API-only feature -} -#endif - -/* MathInitCode */ -#if defined(_WIN32) || defined(WIN32) || defined(MS_WINDOWS) - #ifndef _USE_MATH_DEFINES - #define _USE_MATH_DEFINES - #endif -#endif -#include -#ifdef NAN -#define __PYX_NAN() ((float) NAN) -#else -static CYTHON_INLINE float __PYX_NAN() { - float value; - memset(&value, 0xFF, sizeof(value)); - return value; -} -#endif -#if defined(__CYGWIN__) && defined(_LDBL_EQ_DBL) -#define __Pyx_truncl trunc -#else -#define __Pyx_truncl truncl -#endif - -#ifndef CYTHON_CLINE_IN_TRACEBACK_RUNTIME -#define CYTHON_CLINE_IN_TRACEBACK_RUNTIME 0 -#endif -#ifndef CYTHON_CLINE_IN_TRACEBACK -#define CYTHON_CLINE_IN_TRACEBACK CYTHON_CLINE_IN_TRACEBACK_RUNTIME -#endif -#if CYTHON_CLINE_IN_TRACEBACK -#define __PYX_MARK_ERR_POS(f_index, lineno) { __pyx_filename = __pyx_f[f_index]; (void) __pyx_filename; __pyx_lineno = lineno; (void) __pyx_lineno; __pyx_clineno = __LINE__; (void) __pyx_clineno; } -#else -#define __PYX_MARK_ERR_POS(f_index, lineno) { __pyx_filename = __pyx_f[f_index]; (void) __pyx_filename; __pyx_lineno = lineno; (void) __pyx_lineno; (void) __pyx_clineno; } -#endif -#define __PYX_ERR(f_index, lineno, Ln_error) \ - { __PYX_MARK_ERR_POS(f_index, lineno) goto Ln_error; } - -#ifdef CYTHON_EXTERN_C - #undef __PYX_EXTERN_C - #define __PYX_EXTERN_C CYTHON_EXTERN_C -#elif defined(__PYX_EXTERN_C) - #ifdef _MSC_VER - #pragma message ("Please do not define the '__PYX_EXTERN_C' macro externally. Use 'CYTHON_EXTERN_C' instead.") - #else - #warning Please do not define the '__PYX_EXTERN_C' macro externally. Use 'CYTHON_EXTERN_C' instead. - #endif -#else - #ifdef __cplusplus - #define __PYX_EXTERN_C extern "C" - #else - #define __PYX_EXTERN_C extern - #endif -#endif - -#define __PYX_HAVE__epanet__epanet -#define __PYX_HAVE_API__epanet__epanet -/* Early includes */ -#ifdef _OPENMP -#include -#endif /* _OPENMP */ - -#if defined(PYREX_WITHOUT_ASSERTIONS) && !defined(CYTHON_WITHOUT_ASSERTIONS) -#define CYTHON_WITHOUT_ASSERTIONS -#endif - -#define __PYX_DEFAULT_STRING_ENCODING_IS_ASCII 0 -#define __PYX_DEFAULT_STRING_ENCODING_IS_UTF8 0 -#define __PYX_DEFAULT_STRING_ENCODING "" -#define __Pyx_PyObject_FromString __Pyx_PyBytes_FromString -#define __Pyx_PyObject_FromStringAndSize __Pyx_PyBytes_FromStringAndSize -#define __Pyx_uchar_cast(c) ((unsigned char)c) -#define __Pyx_long_cast(x) ((long)x) -#define __Pyx_fits_Py_ssize_t(v, type, is_signed) (\ - (sizeof(type) < sizeof(Py_ssize_t)) ||\ - (sizeof(type) > sizeof(Py_ssize_t) &&\ - likely(v < (type)PY_SSIZE_T_MAX ||\ - v == (type)PY_SSIZE_T_MAX) &&\ - (!is_signed || likely(v > (type)PY_SSIZE_T_MIN ||\ - v == (type)PY_SSIZE_T_MIN))) ||\ - (sizeof(type) == sizeof(Py_ssize_t) &&\ - (is_signed || likely(v < (type)PY_SSIZE_T_MAX ||\ - v == (type)PY_SSIZE_T_MAX))) ) -static CYTHON_INLINE int __Pyx_is_valid_index(Py_ssize_t i, Py_ssize_t limit) { - return (size_t) i < (size_t) limit; -} -#if defined (__cplusplus) && __cplusplus >= 201103L - #include - #define __Pyx_sst_abs(value) std::abs(value) -#elif SIZEOF_INT >= SIZEOF_SIZE_T - #define __Pyx_sst_abs(value) abs(value) -#elif SIZEOF_LONG >= SIZEOF_SIZE_T - #define __Pyx_sst_abs(value) labs(value) -#elif defined (_MSC_VER) - #define __Pyx_sst_abs(value) ((Py_ssize_t)_abs64(value)) -#elif defined (__STDC_VERSION__) && __STDC_VERSION__ >= 199901L - #define __Pyx_sst_abs(value) llabs(value) -#elif defined (__GNUC__) - #define __Pyx_sst_abs(value) __builtin_llabs(value) -#else - #define __Pyx_sst_abs(value) ((value<0) ? -value : value) -#endif -static CYTHON_INLINE Py_ssize_t __Pyx_ssize_strlen(const char *s); -static CYTHON_INLINE const char* __Pyx_PyObject_AsString(PyObject*); -static CYTHON_INLINE const char* __Pyx_PyObject_AsStringAndSize(PyObject*, Py_ssize_t* length); -static CYTHON_INLINE PyObject* __Pyx_PyByteArray_FromString(const char*); -#define __Pyx_PyByteArray_FromStringAndSize(s, l) PyByteArray_FromStringAndSize((const char*)s, l) -#define __Pyx_PyBytes_FromString PyBytes_FromString -#define __Pyx_PyBytes_FromStringAndSize PyBytes_FromStringAndSize -static CYTHON_INLINE PyObject* __Pyx_PyUnicode_FromString(const char*); -#if CYTHON_ASSUME_SAFE_MACROS - #define __Pyx_PyBytes_AsWritableString(s) ((char*) PyBytes_AS_STRING(s)) - #define __Pyx_PyBytes_AsWritableSString(s) ((signed char*) PyBytes_AS_STRING(s)) - #define __Pyx_PyBytes_AsWritableUString(s) ((unsigned char*) PyBytes_AS_STRING(s)) - #define __Pyx_PyBytes_AsString(s) ((const char*) PyBytes_AS_STRING(s)) - #define __Pyx_PyBytes_AsSString(s) ((const signed char*) PyBytes_AS_STRING(s)) - #define __Pyx_PyBytes_AsUString(s) ((const unsigned char*) PyBytes_AS_STRING(s)) - #define __Pyx_PyByteArray_AsString(s) PyByteArray_AS_STRING(s) -#else - #define __Pyx_PyBytes_AsWritableString(s) ((char*) PyBytes_AsString(s)) - #define __Pyx_PyBytes_AsWritableSString(s) ((signed char*) PyBytes_AsString(s)) - #define __Pyx_PyBytes_AsWritableUString(s) ((unsigned char*) PyBytes_AsString(s)) - #define __Pyx_PyBytes_AsString(s) ((const char*) PyBytes_AsString(s)) - #define __Pyx_PyBytes_AsSString(s) ((const signed char*) PyBytes_AsString(s)) - #define __Pyx_PyBytes_AsUString(s) ((const unsigned char*) PyBytes_AsString(s)) - #define __Pyx_PyByteArray_AsString(s) PyByteArray_AsString(s) -#endif -#define __Pyx_PyObject_AsWritableString(s) ((char*)(__pyx_uintptr_t) __Pyx_PyObject_AsString(s)) -#define __Pyx_PyObject_AsWritableSString(s) ((signed char*)(__pyx_uintptr_t) __Pyx_PyObject_AsString(s)) -#define __Pyx_PyObject_AsWritableUString(s) ((unsigned char*)(__pyx_uintptr_t) __Pyx_PyObject_AsString(s)) -#define __Pyx_PyObject_AsSString(s) ((const signed char*) __Pyx_PyObject_AsString(s)) -#define __Pyx_PyObject_AsUString(s) ((const unsigned char*) __Pyx_PyObject_AsString(s)) -#define __Pyx_PyObject_FromCString(s) __Pyx_PyObject_FromString((const char*)s) -#define __Pyx_PyBytes_FromCString(s) __Pyx_PyBytes_FromString((const char*)s) -#define __Pyx_PyByteArray_FromCString(s) __Pyx_PyByteArray_FromString((const char*)s) -#define __Pyx_PyUnicode_FromCString(s) __Pyx_PyUnicode_FromString((const char*)s) -#define __Pyx_PyUnicode_FromOrdinal(o) PyUnicode_FromOrdinal((int)o) -#define __Pyx_PyUnicode_AsUnicode PyUnicode_AsUnicode -static CYTHON_INLINE PyObject *__Pyx_NewRef(PyObject *obj) { -#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030a0000 || defined(Py_NewRef) - return Py_NewRef(obj); -#else - Py_INCREF(obj); - return obj; -#endif -} -static CYTHON_INLINE PyObject *__Pyx_XNewRef(PyObject *obj) { -#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030a0000 || defined(Py_XNewRef) - return Py_XNewRef(obj); -#else - Py_XINCREF(obj); - return obj; -#endif -} -static CYTHON_INLINE PyObject *__Pyx_Owned_Py_None(int b); -static CYTHON_INLINE PyObject * __Pyx_PyBool_FromLong(long b); -static CYTHON_INLINE int __Pyx_PyObject_IsTrue(PyObject*); -static CYTHON_INLINE int __Pyx_PyObject_IsTrueAndDecref(PyObject*); -static CYTHON_INLINE PyObject* __Pyx_PyNumber_Long(PyObject* x); -#define __Pyx_PySequence_Tuple(obj)\ - (likely(PyTuple_CheckExact(obj)) ? __Pyx_NewRef(obj) : PySequence_Tuple(obj)) -static CYTHON_INLINE Py_ssize_t __Pyx_PyIndex_AsSsize_t(PyObject*); -static CYTHON_INLINE PyObject * __Pyx_PyLong_FromSize_t(size_t); -static CYTHON_INLINE Py_hash_t __Pyx_PyIndex_AsHash_t(PyObject*); -#if CYTHON_ASSUME_SAFE_MACROS -#define __Pyx_PyFloat_AsDouble(x) (PyFloat_CheckExact(x) ? PyFloat_AS_DOUBLE(x) : PyFloat_AsDouble(x)) -#define __Pyx_PyFloat_AS_DOUBLE(x) PyFloat_AS_DOUBLE(x) -#else -#define __Pyx_PyFloat_AsDouble(x) PyFloat_AsDouble(x) -#define __Pyx_PyFloat_AS_DOUBLE(x) PyFloat_AsDouble(x) -#endif -#define __Pyx_PyFloat_AsFloat(x) ((float) __Pyx_PyFloat_AsDouble(x)) -#define __Pyx_PyNumber_Int(x) (PyLong_CheckExact(x) ? __Pyx_NewRef(x) : PyNumber_Long(x)) -#if CYTHON_USE_PYLONG_INTERNALS - #if PY_VERSION_HEX >= 0x030C00A7 - #ifndef _PyLong_SIGN_MASK - #define _PyLong_SIGN_MASK 3 - #endif - #ifndef _PyLong_NON_SIZE_BITS - #define _PyLong_NON_SIZE_BITS 3 - #endif - #define __Pyx_PyLong_Sign(x) (((PyLongObject*)x)->long_value.lv_tag & _PyLong_SIGN_MASK) - #define __Pyx_PyLong_IsNeg(x) ((__Pyx_PyLong_Sign(x) & 2) != 0) - #define __Pyx_PyLong_IsNonNeg(x) (!__Pyx_PyLong_IsNeg(x)) - #define __Pyx_PyLong_IsZero(x) (__Pyx_PyLong_Sign(x) & 1) - #define __Pyx_PyLong_IsPos(x) (__Pyx_PyLong_Sign(x) == 0) - #define __Pyx_PyLong_CompactValueUnsigned(x) (__Pyx_PyLong_Digits(x)[0]) - #define __Pyx_PyLong_DigitCount(x) ((Py_ssize_t) (((PyLongObject*)x)->long_value.lv_tag >> _PyLong_NON_SIZE_BITS)) - #define __Pyx_PyLong_SignedDigitCount(x)\ - ((1 - (Py_ssize_t) __Pyx_PyLong_Sign(x)) * __Pyx_PyLong_DigitCount(x)) - #if defined(PyUnstable_Long_IsCompact) && defined(PyUnstable_Long_CompactValue) - #define __Pyx_PyLong_IsCompact(x) PyUnstable_Long_IsCompact((PyLongObject*) x) - #define __Pyx_PyLong_CompactValue(x) PyUnstable_Long_CompactValue((PyLongObject*) x) - #else - #define __Pyx_PyLong_IsCompact(x) (((PyLongObject*)x)->long_value.lv_tag < (2 << _PyLong_NON_SIZE_BITS)) - #define __Pyx_PyLong_CompactValue(x) ((1 - (Py_ssize_t) __Pyx_PyLong_Sign(x)) * (Py_ssize_t) __Pyx_PyLong_Digits(x)[0]) - #endif - typedef Py_ssize_t __Pyx_compact_pylong; - typedef size_t __Pyx_compact_upylong; - #else - #define __Pyx_PyLong_IsNeg(x) (Py_SIZE(x) < 0) - #define __Pyx_PyLong_IsNonNeg(x) (Py_SIZE(x) >= 0) - #define __Pyx_PyLong_IsZero(x) (Py_SIZE(x) == 0) - #define __Pyx_PyLong_IsPos(x) (Py_SIZE(x) > 0) - #define __Pyx_PyLong_CompactValueUnsigned(x) ((Py_SIZE(x) == 0) ? 0 : __Pyx_PyLong_Digits(x)[0]) - #define __Pyx_PyLong_DigitCount(x) __Pyx_sst_abs(Py_SIZE(x)) - #define __Pyx_PyLong_SignedDigitCount(x) Py_SIZE(x) - #define __Pyx_PyLong_IsCompact(x) (Py_SIZE(x) == 0 || Py_SIZE(x) == 1 || Py_SIZE(x) == -1) - #define __Pyx_PyLong_CompactValue(x)\ - ((Py_SIZE(x) == 0) ? (sdigit) 0 : ((Py_SIZE(x) < 0) ? -(sdigit)__Pyx_PyLong_Digits(x)[0] : (sdigit)__Pyx_PyLong_Digits(x)[0])) - typedef sdigit __Pyx_compact_pylong; - typedef digit __Pyx_compact_upylong; - #endif - #if PY_VERSION_HEX >= 0x030C00A5 - #define __Pyx_PyLong_Digits(x) (((PyLongObject*)x)->long_value.ob_digit) - #else - #define __Pyx_PyLong_Digits(x) (((PyLongObject*)x)->ob_digit) - #endif -#endif -#if __PYX_DEFAULT_STRING_ENCODING_IS_UTF8 - #define __Pyx_PyUnicode_FromStringAndSize(c_str, size) PyUnicode_DecodeUTF8(c_str, size, NULL) -#elif __PYX_DEFAULT_STRING_ENCODING_IS_ASCII - #define __Pyx_PyUnicode_FromStringAndSize(c_str, size) PyUnicode_DecodeASCII(c_str, size, NULL) -#else - #define __Pyx_PyUnicode_FromStringAndSize(c_str, size) PyUnicode_Decode(c_str, size, __PYX_DEFAULT_STRING_ENCODING, NULL) -#endif - - -/* Test for GCC > 2.95 */ -#if defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95))) - #define likely(x) __builtin_expect(!!(x), 1) - #define unlikely(x) __builtin_expect(!!(x), 0) -#else /* !__GNUC__ or GCC < 2.95 */ - #define likely(x) (x) - #define unlikely(x) (x) -#endif /* __GNUC__ */ -/* PretendToInitialize */ -#ifdef __cplusplus -#include -template -static void __Pyx_pretend_to_initialize(T* ptr) { -#if __cplusplus > 201103L - if ((std::is_trivially_default_constructible::value)) -#endif - *ptr = T(); - (void)ptr; -} -#else -static CYTHON_INLINE void __Pyx_pretend_to_initialize(void* ptr) { (void)ptr; } -#endif - - -#if !CYTHON_USE_MODULE_STATE -static PyObject *__pyx_m = NULL; -#endif -static int __pyx_lineno; -static int __pyx_clineno = 0; -static const char * const __pyx_cfilenm = __FILE__; -static const char *__pyx_filename; - -/* #### Code section: filename_table ### */ - -static const char* const __pyx_f[] = { - "epanet/epanet.py", -}; -/* #### Code section: utility_code_proto_before_types ### */ -/* Atomics.proto */ -#include -#ifndef CYTHON_ATOMICS - #define CYTHON_ATOMICS 1 -#endif -#define __PYX_CYTHON_ATOMICS_ENABLED() CYTHON_ATOMICS -#define __PYX_GET_CYTHON_COMPILING_IN_CPYTHON_FREETHREADING() CYTHON_COMPILING_IN_CPYTHON_FREETHREADING -#define __pyx_atomic_int_type int -#define __pyx_nonatomic_int_type int -#if CYTHON_ATOMICS && (defined(__STDC_VERSION__) &&\ - (__STDC_VERSION__ >= 201112L) &&\ - !defined(__STDC_NO_ATOMICS__)) - #include -#elif CYTHON_ATOMICS && (defined(__cplusplus) && (\ - (__cplusplus >= 201103L) ||\ - (defined(_MSC_VER) && _MSC_VER >= 1700))) - #include -#endif -#if CYTHON_ATOMICS && (defined(__STDC_VERSION__) &&\ - (__STDC_VERSION__ >= 201112L) &&\ - !defined(__STDC_NO_ATOMICS__) &&\ - ATOMIC_INT_LOCK_FREE == 2) - #undef __pyx_atomic_int_type - #define __pyx_atomic_int_type atomic_int - #define __pyx_atomic_ptr_type atomic_uintptr_t - #define __pyx_nonatomic_ptr_type uintptr_t - #define __pyx_atomic_incr_relaxed(value) atomic_fetch_add_explicit(value, 1, memory_order_relaxed) - #define __pyx_atomic_incr_acq_rel(value) atomic_fetch_add_explicit(value, 1, memory_order_acq_rel) - #define __pyx_atomic_decr_acq_rel(value) atomic_fetch_sub_explicit(value, 1, memory_order_acq_rel) - #define __pyx_atomic_sub(value, arg) atomic_fetch_sub(value, arg) - #define __pyx_atomic_int_cmp_exchange(value, expected, desired) atomic_compare_exchange_strong(value, expected, desired) - #define __pyx_atomic_load(value) atomic_load(value) - #define __pyx_atomic_store(value, new_value) atomic_store(value, new_value) - #define __pyx_atomic_pointer_load_relaxed(value) atomic_load_explicit(value, memory_order_relaxed) - #define __pyx_atomic_pointer_load_acquire(value) atomic_load_explicit(value, memory_order_acquire) - #define __pyx_atomic_pointer_exchange(value, new_value) atomic_exchange(value, (__pyx_nonatomic_ptr_type)new_value) - #if defined(__PYX_DEBUG_ATOMICS) && defined(_MSC_VER) - #pragma message ("Using standard C atomics") - #elif defined(__PYX_DEBUG_ATOMICS) - #warning "Using standard C atomics" - #endif -#elif CYTHON_ATOMICS && (defined(__cplusplus) && (\ - (__cplusplus >= 201103L) ||\ -\ - (defined(_MSC_VER) && _MSC_VER >= 1700)) &&\ - ATOMIC_INT_LOCK_FREE == 2) - #undef __pyx_atomic_int_type - #define __pyx_atomic_int_type std::atomic_int - #define __pyx_atomic_ptr_type std::atomic_uintptr_t - #define __pyx_nonatomic_ptr_type uintptr_t - #define __pyx_atomic_incr_relaxed(value) std::atomic_fetch_add_explicit(value, 1, std::memory_order_relaxed) - #define __pyx_atomic_incr_acq_rel(value) std::atomic_fetch_add_explicit(value, 1, std::memory_order_acq_rel) - #define __pyx_atomic_decr_acq_rel(value) std::atomic_fetch_sub_explicit(value, 1, std::memory_order_acq_rel) - #define __pyx_atomic_sub(value, arg) std::atomic_fetch_sub(value, arg) - #define __pyx_atomic_int_cmp_exchange(value, expected, desired) std::atomic_compare_exchange_strong(value, expected, desired) - #define __pyx_atomic_load(value) std::atomic_load(value) - #define __pyx_atomic_store(value, new_value) std::atomic_store(value, new_value) - #define __pyx_atomic_pointer_load_relaxed(value) std::atomic_load_explicit(value, std::memory_order_relaxed) - #define __pyx_atomic_pointer_load_acquire(value) std::atomic_load_explicit(value, std::memory_order_acquire) - #define __pyx_atomic_pointer_exchange(value, new_value) std::atomic_exchange(value, (__pyx_nonatomic_ptr_type)new_value) - #if defined(__PYX_DEBUG_ATOMICS) && defined(_MSC_VER) - #pragma message ("Using standard C++ atomics") - #elif defined(__PYX_DEBUG_ATOMICS) - #warning "Using standard C++ atomics" - #endif -#elif CYTHON_ATOMICS && (__GNUC__ >= 5 || (__GNUC__ == 4 &&\ - (__GNUC_MINOR__ > 1 ||\ - (__GNUC_MINOR__ == 1 && __GNUC_PATCHLEVEL__ >= 2)))) - #define __pyx_atomic_ptr_type void* - #define __pyx_atomic_incr_relaxed(value) __sync_fetch_and_add(value, 1) - #define __pyx_atomic_incr_acq_rel(value) __sync_fetch_and_add(value, 1) - #define __pyx_atomic_decr_acq_rel(value) __sync_fetch_and_sub(value, 1) - #define __pyx_atomic_sub(value, arg) __sync_fetch_and_sub(value, arg) - static CYTHON_INLINE int __pyx_atomic_int_cmp_exchange(__pyx_atomic_int_type* value, __pyx_nonatomic_int_type* expected, __pyx_nonatomic_int_type desired) { - __pyx_nonatomic_int_type old = __sync_val_compare_and_swap(value, *expected, desired); - int result = old == *expected; - *expected = old; - return result; - } - #define __pyx_atomic_load(value) __sync_fetch_and_add(value, 0) - #define __pyx_atomic_store(value, new_value) __sync_lock_test_and_set(value, new_value) - #define __pyx_atomic_pointer_load_relaxed(value) __sync_fetch_and_add(value, 0) - #define __pyx_atomic_pointer_load_acquire(value) __sync_fetch_and_add(value, 0) - #define __pyx_atomic_pointer_exchange(value, new_value) __sync_lock_test_and_set(value, (__pyx_atomic_ptr_type)new_value) - #ifdef __PYX_DEBUG_ATOMICS - #warning "Using GNU atomics" - #endif -#elif CYTHON_ATOMICS && defined(_MSC_VER) - #include - #undef __pyx_atomic_int_type - #define __pyx_atomic_int_type long - #define __pyx_atomic_ptr_type void* - #undef __pyx_nonatomic_int_type - #define __pyx_nonatomic_int_type long - #pragma intrinsic (_InterlockedExchangeAdd, _InterlockedExchange, _InterlockedCompareExchange, _InterlockedCompareExchangePointer, _InterlockedExchangePointer) - #define __pyx_atomic_incr_relaxed(value) _InterlockedExchangeAdd(value, 1) - #define __pyx_atomic_incr_acq_rel(value) _InterlockedExchangeAdd(value, 1) - #define __pyx_atomic_decr_acq_rel(value) _InterlockedExchangeAdd(value, -1) - #define __pyx_atomic_sub(value, arg) _InterlockedExchangeAdd(value, -arg) - static CYTHON_INLINE int __pyx_atomic_int_cmp_exchange(__pyx_atomic_int_type* value, __pyx_nonatomic_int_type* expected, __pyx_nonatomic_int_type desired) { - __pyx_nonatomic_int_type old = _InterlockedCompareExchange(value, desired, *expected); - int result = old == *expected; - *expected = old; - return result; - } - #define __pyx_atomic_load(value) _InterlockedExchangeAdd(value, 0) - #define __pyx_atomic_store(value, new_value) _InterlockedExchange(value, new_value) - #define __pyx_atomic_pointer_load_relaxed(value) *(void * volatile *)value - #define __pyx_atomic_pointer_load_acquire(value) _InterlockedCompareExchangePointer(value, 0, 0) - #define __pyx_atomic_pointer_exchange(value, new_value) _InterlockedExchangePointer(value, (__pyx_atomic_ptr_type)new_value) - #ifdef __PYX_DEBUG_ATOMICS - #pragma message ("Using MSVC atomics") - #endif -#else - #undef CYTHON_ATOMICS - #define CYTHON_ATOMICS 0 - #ifdef __PYX_DEBUG_ATOMICS - #warning "Not using atomics" - #endif -#endif -#if CYTHON_ATOMICS - #define __pyx_add_acquisition_count(memview)\ - __pyx_atomic_incr_relaxed(__pyx_get_slice_count_pointer(memview)) - #define __pyx_sub_acquisition_count(memview)\ - __pyx_atomic_decr_acq_rel(__pyx_get_slice_count_pointer(memview)) -#else - #define __pyx_add_acquisition_count(memview)\ - __pyx_add_acquisition_count_locked(__pyx_get_slice_count_pointer(memview), memview->lock) - #define __pyx_sub_acquisition_count(memview)\ - __pyx_sub_acquisition_count_locked(__pyx_get_slice_count_pointer(memview), memview->lock) -#endif - -/* IncludeStructmemberH.proto */ -#include - -/* CriticalSections.proto */ -#if !CYTHON_COMPILING_IN_CPYTHON_FREETHREADING -#define __Pyx_PyCriticalSection void* -#define __Pyx_PyCriticalSection2 void* -#define __Pyx_PyCriticalSection_Begin1(cs, arg) (void)cs -#define __Pyx_PyCriticalSection_Begin2(cs, arg1, arg2) (void)cs -#define __Pyx_PyCriticalSection_End1(cs) -#define __Pyx_PyCriticalSection_End2(cs) -#else -#define __Pyx_PyCriticalSection PyCriticalSection -#define __Pyx_PyCriticalSection2 PyCriticalSection2 -#define __Pyx_PyCriticalSection_Begin1 PyCriticalSection_Begin -#define __Pyx_PyCriticalSection_Begin2 PyCriticalSection2_Begin -#define __Pyx_PyCriticalSection_End1 PyCriticalSection_End -#define __Pyx_PyCriticalSection_End2 PyCriticalSection2_End -#endif -#if PY_VERSION_HEX < 0x030d0000 || CYTHON_COMPILING_IN_LIMITED_API -#define __Pyx_BEGIN_CRITICAL_SECTION(o) { -#define __Pyx_END_CRITICAL_SECTION() } -#else -#define __Pyx_BEGIN_CRITICAL_SECTION Py_BEGIN_CRITICAL_SECTION -#define __Pyx_END_CRITICAL_SECTION Py_END_CRITICAL_SECTION -#endif - -/* #### Code section: numeric_typedefs ### */ -/* #### Code section: complex_type_declarations ### */ -/* #### Code section: type_declarations ### */ - -/*--- Type declarations ---*/ -/* #### Code section: utility_code_proto ### */ - -/* --- Runtime support code (head) --- */ -/* Refnanny.proto */ -#ifndef CYTHON_REFNANNY - #define CYTHON_REFNANNY 0 -#endif -#if CYTHON_REFNANNY - typedef struct { - void (*INCREF)(void*, PyObject*, Py_ssize_t); - void (*DECREF)(void*, PyObject*, Py_ssize_t); - void (*GOTREF)(void*, PyObject*, Py_ssize_t); - void (*GIVEREF)(void*, PyObject*, Py_ssize_t); - void* (*SetupContext)(const char*, Py_ssize_t, const char*); - void (*FinishContext)(void**); - } __Pyx_RefNannyAPIStruct; - static __Pyx_RefNannyAPIStruct *__Pyx_RefNanny = NULL; - static __Pyx_RefNannyAPIStruct *__Pyx_RefNannyImportAPI(const char *modname); - #define __Pyx_RefNannyDeclarations void *__pyx_refnanny = NULL; - #define __Pyx_RefNannySetupContext(name, acquire_gil)\ - if (acquire_gil) {\ - PyGILState_STATE __pyx_gilstate_save = PyGILState_Ensure();\ - __pyx_refnanny = __Pyx_RefNanny->SetupContext((name), (__LINE__), (__FILE__));\ - PyGILState_Release(__pyx_gilstate_save);\ - } else {\ - __pyx_refnanny = __Pyx_RefNanny->SetupContext((name), (__LINE__), (__FILE__));\ - } - #define __Pyx_RefNannyFinishContextNogil() {\ - PyGILState_STATE __pyx_gilstate_save = PyGILState_Ensure();\ - __Pyx_RefNannyFinishContext();\ - PyGILState_Release(__pyx_gilstate_save);\ - } - #define __Pyx_RefNannyFinishContextNogil() {\ - PyGILState_STATE __pyx_gilstate_save = PyGILState_Ensure();\ - __Pyx_RefNannyFinishContext();\ - PyGILState_Release(__pyx_gilstate_save);\ - } - #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); else {__Pyx_INCREF(r); }} while(0) - #define __Pyx_XDECREF(r) do { if((r) == NULL); else {__Pyx_DECREF(r); }} while(0) - #define __Pyx_XGOTREF(r) do { if((r) == NULL); else {__Pyx_GOTREF(r); }} while(0) - #define __Pyx_XGIVEREF(r) do { if((r) == NULL); else {__Pyx_GIVEREF(r);}} while(0) -#else - #define __Pyx_RefNannyDeclarations - #define __Pyx_RefNannySetupContext(name, acquire_gil) - #define __Pyx_RefNannyFinishContextNogil() - #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 -#define __Pyx_Py_XDECREF_SET(r, v) do {\ - PyObject *tmp = (PyObject *) r;\ - r = v; Py_XDECREF(tmp);\ - } while (0) -#define __Pyx_XDECREF_SET(r, v) do {\ - PyObject *tmp = (PyObject *) r;\ - r = v; __Pyx_XDECREF(tmp);\ - } while (0) -#define __Pyx_DECREF_SET(r, v) do {\ - PyObject *tmp = (PyObject *) r;\ - r = v; __Pyx_DECREF(tmp);\ - } while (0) -#define __Pyx_CLEAR(r) do { PyObject* tmp = ((PyObject*)(r)); r = NULL; __Pyx_DECREF(tmp);} while(0) -#define __Pyx_XCLEAR(r) do { if((r) != NULL) {PyObject* tmp = ((PyObject*)(r)); r = NULL; __Pyx_DECREF(tmp);}} while(0) - -/* PyErrExceptionMatches.proto */ -#if CYTHON_FAST_THREAD_STATE -#define __Pyx_PyErr_ExceptionMatches(err) __Pyx_PyErr_ExceptionMatchesInState(__pyx_tstate, err) -static CYTHON_INLINE int __Pyx_PyErr_ExceptionMatchesInState(PyThreadState* tstate, PyObject* err); -#else -#define __Pyx_PyErr_ExceptionMatches(err) PyErr_ExceptionMatches(err) -#endif - -/* PyThreadStateGet.proto */ -#if CYTHON_FAST_THREAD_STATE -#define __Pyx_PyThreadState_declare PyThreadState *__pyx_tstate; -#define __Pyx_PyThreadState_assign __pyx_tstate = __Pyx_PyThreadState_Current; -#if PY_VERSION_HEX >= 0x030C00A6 -#define __Pyx_PyErr_Occurred() (__pyx_tstate->current_exception != NULL) -#define __Pyx_PyErr_CurrentExceptionType() (__pyx_tstate->current_exception ? (PyObject*) Py_TYPE(__pyx_tstate->current_exception) : (PyObject*) NULL) -#else -#define __Pyx_PyErr_Occurred() (__pyx_tstate->curexc_type != NULL) -#define __Pyx_PyErr_CurrentExceptionType() (__pyx_tstate->curexc_type) -#endif -#else -#define __Pyx_PyThreadState_declare -#define __Pyx_PyThreadState_assign -#define __Pyx_PyErr_Occurred() (PyErr_Occurred() != NULL) -#define __Pyx_PyErr_CurrentExceptionType() PyErr_Occurred() -#endif - -/* PyErrFetchRestore.proto */ -#if CYTHON_FAST_THREAD_STATE -#define __Pyx_PyErr_Clear() __Pyx_ErrRestore(NULL, NULL, NULL) -#define __Pyx_ErrRestoreWithState(type, value, tb) __Pyx_ErrRestoreInState(PyThreadState_GET(), type, value, tb) -#define __Pyx_ErrFetchWithState(type, value, tb) __Pyx_ErrFetchInState(PyThreadState_GET(), type, value, tb) -#define __Pyx_ErrRestore(type, value, tb) __Pyx_ErrRestoreInState(__pyx_tstate, type, value, tb) -#define __Pyx_ErrFetch(type, value, tb) __Pyx_ErrFetchInState(__pyx_tstate, type, value, tb) -static CYTHON_INLINE void __Pyx_ErrRestoreInState(PyThreadState *tstate, PyObject *type, PyObject *value, PyObject *tb); -static CYTHON_INLINE void __Pyx_ErrFetchInState(PyThreadState *tstate, PyObject **type, PyObject **value, PyObject **tb); -#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX < 0x030C00A6 -#define __Pyx_PyErr_SetNone(exc) (Py_INCREF(exc), __Pyx_ErrRestore((exc), NULL, NULL)) -#else -#define __Pyx_PyErr_SetNone(exc) PyErr_SetNone(exc) -#endif -#else -#define __Pyx_PyErr_Clear() PyErr_Clear() -#define __Pyx_PyErr_SetNone(exc) PyErr_SetNone(exc) -#define __Pyx_ErrRestoreWithState(type, value, tb) PyErr_Restore(type, value, tb) -#define __Pyx_ErrFetchWithState(type, value, tb) PyErr_Fetch(type, value, tb) -#define __Pyx_ErrRestoreInState(tstate, type, value, tb) PyErr_Restore(type, value, tb) -#define __Pyx_ErrFetchInState(tstate, type, value, tb) PyErr_Fetch(type, value, tb) -#define __Pyx_ErrRestore(type, value, tb) PyErr_Restore(type, value, tb) -#define __Pyx_ErrFetch(type, value, tb) PyErr_Fetch(type, value, tb) -#endif - -/* PyObjectGetAttrStr.proto */ -#if CYTHON_USE_TYPE_SLOTS -static CYTHON_INLINE PyObject* __Pyx_PyObject_GetAttrStr(PyObject* obj, PyObject* attr_name); -#else -#define __Pyx_PyObject_GetAttrStr(o,n) PyObject_GetAttr(o,n) -#endif - -/* PyObjectGetAttrStrNoError.proto */ -static CYTHON_INLINE PyObject* __Pyx_PyObject_GetAttrStrNoError(PyObject* obj, PyObject* attr_name); - -/* GetBuiltinName.proto */ -static PyObject *__Pyx_GetBuiltinName(PyObject *name); - -/* TupleAndListFromArray.proto */ -#if CYTHON_COMPILING_IN_CPYTHON -static CYTHON_INLINE PyObject* __Pyx_PyList_FromArray(PyObject *const *src, Py_ssize_t n); -#endif -#if CYTHON_COMPILING_IN_CPYTHON || CYTHON_METH_FASTCALL -static CYTHON_INLINE PyObject* __Pyx_PyTuple_FromArray(PyObject *const *src, Py_ssize_t n); -#endif - -/* IncludeStringH.proto */ -#include - -/* BytesEquals.proto */ -static CYTHON_INLINE int __Pyx_PyBytes_Equals(PyObject* s1, PyObject* s2, int equals); - -/* UnicodeEquals.proto */ -static CYTHON_INLINE int __Pyx_PyUnicode_Equals(PyObject* s1, PyObject* s2, int equals); - -/* fastcall.proto */ -#if CYTHON_AVOID_BORROWED_REFS - #define __Pyx_ArgRef_VARARGS(args, i) __Pyx_PySequence_ITEM(args, i) -#elif CYTHON_ASSUME_SAFE_MACROS - #define __Pyx_ArgRef_VARARGS(args, i) __Pyx_NewRef(__Pyx_PyTuple_GET_ITEM(args, i)) -#else - #define __Pyx_ArgRef_VARARGS(args, i) __Pyx_XNewRef(PyTuple_GetItem(args, i)) -#endif -#define __Pyx_NumKwargs_VARARGS(kwds) PyDict_Size(kwds) -#define __Pyx_KwValues_VARARGS(args, nargs) NULL -#define __Pyx_GetKwValue_VARARGS(kw, kwvalues, s) __Pyx_PyDict_GetItemStrWithError(kw, s) -#define __Pyx_KwargsAsDict_VARARGS(kw, kwvalues) PyDict_Copy(kw) -#if CYTHON_METH_FASTCALL - #define __Pyx_ArgRef_FASTCALL(args, i) __Pyx_NewRef(args[i]) - #define __Pyx_NumKwargs_FASTCALL(kwds) __Pyx_PyTuple_GET_SIZE(kwds) - #define __Pyx_KwValues_FASTCALL(args, nargs) ((args) + (nargs)) - static CYTHON_INLINE PyObject * __Pyx_GetKwValue_FASTCALL(PyObject *kwnames, PyObject *const *kwvalues, PyObject *s); - #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030d0000 || CYTHON_COMPILING_IN_LIMITED_API - CYTHON_UNUSED static PyObject *__Pyx_KwargsAsDict_FASTCALL(PyObject *kwnames, PyObject *const *kwvalues); - #else - #define __Pyx_KwargsAsDict_FASTCALL(kw, kwvalues) _PyStack_AsDict(kwvalues, kw) - #endif -#else - #define __Pyx_ArgRef_FASTCALL __Pyx_ArgRef_VARARGS - #define __Pyx_NumKwargs_FASTCALL __Pyx_NumKwargs_VARARGS - #define __Pyx_KwValues_FASTCALL __Pyx_KwValues_VARARGS - #define __Pyx_GetKwValue_FASTCALL __Pyx_GetKwValue_VARARGS - #define __Pyx_KwargsAsDict_FASTCALL __Pyx_KwargsAsDict_VARARGS -#endif -#define __Pyx_ArgsSlice_VARARGS(args, start, stop) PyTuple_GetSlice(args, start, stop) -#if CYTHON_METH_FASTCALL || (CYTHON_COMPILING_IN_CPYTHON && CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS) -#define __Pyx_ArgsSlice_FASTCALL(args, start, stop) __Pyx_PyTuple_FromArray(args + start, stop - start) -#else -#define __Pyx_ArgsSlice_FASTCALL(args, start, stop) PyTuple_GetSlice(args, start, stop) -#endif - -/* PyDictVersioning.proto */ -#if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_TYPE_SLOTS -#define __PYX_DICT_VERSION_INIT ((PY_UINT64_T) -1) -#define __PYX_GET_DICT_VERSION(dict) (((PyDictObject*)(dict))->ma_version_tag) -#define __PYX_UPDATE_DICT_CACHE(dict, value, cache_var, version_var)\ - (version_var) = __PYX_GET_DICT_VERSION(dict);\ - (cache_var) = (value); -#define __PYX_PY_DICT_LOOKUP_IF_MODIFIED(VAR, DICT, LOOKUP) {\ - static PY_UINT64_T __pyx_dict_version = 0;\ - static PyObject *__pyx_dict_cached_value = NULL;\ - if (likely(__PYX_GET_DICT_VERSION(DICT) == __pyx_dict_version)) {\ - (VAR) = __pyx_dict_cached_value;\ - } else {\ - (VAR) = __pyx_dict_cached_value = (LOOKUP);\ - __pyx_dict_version = __PYX_GET_DICT_VERSION(DICT);\ - }\ -} -static CYTHON_INLINE PY_UINT64_T __Pyx_get_tp_dict_version(PyObject *obj); -static CYTHON_INLINE PY_UINT64_T __Pyx_get_object_dict_version(PyObject *obj); -static CYTHON_INLINE int __Pyx_object_dict_version_matches(PyObject* obj, PY_UINT64_T tp_dict_version, PY_UINT64_T obj_dict_version); -#else -#define __PYX_GET_DICT_VERSION(dict) (0) -#define __PYX_UPDATE_DICT_CACHE(dict, value, cache_var, version_var) -#define __PYX_PY_DICT_LOOKUP_IF_MODIFIED(VAR, DICT, LOOKUP) (VAR) = (LOOKUP); -#endif - -/* GetModuleGlobalName.proto */ -#if CYTHON_USE_DICT_VERSIONS -#define __Pyx_GetModuleGlobalName(var, name) do {\ - static PY_UINT64_T __pyx_dict_version = 0;\ - static PyObject *__pyx_dict_cached_value = NULL;\ - (var) = (likely(__pyx_dict_version == __PYX_GET_DICT_VERSION(__pyx_mstate_global->__pyx_d))) ?\ - (likely(__pyx_dict_cached_value) ? __Pyx_NewRef(__pyx_dict_cached_value) : __Pyx_GetBuiltinName(name)) :\ - __Pyx__GetModuleGlobalName(name, &__pyx_dict_version, &__pyx_dict_cached_value);\ -} while(0) -#define __Pyx_GetModuleGlobalNameUncached(var, name) do {\ - PY_UINT64_T __pyx_dict_version;\ - PyObject *__pyx_dict_cached_value;\ - (var) = __Pyx__GetModuleGlobalName(name, &__pyx_dict_version, &__pyx_dict_cached_value);\ -} while(0) -static PyObject *__Pyx__GetModuleGlobalName(PyObject *name, PY_UINT64_T *dict_version, PyObject **dict_cached_value); -#else -#define __Pyx_GetModuleGlobalName(var, name) (var) = __Pyx__GetModuleGlobalName(name) -#define __Pyx_GetModuleGlobalNameUncached(var, name) (var) = __Pyx__GetModuleGlobalName(name) -static CYTHON_INLINE PyObject *__Pyx__GetModuleGlobalName(PyObject *name); -#endif - -/* PyFunctionFastCall.proto */ -#if CYTHON_FAST_PYCALL -#if !CYTHON_VECTORCALL -#define __Pyx_PyFunction_FastCall(func, args, nargs)\ - __Pyx_PyFunction_FastCallDict((func), (args), (nargs), NULL) -static PyObject *__Pyx_PyFunction_FastCallDict(PyObject *func, PyObject *const *args, Py_ssize_t nargs, PyObject *kwargs); -#endif -#define __Pyx_BUILD_ASSERT_EXPR(cond)\ - (sizeof(char [1 - 2*!(cond)]) - 1) -#ifndef Py_MEMBER_SIZE -#define Py_MEMBER_SIZE(type, member) sizeof(((type *)0)->member) -#endif -#if !CYTHON_VECTORCALL -#if PY_VERSION_HEX >= 0x03080000 - #include "frameobject.h" - #define __Pxy_PyFrame_Initialize_Offsets() - #define __Pyx_PyFrame_GetLocalsplus(frame) ((frame)->f_localsplus) -#else - static size_t __pyx_pyframe_localsplus_offset = 0; - #include "frameobject.h" - #define __Pxy_PyFrame_Initialize_Offsets()\ - ((void)__Pyx_BUILD_ASSERT_EXPR(sizeof(PyFrameObject) == offsetof(PyFrameObject, f_localsplus) + Py_MEMBER_SIZE(PyFrameObject, f_localsplus)),\ - (void)(__pyx_pyframe_localsplus_offset = ((size_t)PyFrame_Type.tp_basicsize) - Py_MEMBER_SIZE(PyFrameObject, f_localsplus))) - #define __Pyx_PyFrame_GetLocalsplus(frame)\ - (assert(__pyx_pyframe_localsplus_offset), (PyObject **)(((char *)(frame)) + __pyx_pyframe_localsplus_offset)) -#endif -#endif -#endif - -/* PyObjectCall.proto */ -#if CYTHON_COMPILING_IN_CPYTHON -static CYTHON_INLINE PyObject* __Pyx_PyObject_Call(PyObject *func, PyObject *arg, PyObject *kw); -#else -#define __Pyx_PyObject_Call(func, arg, kw) PyObject_Call(func, arg, kw) -#endif - -/* PyObjectCallMethO.proto */ -#if CYTHON_COMPILING_IN_CPYTHON -static CYTHON_INLINE PyObject* __Pyx_PyObject_CallMethO(PyObject *func, PyObject *arg); -#endif - -/* PyObjectFastCall.proto */ -#define __Pyx_PyObject_FastCall(func, args, nargs) __Pyx_PyObject_FastCallDict(func, args, (size_t)(nargs), NULL) -static CYTHON_INLINE PyObject* __Pyx_PyObject_FastCallDict(PyObject *func, PyObject * const*args, size_t nargs, PyObject *kwargs); - -/* PyObjectFormatSimple.proto */ -#if CYTHON_COMPILING_IN_PYPY - #define __Pyx_PyObject_FormatSimple(s, f) (\ - likely(PyUnicode_CheckExact(s)) ? (Py_INCREF(s), s) :\ - PyObject_Format(s, f)) -#elif CYTHON_USE_TYPE_SLOTS - #define __Pyx_PyObject_FormatSimple(s, f) (\ - likely(PyUnicode_CheckExact(s)) ? (Py_INCREF(s), s) :\ - likely(PyLong_CheckExact(s)) ? PyLong_Type.tp_repr(s) :\ - likely(PyFloat_CheckExact(s)) ? PyFloat_Type.tp_repr(s) :\ - PyObject_Format(s, f)) -#else - #define __Pyx_PyObject_FormatSimple(s, f) (\ - likely(PyUnicode_CheckExact(s)) ? (Py_INCREF(s), s) :\ - PyObject_Format(s, f)) -#endif - -/* JoinPyUnicode.proto */ -static PyObject* __Pyx_PyUnicode_Join(PyObject** values, Py_ssize_t value_count, Py_ssize_t result_ulength, - Py_UCS4 max_char); - -/* RaiseException.proto */ -static void __Pyx_Raise(PyObject *type, PyObject *value, PyObject *tb, PyObject *cause); - -/* RaiseDoubleKeywords.proto */ -static void __Pyx_RaiseDoubleKeywordsError(const char* func_name, PyObject* kw_name); - -/* ParseKeywords.proto */ -static CYTHON_INLINE int __Pyx_ParseKeywords( - PyObject *kwds, PyObject *const *kwvalues, PyObject ** const argnames[], - PyObject *kwds2, PyObject *values[], - Py_ssize_t num_pos_args, Py_ssize_t num_kwargs, - const char* function_name, - int ignore_unknown_kwargs -); - -/* CallCFunction.proto */ -#define __Pyx_CallCFunction(cfunc, self, args)\ - ((PyCFunction)(void(*)(void))(cfunc)->func)(self, args) -#define __Pyx_CallCFunctionWithKeywords(cfunc, self, args, kwargs)\ - ((PyCFunctionWithKeywords)(void(*)(void))(cfunc)->func)(self, args, kwargs) -#define __Pyx_CallCFunctionFast(cfunc, self, args, nargs)\ - ((__Pyx_PyCFunctionFast)(void(*)(void))(PyCFunction)(cfunc)->func)(self, args, nargs) -#define __Pyx_CallCFunctionFastWithKeywords(cfunc, self, args, nargs, kwnames)\ - ((__Pyx_PyCFunctionFastWithKeywords)(void(*)(void))(PyCFunction)(cfunc)->func)(self, args, nargs, kwnames) - -/* UnpackUnboundCMethod.proto */ -typedef struct { - PyObject *type; - PyObject **method_name; -#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING && CYTHON_ATOMICS - __pyx_atomic_int_type initialized; -#endif - PyCFunction func; - PyObject *method; - int flag; -} __Pyx_CachedCFunction; -#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING -static CYTHON_INLINE int __Pyx_CachedCFunction_GetAndSetInitializing(__Pyx_CachedCFunction *cfunc) { -#if !CYTHON_ATOMICS - return 1; -#else - __pyx_nonatomic_int_type expected = 0; - if (__pyx_atomic_int_cmp_exchange(&cfunc->initialized, &expected, 1)) { - return 0; - } - return expected; -#endif -} -static CYTHON_INLINE void __Pyx_CachedCFunction_SetFinishedInitializing(__Pyx_CachedCFunction *cfunc) { -#if CYTHON_ATOMICS - __pyx_atomic_store(&cfunc->initialized, 2); -#endif -} -#else -#define __Pyx_CachedCFunction_GetAndSetInitializing(cfunc) 2 -#define __Pyx_CachedCFunction_SetFinishedInitializing(cfunc) -#endif - -/* CallUnboundCMethod2.proto */ -CYTHON_UNUSED -static PyObject* __Pyx__CallUnboundCMethod2(__Pyx_CachedCFunction* cfunc, PyObject* self, PyObject* arg1, PyObject* arg2); -#if CYTHON_COMPILING_IN_CPYTHON -static CYTHON_INLINE PyObject *__Pyx_CallUnboundCMethod2(__Pyx_CachedCFunction *cfunc, PyObject *self, PyObject *arg1, PyObject *arg2); -#else -#define __Pyx_CallUnboundCMethod2(cfunc, self, arg1, arg2) __Pyx__CallUnboundCMethod2(cfunc, self, arg1, arg2) -#endif - -/* RaiseArgTupleInvalid.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); - -/* ArgTypeTest.proto */ -#define __Pyx_ArgTypeTest(obj, type, none_allowed, name, exact)\ - ((likely(__Pyx_IS_TYPE(obj, type) | (none_allowed && (obj == Py_None)))) ? 1 :\ - __Pyx__ArgTypeTest(obj, type, name, exact)) -static int __Pyx__ArgTypeTest(PyObject *obj, PyTypeObject *type, const char *name, int exact); - -/* PyObjectSetAttrStr.proto */ -#if CYTHON_USE_TYPE_SLOTS -#define __Pyx_PyObject_DelAttrStr(o,n) __Pyx_PyObject_SetAttrStr(o, n, NULL) -static CYTHON_INLINE int __Pyx_PyObject_SetAttrStr(PyObject* obj, PyObject* attr_name, PyObject* value); -#else -#define __Pyx_PyObject_DelAttrStr(o,n) PyObject_DelAttr(o,n) -#define __Pyx_PyObject_SetAttrStr(o,n,v) PyObject_SetAttr(o,n,v) -#endif - -/* PyObjectFastCallMethod.proto */ -#if CYTHON_VECTORCALL && PY_VERSION_HEX >= 0x03090000 -#define __Pyx_PyObject_FastCallMethod(name, args, nargsf) PyObject_VectorcallMethod(name, args, nargsf, NULL) -#else -static PyObject *__Pyx_PyObject_FastCallMethod(PyObject *name, PyObject *const *args, size_t nargsf); -#endif - -/* PyLongCompare.proto */ -static CYTHON_INLINE int __Pyx_PyLong_BoolNeObjC(PyObject *op1, PyObject *op2, long intval, long inplace); - -/* AssertionsEnabled.proto */ -#if CYTHON_COMPILING_IN_LIMITED_API || (CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030C0000) - static int __pyx_assertions_enabled_flag; - #define __pyx_assertions_enabled() (__pyx_assertions_enabled_flag) - static int __Pyx_init_assertions_enabled(void) { - PyObject *builtins, *debug, *debug_str; - int flag; - builtins = PyEval_GetBuiltins(); - if (!builtins) goto bad; - debug_str = PyUnicode_FromStringAndSize("__debug__", 9); - if (!debug_str) goto bad; - debug = PyObject_GetItem(builtins, debug_str); - Py_DECREF(debug_str); - if (!debug) goto bad; - flag = PyObject_IsTrue(debug); - Py_DECREF(debug); - if (flag == -1) goto bad; - __pyx_assertions_enabled_flag = flag; - return 0; - bad: - __pyx_assertions_enabled_flag = 1; - return -1; - } -#else - #define __Pyx_init_assertions_enabled() (0) - #define __pyx_assertions_enabled() (!Py_OptimizeFlag) -#endif - -/* PyObjectCallNoArg.proto */ -static CYTHON_INLINE PyObject* __Pyx_PyObject_CallNoArg(PyObject *func); - -/* RaiseUnexpectedTypeError.proto */ -static int __Pyx_RaiseUnexpectedTypeError(const char *expected, PyObject *obj); - -/* PyLongCompare.proto */ -static CYTHON_INLINE int __Pyx_PyLong_BoolEqObjC(PyObject *op1, PyObject *op2, long intval, long inplace); - -/* GetItemInt.proto */ -#define __Pyx_GetItemInt(o, i, type, is_signed, to_py_func, is_list, wraparound, boundscheck)\ - (__Pyx_fits_Py_ssize_t(i, type, is_signed) ?\ - __Pyx_GetItemInt_Fast(o, (Py_ssize_t)i, is_list, wraparound, boundscheck) :\ - (is_list ? (PyErr_SetString(PyExc_IndexError, "list index out of range"), (PyObject*)NULL) :\ - __Pyx_GetItemInt_Generic(o, to_py_func(i)))) -#define __Pyx_GetItemInt_List(o, i, type, is_signed, to_py_func, is_list, wraparound, boundscheck)\ - (__Pyx_fits_Py_ssize_t(i, type, is_signed) ?\ - __Pyx_GetItemInt_List_Fast(o, (Py_ssize_t)i, wraparound, boundscheck) :\ - (PyErr_SetString(PyExc_IndexError, "list index out of range"), (PyObject*)NULL)) -static CYTHON_INLINE PyObject *__Pyx_GetItemInt_List_Fast(PyObject *o, Py_ssize_t i, - int wraparound, int boundscheck); -#define __Pyx_GetItemInt_Tuple(o, i, type, is_signed, to_py_func, is_list, wraparound, boundscheck)\ - (__Pyx_fits_Py_ssize_t(i, type, is_signed) ?\ - __Pyx_GetItemInt_Tuple_Fast(o, (Py_ssize_t)i, wraparound, boundscheck) :\ - (PyErr_SetString(PyExc_IndexError, "tuple index out of range"), (PyObject*)NULL)) -static CYTHON_INLINE PyObject *__Pyx_GetItemInt_Tuple_Fast(PyObject *o, Py_ssize_t i, - int wraparound, int boundscheck); -static PyObject *__Pyx_GetItemInt_Generic(PyObject *o, PyObject* j); -static CYTHON_INLINE PyObject *__Pyx_GetItemInt_Fast(PyObject *o, Py_ssize_t i, - int is_list, int wraparound, int boundscheck); - -/* PyObjectCallOneArg.proto */ -static CYTHON_INLINE PyObject* __Pyx_PyObject_CallOneArg(PyObject *func, PyObject *arg); - -/* ObjectGetItem.proto */ -#if CYTHON_USE_TYPE_SLOTS -static CYTHON_INLINE PyObject *__Pyx_PyObject_GetItem(PyObject *obj, PyObject *key); -#else -#define __Pyx_PyObject_GetItem(obj, key) PyObject_GetItem(obj, key) -#endif - -/* ListAppend.proto */ -#if CYTHON_USE_PYLIST_INTERNALS && CYTHON_ASSUME_SAFE_MACROS -static CYTHON_INLINE int __Pyx_PyList_Append(PyObject* list, PyObject* x) { - PyListObject* L = (PyListObject*) list; - Py_ssize_t len = Py_SIZE(list); - if (likely(L->allocated > len) & likely(len > (L->allocated >> 1))) { - Py_INCREF(x); - #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030d0000 - L->ob_item[len] = x; - #else - PyList_SET_ITEM(list, len, x); - #endif - __Pyx_SET_SIZE(list, len + 1); - return 0; - } - return PyList_Append(list, x); -} -#else -#define __Pyx_PyList_Append(L,x) PyList_Append(L,x) -#endif - -/* PyLongBinop.proto */ -#if !CYTHON_COMPILING_IN_PYPY -static CYTHON_INLINE PyObject* __Pyx_PyLong_AddObjC(PyObject *op1, PyObject *op2, long intval, int inplace, int zerodivision_check); -#else -#define __Pyx_PyLong_AddObjC(op1, op2, intval, inplace, zerodivision_check)\ - (inplace ? PyNumber_InPlaceAdd(op1, op2) : PyNumber_Add(op1, op2)) -#endif - -/* DictGetItem.proto */ -#if !CYTHON_COMPILING_IN_PYPY -static PyObject *__Pyx_PyDict_GetItem(PyObject *d, PyObject* key); -#define __Pyx_PyObject_Dict_GetItem(obj, name)\ - (likely(PyDict_CheckExact(obj)) ?\ - __Pyx_PyDict_GetItem(obj, name) : PyObject_GetItem(obj, name)) -#else -#define __Pyx_PyDict_GetItem(d, key) PyObject_GetItem(d, key) -#define __Pyx_PyObject_Dict_GetItem(obj, name) PyObject_GetItem(obj, name) -#endif - -/* PyLongBinop.proto */ -#if !CYTHON_COMPILING_IN_PYPY -static CYTHON_INLINE PyObject* __Pyx_PyLong_SubtractObjC(PyObject *op1, PyObject *op2, long intval, int inplace, int zerodivision_check); -#else -#define __Pyx_PyLong_SubtractObjC(op1, op2, intval, inplace, zerodivision_check)\ - (inplace ? PyNumber_InPlaceSubtract(op1, op2) : PyNumber_Subtract(op1, op2)) -#endif - -/* PyObjectCall2Args.proto */ -static CYTHON_INLINE PyObject* __Pyx_PyObject_Call2Args(PyObject* function, PyObject* arg1, PyObject* arg2); - -/* PyObjectGetMethod.proto */ -static int __Pyx_PyObject_GetMethod(PyObject *obj, PyObject *name, PyObject **method); - -/* PyObjectCallMethod1.proto */ -static PyObject* __Pyx_PyObject_CallMethod1(PyObject* obj, PyObject* method_name, PyObject* arg); - -/* append.proto */ -static CYTHON_INLINE int __Pyx_PyObject_Append(PyObject* L, PyObject* x); - -/* PyFloatBinop.proto */ -#if !CYTHON_COMPILING_IN_PYPY -static int __Pyx_PyFloat_BoolEqObjC(PyObject *op1, PyObject *op2, double floatval, int inplace, int zerodivision_check); -#else -#define __Pyx_PyFloat_BoolEqObjC(op1, op2, floatval, inplace, zerodivision_check)\ - __Pyx_PyObject_IsTrueAndDecref(PyObject_RichCompare(op1, op2, Py_EQ)) - #endif - -/* PyObjectLookupSpecial.proto */ -#if CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS -#define __Pyx_PyObject_LookupSpecialNoError(obj, attr_name) __Pyx__PyObject_LookupSpecial(obj, attr_name, 0) -#define __Pyx_PyObject_LookupSpecial(obj, attr_name) __Pyx__PyObject_LookupSpecial(obj, attr_name, 1) -static CYTHON_INLINE PyObject* __Pyx__PyObject_LookupSpecial(PyObject* obj, PyObject* attr_name, int with_error); -#else -#define __Pyx_PyObject_LookupSpecialNoError(o,n) __Pyx_PyObject_GetAttrStrNoError(o,n) -#define __Pyx_PyObject_LookupSpecial(o,n) __Pyx_PyObject_GetAttrStr(o,n) -#endif - -/* GetTopmostException.proto */ -#if CYTHON_USE_EXC_INFO_STACK && CYTHON_FAST_THREAD_STATE -static _PyErr_StackItem * __Pyx_PyErr_GetTopmostException(PyThreadState *tstate); -#endif - -/* SaveResetException.proto */ -#if CYTHON_FAST_THREAD_STATE -#define __Pyx_ExceptionSave(type, value, tb) __Pyx__ExceptionSave(__pyx_tstate, type, value, tb) -static CYTHON_INLINE void __Pyx__ExceptionSave(PyThreadState *tstate, PyObject **type, PyObject **value, PyObject **tb); -#define __Pyx_ExceptionReset(type, value, tb) __Pyx__ExceptionReset(__pyx_tstate, type, value, tb) -static CYTHON_INLINE void __Pyx__ExceptionReset(PyThreadState *tstate, PyObject *type, PyObject *value, PyObject *tb); -#else -#define __Pyx_ExceptionSave(type, value, tb) PyErr_GetExcInfo(type, value, tb) -#define __Pyx_ExceptionReset(type, value, tb) PyErr_SetExcInfo(type, value, tb) -#endif - -/* GetException.proto */ -#if CYTHON_FAST_THREAD_STATE -#define __Pyx_GetException(type, value, tb) __Pyx__GetException(__pyx_tstate, type, value, tb) -static int __Pyx__GetException(PyThreadState *tstate, PyObject **type, PyObject **value, PyObject **tb); -#else -static int __Pyx_GetException(PyObject **type, PyObject **value, PyObject **tb); -#endif - -/* Import.proto */ -static PyObject *__Pyx_Import(PyObject *name, PyObject *from_list, int level); - -/* ImportDottedModule.proto */ -static PyObject *__Pyx_ImportDottedModule(PyObject *name, PyObject *parts_tuple); -static PyObject *__Pyx_ImportDottedModule_WalkParts(PyObject *module, PyObject *name, PyObject *parts_tuple); - -/* ListPack.proto */ -static PyObject *__Pyx_PyList_Pack(Py_ssize_t n, ...); - -/* ImportFrom.proto */ -static PyObject* __Pyx_ImportFrom(PyObject* module, PyObject* name); - -/* FixUpExtensionType.proto */ -static CYTHON_INLINE int __Pyx_fix_up_extension_type_from_spec(PyType_Spec *spec, PyTypeObject *type); - -/* FetchSharedCythonModule.proto */ -static PyObject *__Pyx_FetchSharedCythonABIModule(void); - -/* dict_setdefault.proto */ -static CYTHON_INLINE PyObject *__Pyx_PyDict_SetDefault(PyObject *d, PyObject *key, PyObject *default_value, int is_safe_type); - -/* FetchCommonType.proto */ -static PyTypeObject* __Pyx_FetchCommonTypeFromSpec(PyObject *module, PyType_Spec *spec, PyObject *bases); - -/* CallTypeTraverse.proto */ -#if !CYTHON_USE_TYPE_SPECS || (!CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX < 0x03090000) -#define __Pyx_call_type_traverse(o, always_call, visit, arg) 0 -#else -static int __Pyx_call_type_traverse(PyObject *o, int always_call, visitproc visit, void *arg); -#endif - -/* PyMethodNew.proto */ -static PyObject *__Pyx_PyMethod_New(PyObject *func, PyObject *self, PyObject *typ); - -/* PyVectorcallFastCallDict.proto */ -#if CYTHON_METH_FASTCALL && (CYTHON_VECTORCALL || CYTHON_BACKPORT_VECTORCALL) -static CYTHON_INLINE PyObject *__Pyx_PyVectorcall_FastCallDict(PyObject *func, __pyx_vectorcallfunc vc, PyObject *const *args, size_t nargs, PyObject *kw); -#endif - -/* CythonFunctionShared.proto */ -#define __Pyx_CyFunction_USED -#define __Pyx_CYFUNCTION_STATICMETHOD 0x01 -#define __Pyx_CYFUNCTION_CLASSMETHOD 0x02 -#define __Pyx_CYFUNCTION_CCLASS 0x04 -#define __Pyx_CYFUNCTION_COROUTINE 0x08 -#define __Pyx_CyFunction_GetClosure(f)\ - (((__pyx_CyFunctionObject *) (f))->func_closure) -#if PY_VERSION_HEX < 0x030900B1 || CYTHON_COMPILING_IN_LIMITED_API - #define __Pyx_CyFunction_GetClassObj(f)\ - (((__pyx_CyFunctionObject *) (f))->func_classobj) -#else - #define __Pyx_CyFunction_GetClassObj(f)\ - ((PyObject*) ((PyCMethodObject *) (f))->mm_class) -#endif -#define __Pyx_CyFunction_SetClassObj(f, classobj)\ - __Pyx__CyFunction_SetClassObj((__pyx_CyFunctionObject *) (f), (classobj)) -#define __Pyx_CyFunction_Defaults(type, f)\ - ((type *)(((__pyx_CyFunctionObject *) (f))->defaults)) -#define __Pyx_CyFunction_SetDefaultsGetter(f, g)\ - ((__pyx_CyFunctionObject *) (f))->defaults_getter = (g) -typedef struct { -#if CYTHON_COMPILING_IN_LIMITED_API - PyObject_HEAD - PyObject *func; -#elif PY_VERSION_HEX < 0x030900B1 - PyCFunctionObject func; -#else - PyCMethodObject func; -#endif -#if CYTHON_BACKPORT_VECTORCALL ||\ - (CYTHON_COMPILING_IN_LIMITED_API && CYTHON_METH_FASTCALL) - __pyx_vectorcallfunc func_vectorcall; -#endif -#if CYTHON_COMPILING_IN_LIMITED_API - PyObject *func_weakreflist; -#endif - PyObject *func_dict; - PyObject *func_name; - PyObject *func_qualname; - PyObject *func_doc; - PyObject *func_globals; - PyObject *func_code; - PyObject *func_closure; -#if PY_VERSION_HEX < 0x030900B1 || CYTHON_COMPILING_IN_LIMITED_API - PyObject *func_classobj; -#endif - PyObject *defaults; - int flags; - PyObject *defaults_tuple; - PyObject *defaults_kwdict; - PyObject *(*defaults_getter)(PyObject *); - PyObject *func_annotations; - PyObject *func_is_coroutine; -} __pyx_CyFunctionObject; -#undef __Pyx_CyOrPyCFunction_Check -#define __Pyx_CyFunction_Check(obj) __Pyx_TypeCheck(obj, __pyx_mstate_global->__pyx_CyFunctionType) -#define __Pyx_CyOrPyCFunction_Check(obj) __Pyx_TypeCheck2(obj, __pyx_mstate_global->__pyx_CyFunctionType, &PyCFunction_Type) -#define __Pyx_CyFunction_CheckExact(obj) __Pyx_IS_TYPE(obj, __pyx_mstate_global->__pyx_CyFunctionType) -static CYTHON_INLINE int __Pyx__IsSameCyOrCFunction(PyObject *func, void (*cfunc)(void)); -#undef __Pyx_IsSameCFunction -#define __Pyx_IsSameCFunction(func, cfunc) __Pyx__IsSameCyOrCFunction(func, cfunc) -static PyObject *__Pyx_CyFunction_Init(__pyx_CyFunctionObject* op, PyMethodDef *ml, - int flags, PyObject* qualname, - PyObject *closure, - PyObject *module, PyObject *globals, - PyObject* code); -static CYTHON_INLINE void __Pyx__CyFunction_SetClassObj(__pyx_CyFunctionObject* f, PyObject* classobj); -static CYTHON_INLINE PyObject *__Pyx_CyFunction_InitDefaults(PyObject *func, - PyTypeObject *defaults_type); -static CYTHON_INLINE void __Pyx_CyFunction_SetDefaultsTuple(PyObject *m, - PyObject *tuple); -static CYTHON_INLINE void __Pyx_CyFunction_SetDefaultsKwDict(PyObject *m, - PyObject *dict); -static CYTHON_INLINE void __Pyx_CyFunction_SetAnnotationsDict(PyObject *m, - PyObject *dict); -static int __pyx_CyFunction_init(PyObject *module); -#if CYTHON_METH_FASTCALL -static PyObject * __Pyx_CyFunction_Vectorcall_NOARGS(PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames); -static PyObject * __Pyx_CyFunction_Vectorcall_O(PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames); -static PyObject * __Pyx_CyFunction_Vectorcall_FASTCALL_KEYWORDS(PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames); -static PyObject * __Pyx_CyFunction_Vectorcall_FASTCALL_KEYWORDS_METHOD(PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames); -#if CYTHON_BACKPORT_VECTORCALL || CYTHON_COMPILING_IN_LIMITED_API -#define __Pyx_CyFunction_func_vectorcall(f) (((__pyx_CyFunctionObject*)f)->func_vectorcall) -#else -#define __Pyx_CyFunction_func_vectorcall(f) (((PyCFunctionObject*)f)->vectorcall) -#endif -#endif - -/* CythonFunction.proto */ -static PyObject *__Pyx_CyFunction_New(PyMethodDef *ml, - int flags, PyObject* qualname, - PyObject *closure, - PyObject *module, PyObject *globals, - PyObject* code); - -/* SetNameInClass.proto */ -#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX < 0x030d0000 -#define __Pyx_SetNameInClass(ns, name, value)\ - (likely(PyDict_CheckExact(ns)) ? _PyDict_SetItem_KnownHash(ns, name, value, ((PyASCIIObject *) name)->hash) : PyObject_SetItem(ns, name, value)) -#elif CYTHON_COMPILING_IN_CPYTHON -#define __Pyx_SetNameInClass(ns, name, value)\ - (likely(PyDict_CheckExact(ns)) ? PyDict_SetItem(ns, name, value) : PyObject_SetItem(ns, name, value)) -#else -#define __Pyx_SetNameInClass(ns, name, value) PyObject_SetItem(ns, name, value) -#endif - -/* CalculateMetaclass.proto */ -static PyObject *__Pyx_CalculateMetaclass(PyTypeObject *metaclass, PyObject *bases); - -/* Py3ClassCreate.proto */ -static PyObject *__Pyx_Py3MetaclassPrepare(PyObject *metaclass, PyObject *bases, PyObject *name, PyObject *qualname, - PyObject *mkw, PyObject *modname, PyObject *doc); -static PyObject *__Pyx_Py3ClassCreate(PyObject *metaclass, PyObject *name, PyObject *bases, PyObject *dict, - PyObject *mkw, int calculate_metaclass, int allow_py2_metaclass); - -/* CLineInTraceback.proto */ -#if CYTHON_CLINE_IN_TRACEBACK && CYTHON_CLINE_IN_TRACEBACK_RUNTIME -static int __Pyx_CLineForTraceback(PyThreadState *tstate, int c_line); -#else -#define __Pyx_CLineForTraceback(tstate, c_line) (((CYTHON_CLINE_IN_TRACEBACK)) ? c_line : 0) -#endif - -/* CodeObjectCache.proto */ -#if CYTHON_COMPILING_IN_LIMITED_API -typedef PyObject __Pyx_CachedCodeObjectType; -#else -typedef PyCodeObject __Pyx_CachedCodeObjectType; -#endif -typedef struct { - __Pyx_CachedCodeObjectType* code_object; - int code_line; -} __Pyx_CodeObjectCacheEntry; -struct __Pyx_CodeObjectCache { - int count; - int max_count; - __Pyx_CodeObjectCacheEntry* entries; - #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - __pyx_atomic_int_type accessor_count; - #endif -}; -static int __pyx_bisect_code_objects(__Pyx_CodeObjectCacheEntry* entries, int count, int code_line); -static __Pyx_CachedCodeObjectType *__pyx_find_code_object(int code_line); -static void __pyx_insert_code_object(int code_line, __Pyx_CachedCodeObjectType* code_object); - -/* AddTraceback.proto */ -static void __Pyx_AddTraceback(const char *funcname, int c_line, - int py_line, const char *filename); - -/* GCCDiagnostics.proto */ -#if !defined(__INTEL_COMPILER) && defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 6)) -#define __Pyx_HAS_GCC_DIAGNOSTIC -#endif - -/* CIntFromPy.proto */ -static CYTHON_INLINE long __Pyx_PyLong_As_long(PyObject *); - -/* PyObjectVectorCallKwBuilder.proto */ -CYTHON_UNUSED static int __Pyx_VectorcallBuilder_AddArg_Check(PyObject *key, PyObject *value, PyObject *builder, PyObject **args, int n); -#if CYTHON_VECTORCALL -#if PY_VERSION_HEX >= 0x03090000 -#define __Pyx_Object_Vectorcall_CallFromBuilder PyObject_Vectorcall -#else -#define __Pyx_Object_Vectorcall_CallFromBuilder _PyObject_Vectorcall -#endif -#define __Pyx_MakeVectorcallBuilderKwds(n) PyTuple_New(n) -static int __Pyx_VectorcallBuilder_AddArg(PyObject *key, PyObject *value, PyObject *builder, PyObject **args, int n); -static int __Pyx_VectorcallBuilder_AddArgStr(const char *key, PyObject *value, PyObject *builder, PyObject **args, int n); -#else -#define __Pyx_Object_Vectorcall_CallFromBuilder __Pyx_PyObject_FastCallDict -#define __Pyx_MakeVectorcallBuilderKwds(n) __Pyx_PyDict_NewPresized(n) -#define __Pyx_VectorcallBuilder_AddArg(key, value, builder, args, n) PyDict_SetItem(builder, key, value) -#define __Pyx_VectorcallBuilder_AddArgStr(key, value, builder, args, n) PyDict_SetItemString(builder, key, value) -#endif - -/* CIntToPy.proto */ -static CYTHON_INLINE PyObject* __Pyx_PyLong_From_long(long value); - -/* FormatTypeName.proto */ -#if CYTHON_COMPILING_IN_LIMITED_API -typedef PyObject *__Pyx_TypeName; -#define __Pyx_FMT_TYPENAME "%U" -#define __Pyx_DECREF_TypeName(obj) Py_XDECREF(obj) -#if __PYX_LIMITED_VERSION_HEX >= 0x030d0000 -#define __Pyx_PyType_GetFullyQualifiedName PyType_GetFullyQualifiedName -#else -static __Pyx_TypeName __Pyx_PyType_GetFullyQualifiedName(PyTypeObject* tp); -#endif -#else // !LIMITED_API -typedef const char *__Pyx_TypeName; -#define __Pyx_FMT_TYPENAME "%.200s" -#define __Pyx_PyType_GetFullyQualifiedName(tp) ((tp)->tp_name) -#define __Pyx_DECREF_TypeName(obj) -#endif - -/* CIntFromPy.proto */ -static CYTHON_INLINE int __Pyx_PyLong_As_int(PyObject *); - -/* FastTypeChecks.proto */ -#if CYTHON_COMPILING_IN_CPYTHON -#define __Pyx_TypeCheck(obj, type) __Pyx_IsSubtype(Py_TYPE(obj), (PyTypeObject *)type) -#define __Pyx_TypeCheck2(obj, type1, type2) __Pyx_IsAnySubtype2(Py_TYPE(obj), (PyTypeObject *)type1, (PyTypeObject *)type2) -static CYTHON_INLINE int __Pyx_IsSubtype(PyTypeObject *a, PyTypeObject *b); -static CYTHON_INLINE int __Pyx_IsAnySubtype2(PyTypeObject *cls, PyTypeObject *a, PyTypeObject *b); -static CYTHON_INLINE int __Pyx_PyErr_GivenExceptionMatches(PyObject *err, PyObject *type); -static CYTHON_INLINE int __Pyx_PyErr_GivenExceptionMatches2(PyObject *err, PyObject *type1, PyObject *type2); -#else -#define __Pyx_TypeCheck(obj, type) PyObject_TypeCheck(obj, (PyTypeObject *)type) -#define __Pyx_TypeCheck2(obj, type1, type2) (PyObject_TypeCheck(obj, (PyTypeObject *)type1) || PyObject_TypeCheck(obj, (PyTypeObject *)type2)) -#define __Pyx_PyErr_GivenExceptionMatches(err, type) PyErr_GivenExceptionMatches(err, type) -static CYTHON_INLINE int __Pyx_PyErr_GivenExceptionMatches2(PyObject *err, PyObject *type1, PyObject *type2) { - return PyErr_GivenExceptionMatches(err, type1) || PyErr_GivenExceptionMatches(err, type2); -} -#endif -#define __Pyx_PyErr_ExceptionMatches2(err1, err2) __Pyx_PyErr_GivenExceptionMatches2(__Pyx_PyErr_CurrentExceptionType(), err1, err2) -#define __Pyx_PyException_Check(obj) __Pyx_TypeCheck(obj, PyExc_Exception) -#ifdef PyExceptionInstance_Check - #define __Pyx_PyBaseException_Check(obj) PyExceptionInstance_Check(obj) -#else - #define __Pyx_PyBaseException_Check(obj) __Pyx_TypeCheck(obj, PyExc_BaseException) -#endif - -/* GetRuntimeVersion.proto */ -static unsigned long __Pyx_get_runtime_version(void); - -/* CheckBinaryVersion.proto */ -static int __Pyx_check_binary_version(unsigned long ct_version, unsigned long rt_version, int allow_newer); - -/* MultiPhaseInitModuleState.proto */ -#if CYTHON_PEP489_MULTI_PHASE_INIT && CYTHON_USE_MODULE_STATE -static PyObject *__Pyx_State_FindModule(void*); -static int __Pyx_State_AddModule(PyObject* module, void*); -static int __Pyx_State_RemoveModule(void*); -#elif CYTHON_USE_MODULE_STATE -#define __Pyx_State_FindModule PyState_FindModule -#define __Pyx_State_AddModule PyState_AddModule -#define __Pyx_State_RemoveModule PyState_RemoveModule -#endif - -/* #### Code section: module_declarations ### */ -/* CythonABIVersion.proto */ -#if CYTHON_COMPILING_IN_LIMITED_API - #if CYTHON_METH_FASTCALL - #define __PYX_FASTCALL_ABI_SUFFIX "_fastcall" - #else - #define __PYX_FASTCALL_ABI_SUFFIX - #endif - #define __PYX_LIMITED_ABI_SUFFIX "limited" __PYX_FASTCALL_ABI_SUFFIX __PYX_AM_SEND_ABI_SUFFIX -#else - #define __PYX_LIMITED_ABI_SUFFIX -#endif -#if __PYX_HAS_PY_AM_SEND == 1 - #define __PYX_AM_SEND_ABI_SUFFIX -#elif __PYX_HAS_PY_AM_SEND == 2 - #define __PYX_AM_SEND_ABI_SUFFIX "amsendbackport" -#else - #define __PYX_AM_SEND_ABI_SUFFIX "noamsend" -#endif -#ifndef __PYX_MONITORING_ABI_SUFFIX - #define __PYX_MONITORING_ABI_SUFFIX -#endif -#if CYTHON_USE_TP_FINALIZE - #define __PYX_TP_FINALIZE_ABI_SUFFIX -#else - #define __PYX_TP_FINALIZE_ABI_SUFFIX "nofinalize" -#endif -#if CYTHON_USE_FREELISTS || !defined(__Pyx_AsyncGen_USED) - #define __PYX_FREELISTS_ABI_SUFFIX -#else - #define __PYX_FREELISTS_ABI_SUFFIX "nofreelists" -#endif -#define CYTHON_ABI __PYX_ABI_VERSION __PYX_LIMITED_ABI_SUFFIX __PYX_MONITORING_ABI_SUFFIX __PYX_TP_FINALIZE_ABI_SUFFIX __PYX_FREELISTS_ABI_SUFFIX __PYX_AM_SEND_ABI_SUFFIX -#define __PYX_ABI_MODULE_NAME "_cython_" CYTHON_ABI -#define __PYX_TYPE_MODULE_PREFIX __PYX_ABI_MODULE_NAME "." - - -/* Module declarations from "epanet.epanet" */ -/* #### Code section: typeinfo ### */ -/* #### Code section: before_global_var ### */ -#define __Pyx_MODULE_NAME "epanet.epanet" -extern int __pyx_module_is_main_epanet__epanet; -int __pyx_module_is_main_epanet__epanet = 0; - -/* Implementation of "epanet.epanet" */ -/* #### Code section: global_var ### */ -static PyObject *__pyx_builtin_AssertionError; -static PyObject *__pyx_builtin_range; -static PyObject *__pyx_builtin_open; -/* #### Code section: string_decls ### */ -static const char __pyx_k_[] = "]"; -static const char __pyx_k_2[] = "2"; -static const char __pyx_k_d[] = "d"; -static const char __pyx_k_f[] = "f"; -static const char __pyx_k_i[] = "i"; -static const char __pyx_k_j[] = "j"; -static const char __pyx_k_k[] = "k"; -static const char __pyx_k_p[] = "p"; -static const char __pyx_k_q[] = "q"; -static const char __pyx_k_r[] = "r"; -static const char __pyx_k_t[] = "t"; -static const char __pyx_k_v[] = "v"; -static const char __pyx_k_w[] = "w"; -static const char __pyx_k__2[] = " "; -static const char __pyx_k__3[] = "."; -static const char __pyx_k__4[] = ".."; -static const char __pyx_k__5[] = "?"; -static const char __pyx_k_db[] = ".db"; -static const char __pyx_k_ds[] = "ds"; -static const char __pyx_k_os[] = "os"; -static const char __pyx_k_rb[] = "rb"; -static const char __pyx_k_ts[] = "ts"; -static const char __pyx_k_AFD[] = "AFD"; -static const char __pyx_k_Any[] = "Any"; -static const char __pyx_k_CFS[] = "CFS"; -static const char __pyx_k_CMD[] = "CMD"; -static const char __pyx_k_CMH[] = "CMH"; -static const char __pyx_k_GPM[] = "GPM"; -static const char __pyx_k_KPA[] = "KPA"; -static const char __pyx_k_LPM[] = "LPM"; -static const char __pyx_k_LPS[] = "LPS"; -static const char __pyx_k_MGD[] = "MGD"; -static const char __pyx_k_MGL[] = "MGL"; -static const char __pyx_k_MLD[] = "MLD"; -static const char __pyx_k_MTR[] = "MTR"; -static const char __pyx_k_PSI[] = "PSI"; -static const char __pyx_k_UGL[] = "UGL"; -static const char __pyx_k_api[] = "api"; -static const char __pyx_k_del[] = "__del__"; -static const char __pyx_k_dir[] = "dir"; -static const char __pyx_k_doc[] = "__doc__"; -static const char __pyx_k_exe[] = "exe"; -static const char __pyx_k_f_u[] = "f_u"; -static const char __pyx_k_inp[] = ".inp"; -static const char __pyx_k_int[] = "int"; -static const char __pyx_k_lib[] = "_lib"; -static const char __pyx_k_msg[] = "msg"; -static const char __pyx_k_opt[] = ".opt"; -static const char __pyx_k_p_u[] = "p_u"; -static const char __pyx_k_pop[] = "pop"; -static const char __pyx_k_q_u[] = "q_u"; -static const char __pyx_k_rpt[] = ".rpt"; -static const char __pyx_k_str[] = "str"; -static const char __pyx_k_sys[] = "sys"; -static const char __pyx_k_CDLL[] = "CDLL"; -static const char __pyx_k_IMGD[] = "IMGD"; -static const char __pyx_k_NONE[] = "NONE"; -static const char __pyx_k_None[] = "None"; -static const char __pyx_k_OPEN[] = "OPEN"; -static const char __pyx_k_bool[] = "bool"; -static const char __pyx_k_bulk[] = "bulk"; -static const char __pyx_k_code[] = "code"; -static const char __pyx_k_data[] = "data"; -static const char __pyx_k_dump[] = "dump"; -static const char __pyx_k_exit[] = "__exit__"; -static const char __pyx_k_f_us[] = "f_us"; -static const char __pyx_k_flow[] = "flow"; -static const char __pyx_k_func[] = "__func__"; -static const char __pyx_k_head[] = "head"; -static const char __pyx_k_init[] = "__init__"; -static const char __pyx_k_join[] = "join"; -static const char __pyx_k_json[] = ".json"; -static const char __pyx_k_link[] = "link"; -static const char __pyx_k_main[] = "__main__"; -static const char __pyx_k_name[] = "name"; -static const char __pyx_k_node[] = "node"; -static const char __pyx_k_open[] = "open"; -static const char __pyx_k_p_us[] = "p_us"; -static const char __pyx_k_path[] = "path"; -static const char __pyx_k_pump[] = "pump"; -static const char __pyx_k_q_us[] = "q_us"; -static const char __pyx_k_read[] = "read"; -static const char __pyx_k_self[] = "self"; -static const char __pyx_k_size[] = "size"; -static const char __pyx_k_spec[] = "__spec__"; -static const char __pyx_k_tank[] = "tank"; -static const char __pyx_k_temp[] = "temp"; -static const char __pyx_k_test[] = "__test__"; -static const char __pyx_k_wall[] = "wall"; -static const char __pyx_k_HOURS[] = "HOURS"; -static const char __pyx_k_PRCNT[] = "PRCNT"; -static const char __pyx_k_byref[] = "byref"; -static const char __pyx_k_c_int[] = "c_int"; -static const char __pyx_k_check[] = "_check"; -static const char __pyx_k_dumps[] = "dumps"; -static const char __pyx_k_enter[] = "__enter__"; -static const char __pyx_k_error[] = "error"; -static const char __pyx_k_index[] = "index"; -static const char __pyx_k_inp_2[] = "inp"; -static const char __pyx_k_input[] = "input"; -static const char __pyx_k_links[] = "links"; -static const char __pyx_k_nodes[] = "nodes"; -static const char __pyx_k_opt_2[] = "opt"; -static const char __pyx_k_range[] = "range"; -static const char __pyx_k_rpt_2[] = "rpt"; -static const char __pyx_k_sizes[] = "sizes"; -static const char __pyx_k_times[] = "times"; -static const char __pyx_k_units[] = "units"; -static const char __pyx_k_utf_8[] = "utf-8"; -static const char __pyx_k_value[] = "value"; -static const char __pyx_k_valve[] = "valve"; -static const char __pyx_k_CLOSED[] = "CLOSED"; -static const char __pyx_k_Output[] = "Output"; -static const char __pyx_k_append[] = "append"; -static const char __pyx_k_base64[] = "base64"; -static const char __pyx_k_ctypes[] = "ctypes"; -static const char __pyx_k_db_inp[] = "db_inp"; -static const char __pyx_k_decode[] = "decode"; -static const char __pyx_k_demand[] = "demand"; -static const char __pyx_k_encode[] = "encode"; -static const char __pyx_k_epanet[] = "epanet"; -static const char __pyx_k_failed[] = "failed"; -static const char __pyx_k_getcwd[] = "getcwd"; -static const char __pyx_k_handle[] = "_handle"; -static const char __pyx_k_json_2[] = "json"; -static const char __pyx_k_length[] = "length"; -static const char __pyx_k_module[] = "__module__"; -static const char __pyx_k_name_2[] = "__name__"; -static const char __pyx_k_output[] = "output"; -static const char __pyx_k_path_2[] = "_path"; -static const char __pyx_k_report[] = "report"; -static const char __pyx_k_result[] = "result"; -static const char __pyx_k_return[] = "return"; -static const char __pyx_k_source[] = "source"; -static const char __pyx_k_status[] = "status"; -static const char __pyx_k_system[] = "system"; -static const char __pyx_k_typing[] = "typing"; -static const char __pyx_k_usages[] = "usages"; -static const char __pyx_k_values[] = "values"; -static const char __pyx_k_POINTER[] = "POINTER"; -static const char __pyx_k_Windows[] = "Windows"; -static const char __pyx_k_abspath[] = "abspath"; -static const char __pyx_k_c_float[] = "c_float"; -static const char __pyx_k_command[] = "command"; -static const char __pyx_k_inp_out[] = "inp_out"; -static const char __pyx_k_prepare[] = "__prepare__"; -static const char __pyx_k_project[] = "project"; -static const char __pyx_k_quality[] = "quality"; -static const char __pyx_k_run_inp[] = "run_inp"; -static const char __pyx_k_setting[] = "setting"; -static const char __pyx_k_version[] = "version"; -static const char __pyx_k_ENR_free[] = "ENR_free"; -static const char __pyx_k_ENR_init[] = "ENR_init"; -static const char __pyx_k_ENR_open[] = "ENR_open"; -static const char __pyx_k_Platform[] = "Platform "; -static const char __pyx_k_add_note[] = "add_note"; -static const char __pyx_k_c_char_p[] = "c_char_p"; -static const char __pyx_k_c_void_p[] = "c_void_p"; -static const char __pyx_k_category[] = "category"; -static const char __pyx_k_cost_day[] = "cost/day"; -static const char __pyx_k_db_inp_2[] = ".db.inp"; -static const char __pyx_k_dump_inp[] = "dump_inp"; -static const char __pyx_k_friction[] = "friction"; -static const char __pyx_k_headloss[] = "headloss"; -static const char __pyx_k_name_len[] = "name_len"; -static const char __pyx_k_net_size[] = "net_size"; -static const char __pyx_k_platform[] = "platform"; -static const char __pyx_k_pressure[] = "pressure"; -static const char __pyx_k_qualname[] = "__qualname__"; -static const char __pyx_k_reaction[] = "reaction"; -static const char __pyx_k_velocity[] = "velocity"; -static const char __pyx_k_ENR_close[] = "ENR_close"; -static const char __pyx_k_b64encode[] = "b64encode"; -static const char __pyx_k_ha_4q_d_q[] = "\320\000\026\220h\230a\330\004\013\2104\210q\220\006\220d\230%\230q"; -static const char __pyx_k_ha_q_4vQa[] = "\320\000\026\220h\230a\330\004\013\210<\220q\230\001\330\004\013\2104\210v\220Q\220a"; -static const char __pyx_k_link_type[] = "link_type"; -static const char __pyx_k_metaclass[] = "__metaclass__"; -static const char __pyx_k_node_type[] = "node_type"; -static const char __pyx_k_reactions[] = "reactions"; -static const char __pyx_k_attributes[] = "attributes"; -static const char __pyx_k_avg_kwatts[] = "avg.kwatts"; -static const char __pyx_k_max_kwatts[] = "max.kwatts"; -static const char __pyx_k_platform_2[] = "_platform"; -static const char __pyx_k_q_z_A_iq_q[] = "\200\001\330\004\020\220\010\230\007\230q\330\004\007\200z\220\023\220A\330\010\016\210i\220q\230\002\230-\240q"; -static const char __pyx_k_successful[] = "successful"; -static const char __pyx_k_Output_dump[] = "Output.dump"; -static const char __pyx_k_avg_kW_flow[] = "avg.kW/flow"; -static const char __pyx_k_bast64_data[] = "bast64_data"; -static const char __pyx_k_dump_output[] = "_dump_output"; -static const char __pyx_k_dump_report[] = "dump_report"; -static const char __pyx_k_num_periods[] = "num_periods"; -static const char __pyx_k_report_step[] = "report_step"; -static const char __pyx_k_run_project[] = "run_project"; -static const char __pyx_k_utilization[] = "utilization"; -static const char __pyx_k_A_G1D_Zq_fAT[] = "\200A\340\010\014\210G\2201\220D\230\005\230Z\240q\250\006\250f\260A\260T\270\021"; -static const char __pyx_k_ENR_getTimes[] = "ENR_getTimes"; -static const char __pyx_k_ENR_getUnits[] = "ENR_getUnits"; -static const char __pyx_k_Output___del[] = "Output.__del__"; -static const char __pyx_k_Output_times[] = "Output.times"; -static const char __pyx_k_Output_units[] = "Output.units"; -static const char __pyx_k_dict_str_Any[] = "dict[str, Any]"; -static const char __pyx_k_dict_str_int[] = "dict[str, int]"; -static const char __pyx_k_dict_str_str[] = "dict[str, str]"; -static const char __pyx_k_element_name[] = "element_name"; -static const char __pyx_k_energy_usage[] = "energy_usage"; -static const char __pyx_k_have_project[] = "have_project"; -static const char __pyx_k_initializing[] = "_initializing"; -static const char __pyx_k_is_coroutine[] = "_is_coroutine"; -static const char __pyx_k_link_results[] = "link_results"; -static const char __pyx_k_node_results[] = "node_results"; -static const char __pyx_k_report_start[] = "report_start"; -static const char __pyx_k_sim_duration[] = "sim_duration"; -static const char __pyx_k_Output___init[] = "Output.__init__"; -static const char __pyx_k_Output__check[] = "Output._check"; -static const char __pyx_k_class_getitem[] = "__class_getitem__"; -static const char __pyx_k_dump_output_2[] = "dump_output"; -static const char __pyx_k_element_count[] = "element_count"; -static const char __pyx_k_epanet_epanet[] = "epanet.epanet"; -static const char __pyx_k_runepanet_exe[] = "runepanet.exe"; -static const char __pyx_k_AssertionError[] = "AssertionError"; -static const char __pyx_k_ENR_checkError[] = "ENR_checkError"; -static const char __pyx_k_ENR_getNetSize[] = "ENR_getNetSize"; -static const char __pyx_k_ENR_getVersion[] = "ENR_getVersion"; -static const char __pyx_k_Output_version[] = "Output.version"; -static const char __pyx_k_avg_efficiency[] = "avg.efficiency"; -static const char __pyx_k_dict_str_float[] = "dict[str, float]"; -static const char __pyx_k_output_message[] = "] output, message ["; -static const char __pyx_k_F_G1D__AT_6_q_q[] = "\320\004\031\230\021\330\010\014\210F\220&\230\001\330\010\014\210G\2201\220D\230\005\230_\250A\250T\260\032\2706\300\026\300q\310\001\330\010\017\210q\220\001"; -static const char __pyx_k_Output_net_size[] = "Output.net_size"; -static const char __pyx_k_readable_output[] = "readable_output"; -static const char __pyx_k_verify_platform[] = "_verify_platform"; -static const char __pyx_k_ENR_getNetReacts[] = "ENR_getNetReacts"; -static const char __pyx_k_Output_reactions[] = "Output.reactions"; -static const char __pyx_k_epanet_epanet_py[] = "epanet/epanet.py"; -static const char __pyx_k_ENR_getLinkResult[] = "ENR_getLinkResult"; -static const char __pyx_k_ENR_getNodeResult[] = "ENR_getNodeResult"; -static const char __pyx_k_Not_found_project[] = "Not found project ["; -static const char __pyx_k_dict_str_list_str[] = "dict[str, list[str]]"; -static const char __pyx_k_epanet_output_dll[] = "epanet-output.dll"; -static const char __pyx_k_list_dict_str_Any[] = "list[dict[str, Any]]"; -static const char __pyx_k_simulation_result[] = "simulation_result"; -static const char __pyx_k_xq_3e1_Qe2Yha_E_1[] = "\320\000\027\220x\230q\330\004\n\210&\220\001\220\021\330\004\013\2103\210e\2201\330\t\r\210Q\210e\2202\220Y\230h\240a\330\010\014\210E\220\021\220&\230\001\330\004\013\2101"; -static const char __pyx_k_ENR_getElementName[] = "ENR_getElementName"; -static const char __pyx_k_ENR_getEnergyUsage[] = "ENR_getEnergyUsage"; -static const char __pyx_k_XQ_QfIQ_q_Q_fJaq_s[] = "\320\000\035\230X\240Q\330\t\r\210Q\210f\220I\230Q\330\010\017\210q\220\005\220Q\330\010\026\220f\230J\240a\240q\330\010\017\210s\220!\220=\240\001"; -static const char __pyx_k_asyncio_coroutines[] = "asyncio.coroutines"; -static const char __pyx_k_cline_in_traceback[] = "cline_in_traceback"; -static const char __pyx_k_dump_output_binary[] = "dump_output_binary"; -static const char __pyx_k_Output_element_name[] = "Output.element_name"; -static const char __pyx_k_Output_energy_usage[] = "Output.energy_usage"; -static const char __pyx_k_Output_link_results[] = "Output.link_results"; -static const char __pyx_k_Output_node_results[] = "Output.node_results"; -static const char __pyx_k_unsupported_not_yet[] = " unsupported (not yet)"; -static const char __pyx_k_Failed_to_read_project[] = "Failed to read project ["; -static const char __pyx_k_run_project_return_dict[] = "run_project_return_dict"; -static const char __pyx_k_a_q_d_t9A_D_a_D_a_4_A_4_A_Ja_4[] = "\320\004\026\220a\330\010\017\210q\330\010\022\220,\230d\240(\250!\330\010\022\220-\230t\2409\250A\330\010\022\220*\230D\240\006\240a\330\010\022\220*\230D\240\006\240a\330\010\022\320\022#\2404\240}\260A\330\010\022\320\022#\2404\240}\260A\330\010\022\220.\240\004\240J\250a\330\010\022\320\022#\2404\240}\260A\330\010\022\320\022#\2404\240}\260A\330\010\017\210q"; -static const char __pyx_k_a_t9Baq_d_1_M_1A_1Jhl_Q_E_as_r[] = "\320\004\036\230a\330\010\017\210t\2209\230B\230a\230q\330\010\026\220d\230&\240\002\240!\2401\330\010\020\220\004\220M\240\022\2401\240A\330\010\023\2201\220J\230h\240l\260!\330\010\r\210Q\330\010\014\210E\220\025\220a\220s\230%\230r\240\021\330\014\022\220)\2305\240\001\240\022\2402\240T\250\033\260A\330\014\020\220\005\220U\230!\2301\330\020\031\230\026\230x\240q\250\006\250i\260q\330\020\031\230\026\230v\240Q\330\020\024\220G\2301\230D\240\005\320%7\260q\270\004\270J\300c\310\023\310F\320RX\320XY\320Yb\320bh\320hn\320no\320op\330\020\027\220v\230W\240C\240s\250!\2501\330\020\035\230Q\330\020\024\220E\230\025\230a\230v\240Q\330\024\036\230a\230x\240q\250\006\250f\260A\260Q\330\020\021\220\021\220)\2307\240!\2401\330\020\024\220E\230\031\240!\2406\250\026\250q\260\001\330\014\016\210g\220Q\220a\330\010\017\210q"; -static const char __pyx_k_1_xq_iq_vQ_G1D_at_V6_SYY___a_vW[] = "\320\004\033\2301\330\010\021\220\026\220x\230q\240\006\240i\250q\330\010\021\220\026\220v\230Q\330\010\014\210G\2201\220D\230\005\320\035.\250a\250t\260:\270V\3006\310\021\310)\320SY\320Y_\320_`\320`a\330\010\017\210v\220W\230C\230q\330\010\023\2201\220H\230H\240H\250A\330\010\014\210A\330\010\014\210E\220\025\220a\220q\330\014\r\210Q\210h\220a\220v\230V\2401\240A\330\010\014\210E\220\031\230!\2306\240\026\240q\250\001\330\010\017\210q"; -static const char __pyx_k_88I_t7_q_iq_1_E_G1_RuE_E_auKuBa[] = "\320\000\"\240%\320'8\3208I\310\021\330\004\007\200t\2107\220-\230q\240\001\330\010\016\210i\220q\230\002\320\0321\260\021\340\004\n\210\"\210E\220\030\230\021\230\"\230G\2401\340\004\r\210R\210u\220E\230\021\230\"\230E\240\025\240a\240u\250K\260u\270B\270a\330\004\013\2109\220A\220V\2308\2401\340\004\014\210E\220\022\2201\330\004\n\210\"\210E\220\025\220a\220r\230\025\230e\2401\240E\250\033\260A\330\004\n\210\"\210E\220\025\220a\220r\230\025\230e\2401\240E\250\033\260F\270\"\270A\330\004\n\210\"\210E\220\025\220a\220r\230\025\230e\2401\240E\250\031\260&\270\002\270!\330\004\n\210\"\210E\220\025\220a\220r\230\025\230e\2401\240E\250\031\260&\270\002\270!\330\004\016\210b\220\004\220F\230&\240\006\240a\340\004\013\2101\340\004\r\210R\210w\220a\220q\330\004\007\200w\210c\220\021\330\010\014\210A\320\r$\240A\340\010\014\210A\320\r$\240A\330\010\013\2101\330\014\021\220\021\220,\230l\250!\2501\340\014\020\220\001\220\034\320\035/\250q\260\001\340\004\010\210\001\210\034\220[\240\001\240\021\340\004\013\2101"; -static const char __pyx_k_E_G1_E_ar_e1E_A_E_ar_e1E_b_E_ar[] = "\320\000\022\220(\230!\330\004\n\210\"\210E\220\030\230\021\230\"\230G\2401\340\004\n\210\"\210E\220\025\220a\220r\230\025\230e\2401\240E\250\033\260A\330\004\n\210\"\210E\220\025\220a\220r\230\025\230e\2401\240E\250\030\260\025\260b\270\001\330\004\n\210\"\210E\220\025\220a\220r\230\025\230e\2401\240E\250\031\260%\260r\270\021\330\004\n\210\"\210E\220\025\220a\220r\230\025\230e\2401\240E\250\031\260%\260r\270\021\330\004\016\210b\220\004\220F\230&\240\006\240a\340\004\013\2101\340\004\r\210R\210w\220a\220q\330\004\007\200w\210c\220\021\330\010\014\210A\320\r$\240A\340\010\014\210A\320\r$\240A\340\010\014\210A\210\\\320\031+\2501\250A\340\004\010\210\001\210\034\220[\240\001\240\021\340\004\013\2104\210v\220Q\220a"; -static const char __pyx_k_XQ_IQ_HF_q_uARwd_A_KvYa_G1D_Yav[] = "\320\004\035\230X\240Q\330\010\014\210I\220Q\340\010\014\210H\220F\230%\230q\240\002\240%\240u\250A\250R\250w\260d\270*\300A\340\010\014\210K\220v\230Y\240a\330\010\014\210G\2201\220D\230\005\230Y\240a\240v\250V\2601\260D\270\001\340\010\014\210G\2201\220D\230\005\230Y\240a\240t\250:\260V\2709\300A\300T\310\026\310w\320VW"; -static const char __pyx_k_a_IQ_F_E_as_q_6_vV1_q_E_4AT_fTZ[] = "\320\004\036\230a\330\010\020\220\004\220I\230Q\340\010\024\220F\230&\240\001\240\021\330\010\020\220\001\330\010\014\210E\220\025\220a\220s\230%\230q\240\010\250\002\250!\330\014\023\2206\230\031\240!\330\014\027\220v\230V\2401\330\014\020\220\007\220q\230\004\230E\320!4\260A\260T\270\032\300;\310f\320TZ\320Z[\320[_\320_e\320ek\320kl\320ls\320sy\320y\360\000\000@\002A\002\360\000\000A\002B\002\330\014\021\220\027\230\001\230\024\230V\2407\250!\330\014\020\220\005\220Y\230a\230v\240V\2501\250A\340\010\024\220F\230&\240\001\240\021\330\010\020\220\001\330\010\014\210E\220\025\220a\220s\230%\230q\240\010\250\002\250!\330\014\023\2206\230\031\240!\330\014\027\220v\230V\2401\330\014\020\220\007\220q\230\004\230E\320!4\260A\260T\270\032\300;\310f\320TZ\320Z[\320[_\320_e\320ek\320kl\320ls\320sy\320y\360\000\000@\002A\002\360\000\000A\002B\002\330\014\021\220\027\230\001\230\024\230V\2407\250!\330\014\020\220\005\220Y\230a\230v\240V\2501\250A\340\010\021\220\032\2307\240)\2501"; -static const char __pyx_k_a_t9Baq_1O_5_NR_a_M_1A_E_as_r_F[] = "\320\004\036\230a\330\010\017\210t\2209\230B\230a\230q\330\010\021\220\021\330\010\023\2201\220O\320#5\260_\300N\320R`\320`a\330\010\020\220\004\220M\240\022\2401\240A\330\010\014\210E\220\025\220a\220s\230%\230r\240\021\330\014\024\220F\230&\240\001\330\014\025\220V\2308\2401\240F\250)\2601\330\014\025\220V\2306\240\021\330\014\020\220\007\220q\230\004\230E\320!4\260A\260T\270\032\3006\310\026\310q\320PT\320TZ\320Z`\320`a\320ai\320io\320ou\320uv\320v\360\000\000@\002F\002\360\000\000F\002L\002\360\000\000L\002M\002\360\000\000M\002N\002\330\014\023\2206\230\027\240\003\2401\330\014\022\220)\2305\240\001\240\025\240g\250R\250q\330\014\020\220\005\220U\230!\2306\240\021\330\020\027\220x\230q\240\005\240V\2501\250A\330\014\022\220'\230\021\230!\330\014\020\220\005\220Y\230a\230v\240V\2501\250A\330\010\017\210q"; -static const char __pyx_k_a_t9Baq_d_1_M_1A_1HL_Kz_T_a_Q_E[] = "\320\004\036\230a\330\010\017\210t\2209\230B\230a\230q\330\010\026\220d\230&\240\002\240!\2401\330\010\020\220\004\220M\240\022\2401\240A\330\010\023\2201\220H\230L\250\014\260K\270z\310\033\320T`\320`a\330\010\r\210Q\340\010\014\210E\220\025\220a\220s\230%\230r\240\021\330\014\022\220)\2305\240\001\240\022\2402\240T\250\033\260A\330\014\020\220\005\220U\230!\2301\330\020\031\230\026\230x\240q\250\006\250i\260q\330\020\031\230\026\230v\240Q\330\020\024\220G\2301\230D\240\005\320%7\260q\270\004\270J\300c\310\023\310F\320RX\320XY\320Yb\320bh\320hn\320no\320op\330\020\027\220v\230W\240C\240s\250!\2501\330\020\035\230Q\330\020\024\220E\230\025\230a\230v\240Q\330\024\027\220x\230q\240\003\2403\240a\330\030\033\2306\240\021\240#\240S\250\001\330\034&\240a\240x\250q\260\006\260a\340\034&\240a\240x\250q\260\006\260a\330\030\031\330\024\036\230a\230x\240q\250\006\250f\260A\260Q\330\020\021\220\021\220)\2307\240!\2401\330\020\024\220E\230\031\240!\2406\250\026\250q\260\001\330\014\016\210g\220Q\220a\330\010\017\210q"; -static const char __pyx_k_e_Q_t7_q_iq_1_E_G1_RuE_E_auKuBa[] = "\320\000\026\220e\320\033,\320,=\270Q\330\004\007\200t\2107\220-\230q\240\001\330\010\016\210i\220q\230\002\320\0321\260\021\340\004\n\210\"\210E\220\030\230\021\230\"\230G\2401\340\004\r\210R\210u\220E\230\021\230\"\230E\240\025\240a\240u\250K\260u\270B\270a\330\004\013\2109\220A\220V\2308\2401\340\004\014\210E\220\022\2201\330\004\n\210\"\210E\220\025\220a\220r\230\025\230e\2401\240E\250\033\260A\330\004\n\210\"\210E\220\025\220a\220r\230\025\230e\2401\240E\250\033\260F\270\"\270A\330\004\n\210\"\210E\220\025\220a\220r\230\025\230e\2401\240E\250\031\260&\270\002\270!\330\004\n\210\"\210E\220\025\220a\220r\230\025\230e\2401\240E\250\031\260&\270\002\270!\330\004\016\210b\220\004\220F\230&\240\006\240a\340\004\013\2101\340\004\r\210R\210w\220a\220q\330\004\007\200w\210c\220\021\330\010\014\210A\320\r$\240A\340\010\014\210A\320\r$\240A\330\010\013\2101\330\014\024\220L\240\001\240\021\340\014\020\220\001\220\034\320\035/\250q\260\001\340\004\010\210\001\210\034\220[\240\001\240\021\340\004\013\2104\210v\220Q\220a"; -static const char __pyx_k_havWA_vQ_G1D__AT_6_qHXX_ddeef_v[] = "\320\004\032\230!\330\010\030\230\006\230h\240a\240v\250W\260A\330\010\021\220\026\220v\230Q\330\010\014\210G\2201\220D\230\005\230_\250A\250T\260\032\2706\300\026\300q\320HX\320X^\320^d\320de\320ef\330\010\017\210v\220W\230C\230q\330\010\023\2201\220H\230H\240H\250H\260A\330\010\020\220\001\330\010\014\210E\220\025\220a\220v\230Q\330\014\021\220\021\220(\230!\2306\240\035\250a\250q\330\010\014\210E\220\031\230!\2306\240\026\240q\250\001\330\010\017\210q"; -static const char __pyx_k_q_Q_E_as_fAQ_q_E_at_V6_fTZZ_gQa[] = "\320\004\027\220q\330\010\r\210Q\330\010\014\210E\220\025\220a\220s\230!\330\014\020\220\006\220f\230A\230Q\330\014\020\220\007\220q\230\004\230E\240\035\250a\250t\260:\270V\3006\310\021\310$\310f\320TZ\320Z[\320[\\\330\014\016\210g\220Q\220a\220q\330\010\014\210A\330\010\023\2201\320\024$\240O\3203C\3001\330\010\014\210E\220\025\220a\220q\330\014\r\210Q\210h\220a\220v\230R\230q\240\001\330\010\017\210q"; -static const char __pyx_k_q_q_wgXWG7_PQ_q_wa_q_wiq_3d_at6[] = "\320\004\027\220q\330\010\017\210q\220\007\220w\230g\240X\250W\260G\2707\300'\310\027\320PQ\330\010\017\210q\220\007\220w\230a\330\010\017\210q\220\010\230\007\230w\240i\250q\330\010\013\2103\210d\220&\230\006\230a\230t\2406\250\026\250q\260\004\260F\270&\300\001\300\021\330\010\r\210U\220&\230\006\230f\240D\250\006\250f\260D\270\006\270f\300A\330\010\014\210G\2201\220D\230\005\230]\250!\2504\250z\270\023\270F\300&\310\001\310\021\330\010\014\210G\2201\220D\230\005\230]\250!\2504\250z\270\023\270F\300&\310\001\310\021\330\010\014\210G\2201\220D\230\005\230]\250!\2504\250z\270\023\270F\300&\310\001\310\021\330\010\021\220\030\230\024\230Q\230c\240\031\250,\260d\270!\2703\270i\300{\320RV\320VW\320WZ\320Z["; -static const char __pyx_k_A_7_Rt7_Q_4uO1D_aq_5_1_B_2_6QQTT[] = "\200A\330\010\013\2107\220#\220R\220t\2307\240#\240Q\330\014\022\220&\230\t\240\021\330\014\023\2204\220u\230O\2501\250D\260\n\270&\300\006\300a\300q\330\014\023\2205\230\003\2301\340\014\024\220B\320\0262\260$\3206Q\320QT\320TZ\320Za\320ab\340\014\020\220\005\220Y\230a\230v\240V\2501\250A\340\014\022\220)\2301\230A"; -static const char __pyx_k_Note_that_Cython_is_deliberately[] = "Note that Cython is deliberately stricter than PEP-484 and rejects subclasses of builtin types. If you need to pass subclasses then set the 'annotation_typing' directive to False."; -/* #### Code section: decls ### */ -static PyObject *__pyx_pf_6epanet_6epanet__verify_platform(CYTHON_UNUSED PyObject *__pyx_self); /* proto */ -static PyObject *__pyx_pf_6epanet_6epanet_6Output___init__(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self, PyObject *__pyx_v_path); /* proto */ -static PyObject *__pyx_pf_6epanet_6epanet_6Output_2__del__(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self); /* proto */ -static PyObject *__pyx_pf_6epanet_6epanet_6Output_4_check(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self, PyObject *__pyx_v_result); /* proto */ -static PyObject *__pyx_pf_6epanet_6epanet_6Output_6version(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self); /* proto */ -static PyObject *__pyx_pf_6epanet_6epanet_6Output_8net_size(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self); /* proto */ -static PyObject *__pyx_pf_6epanet_6epanet_6Output_10units(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self); /* proto */ -static PyObject *__pyx_pf_6epanet_6epanet_6Output_12times(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self); /* proto */ -static PyObject *__pyx_pf_6epanet_6epanet_6Output_14element_name(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self); /* proto */ -static PyObject *__pyx_pf_6epanet_6epanet_6Output_16energy_usage(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self); /* proto */ -static PyObject *__pyx_pf_6epanet_6epanet_6Output_18reactions(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self); /* proto */ -static PyObject *__pyx_pf_6epanet_6epanet_6Output_20node_results(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self); /* proto */ -static PyObject *__pyx_pf_6epanet_6epanet_6Output_22link_results(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self); /* proto */ -static PyObject *__pyx_pf_6epanet_6epanet_6Output_24dump(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self); /* proto */ -static PyObject *__pyx_pf_6epanet_6epanet_2_dump_output(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_path); /* proto */ -static PyObject *__pyx_pf_6epanet_6epanet_4dump_output(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_path); /* proto */ -static PyObject *__pyx_pf_6epanet_6epanet_6dump_report(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_path); /* proto */ -static PyObject *__pyx_pf_6epanet_6epanet_8dump_output_binary(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_path); /* proto */ -static PyObject *__pyx_pf_6epanet_6epanet_10run_project_return_dict(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_name, PyObject *__pyx_v_readable_output); /* proto */ -static PyObject *__pyx_pf_6epanet_6epanet_12run_project(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_name, PyObject *__pyx_v_readable_output); /* proto */ -static PyObject *__pyx_pf_6epanet_6epanet_14run_inp(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_name); /* proto */ -/* #### Code section: late_includes ### */ -/* #### Code section: module_state ### */ -/* SmallCodeConfig */ -#ifndef CYTHON_SMALL_CODE -#if defined(__clang__) - #define CYTHON_SMALL_CODE -#elif defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 3)) - #define CYTHON_SMALL_CODE __attribute__((cold)) -#else - #define CYTHON_SMALL_CODE -#endif -#endif - -typedef struct { - PyObject *__pyx_d; - PyObject *__pyx_b; - PyObject *__pyx_cython_runtime; - PyObject *__pyx_empty_tuple; - PyObject *__pyx_empty_bytes; - PyObject *__pyx_empty_unicode; - #ifdef __Pyx_CyFunction_USED - PyTypeObject *__pyx_CyFunctionType; - #endif - #ifdef __Pyx_FusedFunction_USED - PyTypeObject *__pyx_FusedFunctionType; - #endif - #ifdef __Pyx_Generator_USED - PyTypeObject *__pyx_GeneratorType; - #endif - #ifdef __Pyx_IterableCoroutine_USED - PyTypeObject *__pyx_IterableCoroutineType; - #endif - #ifdef __Pyx_Coroutine_USED - PyTypeObject *__pyx_CoroutineAwaitType; - #endif - #ifdef __Pyx_Coroutine_USED - PyTypeObject *__pyx_CoroutineType; - #endif - __Pyx_CachedCFunction __pyx_umethod_PyDict_Type_pop; - PyObject *__pyx_tuple[2]; - PyObject *__pyx_codeobj_tab[21]; - PyObject *__pyx_string_tab[249]; - PyObject *__pyx_float_2_0; - PyObject *__pyx_int_0; - PyObject *__pyx_int_1; - PyObject *__pyx_int_2; - PyObject *__pyx_int_3; - PyObject *__pyx_int_4; - PyObject *__pyx_int_5; - PyObject *__pyx_int_6; - PyObject *__pyx_int_10; -/* #### Code section: module_state_contents ### */ -/* CachedMethodType.module_state_decls */ -#if CYTHON_COMPILING_IN_LIMITED_API -PyObject *__Pyx_CachedMethodType; -#endif - -/* CodeObjectCache.module_state_decls */ -struct __Pyx_CodeObjectCache __pyx_code_cache; - -/* #### Code section: module_state_end ### */ -} __pyx_mstatetype; - -#if CYTHON_USE_MODULE_STATE -#ifdef __cplusplus -namespace { -extern struct PyModuleDef __pyx_moduledef; -} /* anonymous namespace */ -#else -static struct PyModuleDef __pyx_moduledef; -#endif - -#define __pyx_mstate_global (__Pyx_PyModule_GetState(__Pyx_State_FindModule(&__pyx_moduledef))) - -#define __pyx_m (__Pyx_State_FindModule(&__pyx_moduledef)) -#else -static __pyx_mstatetype __pyx_mstate_global_static = -#ifdef __cplusplus - {}; -#else - {0}; -#endif -static __pyx_mstatetype * const __pyx_mstate_global = &__pyx_mstate_global_static; -#endif -/* #### Code section: constant_name_defines ### */ -#define __pyx_kp_u_ __pyx_string_tab[0] -#define __pyx_kp_u_2 __pyx_string_tab[1] -#define __pyx_n_u_AFD __pyx_string_tab[2] -#define __pyx_n_u_Any __pyx_string_tab[3] -#define __pyx_n_u_AssertionError __pyx_string_tab[4] -#define __pyx_n_u_CDLL __pyx_string_tab[5] -#define __pyx_n_u_CFS __pyx_string_tab[6] -#define __pyx_n_u_CLOSED __pyx_string_tab[7] -#define __pyx_n_u_CMD __pyx_string_tab[8] -#define __pyx_n_u_CMH __pyx_string_tab[9] -#define __pyx_n_u_ENR_checkError __pyx_string_tab[10] -#define __pyx_n_u_ENR_close __pyx_string_tab[11] -#define __pyx_n_u_ENR_free __pyx_string_tab[12] -#define __pyx_n_u_ENR_getElementName __pyx_string_tab[13] -#define __pyx_n_u_ENR_getEnergyUsage __pyx_string_tab[14] -#define __pyx_n_u_ENR_getLinkResult __pyx_string_tab[15] -#define __pyx_n_u_ENR_getNetReacts __pyx_string_tab[16] -#define __pyx_n_u_ENR_getNetSize __pyx_string_tab[17] -#define __pyx_n_u_ENR_getNodeResult __pyx_string_tab[18] -#define __pyx_n_u_ENR_getTimes __pyx_string_tab[19] -#define __pyx_n_u_ENR_getUnits __pyx_string_tab[20] -#define __pyx_n_u_ENR_getVersion __pyx_string_tab[21] -#define __pyx_n_u_ENR_init __pyx_string_tab[22] -#define __pyx_n_u_ENR_open __pyx_string_tab[23] -#define __pyx_kp_u_Failed_to_read_project __pyx_string_tab[24] -#define __pyx_n_u_GPM __pyx_string_tab[25] -#define __pyx_n_u_HOURS __pyx_string_tab[26] -#define __pyx_n_u_IMGD __pyx_string_tab[27] -#define __pyx_n_u_KPA __pyx_string_tab[28] -#define __pyx_n_u_LPM __pyx_string_tab[29] -#define __pyx_n_u_LPS __pyx_string_tab[30] -#define __pyx_n_u_MGD __pyx_string_tab[31] -#define __pyx_n_u_MGL __pyx_string_tab[32] -#define __pyx_n_u_MLD __pyx_string_tab[33] -#define __pyx_n_u_MTR __pyx_string_tab[34] -#define __pyx_n_u_NONE __pyx_string_tab[35] -#define __pyx_n_u_None __pyx_string_tab[36] -#define __pyx_kp_u_Not_found_project __pyx_string_tab[37] -#define __pyx_kp_u_Note_that_Cython_is_deliberately __pyx_string_tab[38] -#define __pyx_n_u_OPEN __pyx_string_tab[39] -#define __pyx_n_u_Output __pyx_string_tab[40] -#define __pyx_n_u_Output___del __pyx_string_tab[41] -#define __pyx_n_u_Output___init __pyx_string_tab[42] -#define __pyx_n_u_Output__check __pyx_string_tab[43] -#define __pyx_n_u_Output_dump __pyx_string_tab[44] -#define __pyx_n_u_Output_element_name __pyx_string_tab[45] -#define __pyx_n_u_Output_energy_usage __pyx_string_tab[46] -#define __pyx_n_u_Output_link_results __pyx_string_tab[47] -#define __pyx_n_u_Output_net_size __pyx_string_tab[48] -#define __pyx_n_u_Output_node_results __pyx_string_tab[49] -#define __pyx_n_u_Output_reactions __pyx_string_tab[50] -#define __pyx_n_u_Output_times __pyx_string_tab[51] -#define __pyx_n_u_Output_units __pyx_string_tab[52] -#define __pyx_n_u_Output_version __pyx_string_tab[53] -#define __pyx_n_u_POINTER __pyx_string_tab[54] -#define __pyx_n_u_PRCNT __pyx_string_tab[55] -#define __pyx_n_u_PSI __pyx_string_tab[56] -#define __pyx_kp_u_Platform __pyx_string_tab[57] -#define __pyx_n_u_UGL __pyx_string_tab[58] -#define __pyx_n_u_Windows __pyx_string_tab[59] -#define __pyx_kp_u__2 __pyx_string_tab[60] -#define __pyx_kp_u__3 __pyx_string_tab[61] -#define __pyx_kp_u__4 __pyx_string_tab[62] -#define __pyx_kp_u__5 __pyx_string_tab[63] -#define __pyx_n_u_abspath __pyx_string_tab[64] -#define __pyx_kp_u_add_note __pyx_string_tab[65] -#define __pyx_n_u_api __pyx_string_tab[66] -#define __pyx_n_u_append __pyx_string_tab[67] -#define __pyx_n_u_asyncio_coroutines __pyx_string_tab[68] -#define __pyx_n_u_attributes __pyx_string_tab[69] -#define __pyx_kp_u_avg_efficiency __pyx_string_tab[70] -#define __pyx_kp_u_avg_kW_flow __pyx_string_tab[71] -#define __pyx_kp_u_avg_kwatts __pyx_string_tab[72] -#define __pyx_n_u_b64encode __pyx_string_tab[73] -#define __pyx_n_u_base64 __pyx_string_tab[74] -#define __pyx_n_u_bast64_data __pyx_string_tab[75] -#define __pyx_n_u_bool __pyx_string_tab[76] -#define __pyx_n_u_bulk __pyx_string_tab[77] -#define __pyx_n_u_byref __pyx_string_tab[78] -#define __pyx_n_u_c_char_p __pyx_string_tab[79] -#define __pyx_n_u_c_float __pyx_string_tab[80] -#define __pyx_n_u_c_int __pyx_string_tab[81] -#define __pyx_n_u_c_void_p __pyx_string_tab[82] -#define __pyx_n_u_category __pyx_string_tab[83] -#define __pyx_n_u_check __pyx_string_tab[84] -#define __pyx_n_u_class_getitem __pyx_string_tab[85] -#define __pyx_n_u_cline_in_traceback __pyx_string_tab[86] -#define __pyx_n_u_code __pyx_string_tab[87] -#define __pyx_n_u_command __pyx_string_tab[88] -#define __pyx_kp_u_cost_day __pyx_string_tab[89] -#define __pyx_n_u_ctypes __pyx_string_tab[90] -#define __pyx_n_u_d __pyx_string_tab[91] -#define __pyx_n_u_data __pyx_string_tab[92] -#define __pyx_kp_u_db __pyx_string_tab[93] -#define __pyx_n_u_db_inp __pyx_string_tab[94] -#define __pyx_kp_u_db_inp_2 __pyx_string_tab[95] -#define __pyx_n_u_decode __pyx_string_tab[96] -#define __pyx_n_u_del __pyx_string_tab[97] -#define __pyx_n_u_demand __pyx_string_tab[98] -#define __pyx_kp_u_dict_str_Any __pyx_string_tab[99] -#define __pyx_kp_u_dict_str_float __pyx_string_tab[100] -#define __pyx_kp_u_dict_str_int __pyx_string_tab[101] -#define __pyx_kp_u_dict_str_list_str __pyx_string_tab[102] -#define __pyx_kp_u_dict_str_str __pyx_string_tab[103] -#define __pyx_n_u_dir __pyx_string_tab[104] -#define __pyx_n_u_doc __pyx_string_tab[105] -#define __pyx_n_u_ds __pyx_string_tab[106] -#define __pyx_n_u_dump __pyx_string_tab[107] -#define __pyx_n_u_dump_inp __pyx_string_tab[108] -#define __pyx_n_u_dump_output __pyx_string_tab[109] -#define __pyx_n_u_dump_output_2 __pyx_string_tab[110] -#define __pyx_n_u_dump_output_binary __pyx_string_tab[111] -#define __pyx_n_u_dump_report __pyx_string_tab[112] -#define __pyx_n_u_dumps __pyx_string_tab[113] -#define __pyx_n_u_element_count __pyx_string_tab[114] -#define __pyx_n_u_element_name __pyx_string_tab[115] -#define __pyx_n_u_encode __pyx_string_tab[116] -#define __pyx_n_u_energy_usage __pyx_string_tab[117] -#define __pyx_n_u_enter __pyx_string_tab[118] -#define __pyx_n_u_epanet __pyx_string_tab[119] -#define __pyx_n_u_epanet_epanet __pyx_string_tab[120] -#define __pyx_kp_u_epanet_epanet_py __pyx_string_tab[121] -#define __pyx_kp_u_epanet_output_dll __pyx_string_tab[122] -#define __pyx_n_u_error __pyx_string_tab[123] -#define __pyx_n_u_exe __pyx_string_tab[124] -#define __pyx_n_u_exit __pyx_string_tab[125] -#define __pyx_n_u_f __pyx_string_tab[126] -#define __pyx_n_u_f_u __pyx_string_tab[127] -#define __pyx_n_u_f_us __pyx_string_tab[128] -#define __pyx_n_u_failed __pyx_string_tab[129] -#define __pyx_n_u_flow __pyx_string_tab[130] -#define __pyx_n_u_friction __pyx_string_tab[131] -#define __pyx_n_u_func __pyx_string_tab[132] -#define __pyx_n_u_getcwd __pyx_string_tab[133] -#define __pyx_n_u_handle __pyx_string_tab[134] -#define __pyx_n_u_have_project __pyx_string_tab[135] -#define __pyx_n_u_head __pyx_string_tab[136] -#define __pyx_n_u_headloss __pyx_string_tab[137] -#define __pyx_n_u_i __pyx_string_tab[138] -#define __pyx_n_u_index __pyx_string_tab[139] -#define __pyx_n_u_init __pyx_string_tab[140] -#define __pyx_n_u_initializing __pyx_string_tab[141] -#define __pyx_kp_u_inp __pyx_string_tab[142] -#define __pyx_n_u_inp_2 __pyx_string_tab[143] -#define __pyx_n_u_inp_out __pyx_string_tab[144] -#define __pyx_n_u_input __pyx_string_tab[145] -#define __pyx_n_u_int __pyx_string_tab[146] -#define __pyx_n_u_is_coroutine __pyx_string_tab[147] -#define __pyx_n_u_j __pyx_string_tab[148] -#define __pyx_n_u_join __pyx_string_tab[149] -#define __pyx_kp_u_json __pyx_string_tab[150] -#define __pyx_n_u_json_2 __pyx_string_tab[151] -#define __pyx_n_u_k __pyx_string_tab[152] -#define __pyx_n_u_length __pyx_string_tab[153] -#define __pyx_n_u_lib __pyx_string_tab[154] -#define __pyx_n_u_link __pyx_string_tab[155] -#define __pyx_n_u_link_results __pyx_string_tab[156] -#define __pyx_n_u_link_type __pyx_string_tab[157] -#define __pyx_n_u_links __pyx_string_tab[158] -#define __pyx_kp_u_list_dict_str_Any __pyx_string_tab[159] -#define __pyx_n_u_main __pyx_string_tab[160] -#define __pyx_kp_u_max_kwatts __pyx_string_tab[161] -#define __pyx_n_u_metaclass __pyx_string_tab[162] -#define __pyx_n_u_module __pyx_string_tab[163] -#define __pyx_n_u_msg __pyx_string_tab[164] -#define __pyx_n_u_name __pyx_string_tab[165] -#define __pyx_n_u_name_2 __pyx_string_tab[166] -#define __pyx_n_u_name_len __pyx_string_tab[167] -#define __pyx_n_u_net_size __pyx_string_tab[168] -#define __pyx_n_u_node __pyx_string_tab[169] -#define __pyx_n_u_node_results __pyx_string_tab[170] -#define __pyx_n_u_node_type __pyx_string_tab[171] -#define __pyx_n_u_nodes __pyx_string_tab[172] -#define __pyx_n_u_num_periods __pyx_string_tab[173] -#define __pyx_n_u_open __pyx_string_tab[174] -#define __pyx_kp_u_opt __pyx_string_tab[175] -#define __pyx_n_u_opt_2 __pyx_string_tab[176] -#define __pyx_n_u_os __pyx_string_tab[177] -#define __pyx_n_u_output __pyx_string_tab[178] -#define __pyx_kp_u_output_message __pyx_string_tab[179] -#define __pyx_n_u_p __pyx_string_tab[180] -#define __pyx_n_u_p_u __pyx_string_tab[181] -#define __pyx_n_u_p_us __pyx_string_tab[182] -#define __pyx_n_u_path __pyx_string_tab[183] -#define __pyx_n_u_path_2 __pyx_string_tab[184] -#define __pyx_n_u_platform __pyx_string_tab[185] -#define __pyx_n_u_platform_2 __pyx_string_tab[186] -#define __pyx_n_u_pop __pyx_string_tab[187] -#define __pyx_n_u_prepare __pyx_string_tab[188] -#define __pyx_n_u_pressure __pyx_string_tab[189] -#define __pyx_n_u_project __pyx_string_tab[190] -#define __pyx_n_u_pump __pyx_string_tab[191] -#define __pyx_n_u_q __pyx_string_tab[192] -#define __pyx_n_u_q_u __pyx_string_tab[193] -#define __pyx_n_u_q_us __pyx_string_tab[194] -#define __pyx_n_u_quality __pyx_string_tab[195] -#define __pyx_n_u_qualname __pyx_string_tab[196] -#define __pyx_n_u_r __pyx_string_tab[197] -#define __pyx_n_u_range __pyx_string_tab[198] -#define __pyx_n_u_rb __pyx_string_tab[199] -#define __pyx_n_u_reaction __pyx_string_tab[200] -#define __pyx_n_u_reactions __pyx_string_tab[201] -#define __pyx_n_u_read __pyx_string_tab[202] -#define __pyx_n_u_readable_output __pyx_string_tab[203] -#define __pyx_n_u_report __pyx_string_tab[204] -#define __pyx_n_u_report_start __pyx_string_tab[205] -#define __pyx_n_u_report_step __pyx_string_tab[206] -#define __pyx_n_u_result __pyx_string_tab[207] -#define __pyx_n_u_return __pyx_string_tab[208] -#define __pyx_kp_u_rpt __pyx_string_tab[209] -#define __pyx_n_u_rpt_2 __pyx_string_tab[210] -#define __pyx_n_u_run_inp __pyx_string_tab[211] -#define __pyx_n_u_run_project __pyx_string_tab[212] -#define __pyx_n_u_run_project_return_dict __pyx_string_tab[213] -#define __pyx_kp_u_runepanet_exe __pyx_string_tab[214] -#define __pyx_n_u_self __pyx_string_tab[215] -#define __pyx_n_u_setting __pyx_string_tab[216] -#define __pyx_n_u_sim_duration __pyx_string_tab[217] -#define __pyx_n_u_simulation_result __pyx_string_tab[218] -#define __pyx_n_u_size __pyx_string_tab[219] -#define __pyx_n_u_sizes __pyx_string_tab[220] -#define __pyx_n_u_source __pyx_string_tab[221] -#define __pyx_n_u_spec __pyx_string_tab[222] -#define __pyx_n_u_status __pyx_string_tab[223] -#define __pyx_n_u_str __pyx_string_tab[224] -#define __pyx_n_u_successful __pyx_string_tab[225] -#define __pyx_n_u_sys __pyx_string_tab[226] -#define __pyx_n_u_system __pyx_string_tab[227] -#define __pyx_n_u_t __pyx_string_tab[228] -#define __pyx_n_u_tank __pyx_string_tab[229] -#define __pyx_n_u_temp __pyx_string_tab[230] -#define __pyx_n_u_test __pyx_string_tab[231] -#define __pyx_n_u_times __pyx_string_tab[232] -#define __pyx_n_u_ts __pyx_string_tab[233] -#define __pyx_n_u_typing __pyx_string_tab[234] -#define __pyx_n_u_units __pyx_string_tab[235] -#define __pyx_kp_u_unsupported_not_yet __pyx_string_tab[236] -#define __pyx_n_u_usages __pyx_string_tab[237] -#define __pyx_kp_u_utf_8 __pyx_string_tab[238] -#define __pyx_n_u_utilization __pyx_string_tab[239] -#define __pyx_n_u_v __pyx_string_tab[240] -#define __pyx_n_u_value __pyx_string_tab[241] -#define __pyx_n_u_values __pyx_string_tab[242] -#define __pyx_n_u_valve __pyx_string_tab[243] -#define __pyx_n_u_velocity __pyx_string_tab[244] -#define __pyx_n_u_verify_platform __pyx_string_tab[245] -#define __pyx_n_u_version __pyx_string_tab[246] -#define __pyx_n_u_w __pyx_string_tab[247] -#define __pyx_n_u_wall __pyx_string_tab[248] -/* #### Code section: module_state_clear ### */ -#if CYTHON_USE_MODULE_STATE -static CYTHON_SMALL_CODE int __pyx_m_clear(PyObject *m) { - __pyx_mstatetype *clear_module_state = __Pyx_PyModule_GetState(m); - if (!clear_module_state) return 0; - Py_CLEAR(clear_module_state->__pyx_d); - Py_CLEAR(clear_module_state->__pyx_b); - Py_CLEAR(clear_module_state->__pyx_cython_runtime); - Py_CLEAR(clear_module_state->__pyx_empty_tuple); - Py_CLEAR(clear_module_state->__pyx_empty_bytes); - Py_CLEAR(clear_module_state->__pyx_empty_unicode); - #ifdef __Pyx_CyFunction_USED - Py_CLEAR(clear_module_state->__pyx_CyFunctionType); - #endif - #ifdef __Pyx_FusedFunction_USED - Py_CLEAR(clear_module_state->__pyx_FusedFunctionType); - #endif - #if CYTHON_PEP489_MULTI_PHASE_INIT - __Pyx_State_RemoveModule(NULL); - #endif - for (int i=0; i<2; ++i) { Py_CLEAR(clear_module_state->__pyx_tuple[i]); } - for (int i=0; i<21; ++i) { Py_CLEAR(clear_module_state->__pyx_codeobj_tab[i]); } - for (int i=0; i<249; ++i) { Py_CLEAR(clear_module_state->__pyx_string_tab[i]); } - Py_CLEAR(clear_module_state->__pyx_float_2_0); - Py_CLEAR(clear_module_state->__pyx_int_0); - Py_CLEAR(clear_module_state->__pyx_int_1); - Py_CLEAR(clear_module_state->__pyx_int_2); - Py_CLEAR(clear_module_state->__pyx_int_3); - Py_CLEAR(clear_module_state->__pyx_int_4); - Py_CLEAR(clear_module_state->__pyx_int_5); - Py_CLEAR(clear_module_state->__pyx_int_6); - Py_CLEAR(clear_module_state->__pyx_int_10); - return 0; -} -#endif -/* #### Code section: module_state_traverse ### */ -#if CYTHON_USE_MODULE_STATE -static CYTHON_SMALL_CODE int __pyx_m_traverse(PyObject *m, visitproc visit, void *arg) { - __pyx_mstatetype *traverse_module_state = __Pyx_PyModule_GetState(m); - if (!traverse_module_state) return 0; - Py_VISIT(traverse_module_state->__pyx_d); - Py_VISIT(traverse_module_state->__pyx_b); - Py_VISIT(traverse_module_state->__pyx_cython_runtime); - __Pyx_VISIT_CONST(traverse_module_state->__pyx_empty_tuple); - __Pyx_VISIT_CONST(traverse_module_state->__pyx_empty_bytes); - __Pyx_VISIT_CONST(traverse_module_state->__pyx_empty_unicode); - #ifdef __Pyx_CyFunction_USED - Py_VISIT(traverse_module_state->__pyx_CyFunctionType); - #endif - #ifdef __Pyx_FusedFunction_USED - Py_VISIT(traverse_module_state->__pyx_FusedFunctionType); - #endif - for (int i=0; i<2; ++i) { __Pyx_VISIT_CONST(traverse_module_state->__pyx_tuple[i]); } - for (int i=0; i<21; ++i) { __Pyx_VISIT_CONST(traverse_module_state->__pyx_codeobj_tab[i]); } - for (int i=0; i<249; ++i) { __Pyx_VISIT_CONST(traverse_module_state->__pyx_string_tab[i]); } - __Pyx_VISIT_CONST(traverse_module_state->__pyx_float_2_0); - __Pyx_VISIT_CONST(traverse_module_state->__pyx_int_0); - __Pyx_VISIT_CONST(traverse_module_state->__pyx_int_1); - __Pyx_VISIT_CONST(traverse_module_state->__pyx_int_2); - __Pyx_VISIT_CONST(traverse_module_state->__pyx_int_3); - __Pyx_VISIT_CONST(traverse_module_state->__pyx_int_4); - __Pyx_VISIT_CONST(traverse_module_state->__pyx_int_5); - __Pyx_VISIT_CONST(traverse_module_state->__pyx_int_6); - __Pyx_VISIT_CONST(traverse_module_state->__pyx_int_10); - return 0; -} -#endif -/* #### Code section: module_code ### */ - -/* "epanet/epanet.py":13 - * - * - * def _verify_platform(): # <<<<<<<<<<<<<< - * _platform = platform.system() - * if _platform != "Windows": -*/ - -/* Python wrapper */ -static PyObject *__pyx_pw_6epanet_6epanet_1_verify_platform(PyObject *__pyx_self, CYTHON_UNUSED PyObject *unused); /*proto*/ -static PyMethodDef __pyx_mdef_6epanet_6epanet_1_verify_platform = {"_verify_platform", (PyCFunction)__pyx_pw_6epanet_6epanet_1_verify_platform, METH_NOARGS, 0}; -static PyObject *__pyx_pw_6epanet_6epanet_1_verify_platform(PyObject *__pyx_self, CYTHON_UNUSED PyObject *unused) { - CYTHON_UNUSED PyObject *const *__pyx_kwvalues; - PyObject *__pyx_r = 0; - __Pyx_RefNannyDeclarations - __Pyx_RefNannySetupContext("_verify_platform (wrapper)", 0); - __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); - __pyx_r = __pyx_pf_6epanet_6epanet__verify_platform(__pyx_self); - - /* function exit code */ - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -static PyObject *__pyx_pf_6epanet_6epanet__verify_platform(CYTHON_UNUSED PyObject *__pyx_self) { - PyObject *__pyx_v__platform = NULL; - PyObject *__pyx_r = NULL; - __Pyx_RefNannyDeclarations - PyObject *__pyx_t_1 = NULL; - PyObject *__pyx_t_2 = NULL; - PyObject *__pyx_t_3 = NULL; - PyObject *__pyx_t_4 = NULL; - size_t __pyx_t_5; - int __pyx_t_6; - PyObject *__pyx_t_7[3]; - PyObject *__pyx_t_8 = NULL; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - __Pyx_RefNannySetupContext("_verify_platform", 0); - - /* "epanet/epanet.py":14 - * - * def _verify_platform(): - * _platform = platform.system() # <<<<<<<<<<<<<< - * if _platform != "Windows": - * raise Exception(f'Platform {_platform} unsupported (not yet)') -*/ - __pyx_t_2 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_platform); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 14, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_system); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 14, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __pyx_t_5 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_4))) { - __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_4); - assert(__pyx_t_2); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); - __Pyx_INCREF(__pyx_t_2); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); - __pyx_t_5 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_2, NULL}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (1-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 14, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_v__platform = __pyx_t_1; - __pyx_t_1 = 0; - - /* "epanet/epanet.py":15 - * def _verify_platform(): - * _platform = platform.system() - * if _platform != "Windows": # <<<<<<<<<<<<<< - * raise Exception(f'Platform {_platform} unsupported (not yet)') - * -*/ - __pyx_t_6 = (__Pyx_PyUnicode_Equals(__pyx_v__platform, __pyx_mstate_global->__pyx_n_u_Windows, Py_NE)); if (unlikely((__pyx_t_6 < 0))) __PYX_ERR(0, 15, __pyx_L1_error) - if (unlikely(__pyx_t_6)) { - - /* "epanet/epanet.py":16 - * _platform = platform.system() - * if _platform != "Windows": - * raise Exception(f'Platform {_platform} unsupported (not yet)') # <<<<<<<<<<<<<< - * - * -*/ - __pyx_t_4 = NULL; - __Pyx_INCREF((PyObject *)(((PyTypeObject*)PyExc_Exception))); - __pyx_t_2 = ((PyObject *)(((PyTypeObject*)PyExc_Exception))); - __pyx_t_3 = __Pyx_PyObject_FormatSimple(__pyx_v__platform, __pyx_mstate_global->__pyx_empty_unicode); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 16, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __pyx_t_7[0] = __pyx_mstate_global->__pyx_kp_u_Platform; - __pyx_t_7[1] = __pyx_t_3; - __pyx_t_7[2] = __pyx_mstate_global->__pyx_kp_u_unsupported_not_yet; - __pyx_t_8 = __Pyx_PyUnicode_Join(__pyx_t_7, 3, 9 + __Pyx_PyUnicode_GET_LENGTH(__pyx_t_3) + 22, 127 | __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_3)); - if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 16, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_8); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __pyx_t_5 = 1; - { - PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_t_8}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_2, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 16, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __Pyx_Raise(__pyx_t_1, 0, 0, 0); - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __PYX_ERR(0, 16, __pyx_L1_error) - - /* "epanet/epanet.py":15 - * def _verify_platform(): - * _platform = platform.system() - * if _platform != "Windows": # <<<<<<<<<<<<<< - * raise Exception(f'Platform {_platform} unsupported (not yet)') - * -*/ - } - - /* "epanet/epanet.py":13 - * - * - * def _verify_platform(): # <<<<<<<<<<<<<< - * _platform = platform.system() - * if _platform != "Windows": -*/ - - /* function exit code */ - __pyx_r = Py_None; __Pyx_INCREF(Py_None); - goto __pyx_L0; - __pyx_L1_error:; - __Pyx_XDECREF(__pyx_t_1); - __Pyx_XDECREF(__pyx_t_2); - __Pyx_XDECREF(__pyx_t_3); - __Pyx_XDECREF(__pyx_t_4); - __Pyx_XDECREF(__pyx_t_8); - __Pyx_AddTraceback("epanet.epanet._verify_platform", __pyx_clineno, __pyx_lineno, __pyx_filename); - __pyx_r = NULL; - __pyx_L0:; - __Pyx_XDECREF(__pyx_v__platform); - __Pyx_XGIVEREF(__pyx_r); - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -/* "epanet/epanet.py":24 - * - * class Output: - * def __init__(self, path: str) -> None: # <<<<<<<<<<<<<< - * self._path = path - * -*/ - -/* Python wrapper */ -static PyObject *__pyx_pw_6epanet_6epanet_6Output_1__init__(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -); /*proto*/ -static PyMethodDef __pyx_mdef_6epanet_6epanet_6Output_1__init__ = {"__init__", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6epanet_6epanet_6Output_1__init__, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}; -static PyObject *__pyx_pw_6epanet_6epanet_6Output_1__init__(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -) { - PyObject *__pyx_v_self = 0; - PyObject *__pyx_v_path = 0; - #if !CYTHON_METH_FASTCALL - CYTHON_UNUSED Py_ssize_t __pyx_nargs; - #endif - CYTHON_UNUSED PyObject *const *__pyx_kwvalues; - PyObject* values[2] = {0,0}; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - PyObject *__pyx_r = 0; - __Pyx_RefNannyDeclarations - __Pyx_RefNannySetupContext("__init__ (wrapper)", 0); - #if !CYTHON_METH_FASTCALL - #if CYTHON_ASSUME_SAFE_SIZE - __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); - #else - __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; - #endif - #endif - __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); - { - PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_self,&__pyx_mstate_global->__pyx_n_u_path,0}; - const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; - if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 24, __pyx_L3_error) - if (__pyx_kwds_len > 0) { - switch (__pyx_nargs) { - case 2: - values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 24, __pyx_L3_error) - CYTHON_FALLTHROUGH; - case 1: - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 24, __pyx_L3_error) - CYTHON_FALLTHROUGH; - case 0: break; - default: goto __pyx_L5_argtuple_error; - } - const Py_ssize_t kwd_pos_args = __pyx_nargs; - if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "__init__", 0) < 0) __PYX_ERR(0, 24, __pyx_L3_error) - for (Py_ssize_t i = __pyx_nargs; i < 2; i++) { - if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("__init__", 1, 2, 2, i); __PYX_ERR(0, 24, __pyx_L3_error) } - } - } else if (unlikely(__pyx_nargs != 2)) { - goto __pyx_L5_argtuple_error; - } else { - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 24, __pyx_L3_error) - values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 24, __pyx_L3_error) - } - __pyx_v_self = values[0]; - __pyx_v_path = ((PyObject*)values[1]); - } - goto __pyx_L6_skip; - __pyx_L5_argtuple_error:; - __Pyx_RaiseArgtupleInvalid("__init__", 1, 2, 2, __pyx_nargs); __PYX_ERR(0, 24, __pyx_L3_error) - __pyx_L6_skip:; - goto __pyx_L4_argument_unpacking_done; - __pyx_L3_error:; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_AddTraceback("epanet.epanet.Output.__init__", __pyx_clineno, __pyx_lineno, __pyx_filename); - __Pyx_RefNannyFinishContext(); - return NULL; - __pyx_L4_argument_unpacking_done:; - if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_path), (&PyUnicode_Type), 0, "path", 2))) __PYX_ERR(0, 24, __pyx_L1_error) - __pyx_r = __pyx_pf_6epanet_6epanet_6Output___init__(__pyx_self, __pyx_v_self, __pyx_v_path); - - /* function exit code */ - goto __pyx_L0; - __pyx_L1_error:; - __pyx_r = NULL; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - goto __pyx_L7_cleaned_up; - __pyx_L0:; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __pyx_L7_cleaned_up:; - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -static PyObject *__pyx_pf_6epanet_6epanet_6Output___init__(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self, PyObject *__pyx_v_path) { - PyObject *__pyx_r = NULL; - __Pyx_RefNannyDeclarations - PyObject *__pyx_t_1 = NULL; - PyObject *__pyx_t_2 = NULL; - PyObject *__pyx_t_3 = NULL; - PyObject *__pyx_t_4 = NULL; - PyObject *__pyx_t_5 = NULL; - PyObject *__pyx_t_6 = NULL; - PyObject *__pyx_t_7 = NULL; - PyObject *__pyx_t_8 = NULL; - PyObject *__pyx_t_9 = NULL; - PyObject *__pyx_t_10 = NULL; - size_t __pyx_t_11; - PyObject *__pyx_t_12 = NULL; - PyObject *__pyx_t_13 = NULL; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - __Pyx_RefNannySetupContext("__init__", 0); - - /* "epanet/epanet.py":25 - * class Output: - * def __init__(self, path: str) -> None: - * self._path = path # <<<<<<<<<<<<<< - * - * self._lib = ctypes.CDLL(os.path.join(os.getcwd(), 'epanet', 'epanet-output.dll')) -*/ - if (__Pyx_PyObject_SetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_path_2, __pyx_v_path) < 0) __PYX_ERR(0, 25, __pyx_L1_error) - - /* "epanet/epanet.py":27 - * self._path = path - * - * self._lib = ctypes.CDLL(os.path.join(os.getcwd(), 'epanet', 'epanet-output.dll')) # <<<<<<<<<<<<<< - * - * self._handle = ctypes.c_void_p() -*/ - __pyx_t_2 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 27, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_CDLL); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 27, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 27, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 27, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_7); - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - __pyx_t_5 = __pyx_t_7; - __Pyx_INCREF(__pyx_t_5); - __pyx_t_8 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 27, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_getcwd); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 27, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - __pyx_t_11 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_10))) { - __pyx_t_8 = PyMethod_GET_SELF(__pyx_t_10); - assert(__pyx_t_8); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_10); - __Pyx_INCREF(__pyx_t_8); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_10, __pyx__function); - __pyx_t_11 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_8, NULL}; - __pyx_t_6 = __Pyx_PyObject_FastCall(__pyx_t_10, __pyx_callargs+__pyx_t_11, (1-__pyx_t_11) | (__pyx_t_11*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0; - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 27, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - } - __pyx_t_11 = 0; - { - PyObject *__pyx_callargs[4] = {__pyx_t_5, __pyx_t_6, __pyx_mstate_global->__pyx_n_u_epanet, __pyx_mstate_global->__pyx_kp_u_epanet_output_dll}; - __pyx_t_3 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_join, __pyx_callargs+__pyx_t_11, (4-__pyx_t_11) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; - if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 27, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - } - __pyx_t_11 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_4))) { - __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_4); - assert(__pyx_t_2); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); - __Pyx_INCREF(__pyx_t_2); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); - __pyx_t_11 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_t_3}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_11, (2-__pyx_t_11) | (__pyx_t_11*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 27, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - if (__Pyx_PyObject_SetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_lib, __pyx_t_1) < 0) __PYX_ERR(0, 27, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - - /* "epanet/epanet.py":29 - * self._lib = ctypes.CDLL(os.path.join(os.getcwd(), 'epanet', 'epanet-output.dll')) - * - * self._handle = ctypes.c_void_p() # <<<<<<<<<<<<<< - * self._check(self._lib.ENR_init(ctypes.byref(self._handle))) - * -*/ - __pyx_t_4 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 29, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_c_void_p); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 29, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __pyx_t_11 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_2))) { - __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_2); - assert(__pyx_t_4); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_2); - __Pyx_INCREF(__pyx_t_4); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_2, __pyx__function); - __pyx_t_11 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_4, NULL}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_2, __pyx_callargs+__pyx_t_11, (1-__pyx_t_11) | (__pyx_t_11*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 29, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - if (__Pyx_PyObject_SetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_handle, __pyx_t_1) < 0) __PYX_ERR(0, 29, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - - /* "epanet/epanet.py":30 - * - * self._handle = ctypes.c_void_p() - * self._check(self._lib.ENR_init(ctypes.byref(self._handle))) # <<<<<<<<<<<<<< - * - * self._check(self._lib.ENR_open(self._handle, ctypes.c_char_p(self._path.encode()))) -*/ - __pyx_t_2 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_2); - __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_lib); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 30, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_7); - __pyx_t_3 = __pyx_t_7; - __Pyx_INCREF(__pyx_t_3); - __pyx_t_5 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 30, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - __pyx_t_8 = __Pyx_PyObject_GetAttrStr(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_byref); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 30, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_8); - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_handle); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 30, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - __pyx_t_11 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_8))) { - __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_8); - assert(__pyx_t_5); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_8); - __Pyx_INCREF(__pyx_t_5); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_8, __pyx__function); - __pyx_t_11 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_5, __pyx_t_10}; - __pyx_t_6 = __Pyx_PyObject_FastCall(__pyx_t_8, __pyx_callargs+__pyx_t_11, (2-__pyx_t_11) | (__pyx_t_11*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; - if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 30, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - } - __pyx_t_11 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_t_6}; - __pyx_t_4 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_ENR_init, __pyx_callargs+__pyx_t_11, (2-__pyx_t_11) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; - if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 30, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - } - __pyx_t_11 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_t_4}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_check, __pyx_callargs+__pyx_t_11, (2-__pyx_t_11) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 30, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - - /* "epanet/epanet.py":32 - * self._check(self._lib.ENR_init(ctypes.byref(self._handle))) - * - * self._check(self._lib.ENR_open(self._handle, ctypes.c_char_p(self._path.encode()))) # <<<<<<<<<<<<<< - * - * -*/ - __pyx_t_4 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_4); - __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_lib); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 32, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __pyx_t_7 = __pyx_t_6; - __Pyx_INCREF(__pyx_t_7); - __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_handle); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 32, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __pyx_t_10 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 32, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __pyx_t_9 = __Pyx_PyObject_GetAttrStr(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_c_char_p); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 32, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - __pyx_t_13 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_path_2); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 32, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_13); - __pyx_t_12 = __pyx_t_13; - __Pyx_INCREF(__pyx_t_12); - __pyx_t_11 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_12, NULL}; - __pyx_t_5 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_encode, __pyx_callargs+__pyx_t_11, (1-__pyx_t_11) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0; - __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0; - if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 32, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - } - __pyx_t_11 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_9))) { - __pyx_t_10 = PyMethod_GET_SELF(__pyx_t_9); - assert(__pyx_t_10); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_9); - __Pyx_INCREF(__pyx_t_10); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_9, __pyx__function); - __pyx_t_11 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_10, __pyx_t_5}; - __pyx_t_8 = __Pyx_PyObject_FastCall(__pyx_t_9, __pyx_callargs+__pyx_t_11, (2-__pyx_t_11) | (__pyx_t_11*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 32, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_8); - } - __pyx_t_11 = 0; - { - PyObject *__pyx_callargs[3] = {__pyx_t_7, __pyx_t_3, __pyx_t_8}; - __pyx_t_2 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_ENR_open, __pyx_callargs+__pyx_t_11, (3-__pyx_t_11) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 32, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - __pyx_t_11 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_t_2}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_check, __pyx_callargs+__pyx_t_11, (2-__pyx_t_11) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 32, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - - /* "epanet/epanet.py":24 - * - * class Output: - * def __init__(self, path: str) -> None: # <<<<<<<<<<<<<< - * self._path = path - * -*/ - - /* function exit code */ - __pyx_r = Py_None; __Pyx_INCREF(Py_None); - goto __pyx_L0; - __pyx_L1_error:; - __Pyx_XDECREF(__pyx_t_1); - __Pyx_XDECREF(__pyx_t_2); - __Pyx_XDECREF(__pyx_t_3); - __Pyx_XDECREF(__pyx_t_4); - __Pyx_XDECREF(__pyx_t_5); - __Pyx_XDECREF(__pyx_t_6); - __Pyx_XDECREF(__pyx_t_7); - __Pyx_XDECREF(__pyx_t_8); - __Pyx_XDECREF(__pyx_t_9); - __Pyx_XDECREF(__pyx_t_10); - __Pyx_XDECREF(__pyx_t_12); - __Pyx_XDECREF(__pyx_t_13); - __Pyx_AddTraceback("epanet.epanet.Output.__init__", __pyx_clineno, __pyx_lineno, __pyx_filename); - __pyx_r = NULL; - __pyx_L0:; - __Pyx_XGIVEREF(__pyx_r); - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -/* "epanet/epanet.py":35 - * - * - * def __del__(self): # <<<<<<<<<<<<<< - * # throw exception in destructor ? :) - * self._check(self._lib.ENR_close(ctypes.byref(self._handle))) -*/ - -/* Python wrapper */ -static PyObject *__pyx_pw_6epanet_6epanet_6Output_3__del__(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -); /*proto*/ -static PyMethodDef __pyx_mdef_6epanet_6epanet_6Output_3__del__ = {"__del__", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6epanet_6epanet_6Output_3__del__, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}; -static PyObject *__pyx_pw_6epanet_6epanet_6Output_3__del__(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -) { - PyObject *__pyx_v_self = 0; - #if !CYTHON_METH_FASTCALL - CYTHON_UNUSED Py_ssize_t __pyx_nargs; - #endif - CYTHON_UNUSED PyObject *const *__pyx_kwvalues; - PyObject* values[1] = {0}; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - PyObject *__pyx_r = 0; - __Pyx_RefNannyDeclarations - __Pyx_RefNannySetupContext("__del__ (wrapper)", 0); - #if !CYTHON_METH_FASTCALL - #if CYTHON_ASSUME_SAFE_SIZE - __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); - #else - __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; - #endif - #endif - __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); - { - PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_self,0}; - const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; - if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 35, __pyx_L3_error) - if (__pyx_kwds_len > 0) { - switch (__pyx_nargs) { - case 1: - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 35, __pyx_L3_error) - CYTHON_FALLTHROUGH; - case 0: break; - default: goto __pyx_L5_argtuple_error; - } - const Py_ssize_t kwd_pos_args = __pyx_nargs; - if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "__del__", 0) < 0) __PYX_ERR(0, 35, __pyx_L3_error) - for (Py_ssize_t i = __pyx_nargs; i < 1; i++) { - if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("__del__", 1, 1, 1, i); __PYX_ERR(0, 35, __pyx_L3_error) } - } - } else if (unlikely(__pyx_nargs != 1)) { - goto __pyx_L5_argtuple_error; - } else { - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 35, __pyx_L3_error) - } - __pyx_v_self = values[0]; - } - goto __pyx_L6_skip; - __pyx_L5_argtuple_error:; - __Pyx_RaiseArgtupleInvalid("__del__", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 35, __pyx_L3_error) - __pyx_L6_skip:; - goto __pyx_L4_argument_unpacking_done; - __pyx_L3_error:; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_AddTraceback("epanet.epanet.Output.__del__", __pyx_clineno, __pyx_lineno, __pyx_filename); - __Pyx_RefNannyFinishContext(); - return NULL; - __pyx_L4_argument_unpacking_done:; - __pyx_r = __pyx_pf_6epanet_6epanet_6Output_2__del__(__pyx_self, __pyx_v_self); - - /* function exit code */ - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -static PyObject *__pyx_pf_6epanet_6epanet_6Output_2__del__(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self) { - PyObject *__pyx_r = NULL; - __Pyx_RefNannyDeclarations - PyObject *__pyx_t_1 = NULL; - PyObject *__pyx_t_2 = NULL; - PyObject *__pyx_t_3 = NULL; - PyObject *__pyx_t_4 = NULL; - PyObject *__pyx_t_5 = NULL; - PyObject *__pyx_t_6 = NULL; - PyObject *__pyx_t_7 = NULL; - PyObject *__pyx_t_8 = NULL; - PyObject *__pyx_t_9 = NULL; - size_t __pyx_t_10; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - __Pyx_RefNannySetupContext("__del__", 0); - - /* "epanet/epanet.py":37 - * def __del__(self): - * # throw exception in destructor ? :) - * self._check(self._lib.ENR_close(ctypes.byref(self._handle))) # <<<<<<<<<<<<<< - * - * -*/ - __pyx_t_2 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_2); - __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_lib); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 37, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __pyx_t_4 = __pyx_t_5; - __Pyx_INCREF(__pyx_t_4); - __pyx_t_7 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 37, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_8); - __pyx_t_9 = __Pyx_PyObject_GetAttrStr(__pyx_t_8, __pyx_mstate_global->__pyx_n_u_byref); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 37, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; - __pyx_t_8 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_handle); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 37, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_8); - __pyx_t_10 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_9))) { - __pyx_t_7 = PyMethod_GET_SELF(__pyx_t_9); - assert(__pyx_t_7); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_9); - __Pyx_INCREF(__pyx_t_7); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_9, __pyx__function); - __pyx_t_10 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_7, __pyx_t_8}; - __pyx_t_6 = __Pyx_PyObject_FastCall(__pyx_t_9, __pyx_callargs+__pyx_t_10, (2-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; - __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 37, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - } - __pyx_t_10 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_t_6}; - __pyx_t_3 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_ENR_close, __pyx_callargs+__pyx_t_10, (2-__pyx_t_10) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 37, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - } - __pyx_t_10 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_t_3}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_check, __pyx_callargs+__pyx_t_10, (2-__pyx_t_10) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 37, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - - /* "epanet/epanet.py":35 - * - * - * def __del__(self): # <<<<<<<<<<<<<< - * # throw exception in destructor ? :) - * self._check(self._lib.ENR_close(ctypes.byref(self._handle))) -*/ - - /* function exit code */ - __pyx_r = Py_None; __Pyx_INCREF(Py_None); - goto __pyx_L0; - __pyx_L1_error:; - __Pyx_XDECREF(__pyx_t_1); - __Pyx_XDECREF(__pyx_t_2); - __Pyx_XDECREF(__pyx_t_3); - __Pyx_XDECREF(__pyx_t_4); - __Pyx_XDECREF(__pyx_t_5); - __Pyx_XDECREF(__pyx_t_6); - __Pyx_XDECREF(__pyx_t_7); - __Pyx_XDECREF(__pyx_t_8); - __Pyx_XDECREF(__pyx_t_9); - __Pyx_AddTraceback("epanet.epanet.Output.__del__", __pyx_clineno, __pyx_lineno, __pyx_filename); - __pyx_r = NULL; - __pyx_L0:; - __Pyx_XGIVEREF(__pyx_r); - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -/* "epanet/epanet.py":40 - * - * - * def _check(self, result): # <<<<<<<<<<<<<< - * if result != 0 and result != 10: - * msg = ctypes.c_char_p() -*/ - -/* Python wrapper */ -static PyObject *__pyx_pw_6epanet_6epanet_6Output_5_check(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -); /*proto*/ -static PyMethodDef __pyx_mdef_6epanet_6epanet_6Output_5_check = {"_check", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6epanet_6epanet_6Output_5_check, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}; -static PyObject *__pyx_pw_6epanet_6epanet_6Output_5_check(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -) { - PyObject *__pyx_v_self = 0; - PyObject *__pyx_v_result = 0; - #if !CYTHON_METH_FASTCALL - CYTHON_UNUSED Py_ssize_t __pyx_nargs; - #endif - CYTHON_UNUSED PyObject *const *__pyx_kwvalues; - PyObject* values[2] = {0,0}; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - PyObject *__pyx_r = 0; - __Pyx_RefNannyDeclarations - __Pyx_RefNannySetupContext("_check (wrapper)", 0); - #if !CYTHON_METH_FASTCALL - #if CYTHON_ASSUME_SAFE_SIZE - __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); - #else - __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; - #endif - #endif - __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); - { - PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_self,&__pyx_mstate_global->__pyx_n_u_result,0}; - const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; - if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 40, __pyx_L3_error) - if (__pyx_kwds_len > 0) { - switch (__pyx_nargs) { - case 2: - values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 40, __pyx_L3_error) - CYTHON_FALLTHROUGH; - case 1: - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 40, __pyx_L3_error) - CYTHON_FALLTHROUGH; - case 0: break; - default: goto __pyx_L5_argtuple_error; - } - const Py_ssize_t kwd_pos_args = __pyx_nargs; - if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "_check", 0) < 0) __PYX_ERR(0, 40, __pyx_L3_error) - for (Py_ssize_t i = __pyx_nargs; i < 2; i++) { - if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("_check", 1, 2, 2, i); __PYX_ERR(0, 40, __pyx_L3_error) } - } - } else if (unlikely(__pyx_nargs != 2)) { - goto __pyx_L5_argtuple_error; - } else { - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 40, __pyx_L3_error) - values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 40, __pyx_L3_error) - } - __pyx_v_self = values[0]; - __pyx_v_result = values[1]; - } - goto __pyx_L6_skip; - __pyx_L5_argtuple_error:; - __Pyx_RaiseArgtupleInvalid("_check", 1, 2, 2, __pyx_nargs); __PYX_ERR(0, 40, __pyx_L3_error) - __pyx_L6_skip:; - goto __pyx_L4_argument_unpacking_done; - __pyx_L3_error:; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_AddTraceback("epanet.epanet.Output._check", __pyx_clineno, __pyx_lineno, __pyx_filename); - __Pyx_RefNannyFinishContext(); - return NULL; - __pyx_L4_argument_unpacking_done:; - __pyx_r = __pyx_pf_6epanet_6epanet_6Output_4_check(__pyx_self, __pyx_v_self, __pyx_v_result); - - /* function exit code */ - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -static PyObject *__pyx_pf_6epanet_6epanet_6Output_4_check(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self, PyObject *__pyx_v_result) { - PyObject *__pyx_v_msg = NULL; - PyObject *__pyx_v_code = NULL; - PyObject *__pyx_v_error = NULL; - PyObject *__pyx_r = NULL; - __Pyx_RefNannyDeclarations - int __pyx_t_1; - int __pyx_t_2; - PyObject *__pyx_t_3 = NULL; - PyObject *__pyx_t_4 = NULL; - PyObject *__pyx_t_5 = NULL; - PyObject *__pyx_t_6 = NULL; - size_t __pyx_t_7; - PyObject *__pyx_t_8 = NULL; - PyObject *__pyx_t_9 = NULL; - PyObject *__pyx_t_10 = NULL; - PyObject *__pyx_t_11 = NULL; - PyObject *__pyx_t_12[5]; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - __Pyx_RefNannySetupContext("_check", 0); - - /* "epanet/epanet.py":41 - * - * def _check(self, result): - * if result != 0 and result != 10: # <<<<<<<<<<<<<< - * msg = ctypes.c_char_p() - * code = self._lib.ENR_checkError(self._handle, ctypes.byref(msg)) -*/ - __pyx_t_2 = (__Pyx_PyLong_BoolNeObjC(__pyx_v_result, __pyx_mstate_global->__pyx_int_0, 0, 0)); if (unlikely((__pyx_t_2 < 0))) __PYX_ERR(0, 41, __pyx_L1_error) - if (__pyx_t_2) { - } else { - __pyx_t_1 = __pyx_t_2; - goto __pyx_L4_bool_binop_done; - } - __pyx_t_2 = (__Pyx_PyLong_BoolNeObjC(__pyx_v_result, __pyx_mstate_global->__pyx_int_10, 10, 0)); if (unlikely((__pyx_t_2 < 0))) __PYX_ERR(0, 41, __pyx_L1_error) - __pyx_t_1 = __pyx_t_2; - __pyx_L4_bool_binop_done:; - if (unlikely(__pyx_t_1)) { - - /* "epanet/epanet.py":42 - * def _check(self, result): - * if result != 0 and result != 10: - * msg = ctypes.c_char_p() # <<<<<<<<<<<<<< - * code = self._lib.ENR_checkError(self._handle, ctypes.byref(msg)) - * assert code == result -*/ - __pyx_t_4 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 42, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_c_char_p); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 42, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - __pyx_t_7 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_6))) { - __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_6); - assert(__pyx_t_4); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_6); - __Pyx_INCREF(__pyx_t_4); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_6, __pyx__function); - __pyx_t_7 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_4, NULL}; - __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_6, __pyx_callargs+__pyx_t_7, (1-__pyx_t_7) | (__pyx_t_7*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 42, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - } - __pyx_v_msg = __pyx_t_3; - __pyx_t_3 = 0; - - /* "epanet/epanet.py":43 - * if result != 0 and result != 10: - * msg = ctypes.c_char_p() - * code = self._lib.ENR_checkError(self._handle, ctypes.byref(msg)) # <<<<<<<<<<<<<< - * assert code == result - * -*/ - __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_lib); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 43, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __pyx_t_6 = __pyx_t_4; - __Pyx_INCREF(__pyx_t_6); - __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_handle); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 43, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __pyx_t_9 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 43, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_byref); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 43, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - __pyx_t_7 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_11))) { - __pyx_t_9 = PyMethod_GET_SELF(__pyx_t_11); - assert(__pyx_t_9); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_11); - __Pyx_INCREF(__pyx_t_9); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_11, __pyx__function); - __pyx_t_7 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_9, __pyx_v_msg}; - __pyx_t_8 = __Pyx_PyObject_FastCall(__pyx_t_11, __pyx_callargs+__pyx_t_7, (2-__pyx_t_7) | (__pyx_t_7*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 43, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_8); - } - __pyx_t_7 = 0; - { - PyObject *__pyx_callargs[3] = {__pyx_t_6, __pyx_t_5, __pyx_t_8}; - __pyx_t_3 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_ENR_checkError, __pyx_callargs+__pyx_t_7, (3-__pyx_t_7) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 43, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - } - __pyx_v_code = __pyx_t_3; - __pyx_t_3 = 0; - - /* "epanet/epanet.py":44 - * msg = ctypes.c_char_p() - * code = self._lib.ENR_checkError(self._handle, ctypes.byref(msg)) - * assert code == result # <<<<<<<<<<<<<< - * - * error = f'Failed to read project [{self._path}] output, message [{msg.value.decode()}]' -*/ - #ifndef CYTHON_WITHOUT_ASSERTIONS - if (unlikely(__pyx_assertions_enabled())) { - __pyx_t_3 = PyObject_RichCompare(__pyx_v_code, __pyx_v_result, Py_EQ); __Pyx_XGOTREF(__pyx_t_3); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 44, __pyx_L1_error) - __pyx_t_1 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 44, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - if (unlikely(!__pyx_t_1)) { - __Pyx_Raise(__pyx_builtin_AssertionError, 0, 0, 0); - __PYX_ERR(0, 44, __pyx_L1_error) - } - } - #else - if ((1)); else __PYX_ERR(0, 44, __pyx_L1_error) - #endif - - /* "epanet/epanet.py":46 - * assert code == result - * - * error = f'Failed to read project [{self._path}] output, message [{msg.value.decode()}]' # <<<<<<<<<<<<<< - * - * self._lib.ENR_free(ctypes.byref(msg)) -*/ - __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_path_2); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 46, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __pyx_t_4 = __Pyx_PyObject_FormatSimple(__pyx_t_3, __pyx_mstate_global->__pyx_empty_unicode); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 46, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_v_msg, __pyx_mstate_global->__pyx_n_u_value); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 46, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __pyx_t_8 = __Pyx_PyObject_GetAttrStr(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_decode); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 46, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_8); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __pyx_t_3 = __Pyx_PyObject_CallNoArg(__pyx_t_8); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 46, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; - __pyx_t_8 = __Pyx_PyObject_FormatSimple(__pyx_t_3, __pyx_mstate_global->__pyx_empty_unicode); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 46, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_8); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __pyx_t_12[0] = __pyx_mstate_global->__pyx_kp_u_Failed_to_read_project; - __pyx_t_12[1] = __pyx_t_4; - __pyx_t_12[2] = __pyx_mstate_global->__pyx_kp_u_output_message; - __pyx_t_12[3] = __pyx_t_8; - __pyx_t_12[4] = __pyx_mstate_global->__pyx_kp_u_; - __pyx_t_3 = __Pyx_PyUnicode_Join(__pyx_t_12, 5, 24 + __Pyx_PyUnicode_GET_LENGTH(__pyx_t_4) + 19 + __Pyx_PyUnicode_GET_LENGTH(__pyx_t_8) + 1, 127 | __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_4) | __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_8)); - if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 46, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; - __pyx_v_error = ((PyObject*)__pyx_t_3); - __pyx_t_3 = 0; - - /* "epanet/epanet.py":48 - * error = f'Failed to read project [{self._path}] output, message [{msg.value.decode()}]' - * - * self._lib.ENR_free(ctypes.byref(msg)) # <<<<<<<<<<<<<< - * - * raise Exception(error) -*/ - __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_lib); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 48, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __pyx_t_8 = __pyx_t_4; - __Pyx_INCREF(__pyx_t_8); - __pyx_t_6 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 48, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __pyx_t_9 = __Pyx_PyObject_GetAttrStr(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_byref); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 48, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - __pyx_t_7 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_9))) { - __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_9); - assert(__pyx_t_6); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_9); - __Pyx_INCREF(__pyx_t_6); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_9, __pyx__function); - __pyx_t_7 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_v_msg}; - __pyx_t_5 = __Pyx_PyObject_FastCall(__pyx_t_9, __pyx_callargs+__pyx_t_7, (2-__pyx_t_7) | (__pyx_t_7*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 48, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - } - __pyx_t_7 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_8, __pyx_t_5}; - __pyx_t_3 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_ENR_free, __pyx_callargs+__pyx_t_7, (2-__pyx_t_7) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 48, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - } - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - - /* "epanet/epanet.py":50 - * self._lib.ENR_free(ctypes.byref(msg)) - * - * raise Exception(error) # <<<<<<<<<<<<<< - * - * -*/ - __pyx_t_4 = NULL; - __Pyx_INCREF((PyObject *)(((PyTypeObject*)PyExc_Exception))); - __pyx_t_5 = ((PyObject *)(((PyTypeObject*)PyExc_Exception))); - __pyx_t_7 = 1; - { - PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_v_error}; - __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_5, __pyx_callargs+__pyx_t_7, (2-__pyx_t_7) | (__pyx_t_7*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 50, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - } - __Pyx_Raise(__pyx_t_3, 0, 0, 0); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __PYX_ERR(0, 50, __pyx_L1_error) - - /* "epanet/epanet.py":41 - * - * def _check(self, result): - * if result != 0 and result != 10: # <<<<<<<<<<<<<< - * msg = ctypes.c_char_p() - * code = self._lib.ENR_checkError(self._handle, ctypes.byref(msg)) -*/ - } - - /* "epanet/epanet.py":40 - * - * - * def _check(self, result): # <<<<<<<<<<<<<< - * if result != 0 and result != 10: - * msg = ctypes.c_char_p() -*/ - - /* function exit code */ - __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_XDECREF(__pyx_t_6); - __Pyx_XDECREF(__pyx_t_8); - __Pyx_XDECREF(__pyx_t_9); - __Pyx_XDECREF(__pyx_t_10); - __Pyx_XDECREF(__pyx_t_11); - __Pyx_AddTraceback("epanet.epanet.Output._check", __pyx_clineno, __pyx_lineno, __pyx_filename); - __pyx_r = NULL; - __pyx_L0:; - __Pyx_XDECREF(__pyx_v_msg); - __Pyx_XDECREF(__pyx_v_code); - __Pyx_XDECREF(__pyx_v_error); - __Pyx_XGIVEREF(__pyx_r); - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -/* "epanet/epanet.py":53 - * - * - * def version(self) -> int: # <<<<<<<<<<<<<< - * v = ctypes.c_int() - * self._check(self._lib.ENR_getVersion(self._handle, ctypes.byref(v))) -*/ - -/* Python wrapper */ -static PyObject *__pyx_pw_6epanet_6epanet_6Output_7version(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -); /*proto*/ -static PyMethodDef __pyx_mdef_6epanet_6epanet_6Output_7version = {"version", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6epanet_6epanet_6Output_7version, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}; -static PyObject *__pyx_pw_6epanet_6epanet_6Output_7version(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -) { - PyObject *__pyx_v_self = 0; - #if !CYTHON_METH_FASTCALL - CYTHON_UNUSED Py_ssize_t __pyx_nargs; - #endif - CYTHON_UNUSED PyObject *const *__pyx_kwvalues; - PyObject* values[1] = {0}; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - PyObject *__pyx_r = 0; - __Pyx_RefNannyDeclarations - __Pyx_RefNannySetupContext("version (wrapper)", 0); - #if !CYTHON_METH_FASTCALL - #if CYTHON_ASSUME_SAFE_SIZE - __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); - #else - __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; - #endif - #endif - __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); - { - PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_self,0}; - const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; - if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 53, __pyx_L3_error) - if (__pyx_kwds_len > 0) { - switch (__pyx_nargs) { - case 1: - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 53, __pyx_L3_error) - CYTHON_FALLTHROUGH; - case 0: break; - default: goto __pyx_L5_argtuple_error; - } - const Py_ssize_t kwd_pos_args = __pyx_nargs; - if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "version", 0) < 0) __PYX_ERR(0, 53, __pyx_L3_error) - for (Py_ssize_t i = __pyx_nargs; i < 1; i++) { - if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("version", 1, 1, 1, i); __PYX_ERR(0, 53, __pyx_L3_error) } - } - } else if (unlikely(__pyx_nargs != 1)) { - goto __pyx_L5_argtuple_error; - } else { - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 53, __pyx_L3_error) - } - __pyx_v_self = values[0]; - } - goto __pyx_L6_skip; - __pyx_L5_argtuple_error:; - __Pyx_RaiseArgtupleInvalid("version", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 53, __pyx_L3_error) - __pyx_L6_skip:; - goto __pyx_L4_argument_unpacking_done; - __pyx_L3_error:; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_AddTraceback("epanet.epanet.Output.version", __pyx_clineno, __pyx_lineno, __pyx_filename); - __Pyx_RefNannyFinishContext(); - return NULL; - __pyx_L4_argument_unpacking_done:; - __pyx_r = __pyx_pf_6epanet_6epanet_6Output_6version(__pyx_self, __pyx_v_self); - - /* function exit code */ - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -static PyObject *__pyx_pf_6epanet_6epanet_6Output_6version(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self) { - PyObject *__pyx_v_v = NULL; - PyObject *__pyx_r = NULL; - __Pyx_RefNannyDeclarations - PyObject *__pyx_t_1 = NULL; - PyObject *__pyx_t_2 = NULL; - PyObject *__pyx_t_3 = NULL; - PyObject *__pyx_t_4 = NULL; - size_t __pyx_t_5; - PyObject *__pyx_t_6 = NULL; - PyObject *__pyx_t_7 = NULL; - PyObject *__pyx_t_8 = NULL; - PyObject *__pyx_t_9 = NULL; - PyObject *__pyx_t_10 = NULL; - PyObject *__pyx_t_11 = NULL; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - __Pyx_RefNannySetupContext("version", 0); - - /* "epanet/epanet.py":54 - * - * def version(self) -> int: - * v = ctypes.c_int() # <<<<<<<<<<<<<< - * self._check(self._lib.ENR_getVersion(self._handle, ctypes.byref(v))) - * return v.value -*/ - __pyx_t_2 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 54, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_c_int); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 54, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __pyx_t_5 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_4))) { - __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_4); - assert(__pyx_t_2); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); - __Pyx_INCREF(__pyx_t_2); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); - __pyx_t_5 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_2, NULL}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (1-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 54, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_v_v = __pyx_t_1; - __pyx_t_1 = 0; - - /* "epanet/epanet.py":55 - * def version(self) -> int: - * v = ctypes.c_int() - * self._check(self._lib.ENR_getVersion(self._handle, ctypes.byref(v))) # <<<<<<<<<<<<<< - * return v.value - * -*/ - __pyx_t_4 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_4); - __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_lib); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 55, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __pyx_t_3 = __pyx_t_6; - __Pyx_INCREF(__pyx_t_3); - __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_handle); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 55, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_7); - __pyx_t_9 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 55, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_byref); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 55, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - __pyx_t_5 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_11))) { - __pyx_t_9 = PyMethod_GET_SELF(__pyx_t_11); - assert(__pyx_t_9); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_11); - __Pyx_INCREF(__pyx_t_9); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_11, __pyx__function); - __pyx_t_5 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_9, __pyx_v_v}; - __pyx_t_8 = __Pyx_PyObject_FastCall(__pyx_t_11, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 55, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_8); - } - __pyx_t_5 = 0; - { - PyObject *__pyx_callargs[3] = {__pyx_t_3, __pyx_t_7, __pyx_t_8}; - __pyx_t_2 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_ENR_getVersion, __pyx_callargs+__pyx_t_5, (3-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; - __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 55, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - __pyx_t_5 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_t_2}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_check, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 55, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - - /* "epanet/epanet.py":56 - * v = ctypes.c_int() - * self._check(self._lib.ENR_getVersion(self._handle, ctypes.byref(v))) - * return v.value # <<<<<<<<<<<<<< - * - * -*/ - __Pyx_XDECREF(__pyx_r); - __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_v, __pyx_mstate_global->__pyx_n_u_value); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 56, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - if (!(likely(PyLong_CheckExact(__pyx_t_1))||((__pyx_t_1) == Py_None) || __Pyx_RaiseUnexpectedTypeError("int", __pyx_t_1))) __PYX_ERR(0, 56, __pyx_L1_error) - __pyx_r = ((PyObject*)__pyx_t_1); - __pyx_t_1 = 0; - goto __pyx_L0; - - /* "epanet/epanet.py":53 - * - * - * def version(self) -> int: # <<<<<<<<<<<<<< - * v = ctypes.c_int() - * self._check(self._lib.ENR_getVersion(self._handle, ctypes.byref(v))) -*/ - - /* function exit code */ - __pyx_L1_error:; - __Pyx_XDECREF(__pyx_t_1); - __Pyx_XDECREF(__pyx_t_2); - __Pyx_XDECREF(__pyx_t_3); - __Pyx_XDECREF(__pyx_t_4); - __Pyx_XDECREF(__pyx_t_6); - __Pyx_XDECREF(__pyx_t_7); - __Pyx_XDECREF(__pyx_t_8); - __Pyx_XDECREF(__pyx_t_9); - __Pyx_XDECREF(__pyx_t_10); - __Pyx_XDECREF(__pyx_t_11); - __Pyx_AddTraceback("epanet.epanet.Output.version", __pyx_clineno, __pyx_lineno, __pyx_filename); - __pyx_r = NULL; - __pyx_L0:; - __Pyx_XDECREF(__pyx_v_v); - __Pyx_XGIVEREF(__pyx_r); - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -/* "epanet/epanet.py":59 - * - * - * def net_size(self) -> dict[str, int]: # <<<<<<<<<<<<<< - * element_count = ctypes.POINTER(ctypes.c_int)() - * length = ctypes.c_int() -*/ - -/* Python wrapper */ -static PyObject *__pyx_pw_6epanet_6epanet_6Output_9net_size(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -); /*proto*/ -static PyMethodDef __pyx_mdef_6epanet_6epanet_6Output_9net_size = {"net_size", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6epanet_6epanet_6Output_9net_size, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}; -static PyObject *__pyx_pw_6epanet_6epanet_6Output_9net_size(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -) { - PyObject *__pyx_v_self = 0; - #if !CYTHON_METH_FASTCALL - CYTHON_UNUSED Py_ssize_t __pyx_nargs; - #endif - CYTHON_UNUSED PyObject *const *__pyx_kwvalues; - PyObject* values[1] = {0}; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - PyObject *__pyx_r = 0; - __Pyx_RefNannyDeclarations - __Pyx_RefNannySetupContext("net_size (wrapper)", 0); - #if !CYTHON_METH_FASTCALL - #if CYTHON_ASSUME_SAFE_SIZE - __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); - #else - __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; - #endif - #endif - __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); - { - PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_self,0}; - const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; - if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 59, __pyx_L3_error) - if (__pyx_kwds_len > 0) { - switch (__pyx_nargs) { - case 1: - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 59, __pyx_L3_error) - CYTHON_FALLTHROUGH; - case 0: break; - default: goto __pyx_L5_argtuple_error; - } - const Py_ssize_t kwd_pos_args = __pyx_nargs; - if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "net_size", 0) < 0) __PYX_ERR(0, 59, __pyx_L3_error) - for (Py_ssize_t i = __pyx_nargs; i < 1; i++) { - if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("net_size", 1, 1, 1, i); __PYX_ERR(0, 59, __pyx_L3_error) } - } - } else if (unlikely(__pyx_nargs != 1)) { - goto __pyx_L5_argtuple_error; - } else { - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 59, __pyx_L3_error) - } - __pyx_v_self = values[0]; - } - goto __pyx_L6_skip; - __pyx_L5_argtuple_error:; - __Pyx_RaiseArgtupleInvalid("net_size", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 59, __pyx_L3_error) - __pyx_L6_skip:; - goto __pyx_L4_argument_unpacking_done; - __pyx_L3_error:; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_AddTraceback("epanet.epanet.Output.net_size", __pyx_clineno, __pyx_lineno, __pyx_filename); - __Pyx_RefNannyFinishContext(); - return NULL; - __pyx_L4_argument_unpacking_done:; - __pyx_r = __pyx_pf_6epanet_6epanet_6Output_8net_size(__pyx_self, __pyx_v_self); - - /* function exit code */ - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -static PyObject *__pyx_pf_6epanet_6epanet_6Output_8net_size(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self) { - PyObject *__pyx_v_element_count = NULL; - PyObject *__pyx_v_length = NULL; - PyObject *__pyx_v_category = NULL; - PyObject *__pyx_v_sizes = NULL; - PyObject *__pyx_v_i = NULL; - PyObject *__pyx_r = NULL; - __Pyx_RefNannyDeclarations - PyObject *__pyx_t_1 = NULL; - PyObject *__pyx_t_2 = NULL; - PyObject *__pyx_t_3 = NULL; - PyObject *__pyx_t_4 = NULL; - PyObject *__pyx_t_5 = NULL; - PyObject *__pyx_t_6 = NULL; - PyObject *__pyx_t_7 = NULL; - size_t __pyx_t_8; - PyObject *__pyx_t_9 = NULL; - PyObject *__pyx_t_10 = NULL; - PyObject *__pyx_t_11 = NULL; - PyObject *__pyx_t_12 = NULL; - int __pyx_t_13; - Py_ssize_t __pyx_t_14; - PyObject *(*__pyx_t_15)(PyObject *); - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - __Pyx_RefNannySetupContext("net_size", 0); - - /* "epanet/epanet.py":60 - * - * def net_size(self) -> dict[str, int]: - * element_count = ctypes.POINTER(ctypes.c_int)() # <<<<<<<<<<<<<< - * length = ctypes.c_int() - * self._check(self._lib.ENR_getNetSize(self._handle, ctypes.byref(element_count), ctypes.byref(length))) -*/ - __pyx_t_2 = NULL; - __pyx_t_4 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 60, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_POINTER); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 60, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 60, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_c_int); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 60, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_7); - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - __pyx_t_8 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_6))) { - __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_6); - assert(__pyx_t_4); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_6); - __Pyx_INCREF(__pyx_t_4); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_6, __pyx__function); - __pyx_t_8 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_t_7}; - __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_6, __pyx_callargs+__pyx_t_8, (2-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 60, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - } - __pyx_t_8 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_3))) { - __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_3); - assert(__pyx_t_2); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_3); - __Pyx_INCREF(__pyx_t_2); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_3, __pyx__function); - __pyx_t_8 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_2, NULL}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_3, __pyx_callargs+__pyx_t_8, (1-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 60, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_v_element_count = __pyx_t_1; - __pyx_t_1 = 0; - - /* "epanet/epanet.py":61 - * def net_size(self) -> dict[str, int]: - * element_count = ctypes.POINTER(ctypes.c_int)() - * length = ctypes.c_int() # <<<<<<<<<<<<<< - * self._check(self._lib.ENR_getNetSize(self._handle, ctypes.byref(element_count), ctypes.byref(length))) - * assert length.value == 5 -*/ - __pyx_t_3 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 61, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_c_int); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 61, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __pyx_t_8 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_6))) { - __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_6); - assert(__pyx_t_3); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_6); - __Pyx_INCREF(__pyx_t_3); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_6, __pyx__function); - __pyx_t_8 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_6, __pyx_callargs+__pyx_t_8, (1-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 61, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_v_length = __pyx_t_1; - __pyx_t_1 = 0; - - /* "epanet/epanet.py":62 - * element_count = ctypes.POINTER(ctypes.c_int)() - * length = ctypes.c_int() - * self._check(self._lib.ENR_getNetSize(self._handle, ctypes.byref(element_count), ctypes.byref(length))) # <<<<<<<<<<<<<< - * assert length.value == 5 - * category = ['node', 'tank', 'link', 'pump', 'valve'] -*/ - __pyx_t_6 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_6); - __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_lib); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 62, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_7); - __pyx_t_2 = __pyx_t_7; - __Pyx_INCREF(__pyx_t_2); - __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_handle); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 62, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __pyx_t_9 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 62, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_byref); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 62, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - __pyx_t_8 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_11))) { - __pyx_t_9 = PyMethod_GET_SELF(__pyx_t_11); - assert(__pyx_t_9); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_11); - __Pyx_INCREF(__pyx_t_9); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_11, __pyx__function); - __pyx_t_8 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_9, __pyx_v_element_count}; - __pyx_t_5 = __Pyx_PyObject_FastCall(__pyx_t_11, __pyx_callargs+__pyx_t_8, (2-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 62, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - } - __pyx_t_9 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 62, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - __pyx_t_12 = __Pyx_PyObject_GetAttrStr(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_byref); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 62, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_12); - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - __pyx_t_8 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_12))) { - __pyx_t_9 = PyMethod_GET_SELF(__pyx_t_12); - assert(__pyx_t_9); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_12); - __Pyx_INCREF(__pyx_t_9); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_12, __pyx__function); - __pyx_t_8 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_9, __pyx_v_length}; - __pyx_t_11 = __Pyx_PyObject_FastCall(__pyx_t_12, __pyx_callargs+__pyx_t_8, (2-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0; - __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0; - if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 62, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - } - __pyx_t_8 = 0; - { - PyObject *__pyx_callargs[4] = {__pyx_t_2, __pyx_t_4, __pyx_t_5, __pyx_t_11}; - __pyx_t_3 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_ENR_getNetSize, __pyx_callargs+__pyx_t_8, (4-__pyx_t_8) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; - if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 62, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - } - __pyx_t_8 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_t_3}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_check, __pyx_callargs+__pyx_t_8, (2-__pyx_t_8) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 62, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - - /* "epanet/epanet.py":63 - * length = ctypes.c_int() - * self._check(self._lib.ENR_getNetSize(self._handle, ctypes.byref(element_count), ctypes.byref(length))) - * assert length.value == 5 # <<<<<<<<<<<<<< - * category = ['node', 'tank', 'link', 'pump', 'valve'] - * sizes = {} -*/ - #ifndef CYTHON_WITHOUT_ASSERTIONS - if (unlikely(__pyx_assertions_enabled())) { - __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_length, __pyx_mstate_global->__pyx_n_u_value); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 63, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_t_13 = (__Pyx_PyLong_BoolEqObjC(__pyx_t_1, __pyx_mstate_global->__pyx_int_5, 5, 0)); if (unlikely((__pyx_t_13 < 0))) __PYX_ERR(0, 63, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - if (unlikely(!__pyx_t_13)) { - __Pyx_Raise(__pyx_builtin_AssertionError, 0, 0, 0); - __PYX_ERR(0, 63, __pyx_L1_error) - } - } - #else - if ((1)); else __PYX_ERR(0, 63, __pyx_L1_error) - #endif - - /* "epanet/epanet.py":64 - * self._check(self._lib.ENR_getNetSize(self._handle, ctypes.byref(element_count), ctypes.byref(length))) - * assert length.value == 5 - * category = ['node', 'tank', 'link', 'pump', 'valve'] # <<<<<<<<<<<<<< - * sizes = {} - * for i in range(length.value): -*/ - __pyx_t_1 = PyList_New(5); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 64, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_node); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_node); - if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 0, __pyx_mstate_global->__pyx_n_u_node) != (0)) __PYX_ERR(0, 64, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_tank); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_tank); - if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 1, __pyx_mstate_global->__pyx_n_u_tank) != (0)) __PYX_ERR(0, 64, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_link); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_link); - if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 2, __pyx_mstate_global->__pyx_n_u_link) != (0)) __PYX_ERR(0, 64, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_pump); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_pump); - if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 3, __pyx_mstate_global->__pyx_n_u_pump) != (0)) __PYX_ERR(0, 64, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_valve); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_valve); - if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 4, __pyx_mstate_global->__pyx_n_u_valve) != (0)) __PYX_ERR(0, 64, __pyx_L1_error); - __pyx_v_category = ((PyObject*)__pyx_t_1); - __pyx_t_1 = 0; - - /* "epanet/epanet.py":65 - * assert length.value == 5 - * category = ['node', 'tank', 'link', 'pump', 'valve'] - * sizes = {} # <<<<<<<<<<<<<< - * for i in range(length.value): - * sizes[category[i]] = element_count[i] -*/ - __pyx_t_1 = __Pyx_PyDict_NewPresized(0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 65, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_v_sizes = ((PyObject*)__pyx_t_1); - __pyx_t_1 = 0; - - /* "epanet/epanet.py":66 - * category = ['node', 'tank', 'link', 'pump', 'valve'] - * sizes = {} - * for i in range(length.value): # <<<<<<<<<<<<<< - * sizes[category[i]] = element_count[i] - * self._lib.ENR_free(ctypes.byref(element_count)) -*/ - __pyx_t_3 = NULL; - __Pyx_INCREF(__pyx_builtin_range); - __pyx_t_6 = __pyx_builtin_range; - __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_v_length, __pyx_mstate_global->__pyx_n_u_value); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 66, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_7); - __pyx_t_8 = 1; - { - PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_t_7}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_6, __pyx_callargs+__pyx_t_8, (2-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 66, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - if (likely(PyList_CheckExact(__pyx_t_1)) || PyTuple_CheckExact(__pyx_t_1)) { - __pyx_t_6 = __pyx_t_1; __Pyx_INCREF(__pyx_t_6); - __pyx_t_14 = 0; - __pyx_t_15 = NULL; - } else { - __pyx_t_14 = -1; __pyx_t_6 = PyObject_GetIter(__pyx_t_1); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 66, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __pyx_t_15 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_6); if (unlikely(!__pyx_t_15)) __PYX_ERR(0, 66, __pyx_L1_error) - } - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - for (;;) { - if (likely(!__pyx_t_15)) { - if (likely(PyList_CheckExact(__pyx_t_6))) { - { - Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_6); - #if !CYTHON_ASSUME_SAFE_SIZE - if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 66, __pyx_L1_error) - #endif - if (__pyx_t_14 >= __pyx_temp) break; - } - __pyx_t_1 = __Pyx_PyList_GetItemRef(__pyx_t_6, __pyx_t_14); - ++__pyx_t_14; - } else { - { - Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_6); - #if !CYTHON_ASSUME_SAFE_SIZE - if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 66, __pyx_L1_error) - #endif - if (__pyx_t_14 >= __pyx_temp) break; - } - #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS - __pyx_t_1 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_6, __pyx_t_14)); - #else - __pyx_t_1 = __Pyx_PySequence_ITEM(__pyx_t_6, __pyx_t_14); - #endif - ++__pyx_t_14; - } - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 66, __pyx_L1_error) - } else { - __pyx_t_1 = __pyx_t_15(__pyx_t_6); - if (unlikely(!__pyx_t_1)) { - PyObject* exc_type = PyErr_Occurred(); - if (exc_type) { - if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 66, __pyx_L1_error) - PyErr_Clear(); - } - break; - } - } - __Pyx_GOTREF(__pyx_t_1); - __Pyx_XDECREF_SET(__pyx_v_i, __pyx_t_1); - __pyx_t_1 = 0; - - /* "epanet/epanet.py":67 - * sizes = {} - * for i in range(length.value): - * sizes[category[i]] = element_count[i] # <<<<<<<<<<<<<< - * self._lib.ENR_free(ctypes.byref(element_count)) - * return sizes -*/ - __pyx_t_1 = __Pyx_PyObject_GetItem(__pyx_v_element_count, __pyx_v_i); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 67, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_t_7 = __Pyx_PyObject_GetItem(__pyx_v_category, __pyx_v_i); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 67, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_7); - if (unlikely((PyDict_SetItem(__pyx_v_sizes, __pyx_t_7, __pyx_t_1) < 0))) __PYX_ERR(0, 67, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - - /* "epanet/epanet.py":66 - * category = ['node', 'tank', 'link', 'pump', 'valve'] - * sizes = {} - * for i in range(length.value): # <<<<<<<<<<<<<< - * sizes[category[i]] = element_count[i] - * self._lib.ENR_free(ctypes.byref(element_count)) -*/ - } - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - - /* "epanet/epanet.py":68 - * for i in range(length.value): - * sizes[category[i]] = element_count[i] - * self._lib.ENR_free(ctypes.byref(element_count)) # <<<<<<<<<<<<<< - * return sizes - * -*/ - __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_lib); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 68, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_7); - __pyx_t_1 = __pyx_t_7; - __Pyx_INCREF(__pyx_t_1); - __pyx_t_11 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 68, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_byref); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 68, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - __pyx_t_8 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_4))) { - __pyx_t_11 = PyMethod_GET_SELF(__pyx_t_4); - assert(__pyx_t_11); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); - __Pyx_INCREF(__pyx_t_11); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); - __pyx_t_8 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_11, __pyx_v_element_count}; - __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_8, (2-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 68, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - } - __pyx_t_8 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_1, __pyx_t_3}; - __pyx_t_6 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_ENR_free, __pyx_callargs+__pyx_t_8, (2-__pyx_t_8) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; - if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 68, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - } - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - - /* "epanet/epanet.py":69 - * sizes[category[i]] = element_count[i] - * self._lib.ENR_free(ctypes.byref(element_count)) - * return sizes # <<<<<<<<<<<<<< - * - * -*/ - __Pyx_XDECREF(__pyx_r); - __Pyx_INCREF(__pyx_v_sizes); - __pyx_r = __pyx_v_sizes; - goto __pyx_L0; - - /* "epanet/epanet.py":59 - * - * - * def net_size(self) -> dict[str, int]: # <<<<<<<<<<<<<< - * element_count = ctypes.POINTER(ctypes.c_int)() - * length = ctypes.c_int() -*/ - - /* function exit code */ - __pyx_L1_error:; - __Pyx_XDECREF(__pyx_t_1); - __Pyx_XDECREF(__pyx_t_2); - __Pyx_XDECREF(__pyx_t_3); - __Pyx_XDECREF(__pyx_t_4); - __Pyx_XDECREF(__pyx_t_5); - __Pyx_XDECREF(__pyx_t_6); - __Pyx_XDECREF(__pyx_t_7); - __Pyx_XDECREF(__pyx_t_9); - __Pyx_XDECREF(__pyx_t_10); - __Pyx_XDECREF(__pyx_t_11); - __Pyx_XDECREF(__pyx_t_12); - __Pyx_AddTraceback("epanet.epanet.Output.net_size", __pyx_clineno, __pyx_lineno, __pyx_filename); - __pyx_r = NULL; - __pyx_L0:; - __Pyx_XDECREF(__pyx_v_element_count); - __Pyx_XDECREF(__pyx_v_length); - __Pyx_XDECREF(__pyx_v_category); - __Pyx_XDECREF(__pyx_v_sizes); - __Pyx_XDECREF(__pyx_v_i); - __Pyx_XGIVEREF(__pyx_r); - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -/* "epanet/epanet.py":72 - * - * - * def units(self) -> dict[str, str]: # <<<<<<<<<<<<<< - * f_us = ['CFS', 'GPM', 'MGD', 'IMGD', 'AFD', 'LPS', 'LPM', 'MLD', 'CMH', 'CMD'] - * p_us = ['PSI', 'MTR', 'KPA'] -*/ - -/* Python wrapper */ -static PyObject *__pyx_pw_6epanet_6epanet_6Output_11units(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -); /*proto*/ -static PyMethodDef __pyx_mdef_6epanet_6epanet_6Output_11units = {"units", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6epanet_6epanet_6Output_11units, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}; -static PyObject *__pyx_pw_6epanet_6epanet_6Output_11units(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -) { - PyObject *__pyx_v_self = 0; - #if !CYTHON_METH_FASTCALL - CYTHON_UNUSED Py_ssize_t __pyx_nargs; - #endif - CYTHON_UNUSED PyObject *const *__pyx_kwvalues; - PyObject* values[1] = {0}; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - PyObject *__pyx_r = 0; - __Pyx_RefNannyDeclarations - __Pyx_RefNannySetupContext("units (wrapper)", 0); - #if !CYTHON_METH_FASTCALL - #if CYTHON_ASSUME_SAFE_SIZE - __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); - #else - __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; - #endif - #endif - __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); - { - PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_self,0}; - const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; - if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 72, __pyx_L3_error) - if (__pyx_kwds_len > 0) { - switch (__pyx_nargs) { - case 1: - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 72, __pyx_L3_error) - CYTHON_FALLTHROUGH; - case 0: break; - default: goto __pyx_L5_argtuple_error; - } - const Py_ssize_t kwd_pos_args = __pyx_nargs; - if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "units", 0) < 0) __PYX_ERR(0, 72, __pyx_L3_error) - for (Py_ssize_t i = __pyx_nargs; i < 1; i++) { - if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("units", 1, 1, 1, i); __PYX_ERR(0, 72, __pyx_L3_error) } - } - } else if (unlikely(__pyx_nargs != 1)) { - goto __pyx_L5_argtuple_error; - } else { - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 72, __pyx_L3_error) - } - __pyx_v_self = values[0]; - } - goto __pyx_L6_skip; - __pyx_L5_argtuple_error:; - __Pyx_RaiseArgtupleInvalid("units", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 72, __pyx_L3_error) - __pyx_L6_skip:; - goto __pyx_L4_argument_unpacking_done; - __pyx_L3_error:; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_AddTraceback("epanet.epanet.Output.units", __pyx_clineno, __pyx_lineno, __pyx_filename); - __Pyx_RefNannyFinishContext(); - return NULL; - __pyx_L4_argument_unpacking_done:; - __pyx_r = __pyx_pf_6epanet_6epanet_6Output_10units(__pyx_self, __pyx_v_self); - - /* function exit code */ - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -static PyObject *__pyx_pf_6epanet_6epanet_6Output_10units(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self) { - PyObject *__pyx_v_f_us = NULL; - PyObject *__pyx_v_p_us = NULL; - PyObject *__pyx_v_q_us = NULL; - PyObject *__pyx_v_f = NULL; - PyObject *__pyx_v_p = NULL; - PyObject *__pyx_v_q = NULL; - PyObject *__pyx_v_f_u = NULL; - PyObject *__pyx_v_p_u = NULL; - PyObject *__pyx_v_q_u = NULL; - PyObject *__pyx_r = NULL; - __Pyx_RefNannyDeclarations - PyObject *__pyx_t_1 = NULL; - PyObject *__pyx_t_2 = NULL; - PyObject *__pyx_t_3 = NULL; - PyObject *__pyx_t_4 = NULL; - size_t __pyx_t_5; - PyObject *__pyx_t_6 = NULL; - PyObject *__pyx_t_7 = NULL; - PyObject *__pyx_t_8 = NULL; - PyObject *__pyx_t_9 = NULL; - PyObject *__pyx_t_10 = NULL; - PyObject *__pyx_t_11 = NULL; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - __Pyx_RefNannySetupContext("units", 0); - - /* "epanet/epanet.py":73 - * - * def units(self) -> dict[str, str]: - * f_us = ['CFS', 'GPM', 'MGD', 'IMGD', 'AFD', 'LPS', 'LPM', 'MLD', 'CMH', 'CMD'] # <<<<<<<<<<<<<< - * p_us = ['PSI', 'MTR', 'KPA'] - * q_us = ['NONE', 'MGL', 'UGL', 'HOURS', 'PRCNT'] -*/ - __pyx_t_1 = PyList_New(10); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 73, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_CFS); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_CFS); - if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 0, __pyx_mstate_global->__pyx_n_u_CFS) != (0)) __PYX_ERR(0, 73, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_GPM); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_GPM); - if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 1, __pyx_mstate_global->__pyx_n_u_GPM) != (0)) __PYX_ERR(0, 73, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_MGD); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_MGD); - if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 2, __pyx_mstate_global->__pyx_n_u_MGD) != (0)) __PYX_ERR(0, 73, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_IMGD); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_IMGD); - if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 3, __pyx_mstate_global->__pyx_n_u_IMGD) != (0)) __PYX_ERR(0, 73, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_AFD); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_AFD); - if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 4, __pyx_mstate_global->__pyx_n_u_AFD) != (0)) __PYX_ERR(0, 73, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_LPS); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_LPS); - if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 5, __pyx_mstate_global->__pyx_n_u_LPS) != (0)) __PYX_ERR(0, 73, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_LPM); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_LPM); - if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 6, __pyx_mstate_global->__pyx_n_u_LPM) != (0)) __PYX_ERR(0, 73, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_MLD); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_MLD); - if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 7, __pyx_mstate_global->__pyx_n_u_MLD) != (0)) __PYX_ERR(0, 73, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_CMH); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_CMH); - if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 8, __pyx_mstate_global->__pyx_n_u_CMH) != (0)) __PYX_ERR(0, 73, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_CMD); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_CMD); - if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 9, __pyx_mstate_global->__pyx_n_u_CMD) != (0)) __PYX_ERR(0, 73, __pyx_L1_error); - __pyx_v_f_us = ((PyObject*)__pyx_t_1); - __pyx_t_1 = 0; - - /* "epanet/epanet.py":74 - * def units(self) -> dict[str, str]: - * f_us = ['CFS', 'GPM', 'MGD', 'IMGD', 'AFD', 'LPS', 'LPM', 'MLD', 'CMH', 'CMD'] - * p_us = ['PSI', 'MTR', 'KPA'] # <<<<<<<<<<<<<< - * q_us = ['NONE', 'MGL', 'UGL', 'HOURS', 'PRCNT'] - * f, p, q = ctypes.c_int(1), ctypes.c_int(2), ctypes.c_int(3) -*/ - __pyx_t_1 = PyList_New(3); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 74, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_PSI); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_PSI); - if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 0, __pyx_mstate_global->__pyx_n_u_PSI) != (0)) __PYX_ERR(0, 74, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_MTR); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_MTR); - if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 1, __pyx_mstate_global->__pyx_n_u_MTR) != (0)) __PYX_ERR(0, 74, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_KPA); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_KPA); - if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 2, __pyx_mstate_global->__pyx_n_u_KPA) != (0)) __PYX_ERR(0, 74, __pyx_L1_error); - __pyx_v_p_us = ((PyObject*)__pyx_t_1); - __pyx_t_1 = 0; - - /* "epanet/epanet.py":75 - * f_us = ['CFS', 'GPM', 'MGD', 'IMGD', 'AFD', 'LPS', 'LPM', 'MLD', 'CMH', 'CMD'] - * p_us = ['PSI', 'MTR', 'KPA'] - * q_us = ['NONE', 'MGL', 'UGL', 'HOURS', 'PRCNT'] # <<<<<<<<<<<<<< - * f, p, q = ctypes.c_int(1), ctypes.c_int(2), ctypes.c_int(3) - * f_u, p_u, q_u = ctypes.c_int(), ctypes.c_int(), ctypes.c_int() -*/ - __pyx_t_1 = PyList_New(5); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 75, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_NONE); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_NONE); - if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 0, __pyx_mstate_global->__pyx_n_u_NONE) != (0)) __PYX_ERR(0, 75, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_MGL); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_MGL); - if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 1, __pyx_mstate_global->__pyx_n_u_MGL) != (0)) __PYX_ERR(0, 75, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_UGL); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_UGL); - if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 2, __pyx_mstate_global->__pyx_n_u_UGL) != (0)) __PYX_ERR(0, 75, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_HOURS); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_HOURS); - if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 3, __pyx_mstate_global->__pyx_n_u_HOURS) != (0)) __PYX_ERR(0, 75, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_PRCNT); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_PRCNT); - if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 4, __pyx_mstate_global->__pyx_n_u_PRCNT) != (0)) __PYX_ERR(0, 75, __pyx_L1_error); - __pyx_v_q_us = ((PyObject*)__pyx_t_1); - __pyx_t_1 = 0; - - /* "epanet/epanet.py":76 - * p_us = ['PSI', 'MTR', 'KPA'] - * q_us = ['NONE', 'MGL', 'UGL', 'HOURS', 'PRCNT'] - * f, p, q = ctypes.c_int(1), ctypes.c_int(2), ctypes.c_int(3) # <<<<<<<<<<<<<< - * f_u, p_u, q_u = ctypes.c_int(), ctypes.c_int(), ctypes.c_int() - * self._check(self._lib.ENR_getUnits(self._handle, f, ctypes.byref(f_u))) -*/ - __pyx_t_2 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 76, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_c_int); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 76, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __pyx_t_5 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_4))) { - __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_4); - assert(__pyx_t_2); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); - __Pyx_INCREF(__pyx_t_2); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); - __pyx_t_5 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_mstate_global->__pyx_int_1}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 76, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_t_2 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 76, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_c_int); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 76, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __pyx_t_5 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_6))) { - __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_6); - assert(__pyx_t_2); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_6); - __Pyx_INCREF(__pyx_t_2); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_6, __pyx__function); - __pyx_t_5 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_mstate_global->__pyx_int_2}; - __pyx_t_4 = __Pyx_PyObject_FastCall(__pyx_t_6, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 76, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - } - __pyx_t_2 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 76, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_c_int); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 76, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_7); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __pyx_t_5 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_7))) { - __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_7); - assert(__pyx_t_2); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_7); - __Pyx_INCREF(__pyx_t_2); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_7, __pyx__function); - __pyx_t_5 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_mstate_global->__pyx_int_3}; - __pyx_t_6 = __Pyx_PyObject_FastCall(__pyx_t_7, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; - if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 76, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - } - __pyx_v_f = __pyx_t_1; - __pyx_t_1 = 0; - __pyx_v_p = __pyx_t_4; - __pyx_t_4 = 0; - __pyx_v_q = __pyx_t_6; - __pyx_t_6 = 0; - - /* "epanet/epanet.py":77 - * q_us = ['NONE', 'MGL', 'UGL', 'HOURS', 'PRCNT'] - * f, p, q = ctypes.c_int(1), ctypes.c_int(2), ctypes.c_int(3) - * f_u, p_u, q_u = ctypes.c_int(), ctypes.c_int(), ctypes.c_int() # <<<<<<<<<<<<<< - * self._check(self._lib.ENR_getUnits(self._handle, f, ctypes.byref(f_u))) - * self._check(self._lib.ENR_getUnits(self._handle, p, ctypes.byref(p_u))) -*/ - __pyx_t_4 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 77, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_c_int); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 77, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_7); - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __pyx_t_5 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_7))) { - __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_7); - assert(__pyx_t_4); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_7); - __Pyx_INCREF(__pyx_t_4); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_7, __pyx__function); - __pyx_t_5 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_4, NULL}; - __pyx_t_6 = __Pyx_PyObject_FastCall(__pyx_t_7, __pyx_callargs+__pyx_t_5, (1-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; - if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 77, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - } - __pyx_t_4 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 77, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_c_int); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 77, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __pyx_t_5 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_2))) { - __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_2); - assert(__pyx_t_4); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_2); - __Pyx_INCREF(__pyx_t_4); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_2, __pyx__function); - __pyx_t_5 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_4, NULL}; - __pyx_t_7 = __Pyx_PyObject_FastCall(__pyx_t_2, __pyx_callargs+__pyx_t_5, (1-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 77, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_7); - } - __pyx_t_4 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 77, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_c_int); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 77, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __pyx_t_5 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_3))) { - __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_3); - assert(__pyx_t_4); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_3); - __Pyx_INCREF(__pyx_t_4); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_3, __pyx__function); - __pyx_t_5 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_4, NULL}; - __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_3, __pyx_callargs+__pyx_t_5, (1-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 77, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - __pyx_v_f_u = __pyx_t_6; - __pyx_t_6 = 0; - __pyx_v_p_u = __pyx_t_7; - __pyx_t_7 = 0; - __pyx_v_q_u = __pyx_t_2; - __pyx_t_2 = 0; - - /* "epanet/epanet.py":78 - * f, p, q = ctypes.c_int(1), ctypes.c_int(2), ctypes.c_int(3) - * f_u, p_u, q_u = ctypes.c_int(), ctypes.c_int(), ctypes.c_int() - * self._check(self._lib.ENR_getUnits(self._handle, f, ctypes.byref(f_u))) # <<<<<<<<<<<<<< - * self._check(self._lib.ENR_getUnits(self._handle, p, ctypes.byref(p_u))) - * self._check(self._lib.ENR_getUnits(self._handle, q, ctypes.byref(q_u))) -*/ - __pyx_t_7 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_7); - __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_lib); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 78, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __pyx_t_3 = __pyx_t_4; - __Pyx_INCREF(__pyx_t_3); - __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_handle); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 78, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_t_9 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 78, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_byref); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 78, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - __pyx_t_5 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_11))) { - __pyx_t_9 = PyMethod_GET_SELF(__pyx_t_11); - assert(__pyx_t_9); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_11); - __Pyx_INCREF(__pyx_t_9); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_11, __pyx__function); - __pyx_t_5 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_9, __pyx_v_f_u}; - __pyx_t_8 = __Pyx_PyObject_FastCall(__pyx_t_11, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 78, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_8); - } - __pyx_t_5 = 0; - { - PyObject *__pyx_callargs[4] = {__pyx_t_3, __pyx_t_1, __pyx_v_f, __pyx_t_8}; - __pyx_t_6 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_ENR_getUnits, __pyx_callargs+__pyx_t_5, (4-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 78, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - } - __pyx_t_5 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_7, __pyx_t_6}; - __pyx_t_2 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_check, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 78, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet.py":79 - * f_u, p_u, q_u = ctypes.c_int(), ctypes.c_int(), ctypes.c_int() - * self._check(self._lib.ENR_getUnits(self._handle, f, ctypes.byref(f_u))) - * self._check(self._lib.ENR_getUnits(self._handle, p, ctypes.byref(p_u))) # <<<<<<<<<<<<<< - * self._check(self._lib.ENR_getUnits(self._handle, q, ctypes.byref(q_u))) - * return { 'flow': f_us[f_u.value], 'pressure': p_us[p_u.value], 'quality': q_us[q_u.value] } -*/ - __pyx_t_6 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_6); - __pyx_t_8 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_lib); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 79, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_8); - __pyx_t_4 = __pyx_t_8; - __Pyx_INCREF(__pyx_t_4); - __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_handle); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 79, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_t_11 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 79, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_byref); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 79, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - __pyx_t_5 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_10))) { - __pyx_t_11 = PyMethod_GET_SELF(__pyx_t_10); - assert(__pyx_t_11); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_10); - __Pyx_INCREF(__pyx_t_11); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_10, __pyx__function); - __pyx_t_5 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_11, __pyx_v_p_u}; - __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_10, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 79, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - } - __pyx_t_5 = 0; - { - PyObject *__pyx_callargs[4] = {__pyx_t_4, __pyx_t_1, __pyx_v_p, __pyx_t_3}; - __pyx_t_7 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_ENR_getUnits, __pyx_callargs+__pyx_t_5, (4-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; - if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 79, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_7); - } - __pyx_t_5 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_t_7}; - __pyx_t_2 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_check, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; - __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 79, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet.py":80 - * self._check(self._lib.ENR_getUnits(self._handle, f, ctypes.byref(f_u))) - * self._check(self._lib.ENR_getUnits(self._handle, p, ctypes.byref(p_u))) - * self._check(self._lib.ENR_getUnits(self._handle, q, ctypes.byref(q_u))) # <<<<<<<<<<<<<< - * return { 'flow': f_us[f_u.value], 'pressure': p_us[p_u.value], 'quality': q_us[q_u.value] } - * -*/ - __pyx_t_7 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_7); - __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_lib); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 80, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __pyx_t_8 = __pyx_t_3; - __Pyx_INCREF(__pyx_t_8); - __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_handle); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 80, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_t_10 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 80, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __pyx_t_9 = __Pyx_PyObject_GetAttrStr(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_byref); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 80, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - __pyx_t_5 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_9))) { - __pyx_t_10 = PyMethod_GET_SELF(__pyx_t_9); - assert(__pyx_t_10); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_9); - __Pyx_INCREF(__pyx_t_10); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_9, __pyx__function); - __pyx_t_5 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_10, __pyx_v_q_u}; - __pyx_t_4 = __Pyx_PyObject_FastCall(__pyx_t_9, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0; - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 80, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - } - __pyx_t_5 = 0; - { - PyObject *__pyx_callargs[4] = {__pyx_t_8, __pyx_t_1, __pyx_v_q, __pyx_t_4}; - __pyx_t_6 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_ENR_getUnits, __pyx_callargs+__pyx_t_5, (4-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0; - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 80, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - } - __pyx_t_5 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_7, __pyx_t_6}; - __pyx_t_2 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_check, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 80, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet.py":81 - * self._check(self._lib.ENR_getUnits(self._handle, p, ctypes.byref(p_u))) - * self._check(self._lib.ENR_getUnits(self._handle, q, ctypes.byref(q_u))) - * return { 'flow': f_us[f_u.value], 'pressure': p_us[p_u.value], 'quality': q_us[q_u.value] } # <<<<<<<<<<<<<< - * - * -*/ - __Pyx_XDECREF(__pyx_r); - __pyx_t_2 = __Pyx_PyDict_NewPresized(3); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 81, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_v_f_u, __pyx_mstate_global->__pyx_n_u_value); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 81, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __pyx_t_7 = __Pyx_PyObject_GetItem(__pyx_v_f_us, __pyx_t_6); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 81, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_7); - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - if (PyDict_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_flow, __pyx_t_7) < 0) __PYX_ERR(0, 81, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; - __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_v_p_u, __pyx_mstate_global->__pyx_n_u_value); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 81, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_7); - __pyx_t_6 = __Pyx_PyObject_GetItem(__pyx_v_p_us, __pyx_t_7); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 81, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; - if (PyDict_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_pressure, __pyx_t_6) < 0) __PYX_ERR(0, 81, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_v_q_u, __pyx_mstate_global->__pyx_n_u_value); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 81, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __pyx_t_7 = __Pyx_PyObject_GetItem(__pyx_v_q_us, __pyx_t_6); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 81, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_7); - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - if (PyDict_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_quality, __pyx_t_7) < 0) __PYX_ERR(0, 81, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; - __pyx_r = ((PyObject*)__pyx_t_2); - __pyx_t_2 = 0; - goto __pyx_L0; - - /* "epanet/epanet.py":72 - * - * - * def units(self) -> dict[str, str]: # <<<<<<<<<<<<<< - * f_us = ['CFS', 'GPM', 'MGD', 'IMGD', 'AFD', 'LPS', 'LPM', 'MLD', 'CMH', 'CMD'] - * p_us = ['PSI', 'MTR', 'KPA'] -*/ - - /* function exit code */ - __pyx_L1_error:; - __Pyx_XDECREF(__pyx_t_1); - __Pyx_XDECREF(__pyx_t_2); - __Pyx_XDECREF(__pyx_t_3); - __Pyx_XDECREF(__pyx_t_4); - __Pyx_XDECREF(__pyx_t_6); - __Pyx_XDECREF(__pyx_t_7); - __Pyx_XDECREF(__pyx_t_8); - __Pyx_XDECREF(__pyx_t_9); - __Pyx_XDECREF(__pyx_t_10); - __Pyx_XDECREF(__pyx_t_11); - __Pyx_AddTraceback("epanet.epanet.Output.units", __pyx_clineno, __pyx_lineno, __pyx_filename); - __pyx_r = NULL; - __pyx_L0:; - __Pyx_XDECREF(__pyx_v_f_us); - __Pyx_XDECREF(__pyx_v_p_us); - __Pyx_XDECREF(__pyx_v_q_us); - __Pyx_XDECREF(__pyx_v_f); - __Pyx_XDECREF(__pyx_v_p); - __Pyx_XDECREF(__pyx_v_q); - __Pyx_XDECREF(__pyx_v_f_u); - __Pyx_XDECREF(__pyx_v_p_u); - __Pyx_XDECREF(__pyx_v_q_u); - __Pyx_XGIVEREF(__pyx_r); - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -/* "epanet/epanet.py":84 - * - * - * def times(self) -> dict[str, int]: # <<<<<<<<<<<<<< - * ts = [] - * for i in range(1, 5): -*/ - -/* Python wrapper */ -static PyObject *__pyx_pw_6epanet_6epanet_6Output_13times(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -); /*proto*/ -static PyMethodDef __pyx_mdef_6epanet_6epanet_6Output_13times = {"times", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6epanet_6epanet_6Output_13times, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}; -static PyObject *__pyx_pw_6epanet_6epanet_6Output_13times(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -) { - PyObject *__pyx_v_self = 0; - #if !CYTHON_METH_FASTCALL - CYTHON_UNUSED Py_ssize_t __pyx_nargs; - #endif - CYTHON_UNUSED PyObject *const *__pyx_kwvalues; - PyObject* values[1] = {0}; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - PyObject *__pyx_r = 0; - __Pyx_RefNannyDeclarations - __Pyx_RefNannySetupContext("times (wrapper)", 0); - #if !CYTHON_METH_FASTCALL - #if CYTHON_ASSUME_SAFE_SIZE - __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); - #else - __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; - #endif - #endif - __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); - { - PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_self,0}; - const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; - if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 84, __pyx_L3_error) - if (__pyx_kwds_len > 0) { - switch (__pyx_nargs) { - case 1: - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 84, __pyx_L3_error) - CYTHON_FALLTHROUGH; - case 0: break; - default: goto __pyx_L5_argtuple_error; - } - const Py_ssize_t kwd_pos_args = __pyx_nargs; - if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "times", 0) < 0) __PYX_ERR(0, 84, __pyx_L3_error) - for (Py_ssize_t i = __pyx_nargs; i < 1; i++) { - if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("times", 1, 1, 1, i); __PYX_ERR(0, 84, __pyx_L3_error) } - } - } else if (unlikely(__pyx_nargs != 1)) { - goto __pyx_L5_argtuple_error; - } else { - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 84, __pyx_L3_error) - } - __pyx_v_self = values[0]; - } - goto __pyx_L6_skip; - __pyx_L5_argtuple_error:; - __Pyx_RaiseArgtupleInvalid("times", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 84, __pyx_L3_error) - __pyx_L6_skip:; - goto __pyx_L4_argument_unpacking_done; - __pyx_L3_error:; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_AddTraceback("epanet.epanet.Output.times", __pyx_clineno, __pyx_lineno, __pyx_filename); - __Pyx_RefNannyFinishContext(); - return NULL; - __pyx_L4_argument_unpacking_done:; - __pyx_r = __pyx_pf_6epanet_6epanet_6Output_12times(__pyx_self, __pyx_v_self); - - /* function exit code */ - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -static PyObject *__pyx_pf_6epanet_6epanet_6Output_12times(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self) { - PyObject *__pyx_v_ts = NULL; - long __pyx_v_i; - PyObject *__pyx_v_t = NULL; - PyObject *__pyx_v_d = NULL; - PyObject *__pyx_v_category = NULL; - PyObject *__pyx_r = NULL; - __Pyx_RefNannyDeclarations - PyObject *__pyx_t_1 = NULL; - long __pyx_t_2; - PyObject *__pyx_t_3 = NULL; - PyObject *__pyx_t_4 = NULL; - PyObject *__pyx_t_5 = NULL; - size_t __pyx_t_6; - PyObject *__pyx_t_7 = NULL; - PyObject *__pyx_t_8 = NULL; - PyObject *__pyx_t_9 = NULL; - PyObject *__pyx_t_10 = NULL; - PyObject *__pyx_t_11 = NULL; - PyObject *__pyx_t_12 = NULL; - PyObject *__pyx_t_13 = NULL; - int __pyx_t_14; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - __Pyx_RefNannySetupContext("times", 0); - - /* "epanet/epanet.py":85 - * - * def times(self) -> dict[str, int]: - * ts = [] # <<<<<<<<<<<<<< - * for i in range(1, 5): - * t = ctypes.c_int(1) -*/ - __pyx_t_1 = PyList_New(0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 85, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_v_ts = ((PyObject*)__pyx_t_1); - __pyx_t_1 = 0; - - /* "epanet/epanet.py":86 - * def times(self) -> dict[str, int]: - * ts = [] - * for i in range(1, 5): # <<<<<<<<<<<<<< - * t = ctypes.c_int(1) - * self._check(self._lib.ENR_getTimes(self._handle, ctypes.c_int(i), ctypes.byref(t))) -*/ - for (__pyx_t_2 = 1; __pyx_t_2 < 5; __pyx_t_2+=1) { - __pyx_v_i = __pyx_t_2; - - /* "epanet/epanet.py":87 - * ts = [] - * for i in range(1, 5): - * t = ctypes.c_int(1) # <<<<<<<<<<<<<< - * self._check(self._lib.ENR_getTimes(self._handle, ctypes.c_int(i), ctypes.byref(t))) - * ts.append(t.value) -*/ - __pyx_t_3 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 87, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_c_int); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 87, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - __pyx_t_6 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_5))) { - __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_5); - assert(__pyx_t_3); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_5); - __Pyx_INCREF(__pyx_t_3); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_5, __pyx__function); - __pyx_t_6 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_mstate_global->__pyx_int_1}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_5, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (__pyx_t_6*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 87, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __Pyx_XDECREF_SET(__pyx_v_t, __pyx_t_1); - __pyx_t_1 = 0; - - /* "epanet/epanet.py":88 - * for i in range(1, 5): - * t = ctypes.c_int(1) - * self._check(self._lib.ENR_getTimes(self._handle, ctypes.c_int(i), ctypes.byref(t))) # <<<<<<<<<<<<<< - * ts.append(t.value) - * d = {} -*/ - __pyx_t_5 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_5); - __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_lib); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 88, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_7); - __pyx_t_4 = __pyx_t_7; - __Pyx_INCREF(__pyx_t_4); - __pyx_t_8 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_handle); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 88, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_8); - __pyx_t_10 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 88, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __pyx_t_12 = __Pyx_PyObject_GetAttrStr(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_c_int); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 88, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_12); - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - __pyx_t_11 = __Pyx_PyLong_From_long(__pyx_v_i); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 88, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __pyx_t_6 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_12))) { - __pyx_t_10 = PyMethod_GET_SELF(__pyx_t_12); - assert(__pyx_t_10); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_12); - __Pyx_INCREF(__pyx_t_10); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_12, __pyx__function); - __pyx_t_6 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_10, __pyx_t_11}; - __pyx_t_9 = __Pyx_PyObject_FastCall(__pyx_t_12, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (__pyx_t_6*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0; - if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 88, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - } - __pyx_t_11 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 88, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - __pyx_t_13 = __Pyx_PyObject_GetAttrStr(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_byref); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 88, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_13); - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - __pyx_t_6 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_13))) { - __pyx_t_11 = PyMethod_GET_SELF(__pyx_t_13); - assert(__pyx_t_11); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_13); - __Pyx_INCREF(__pyx_t_11); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_13, __pyx__function); - __pyx_t_6 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_11, __pyx_v_t}; - __pyx_t_12 = __Pyx_PyObject_FastCall(__pyx_t_13, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (__pyx_t_6*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; - __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0; - if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 88, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_12); - } - __pyx_t_6 = 0; - { - PyObject *__pyx_callargs[4] = {__pyx_t_4, __pyx_t_8, __pyx_t_9, __pyx_t_12}; - __pyx_t_3 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_ENR_getTimes, __pyx_callargs+__pyx_t_6, (4-__pyx_t_6) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0; - __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; - if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 88, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - } - __pyx_t_6 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_5, __pyx_t_3}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_check, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 88, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - - /* "epanet/epanet.py":89 - * t = ctypes.c_int(1) - * self._check(self._lib.ENR_getTimes(self._handle, ctypes.c_int(i), ctypes.byref(t))) - * ts.append(t.value) # <<<<<<<<<<<<<< - * d = {} - * category = ['report_start', 'report_step', 'sim_duration', 'num_periods'] -*/ - __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_t, __pyx_mstate_global->__pyx_n_u_value); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 89, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_t_14 = __Pyx_PyList_Append(__pyx_v_ts, __pyx_t_1); if (unlikely(__pyx_t_14 == ((int)-1))) __PYX_ERR(0, 89, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - } - - /* "epanet/epanet.py":90 - * self._check(self._lib.ENR_getTimes(self._handle, ctypes.c_int(i), ctypes.byref(t))) - * ts.append(t.value) - * d = {} # <<<<<<<<<<<<<< - * category = ['report_start', 'report_step', 'sim_duration', 'num_periods'] - * for i in range(4): -*/ - __pyx_t_1 = __Pyx_PyDict_NewPresized(0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 90, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_v_d = ((PyObject*)__pyx_t_1); - __pyx_t_1 = 0; - - /* "epanet/epanet.py":91 - * ts.append(t.value) - * d = {} - * category = ['report_start', 'report_step', 'sim_duration', 'num_periods'] # <<<<<<<<<<<<<< - * for i in range(4): - * d[category[i]] = ts[i] -*/ - __pyx_t_1 = PyList_New(4); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 91, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_report_start); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_report_start); - if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 0, __pyx_mstate_global->__pyx_n_u_report_start) != (0)) __PYX_ERR(0, 91, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_report_step); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_report_step); - if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 1, __pyx_mstate_global->__pyx_n_u_report_step) != (0)) __PYX_ERR(0, 91, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_sim_duration); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_sim_duration); - if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 2, __pyx_mstate_global->__pyx_n_u_sim_duration) != (0)) __PYX_ERR(0, 91, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_num_periods); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_num_periods); - if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 3, __pyx_mstate_global->__pyx_n_u_num_periods) != (0)) __PYX_ERR(0, 91, __pyx_L1_error); - __pyx_v_category = ((PyObject*)__pyx_t_1); - __pyx_t_1 = 0; - - /* "epanet/epanet.py":92 - * d = {} - * category = ['report_start', 'report_step', 'sim_duration', 'num_periods'] - * for i in range(4): # <<<<<<<<<<<<<< - * d[category[i]] = ts[i] - * return d -*/ - for (__pyx_t_2 = 0; __pyx_t_2 < 4; __pyx_t_2+=1) { - __pyx_v_i = __pyx_t_2; - - /* "epanet/epanet.py":93 - * category = ['report_start', 'report_step', 'sim_duration', 'num_periods'] - * for i in range(4): - * d[category[i]] = ts[i] # <<<<<<<<<<<<<< - * return d - * -*/ - __pyx_t_1 = __Pyx_GetItemInt_List(__pyx_v_ts, __pyx_v_i, long, 1, __Pyx_PyLong_From_long, 1, 1, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 93, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_t_3 = __Pyx_GetItemInt_List(__pyx_v_category, __pyx_v_i, long, 1, __Pyx_PyLong_From_long, 1, 1, 1); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 93, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - if (unlikely((PyDict_SetItem(__pyx_v_d, __pyx_t_3, __pyx_t_1) < 0))) __PYX_ERR(0, 93, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - } - - /* "epanet/epanet.py":94 - * for i in range(4): - * d[category[i]] = ts[i] - * return d # <<<<<<<<<<<<<< - * - * -*/ - __Pyx_XDECREF(__pyx_r); - __Pyx_INCREF(__pyx_v_d); - __pyx_r = __pyx_v_d; - goto __pyx_L0; - - /* "epanet/epanet.py":84 - * - * - * def times(self) -> dict[str, int]: # <<<<<<<<<<<<<< - * ts = [] - * for i in range(1, 5): -*/ - - /* function exit code */ - __pyx_L1_error:; - __Pyx_XDECREF(__pyx_t_1); - __Pyx_XDECREF(__pyx_t_3); - __Pyx_XDECREF(__pyx_t_4); - __Pyx_XDECREF(__pyx_t_5); - __Pyx_XDECREF(__pyx_t_7); - __Pyx_XDECREF(__pyx_t_8); - __Pyx_XDECREF(__pyx_t_9); - __Pyx_XDECREF(__pyx_t_10); - __Pyx_XDECREF(__pyx_t_11); - __Pyx_XDECREF(__pyx_t_12); - __Pyx_XDECREF(__pyx_t_13); - __Pyx_AddTraceback("epanet.epanet.Output.times", __pyx_clineno, __pyx_lineno, __pyx_filename); - __pyx_r = NULL; - __pyx_L0:; - __Pyx_XDECREF(__pyx_v_ts); - __Pyx_XDECREF(__pyx_v_t); - __Pyx_XDECREF(__pyx_v_d); - __Pyx_XDECREF(__pyx_v_category); - __Pyx_XGIVEREF(__pyx_r); - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -/* "epanet/epanet.py":97 - * - * - * def element_name(self) -> dict[str, list[str]]: # <<<<<<<<<<<<<< - * sizes = self.net_size() - * -*/ - -/* Python wrapper */ -static PyObject *__pyx_pw_6epanet_6epanet_6Output_15element_name(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -); /*proto*/ -static PyMethodDef __pyx_mdef_6epanet_6epanet_6Output_15element_name = {"element_name", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6epanet_6epanet_6Output_15element_name, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}; -static PyObject *__pyx_pw_6epanet_6epanet_6Output_15element_name(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -) { - PyObject *__pyx_v_self = 0; - #if !CYTHON_METH_FASTCALL - CYTHON_UNUSED Py_ssize_t __pyx_nargs; - #endif - CYTHON_UNUSED PyObject *const *__pyx_kwvalues; - PyObject* values[1] = {0}; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - PyObject *__pyx_r = 0; - __Pyx_RefNannyDeclarations - __Pyx_RefNannySetupContext("element_name (wrapper)", 0); - #if !CYTHON_METH_FASTCALL - #if CYTHON_ASSUME_SAFE_SIZE - __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); - #else - __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; - #endif - #endif - __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); - { - PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_self,0}; - const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; - if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 97, __pyx_L3_error) - if (__pyx_kwds_len > 0) { - switch (__pyx_nargs) { - case 1: - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 97, __pyx_L3_error) - CYTHON_FALLTHROUGH; - case 0: break; - default: goto __pyx_L5_argtuple_error; - } - const Py_ssize_t kwd_pos_args = __pyx_nargs; - if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "element_name", 0) < 0) __PYX_ERR(0, 97, __pyx_L3_error) - for (Py_ssize_t i = __pyx_nargs; i < 1; i++) { - if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("element_name", 1, 1, 1, i); __PYX_ERR(0, 97, __pyx_L3_error) } - } - } else if (unlikely(__pyx_nargs != 1)) { - goto __pyx_L5_argtuple_error; - } else { - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 97, __pyx_L3_error) - } - __pyx_v_self = values[0]; - } - goto __pyx_L6_skip; - __pyx_L5_argtuple_error:; - __Pyx_RaiseArgtupleInvalid("element_name", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 97, __pyx_L3_error) - __pyx_L6_skip:; - goto __pyx_L4_argument_unpacking_done; - __pyx_L3_error:; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_AddTraceback("epanet.epanet.Output.element_name", __pyx_clineno, __pyx_lineno, __pyx_filename); - __Pyx_RefNannyFinishContext(); - return NULL; - __pyx_L4_argument_unpacking_done:; - __pyx_r = __pyx_pf_6epanet_6epanet_6Output_14element_name(__pyx_self, __pyx_v_self); - - /* function exit code */ - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -static PyObject *__pyx_pf_6epanet_6epanet_6Output_14element_name(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self) { - PyObject *__pyx_v_sizes = NULL; - PyObject *__pyx_v_node_type = NULL; - PyObject *__pyx_v_nodes = NULL; - PyObject *__pyx_v_i = NULL; - PyObject *__pyx_v_name = NULL; - PyObject *__pyx_v_name_len = NULL; - PyObject *__pyx_v_link_type = NULL; - PyObject *__pyx_v_links = NULL; - PyObject *__pyx_r = NULL; - __Pyx_RefNannyDeclarations - PyObject *__pyx_t_1 = NULL; - PyObject *__pyx_t_2 = NULL; - size_t __pyx_t_3; - PyObject *__pyx_t_4 = NULL; - PyObject *__pyx_t_5 = NULL; - PyObject *__pyx_t_6 = NULL; - Py_ssize_t __pyx_t_7; - PyObject *(*__pyx_t_8)(PyObject *); - PyObject *__pyx_t_9 = NULL; - PyObject *__pyx_t_10 = NULL; - PyObject *__pyx_t_11 = NULL; - PyObject *__pyx_t_12 = NULL; - PyObject *__pyx_t_13 = NULL; - PyObject *__pyx_t_14 = NULL; - PyObject *__pyx_t_15 = NULL; - PyObject *__pyx_t_16 = NULL; - int __pyx_t_17; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - __Pyx_RefNannySetupContext("element_name", 0); - - /* "epanet/epanet.py":98 - * - * def element_name(self) -> dict[str, list[str]]: - * sizes = self.net_size() # <<<<<<<<<<<<<< - * - * node_type = ctypes.c_int(1) -*/ - __pyx_t_2 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_2); - __pyx_t_3 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_2, NULL}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_net_size, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 98, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_v_sizes = __pyx_t_1; - __pyx_t_1 = 0; - - /* "epanet/epanet.py":100 - * sizes = self.net_size() - * - * node_type = ctypes.c_int(1) # <<<<<<<<<<<<<< - * nodes = [] - * for i in range(1, sizes['node'] + 1): -*/ - __pyx_t_2 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 100, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_c_int); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 100, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_5))) { - __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_5); - assert(__pyx_t_2); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_5); - __Pyx_INCREF(__pyx_t_2); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_5, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_mstate_global->__pyx_int_1}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_5, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 100, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_v_node_type = __pyx_t_1; - __pyx_t_1 = 0; - - /* "epanet/epanet.py":101 - * - * node_type = ctypes.c_int(1) - * nodes = [] # <<<<<<<<<<<<<< - * for i in range(1, sizes['node'] + 1): - * name = ctypes.c_char_p() -*/ - __pyx_t_1 = PyList_New(0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 101, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_v_nodes = ((PyObject*)__pyx_t_1); - __pyx_t_1 = 0; - - /* "epanet/epanet.py":102 - * node_type = ctypes.c_int(1) - * nodes = [] - * for i in range(1, sizes['node'] + 1): # <<<<<<<<<<<<<< - * name = ctypes.c_char_p() - * name_len = ctypes.c_int() -*/ - __pyx_t_5 = NULL; - __Pyx_INCREF(__pyx_builtin_range); - __pyx_t_2 = __pyx_builtin_range; - __pyx_t_4 = __Pyx_PyObject_Dict_GetItem(__pyx_v_sizes, __pyx_mstate_global->__pyx_n_u_node); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 102, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __pyx_t_6 = __Pyx_PyLong_AddObjC(__pyx_t_4, __pyx_mstate_global->__pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 102, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - __pyx_t_3 = 1; - { - PyObject *__pyx_callargs[3] = {__pyx_t_5, __pyx_mstate_global->__pyx_int_1, __pyx_t_6}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_2, __pyx_callargs+__pyx_t_3, (3-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 102, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - if (likely(PyList_CheckExact(__pyx_t_1)) || PyTuple_CheckExact(__pyx_t_1)) { - __pyx_t_2 = __pyx_t_1; __Pyx_INCREF(__pyx_t_2); - __pyx_t_7 = 0; - __pyx_t_8 = NULL; - } else { - __pyx_t_7 = -1; __pyx_t_2 = PyObject_GetIter(__pyx_t_1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 102, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_t_8 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_2); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 102, __pyx_L1_error) - } - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - for (;;) { - if (likely(!__pyx_t_8)) { - if (likely(PyList_CheckExact(__pyx_t_2))) { - { - Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_2); - #if !CYTHON_ASSUME_SAFE_SIZE - if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 102, __pyx_L1_error) - #endif - if (__pyx_t_7 >= __pyx_temp) break; - } - __pyx_t_1 = __Pyx_PyList_GetItemRef(__pyx_t_2, __pyx_t_7); - ++__pyx_t_7; - } else { - { - Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_2); - #if !CYTHON_ASSUME_SAFE_SIZE - if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 102, __pyx_L1_error) - #endif - if (__pyx_t_7 >= __pyx_temp) break; - } - #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS - __pyx_t_1 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_2, __pyx_t_7)); - #else - __pyx_t_1 = __Pyx_PySequence_ITEM(__pyx_t_2, __pyx_t_7); - #endif - ++__pyx_t_7; - } - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 102, __pyx_L1_error) - } else { - __pyx_t_1 = __pyx_t_8(__pyx_t_2); - if (unlikely(!__pyx_t_1)) { - PyObject* exc_type = PyErr_Occurred(); - if (exc_type) { - if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 102, __pyx_L1_error) - PyErr_Clear(); - } - break; - } - } - __Pyx_GOTREF(__pyx_t_1); - __Pyx_XDECREF_SET(__pyx_v_i, __pyx_t_1); - __pyx_t_1 = 0; - - /* "epanet/epanet.py":103 - * nodes = [] - * for i in range(1, sizes['node'] + 1): - * name = ctypes.c_char_p() # <<<<<<<<<<<<<< - * name_len = ctypes.c_int() - * self._check(self._lib.ENR_getElementName(self._handle, node_type, ctypes.c_int(i), ctypes.byref(name), ctypes.byref(name_len))) -*/ - __pyx_t_6 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 103, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_c_char_p); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 103, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_4))) { - __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_4); - assert(__pyx_t_6); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); - __Pyx_INCREF(__pyx_t_6); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_6, NULL}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 103, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __Pyx_XDECREF_SET(__pyx_v_name, __pyx_t_1); - __pyx_t_1 = 0; - - /* "epanet/epanet.py":104 - * for i in range(1, sizes['node'] + 1): - * name = ctypes.c_char_p() - * name_len = ctypes.c_int() # <<<<<<<<<<<<<< - * self._check(self._lib.ENR_getElementName(self._handle, node_type, ctypes.c_int(i), ctypes.byref(name), ctypes.byref(name_len))) - * nodes.append(name.value.decode()) -*/ - __pyx_t_4 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 104, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_c_int); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 104, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_5))) { - __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_5); - assert(__pyx_t_4); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_5); - __Pyx_INCREF(__pyx_t_4); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_5, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_4, NULL}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_5, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 104, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __Pyx_XDECREF_SET(__pyx_v_name_len, __pyx_t_1); - __pyx_t_1 = 0; - - /* "epanet/epanet.py":105 - * name = ctypes.c_char_p() - * name_len = ctypes.c_int() - * self._check(self._lib.ENR_getElementName(self._handle, node_type, ctypes.c_int(i), ctypes.byref(name), ctypes.byref(name_len))) # <<<<<<<<<<<<<< - * nodes.append(name.value.decode()) - * self._lib.ENR_free(ctypes.byref(name)) -*/ - __pyx_t_5 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_5); - __pyx_t_9 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_lib); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 105, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - __pyx_t_6 = __pyx_t_9; - __Pyx_INCREF(__pyx_t_6); - __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_handle); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 105, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - __pyx_t_12 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_13, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 105, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_13); - __pyx_t_14 = __Pyx_PyObject_GetAttrStr(__pyx_t_13, __pyx_mstate_global->__pyx_n_u_c_int); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 105, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_14); - __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_14))) { - __pyx_t_12 = PyMethod_GET_SELF(__pyx_t_14); - assert(__pyx_t_12); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_14); - __Pyx_INCREF(__pyx_t_12); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_14, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_12, __pyx_v_i}; - __pyx_t_11 = __Pyx_PyObject_FastCall(__pyx_t_14, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0; - __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; - if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 105, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - } - __pyx_t_12 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_13, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 105, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_13); - __pyx_t_15 = __Pyx_PyObject_GetAttrStr(__pyx_t_13, __pyx_mstate_global->__pyx_n_u_byref); if (unlikely(!__pyx_t_15)) __PYX_ERR(0, 105, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_15); - __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_15))) { - __pyx_t_12 = PyMethod_GET_SELF(__pyx_t_15); - assert(__pyx_t_12); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_15); - __Pyx_INCREF(__pyx_t_12); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_15, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_12, __pyx_v_name}; - __pyx_t_14 = __Pyx_PyObject_FastCall(__pyx_t_15, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0; - __Pyx_DECREF(__pyx_t_15); __pyx_t_15 = 0; - if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 105, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_14); - } - __pyx_t_12 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_13, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 105, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_13); - __pyx_t_16 = __Pyx_PyObject_GetAttrStr(__pyx_t_13, __pyx_mstate_global->__pyx_n_u_byref); if (unlikely(!__pyx_t_16)) __PYX_ERR(0, 105, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_16); - __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_16))) { - __pyx_t_12 = PyMethod_GET_SELF(__pyx_t_16); - assert(__pyx_t_12); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_16); - __Pyx_INCREF(__pyx_t_12); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_16, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_12, __pyx_v_name_len}; - __pyx_t_15 = __Pyx_PyObject_FastCall(__pyx_t_16, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0; - __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0; - if (unlikely(!__pyx_t_15)) __PYX_ERR(0, 105, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_15); - } - __pyx_t_3 = 0; - { - PyObject *__pyx_callargs[6] = {__pyx_t_6, __pyx_t_10, __pyx_v_node_type, __pyx_t_11, __pyx_t_14, __pyx_t_15}; - __pyx_t_4 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_ENR_getElementName, __pyx_callargs+__pyx_t_3, (6-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; - __Pyx_DECREF(__pyx_t_15); __pyx_t_15 = 0; - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 105, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - } - __pyx_t_3 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_5, __pyx_t_4}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_check, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 105, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - - /* "epanet/epanet.py":106 - * name_len = ctypes.c_int() - * self._check(self._lib.ENR_getElementName(self._handle, node_type, ctypes.c_int(i), ctypes.byref(name), ctypes.byref(name_len))) - * nodes.append(name.value.decode()) # <<<<<<<<<<<<<< - * self._lib.ENR_free(ctypes.byref(name)) - * -*/ - __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_v_name, __pyx_mstate_global->__pyx_n_u_value); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 106, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __pyx_t_4 = __pyx_t_5; - __Pyx_INCREF(__pyx_t_4); - __pyx_t_3 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_4, NULL}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_decode, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 106, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_t_17 = __Pyx_PyList_Append(__pyx_v_nodes, __pyx_t_1); if (unlikely(__pyx_t_17 == ((int)-1))) __PYX_ERR(0, 106, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - - /* "epanet/epanet.py":107 - * self._check(self._lib.ENR_getElementName(self._handle, node_type, ctypes.c_int(i), ctypes.byref(name), ctypes.byref(name_len))) - * nodes.append(name.value.decode()) - * self._lib.ENR_free(ctypes.byref(name)) # <<<<<<<<<<<<<< - * - * link_type = ctypes.c_int(2) -*/ - __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_lib); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 107, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __pyx_t_5 = __pyx_t_4; - __Pyx_INCREF(__pyx_t_5); - __pyx_t_15 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_14, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 107, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_14); - __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_t_14, __pyx_mstate_global->__pyx_n_u_byref); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 107, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_11))) { - __pyx_t_15 = PyMethod_GET_SELF(__pyx_t_11); - assert(__pyx_t_15); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_11); - __Pyx_INCREF(__pyx_t_15); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_11, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_15, __pyx_v_name}; - __pyx_t_9 = __Pyx_PyObject_FastCall(__pyx_t_11, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_15); __pyx_t_15 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 107, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - } - __pyx_t_3 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_5, __pyx_t_9}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_ENR_free, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 107, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - - /* "epanet/epanet.py":102 - * node_type = ctypes.c_int(1) - * nodes = [] - * for i in range(1, sizes['node'] + 1): # <<<<<<<<<<<<<< - * name = ctypes.c_char_p() - * name_len = ctypes.c_int() -*/ - } - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet.py":109 - * self._lib.ENR_free(ctypes.byref(name)) - * - * link_type = ctypes.c_int(2) # <<<<<<<<<<<<<< - * links = [] - * for i in range(1, sizes['link'] + 1): -*/ - __pyx_t_1 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 109, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __pyx_t_9 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_c_int); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 109, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_9))) { - __pyx_t_1 = PyMethod_GET_SELF(__pyx_t_9); - assert(__pyx_t_1); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_9); - __Pyx_INCREF(__pyx_t_1); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_9, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_1, __pyx_mstate_global->__pyx_int_2}; - __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_9, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0; - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 109, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - __pyx_v_link_type = __pyx_t_2; - __pyx_t_2 = 0; - - /* "epanet/epanet.py":110 - * - * link_type = ctypes.c_int(2) - * links = [] # <<<<<<<<<<<<<< - * for i in range(1, sizes['link'] + 1): - * name = ctypes.c_char_p() -*/ - __pyx_t_2 = PyList_New(0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 110, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_v_links = ((PyObject*)__pyx_t_2); - __pyx_t_2 = 0; - - /* "epanet/epanet.py":111 - * link_type = ctypes.c_int(2) - * links = [] - * for i in range(1, sizes['link'] + 1): # <<<<<<<<<<<<<< - * name = ctypes.c_char_p() - * name_len = ctypes.c_int() -*/ - __pyx_t_9 = NULL; - __Pyx_INCREF(__pyx_builtin_range); - __pyx_t_1 = __pyx_builtin_range; - __pyx_t_4 = __Pyx_PyObject_Dict_GetItem(__pyx_v_sizes, __pyx_mstate_global->__pyx_n_u_link); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 111, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __pyx_t_5 = __Pyx_PyLong_AddObjC(__pyx_t_4, __pyx_mstate_global->__pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 111, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - __pyx_t_3 = 1; - { - PyObject *__pyx_callargs[3] = {__pyx_t_9, __pyx_mstate_global->__pyx_int_1, __pyx_t_5}; - __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_1, __pyx_callargs+__pyx_t_3, (3-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 111, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - if (likely(PyList_CheckExact(__pyx_t_2)) || PyTuple_CheckExact(__pyx_t_2)) { - __pyx_t_1 = __pyx_t_2; __Pyx_INCREF(__pyx_t_1); - __pyx_t_7 = 0; - __pyx_t_8 = NULL; - } else { - __pyx_t_7 = -1; __pyx_t_1 = PyObject_GetIter(__pyx_t_2); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 111, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_t_8 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_1); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 111, __pyx_L1_error) - } - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - for (;;) { - if (likely(!__pyx_t_8)) { - if (likely(PyList_CheckExact(__pyx_t_1))) { - { - Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_1); - #if !CYTHON_ASSUME_SAFE_SIZE - if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 111, __pyx_L1_error) - #endif - if (__pyx_t_7 >= __pyx_temp) break; - } - __pyx_t_2 = __Pyx_PyList_GetItemRef(__pyx_t_1, __pyx_t_7); - ++__pyx_t_7; - } else { - { - Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_1); - #if !CYTHON_ASSUME_SAFE_SIZE - if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 111, __pyx_L1_error) - #endif - if (__pyx_t_7 >= __pyx_temp) break; - } - #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS - __pyx_t_2 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_1, __pyx_t_7)); - #else - __pyx_t_2 = __Pyx_PySequence_ITEM(__pyx_t_1, __pyx_t_7); - #endif - ++__pyx_t_7; - } - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 111, __pyx_L1_error) - } else { - __pyx_t_2 = __pyx_t_8(__pyx_t_1); - if (unlikely(!__pyx_t_2)) { - PyObject* exc_type = PyErr_Occurred(); - if (exc_type) { - if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 111, __pyx_L1_error) - PyErr_Clear(); - } - break; - } - } - __Pyx_GOTREF(__pyx_t_2); - __Pyx_XDECREF_SET(__pyx_v_i, __pyx_t_2); - __pyx_t_2 = 0; - - /* "epanet/epanet.py":112 - * links = [] - * for i in range(1, sizes['link'] + 1): - * name = ctypes.c_char_p() # <<<<<<<<<<<<<< - * name_len = ctypes.c_int() - * self._check(self._lib.ENR_getElementName(self._handle, link_type, ctypes.c_int(i), ctypes.byref(name), ctypes.byref(name_len))) -*/ - __pyx_t_5 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 112, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_c_char_p); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 112, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_4))) { - __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_4); - assert(__pyx_t_5); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); - __Pyx_INCREF(__pyx_t_5); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_5, NULL}; - __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 112, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - __Pyx_XDECREF_SET(__pyx_v_name, __pyx_t_2); - __pyx_t_2 = 0; - - /* "epanet/epanet.py":113 - * for i in range(1, sizes['link'] + 1): - * name = ctypes.c_char_p() - * name_len = ctypes.c_int() # <<<<<<<<<<<<<< - * self._check(self._lib.ENR_getElementName(self._handle, link_type, ctypes.c_int(i), ctypes.byref(name), ctypes.byref(name_len))) - * links.append(name.value.decode()) -*/ - __pyx_t_4 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 113, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __pyx_t_9 = __Pyx_PyObject_GetAttrStr(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_c_int); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 113, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_9))) { - __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_9); - assert(__pyx_t_4); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_9); - __Pyx_INCREF(__pyx_t_4); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_9, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_4, NULL}; - __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_9, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 113, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - __Pyx_XDECREF_SET(__pyx_v_name_len, __pyx_t_2); - __pyx_t_2 = 0; - - /* "epanet/epanet.py":114 - * name = ctypes.c_char_p() - * name_len = ctypes.c_int() - * self._check(self._lib.ENR_getElementName(self._handle, link_type, ctypes.c_int(i), ctypes.byref(name), ctypes.byref(name_len))) # <<<<<<<<<<<<<< - * links.append(name.value.decode()) - * self._lib.ENR_free(ctypes.byref(name)) -*/ - __pyx_t_9 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_9); - __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_lib); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 114, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __pyx_t_5 = __pyx_t_11; - __Pyx_INCREF(__pyx_t_5); - __pyx_t_15 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_handle); if (unlikely(!__pyx_t_15)) __PYX_ERR(0, 114, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_15); - __pyx_t_10 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 114, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __pyx_t_16 = __Pyx_PyObject_GetAttrStr(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_c_int); if (unlikely(!__pyx_t_16)) __PYX_ERR(0, 114, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_16); - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_16))) { - __pyx_t_10 = PyMethod_GET_SELF(__pyx_t_16); - assert(__pyx_t_10); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_16); - __Pyx_INCREF(__pyx_t_10); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_16, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_10, __pyx_v_i}; - __pyx_t_14 = __Pyx_PyObject_FastCall(__pyx_t_16, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0; - __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0; - if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 114, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_14); - } - __pyx_t_10 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 114, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __pyx_t_12 = __Pyx_PyObject_GetAttrStr(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_byref); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 114, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_12); - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_12))) { - __pyx_t_10 = PyMethod_GET_SELF(__pyx_t_12); - assert(__pyx_t_10); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_12); - __Pyx_INCREF(__pyx_t_10); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_12, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_10, __pyx_v_name}; - __pyx_t_16 = __Pyx_PyObject_FastCall(__pyx_t_12, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0; - __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0; - if (unlikely(!__pyx_t_16)) __PYX_ERR(0, 114, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_16); - } - __pyx_t_10 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 114, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __pyx_t_13 = __Pyx_PyObject_GetAttrStr(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_byref); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 114, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_13); - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_13))) { - __pyx_t_10 = PyMethod_GET_SELF(__pyx_t_13); - assert(__pyx_t_10); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_13); - __Pyx_INCREF(__pyx_t_10); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_13, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_10, __pyx_v_name_len}; - __pyx_t_12 = __Pyx_PyObject_FastCall(__pyx_t_13, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0; - __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0; - if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 114, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_12); - } - __pyx_t_3 = 0; - { - PyObject *__pyx_callargs[6] = {__pyx_t_5, __pyx_t_15, __pyx_v_link_type, __pyx_t_14, __pyx_t_16, __pyx_t_12}; - __pyx_t_4 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_ENR_getElementName, __pyx_callargs+__pyx_t_3, (6-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_DECREF(__pyx_t_15); __pyx_t_15 = 0; - __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; - __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0; - __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 114, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - } - __pyx_t_3 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_9, __pyx_t_4}; - __pyx_t_2 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_check, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 114, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet.py":115 - * name_len = ctypes.c_int() - * self._check(self._lib.ENR_getElementName(self._handle, link_type, ctypes.c_int(i), ctypes.byref(name), ctypes.byref(name_len))) - * links.append(name.value.decode()) # <<<<<<<<<<<<<< - * self._lib.ENR_free(ctypes.byref(name)) - * -*/ - __pyx_t_9 = __Pyx_PyObject_GetAttrStr(__pyx_v_name, __pyx_mstate_global->__pyx_n_u_value); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 115, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - __pyx_t_4 = __pyx_t_9; - __Pyx_INCREF(__pyx_t_4); - __pyx_t_3 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_4, NULL}; - __pyx_t_2 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_decode, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 115, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - __pyx_t_17 = __Pyx_PyList_Append(__pyx_v_links, __pyx_t_2); if (unlikely(__pyx_t_17 == ((int)-1))) __PYX_ERR(0, 115, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet.py":116 - * self._check(self._lib.ENR_getElementName(self._handle, link_type, ctypes.c_int(i), ctypes.byref(name), ctypes.byref(name_len))) - * links.append(name.value.decode()) - * self._lib.ENR_free(ctypes.byref(name)) # <<<<<<<<<<<<<< - * - * return { 'nodes' : nodes, 'links': links } -*/ - __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_lib); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 116, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __pyx_t_9 = __pyx_t_4; - __Pyx_INCREF(__pyx_t_9); - __pyx_t_12 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_16, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_16)) __PYX_ERR(0, 116, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_16); - __pyx_t_14 = __Pyx_PyObject_GetAttrStr(__pyx_t_16, __pyx_mstate_global->__pyx_n_u_byref); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 116, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_14); - __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_14))) { - __pyx_t_12 = PyMethod_GET_SELF(__pyx_t_14); - assert(__pyx_t_12); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_14); - __Pyx_INCREF(__pyx_t_12); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_14, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_12, __pyx_v_name}; - __pyx_t_11 = __Pyx_PyObject_FastCall(__pyx_t_14, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0; - __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; - if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 116, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - } - __pyx_t_3 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_9, __pyx_t_11}; - __pyx_t_2 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_ENR_free, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 116, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet.py":111 - * link_type = ctypes.c_int(2) - * links = [] - * for i in range(1, sizes['link'] + 1): # <<<<<<<<<<<<<< - * name = ctypes.c_char_p() - * name_len = ctypes.c_int() -*/ - } - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - - /* "epanet/epanet.py":118 - * self._lib.ENR_free(ctypes.byref(name)) - * - * return { 'nodes' : nodes, 'links': links } # <<<<<<<<<<<<<< - * - * -*/ - __Pyx_XDECREF(__pyx_r); - __pyx_t_1 = __Pyx_PyDict_NewPresized(2); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 118, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - if (PyDict_SetItem(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_nodes, __pyx_v_nodes) < 0) __PYX_ERR(0, 118, __pyx_L1_error) - if (PyDict_SetItem(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_links, __pyx_v_links) < 0) __PYX_ERR(0, 118, __pyx_L1_error) - __pyx_r = ((PyObject*)__pyx_t_1); - __pyx_t_1 = 0; - goto __pyx_L0; - - /* "epanet/epanet.py":97 - * - * - * def element_name(self) -> dict[str, list[str]]: # <<<<<<<<<<<<<< - * sizes = self.net_size() - * -*/ - - /* function exit code */ - __pyx_L1_error:; - __Pyx_XDECREF(__pyx_t_1); - __Pyx_XDECREF(__pyx_t_2); - __Pyx_XDECREF(__pyx_t_4); - __Pyx_XDECREF(__pyx_t_5); - __Pyx_XDECREF(__pyx_t_6); - __Pyx_XDECREF(__pyx_t_9); - __Pyx_XDECREF(__pyx_t_10); - __Pyx_XDECREF(__pyx_t_11); - __Pyx_XDECREF(__pyx_t_12); - __Pyx_XDECREF(__pyx_t_13); - __Pyx_XDECREF(__pyx_t_14); - __Pyx_XDECREF(__pyx_t_15); - __Pyx_XDECREF(__pyx_t_16); - __Pyx_AddTraceback("epanet.epanet.Output.element_name", __pyx_clineno, __pyx_lineno, __pyx_filename); - __pyx_r = NULL; - __pyx_L0:; - __Pyx_XDECREF(__pyx_v_sizes); - __Pyx_XDECREF(__pyx_v_node_type); - __Pyx_XDECREF(__pyx_v_nodes); - __Pyx_XDECREF(__pyx_v_i); - __Pyx_XDECREF(__pyx_v_name); - __Pyx_XDECREF(__pyx_v_name_len); - __Pyx_XDECREF(__pyx_v_link_type); - __Pyx_XDECREF(__pyx_v_links); - __Pyx_XGIVEREF(__pyx_r); - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -/* "epanet/epanet.py":121 - * - * - * def energy_usage(self) -> list[dict[str, Any]]: # <<<<<<<<<<<<<< - * size = self.net_size()['pump'] - * usages = [] -*/ - -/* Python wrapper */ -static PyObject *__pyx_pw_6epanet_6epanet_6Output_17energy_usage(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -); /*proto*/ -static PyMethodDef __pyx_mdef_6epanet_6epanet_6Output_17energy_usage = {"energy_usage", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6epanet_6epanet_6Output_17energy_usage, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}; -static PyObject *__pyx_pw_6epanet_6epanet_6Output_17energy_usage(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -) { - PyObject *__pyx_v_self = 0; - #if !CYTHON_METH_FASTCALL - CYTHON_UNUSED Py_ssize_t __pyx_nargs; - #endif - CYTHON_UNUSED PyObject *const *__pyx_kwvalues; - PyObject* values[1] = {0}; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - PyObject *__pyx_r = 0; - __Pyx_RefNannyDeclarations - __Pyx_RefNannySetupContext("energy_usage (wrapper)", 0); - #if !CYTHON_METH_FASTCALL - #if CYTHON_ASSUME_SAFE_SIZE - __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); - #else - __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; - #endif - #endif - __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); - { - PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_self,0}; - const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; - if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 121, __pyx_L3_error) - if (__pyx_kwds_len > 0) { - switch (__pyx_nargs) { - case 1: - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 121, __pyx_L3_error) - CYTHON_FALLTHROUGH; - case 0: break; - default: goto __pyx_L5_argtuple_error; - } - const Py_ssize_t kwd_pos_args = __pyx_nargs; - if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "energy_usage", 0) < 0) __PYX_ERR(0, 121, __pyx_L3_error) - for (Py_ssize_t i = __pyx_nargs; i < 1; i++) { - if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("energy_usage", 1, 1, 1, i); __PYX_ERR(0, 121, __pyx_L3_error) } - } - } else if (unlikely(__pyx_nargs != 1)) { - goto __pyx_L5_argtuple_error; - } else { - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 121, __pyx_L3_error) - } - __pyx_v_self = values[0]; - } - goto __pyx_L6_skip; - __pyx_L5_argtuple_error:; - __Pyx_RaiseArgtupleInvalid("energy_usage", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 121, __pyx_L3_error) - __pyx_L6_skip:; - goto __pyx_L4_argument_unpacking_done; - __pyx_L3_error:; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_AddTraceback("epanet.epanet.Output.energy_usage", __pyx_clineno, __pyx_lineno, __pyx_filename); - __Pyx_RefNannyFinishContext(); - return NULL; - __pyx_L4_argument_unpacking_done:; - __pyx_r = __pyx_pf_6epanet_6epanet_6Output_16energy_usage(__pyx_self, __pyx_v_self); - - /* function exit code */ - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -static PyObject *__pyx_pf_6epanet_6epanet_6Output_16energy_usage(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self) { - PyObject *__pyx_v_size = NULL; - PyObject *__pyx_v_usages = NULL; - PyObject *__pyx_v_category = NULL; - PyObject *__pyx_v_links = NULL; - PyObject *__pyx_v_i = NULL; - PyObject *__pyx_v_index = NULL; - PyObject *__pyx_v_values = NULL; - PyObject *__pyx_v_length = NULL; - PyObject *__pyx_v_d = NULL; - PyObject *__pyx_v_j = NULL; - PyObject *__pyx_r = NULL; - __Pyx_RefNannyDeclarations - PyObject *__pyx_t_1 = NULL; - PyObject *__pyx_t_2 = NULL; - size_t __pyx_t_3; - PyObject *__pyx_t_4 = NULL; - PyObject *__pyx_t_5 = NULL; - Py_ssize_t __pyx_t_6; - PyObject *(*__pyx_t_7)(PyObject *); - PyObject *__pyx_t_8 = NULL; - PyObject *__pyx_t_9 = NULL; - PyObject *__pyx_t_10 = NULL; - PyObject *__pyx_t_11 = NULL; - PyObject *__pyx_t_12 = NULL; - PyObject *__pyx_t_13 = NULL; - PyObject *__pyx_t_14 = NULL; - PyObject *__pyx_t_15 = NULL; - PyObject *__pyx_t_16 = NULL; - PyObject *__pyx_t_17 = NULL; - int __pyx_t_18; - Py_ssize_t __pyx_t_19; - PyObject *(*__pyx_t_20)(PyObject *); - int __pyx_t_21; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - __Pyx_RefNannySetupContext("energy_usage", 0); - - /* "epanet/epanet.py":122 - * - * def energy_usage(self) -> list[dict[str, Any]]: - * size = self.net_size()['pump'] # <<<<<<<<<<<<<< - * usages = [] - * category = ['utilization', 'avg.efficiency', 'avg.kW/flow', 'avg.kwatts', 'max.kwatts', 'cost/day' ] -*/ - __pyx_t_2 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_2); - __pyx_t_3 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_2, NULL}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_net_size, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 122, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_t_2 = __Pyx_PyObject_Dict_GetItem(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_pump); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 122, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __pyx_v_size = __pyx_t_2; - __pyx_t_2 = 0; - - /* "epanet/epanet.py":123 - * def energy_usage(self) -> list[dict[str, Any]]: - * size = self.net_size()['pump'] - * usages = [] # <<<<<<<<<<<<<< - * category = ['utilization', 'avg.efficiency', 'avg.kW/flow', 'avg.kwatts', 'max.kwatts', 'cost/day' ] - * links = self.element_name()['links'] -*/ - __pyx_t_2 = PyList_New(0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 123, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_v_usages = ((PyObject*)__pyx_t_2); - __pyx_t_2 = 0; - - /* "epanet/epanet.py":124 - * size = self.net_size()['pump'] - * usages = [] - * category = ['utilization', 'avg.efficiency', 'avg.kW/flow', 'avg.kwatts', 'max.kwatts', 'cost/day' ] # <<<<<<<<<<<<<< - * links = self.element_name()['links'] - * for i in range(1, size + 1): -*/ - __pyx_t_2 = PyList_New(6); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 124, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_utilization); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_utilization); - if (__Pyx_PyList_SET_ITEM(__pyx_t_2, 0, __pyx_mstate_global->__pyx_n_u_utilization) != (0)) __PYX_ERR(0, 124, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_kp_u_avg_efficiency); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_kp_u_avg_efficiency); - if (__Pyx_PyList_SET_ITEM(__pyx_t_2, 1, __pyx_mstate_global->__pyx_kp_u_avg_efficiency) != (0)) __PYX_ERR(0, 124, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_kp_u_avg_kW_flow); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_kp_u_avg_kW_flow); - if (__Pyx_PyList_SET_ITEM(__pyx_t_2, 2, __pyx_mstate_global->__pyx_kp_u_avg_kW_flow) != (0)) __PYX_ERR(0, 124, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_kp_u_avg_kwatts); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_kp_u_avg_kwatts); - if (__Pyx_PyList_SET_ITEM(__pyx_t_2, 3, __pyx_mstate_global->__pyx_kp_u_avg_kwatts) != (0)) __PYX_ERR(0, 124, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_kp_u_max_kwatts); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_kp_u_max_kwatts); - if (__Pyx_PyList_SET_ITEM(__pyx_t_2, 4, __pyx_mstate_global->__pyx_kp_u_max_kwatts) != (0)) __PYX_ERR(0, 124, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_kp_u_cost_day); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_kp_u_cost_day); - if (__Pyx_PyList_SET_ITEM(__pyx_t_2, 5, __pyx_mstate_global->__pyx_kp_u_cost_day) != (0)) __PYX_ERR(0, 124, __pyx_L1_error); - __pyx_v_category = ((PyObject*)__pyx_t_2); - __pyx_t_2 = 0; - - /* "epanet/epanet.py":125 - * usages = [] - * category = ['utilization', 'avg.efficiency', 'avg.kW/flow', 'avg.kwatts', 'max.kwatts', 'cost/day' ] - * links = self.element_name()['links'] # <<<<<<<<<<<<<< - * for i in range(1, size + 1): - * index = ctypes.c_int() -*/ - __pyx_t_1 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_1); - __pyx_t_3 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_1, NULL}; - __pyx_t_2 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_element_name, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 125, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - __pyx_t_1 = __Pyx_PyObject_Dict_GetItem(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_links); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 125, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __pyx_v_links = __pyx_t_1; - __pyx_t_1 = 0; - - /* "epanet/epanet.py":126 - * category = ['utilization', 'avg.efficiency', 'avg.kW/flow', 'avg.kwatts', 'max.kwatts', 'cost/day' ] - * links = self.element_name()['links'] - * for i in range(1, size + 1): # <<<<<<<<<<<<<< - * index = ctypes.c_int() - * values = ctypes.POINTER(ctypes.c_float)() -*/ - __pyx_t_2 = NULL; - __Pyx_INCREF(__pyx_builtin_range); - __pyx_t_4 = __pyx_builtin_range; - __pyx_t_5 = __Pyx_PyLong_AddObjC(__pyx_v_size, __pyx_mstate_global->__pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 126, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __pyx_t_3 = 1; - { - PyObject *__pyx_callargs[3] = {__pyx_t_2, __pyx_mstate_global->__pyx_int_1, __pyx_t_5}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_3, (3-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 126, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - if (likely(PyList_CheckExact(__pyx_t_1)) || PyTuple_CheckExact(__pyx_t_1)) { - __pyx_t_4 = __pyx_t_1; __Pyx_INCREF(__pyx_t_4); - __pyx_t_6 = 0; - __pyx_t_7 = NULL; - } else { - __pyx_t_6 = -1; __pyx_t_4 = PyObject_GetIter(__pyx_t_1); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 126, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __pyx_t_7 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_4); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 126, __pyx_L1_error) - } - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - for (;;) { - if (likely(!__pyx_t_7)) { - if (likely(PyList_CheckExact(__pyx_t_4))) { - { - Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_4); - #if !CYTHON_ASSUME_SAFE_SIZE - if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 126, __pyx_L1_error) - #endif - if (__pyx_t_6 >= __pyx_temp) break; - } - __pyx_t_1 = __Pyx_PyList_GetItemRef(__pyx_t_4, __pyx_t_6); - ++__pyx_t_6; - } else { - { - Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_4); - #if !CYTHON_ASSUME_SAFE_SIZE - if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 126, __pyx_L1_error) - #endif - if (__pyx_t_6 >= __pyx_temp) break; - } - #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS - __pyx_t_1 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_4, __pyx_t_6)); - #else - __pyx_t_1 = __Pyx_PySequence_ITEM(__pyx_t_4, __pyx_t_6); - #endif - ++__pyx_t_6; - } - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 126, __pyx_L1_error) - } else { - __pyx_t_1 = __pyx_t_7(__pyx_t_4); - if (unlikely(!__pyx_t_1)) { - PyObject* exc_type = PyErr_Occurred(); - if (exc_type) { - if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 126, __pyx_L1_error) - PyErr_Clear(); - } - break; - } - } - __Pyx_GOTREF(__pyx_t_1); - __Pyx_XDECREF_SET(__pyx_v_i, __pyx_t_1); - __pyx_t_1 = 0; - - /* "epanet/epanet.py":127 - * links = self.element_name()['links'] - * for i in range(1, size + 1): - * index = ctypes.c_int() # <<<<<<<<<<<<<< - * values = ctypes.POINTER(ctypes.c_float)() - * length = ctypes.c_int() -*/ - __pyx_t_5 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 127, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_t_8 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_c_int); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 127, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_8); - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_8))) { - __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_8); - assert(__pyx_t_5); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_8); - __Pyx_INCREF(__pyx_t_5); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_8, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_5, NULL}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_8, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 127, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __Pyx_XDECREF_SET(__pyx_v_index, __pyx_t_1); - __pyx_t_1 = 0; - - /* "epanet/epanet.py":128 - * for i in range(1, size + 1): - * index = ctypes.c_int() - * values = ctypes.POINTER(ctypes.c_float)() # <<<<<<<<<<<<<< - * length = ctypes.c_int() - * self._check(self._lib.ENR_getEnergyUsage(self._handle, ctypes.c_int(i), ctypes.byref(index), ctypes.byref(values), ctypes.byref(length))) -*/ - __pyx_t_8 = NULL; - __pyx_t_2 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 128, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_POINTER); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 128, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 128, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_c_float); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 128, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_10))) { - __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_10); - assert(__pyx_t_2); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_10); - __Pyx_INCREF(__pyx_t_2); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_10, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_t_11}; - __pyx_t_5 = __Pyx_PyObject_FastCall(__pyx_t_10, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 128, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - } - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_5))) { - __pyx_t_8 = PyMethod_GET_SELF(__pyx_t_5); - assert(__pyx_t_8); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_5); - __Pyx_INCREF(__pyx_t_8); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_5, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_8, NULL}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_5, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 128, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __Pyx_XDECREF_SET(__pyx_v_values, __pyx_t_1); - __pyx_t_1 = 0; - - /* "epanet/epanet.py":129 - * index = ctypes.c_int() - * values = ctypes.POINTER(ctypes.c_float)() - * length = ctypes.c_int() # <<<<<<<<<<<<<< - * self._check(self._lib.ENR_getEnergyUsage(self._handle, ctypes.c_int(i), ctypes.byref(index), ctypes.byref(values), ctypes.byref(length))) - * assert length.value == 6 -*/ - __pyx_t_5 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 129, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_8); - __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_t_8, __pyx_mstate_global->__pyx_n_u_c_int); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 129, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_10))) { - __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_10); - assert(__pyx_t_5); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_10); - __Pyx_INCREF(__pyx_t_5); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_10, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_5, NULL}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_10, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 129, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __Pyx_XDECREF_SET(__pyx_v_length, __pyx_t_1); - __pyx_t_1 = 0; - - /* "epanet/epanet.py":130 - * values = ctypes.POINTER(ctypes.c_float)() - * length = ctypes.c_int() - * self._check(self._lib.ENR_getEnergyUsage(self._handle, ctypes.c_int(i), ctypes.byref(index), ctypes.byref(values), ctypes.byref(length))) # <<<<<<<<<<<<<< - * assert length.value == 6 - * d = { 'pump' : links[index.value - 1] } -*/ - __pyx_t_10 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_10); - __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_lib); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 130, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __pyx_t_8 = __pyx_t_11; - __Pyx_INCREF(__pyx_t_8); - __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_handle); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 130, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_t_12 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_13, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 130, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_13); - __pyx_t_14 = __Pyx_PyObject_GetAttrStr(__pyx_t_13, __pyx_mstate_global->__pyx_n_u_c_int); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 130, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_14); - __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_14))) { - __pyx_t_12 = PyMethod_GET_SELF(__pyx_t_14); - assert(__pyx_t_12); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_14); - __Pyx_INCREF(__pyx_t_12); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_14, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_12, __pyx_v_i}; - __pyx_t_9 = __Pyx_PyObject_FastCall(__pyx_t_14, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0; - __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; - if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 130, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - } - __pyx_t_12 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_13, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 130, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_13); - __pyx_t_15 = __Pyx_PyObject_GetAttrStr(__pyx_t_13, __pyx_mstate_global->__pyx_n_u_byref); if (unlikely(!__pyx_t_15)) __PYX_ERR(0, 130, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_15); - __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_15))) { - __pyx_t_12 = PyMethod_GET_SELF(__pyx_t_15); - assert(__pyx_t_12); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_15); - __Pyx_INCREF(__pyx_t_12); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_15, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_12, __pyx_v_index}; - __pyx_t_14 = __Pyx_PyObject_FastCall(__pyx_t_15, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0; - __Pyx_DECREF(__pyx_t_15); __pyx_t_15 = 0; - if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 130, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_14); - } - __pyx_t_12 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_13, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 130, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_13); - __pyx_t_16 = __Pyx_PyObject_GetAttrStr(__pyx_t_13, __pyx_mstate_global->__pyx_n_u_byref); if (unlikely(!__pyx_t_16)) __PYX_ERR(0, 130, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_16); - __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_16))) { - __pyx_t_12 = PyMethod_GET_SELF(__pyx_t_16); - assert(__pyx_t_12); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_16); - __Pyx_INCREF(__pyx_t_12); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_16, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_12, __pyx_v_values}; - __pyx_t_15 = __Pyx_PyObject_FastCall(__pyx_t_16, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0; - __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0; - if (unlikely(!__pyx_t_15)) __PYX_ERR(0, 130, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_15); - } - __pyx_t_12 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_13, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 130, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_13); - __pyx_t_17 = __Pyx_PyObject_GetAttrStr(__pyx_t_13, __pyx_mstate_global->__pyx_n_u_byref); if (unlikely(!__pyx_t_17)) __PYX_ERR(0, 130, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_17); - __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_17))) { - __pyx_t_12 = PyMethod_GET_SELF(__pyx_t_17); - assert(__pyx_t_12); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_17); - __Pyx_INCREF(__pyx_t_12); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_17, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_12, __pyx_v_length}; - __pyx_t_16 = __Pyx_PyObject_FastCall(__pyx_t_17, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0; - __Pyx_DECREF(__pyx_t_17); __pyx_t_17 = 0; - if (unlikely(!__pyx_t_16)) __PYX_ERR(0, 130, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_16); - } - __pyx_t_3 = 0; - { - PyObject *__pyx_callargs[6] = {__pyx_t_8, __pyx_t_2, __pyx_t_9, __pyx_t_14, __pyx_t_15, __pyx_t_16}; - __pyx_t_5 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_ENR_getEnergyUsage, __pyx_callargs+__pyx_t_3, (6-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0; - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; - __Pyx_DECREF(__pyx_t_15); __pyx_t_15 = 0; - __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 130, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - } - __pyx_t_3 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_10, __pyx_t_5}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_check, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 130, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - - /* "epanet/epanet.py":131 - * length = ctypes.c_int() - * self._check(self._lib.ENR_getEnergyUsage(self._handle, ctypes.c_int(i), ctypes.byref(index), ctypes.byref(values), ctypes.byref(length))) - * assert length.value == 6 # <<<<<<<<<<<<<< - * d = { 'pump' : links[index.value - 1] } - * for j in range(length.value): -*/ - #ifndef CYTHON_WITHOUT_ASSERTIONS - if (unlikely(__pyx_assertions_enabled())) { - __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_length, __pyx_mstate_global->__pyx_n_u_value); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 131, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_t_18 = (__Pyx_PyLong_BoolEqObjC(__pyx_t_1, __pyx_mstate_global->__pyx_int_6, 6, 0)); if (unlikely((__pyx_t_18 < 0))) __PYX_ERR(0, 131, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - if (unlikely(!__pyx_t_18)) { - __Pyx_Raise(__pyx_builtin_AssertionError, 0, 0, 0); - __PYX_ERR(0, 131, __pyx_L1_error) - } - } - #else - if ((1)); else __PYX_ERR(0, 131, __pyx_L1_error) - #endif - - /* "epanet/epanet.py":132 - * self._check(self._lib.ENR_getEnergyUsage(self._handle, ctypes.c_int(i), ctypes.byref(index), ctypes.byref(values), ctypes.byref(length))) - * assert length.value == 6 - * d = { 'pump' : links[index.value - 1] } # <<<<<<<<<<<<<< - * for j in range(length.value): - * d |= { category[j] : values[j] } -*/ - __pyx_t_1 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 132, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_v_index, __pyx_mstate_global->__pyx_n_u_value); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 132, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __pyx_t_10 = __Pyx_PyLong_SubtractObjC(__pyx_t_5, __pyx_mstate_global->__pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 132, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - __pyx_t_5 = __Pyx_PyObject_GetItem(__pyx_v_links, __pyx_t_10); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 132, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - if (PyDict_SetItem(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_pump, __pyx_t_5) < 0) __PYX_ERR(0, 132, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_XDECREF_SET(__pyx_v_d, ((PyObject*)__pyx_t_1)); - __pyx_t_1 = 0; - - /* "epanet/epanet.py":133 - * assert length.value == 6 - * d = { 'pump' : links[index.value - 1] } - * for j in range(length.value): # <<<<<<<<<<<<<< - * d |= { category[j] : values[j] } - * usages.append(d) -*/ - __pyx_t_5 = NULL; - __Pyx_INCREF(__pyx_builtin_range); - __pyx_t_10 = __pyx_builtin_range; - __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_v_length, __pyx_mstate_global->__pyx_n_u_value); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 133, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __pyx_t_3 = 1; - { - PyObject *__pyx_callargs[2] = {__pyx_t_5, __pyx_t_11}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_10, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 133, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - if (likely(PyList_CheckExact(__pyx_t_1)) || PyTuple_CheckExact(__pyx_t_1)) { - __pyx_t_10 = __pyx_t_1; __Pyx_INCREF(__pyx_t_10); - __pyx_t_19 = 0; - __pyx_t_20 = NULL; - } else { - __pyx_t_19 = -1; __pyx_t_10 = PyObject_GetIter(__pyx_t_1); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 133, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - __pyx_t_20 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_10); if (unlikely(!__pyx_t_20)) __PYX_ERR(0, 133, __pyx_L1_error) - } - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - for (;;) { - if (likely(!__pyx_t_20)) { - if (likely(PyList_CheckExact(__pyx_t_10))) { - { - Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_10); - #if !CYTHON_ASSUME_SAFE_SIZE - if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 133, __pyx_L1_error) - #endif - if (__pyx_t_19 >= __pyx_temp) break; - } - __pyx_t_1 = __Pyx_PyList_GetItemRef(__pyx_t_10, __pyx_t_19); - ++__pyx_t_19; - } else { - { - Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_10); - #if !CYTHON_ASSUME_SAFE_SIZE - if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 133, __pyx_L1_error) - #endif - if (__pyx_t_19 >= __pyx_temp) break; - } - #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS - __pyx_t_1 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_10, __pyx_t_19)); - #else - __pyx_t_1 = __Pyx_PySequence_ITEM(__pyx_t_10, __pyx_t_19); - #endif - ++__pyx_t_19; - } - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 133, __pyx_L1_error) - } else { - __pyx_t_1 = __pyx_t_20(__pyx_t_10); - if (unlikely(!__pyx_t_1)) { - PyObject* exc_type = PyErr_Occurred(); - if (exc_type) { - if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 133, __pyx_L1_error) - PyErr_Clear(); - } - break; - } - } - __Pyx_GOTREF(__pyx_t_1); - __Pyx_XDECREF_SET(__pyx_v_j, __pyx_t_1); - __pyx_t_1 = 0; - - /* "epanet/epanet.py":134 - * d = { 'pump' : links[index.value - 1] } - * for j in range(length.value): - * d |= { category[j] : values[j] } # <<<<<<<<<<<<<< - * usages.append(d) - * self._lib.ENR_free(ctypes.byref(values)) -*/ - __pyx_t_1 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 134, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_t_11 = __Pyx_PyObject_GetItem(__pyx_v_category, __pyx_v_j); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 134, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __pyx_t_5 = __Pyx_PyObject_GetItem(__pyx_v_values, __pyx_v_j); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 134, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - if (PyDict_SetItem(__pyx_t_1, __pyx_t_11, __pyx_t_5) < 0) __PYX_ERR(0, 134, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - __pyx_t_5 = PyNumber_InPlaceOr(__pyx_v_d, __pyx_t_1); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 134, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __Pyx_DECREF_SET(__pyx_v_d, ((PyObject*)__pyx_t_5)); - __pyx_t_5 = 0; - - /* "epanet/epanet.py":133 - * assert length.value == 6 - * d = { 'pump' : links[index.value - 1] } - * for j in range(length.value): # <<<<<<<<<<<<<< - * d |= { category[j] : values[j] } - * usages.append(d) -*/ - } - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - - /* "epanet/epanet.py":135 - * for j in range(length.value): - * d |= { category[j] : values[j] } - * usages.append(d) # <<<<<<<<<<<<<< - * self._lib.ENR_free(ctypes.byref(values)) - * return usages -*/ - __pyx_t_21 = __Pyx_PyList_Append(__pyx_v_usages, __pyx_v_d); if (unlikely(__pyx_t_21 == ((int)-1))) __PYX_ERR(0, 135, __pyx_L1_error) - - /* "epanet/epanet.py":136 - * d |= { category[j] : values[j] } - * usages.append(d) - * self._lib.ENR_free(ctypes.byref(values)) # <<<<<<<<<<<<<< - * return usages - * -*/ - __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_lib); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 136, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_t_5 = __pyx_t_1; - __Pyx_INCREF(__pyx_t_5); - __pyx_t_16 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_15, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_15)) __PYX_ERR(0, 136, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_15); - __pyx_t_14 = __Pyx_PyObject_GetAttrStr(__pyx_t_15, __pyx_mstate_global->__pyx_n_u_byref); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 136, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_14); - __Pyx_DECREF(__pyx_t_15); __pyx_t_15 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_14))) { - __pyx_t_16 = PyMethod_GET_SELF(__pyx_t_14); - assert(__pyx_t_16); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_14); - __Pyx_INCREF(__pyx_t_16); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_14, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_16, __pyx_v_values}; - __pyx_t_11 = __Pyx_PyObject_FastCall(__pyx_t_14, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_16); __pyx_t_16 = 0; - __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; - if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 136, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - } - __pyx_t_3 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_5, __pyx_t_11}; - __pyx_t_10 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_ENR_free, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 136, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - } - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - - /* "epanet/epanet.py":126 - * category = ['utilization', 'avg.efficiency', 'avg.kW/flow', 'avg.kwatts', 'max.kwatts', 'cost/day' ] - * links = self.element_name()['links'] - * for i in range(1, size + 1): # <<<<<<<<<<<<<< - * index = ctypes.c_int() - * values = ctypes.POINTER(ctypes.c_float)() -*/ - } - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - - /* "epanet/epanet.py":137 - * usages.append(d) - * self._lib.ENR_free(ctypes.byref(values)) - * return usages # <<<<<<<<<<<<<< - * - * -*/ - __Pyx_XDECREF(__pyx_r); - __Pyx_INCREF(__pyx_v_usages); - __pyx_r = __pyx_v_usages; - goto __pyx_L0; - - /* "epanet/epanet.py":121 - * - * - * def energy_usage(self) -> list[dict[str, Any]]: # <<<<<<<<<<<<<< - * size = self.net_size()['pump'] - * usages = [] -*/ - - /* function exit code */ - __pyx_L1_error:; - __Pyx_XDECREF(__pyx_t_1); - __Pyx_XDECREF(__pyx_t_2); - __Pyx_XDECREF(__pyx_t_4); - __Pyx_XDECREF(__pyx_t_5); - __Pyx_XDECREF(__pyx_t_8); - __Pyx_XDECREF(__pyx_t_9); - __Pyx_XDECREF(__pyx_t_10); - __Pyx_XDECREF(__pyx_t_11); - __Pyx_XDECREF(__pyx_t_12); - __Pyx_XDECREF(__pyx_t_13); - __Pyx_XDECREF(__pyx_t_14); - __Pyx_XDECREF(__pyx_t_15); - __Pyx_XDECREF(__pyx_t_16); - __Pyx_XDECREF(__pyx_t_17); - __Pyx_AddTraceback("epanet.epanet.Output.energy_usage", __pyx_clineno, __pyx_lineno, __pyx_filename); - __pyx_r = NULL; - __pyx_L0:; - __Pyx_XDECREF(__pyx_v_size); - __Pyx_XDECREF(__pyx_v_usages); - __Pyx_XDECREF(__pyx_v_category); - __Pyx_XDECREF(__pyx_v_links); - __Pyx_XDECREF(__pyx_v_i); - __Pyx_XDECREF(__pyx_v_index); - __Pyx_XDECREF(__pyx_v_values); - __Pyx_XDECREF(__pyx_v_length); - __Pyx_XDECREF(__pyx_v_d); - __Pyx_XDECREF(__pyx_v_j); - __Pyx_XGIVEREF(__pyx_r); - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -/* "epanet/epanet.py":140 - * - * - * def reactions(self) -> dict[str, float]: # <<<<<<<<<<<<<< - * values = ctypes.POINTER(ctypes.c_float)() - * length = ctypes.c_int() -*/ - -/* Python wrapper */ -static PyObject *__pyx_pw_6epanet_6epanet_6Output_19reactions(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -); /*proto*/ -static PyMethodDef __pyx_mdef_6epanet_6epanet_6Output_19reactions = {"reactions", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6epanet_6epanet_6Output_19reactions, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}; -static PyObject *__pyx_pw_6epanet_6epanet_6Output_19reactions(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -) { - PyObject *__pyx_v_self = 0; - #if !CYTHON_METH_FASTCALL - CYTHON_UNUSED Py_ssize_t __pyx_nargs; - #endif - CYTHON_UNUSED PyObject *const *__pyx_kwvalues; - PyObject* values[1] = {0}; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - PyObject *__pyx_r = 0; - __Pyx_RefNannyDeclarations - __Pyx_RefNannySetupContext("reactions (wrapper)", 0); - #if !CYTHON_METH_FASTCALL - #if CYTHON_ASSUME_SAFE_SIZE - __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); - #else - __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; - #endif - #endif - __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); - { - PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_self,0}; - const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; - if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 140, __pyx_L3_error) - if (__pyx_kwds_len > 0) { - switch (__pyx_nargs) { - case 1: - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 140, __pyx_L3_error) - CYTHON_FALLTHROUGH; - case 0: break; - default: goto __pyx_L5_argtuple_error; - } - const Py_ssize_t kwd_pos_args = __pyx_nargs; - if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "reactions", 0) < 0) __PYX_ERR(0, 140, __pyx_L3_error) - for (Py_ssize_t i = __pyx_nargs; i < 1; i++) { - if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("reactions", 1, 1, 1, i); __PYX_ERR(0, 140, __pyx_L3_error) } - } - } else if (unlikely(__pyx_nargs != 1)) { - goto __pyx_L5_argtuple_error; - } else { - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 140, __pyx_L3_error) - } - __pyx_v_self = values[0]; - } - goto __pyx_L6_skip; - __pyx_L5_argtuple_error:; - __Pyx_RaiseArgtupleInvalid("reactions", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 140, __pyx_L3_error) - __pyx_L6_skip:; - goto __pyx_L4_argument_unpacking_done; - __pyx_L3_error:; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_AddTraceback("epanet.epanet.Output.reactions", __pyx_clineno, __pyx_lineno, __pyx_filename); - __Pyx_RefNannyFinishContext(); - return NULL; - __pyx_L4_argument_unpacking_done:; - __pyx_r = __pyx_pf_6epanet_6epanet_6Output_18reactions(__pyx_self, __pyx_v_self); - - /* function exit code */ - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -static PyObject *__pyx_pf_6epanet_6epanet_6Output_18reactions(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self) { - PyObject *__pyx_v_values = NULL; - PyObject *__pyx_v_length = NULL; - PyObject *__pyx_v_category = NULL; - PyObject *__pyx_v_d = NULL; - long __pyx_v_i; - PyObject *__pyx_r = NULL; - __Pyx_RefNannyDeclarations - PyObject *__pyx_t_1 = NULL; - PyObject *__pyx_t_2 = NULL; - PyObject *__pyx_t_3 = NULL; - PyObject *__pyx_t_4 = NULL; - PyObject *__pyx_t_5 = NULL; - PyObject *__pyx_t_6 = NULL; - PyObject *__pyx_t_7 = NULL; - size_t __pyx_t_8; - PyObject *__pyx_t_9 = NULL; - PyObject *__pyx_t_10 = NULL; - PyObject *__pyx_t_11 = NULL; - PyObject *__pyx_t_12 = NULL; - int __pyx_t_13; - long __pyx_t_14; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - __Pyx_RefNannySetupContext("reactions", 0); - - /* "epanet/epanet.py":141 - * - * def reactions(self) -> dict[str, float]: - * values = ctypes.POINTER(ctypes.c_float)() # <<<<<<<<<<<<<< - * length = ctypes.c_int() - * self._check(self._lib.ENR_getNetReacts(self._handle, ctypes.byref(values), ctypes.byref(length))) -*/ - __pyx_t_2 = NULL; - __pyx_t_4 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 141, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_POINTER); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 141, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 141, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_c_float); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 141, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_7); - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - __pyx_t_8 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_6))) { - __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_6); - assert(__pyx_t_4); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_6); - __Pyx_INCREF(__pyx_t_4); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_6, __pyx__function); - __pyx_t_8 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_t_7}; - __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_6, __pyx_callargs+__pyx_t_8, (2-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 141, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - } - __pyx_t_8 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_3))) { - __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_3); - assert(__pyx_t_2); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_3); - __Pyx_INCREF(__pyx_t_2); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_3, __pyx__function); - __pyx_t_8 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_2, NULL}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_3, __pyx_callargs+__pyx_t_8, (1-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 141, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_v_values = __pyx_t_1; - __pyx_t_1 = 0; - - /* "epanet/epanet.py":142 - * def reactions(self) -> dict[str, float]: - * values = ctypes.POINTER(ctypes.c_float)() - * length = ctypes.c_int() # <<<<<<<<<<<<<< - * self._check(self._lib.ENR_getNetReacts(self._handle, ctypes.byref(values), ctypes.byref(length))) - * assert length.value == 4 -*/ - __pyx_t_3 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 142, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_c_int); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 142, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __pyx_t_8 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_6))) { - __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_6); - assert(__pyx_t_3); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_6); - __Pyx_INCREF(__pyx_t_3); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_6, __pyx__function); - __pyx_t_8 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_6, __pyx_callargs+__pyx_t_8, (1-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 142, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_v_length = __pyx_t_1; - __pyx_t_1 = 0; - - /* "epanet/epanet.py":143 - * values = ctypes.POINTER(ctypes.c_float)() - * length = ctypes.c_int() - * self._check(self._lib.ENR_getNetReacts(self._handle, ctypes.byref(values), ctypes.byref(length))) # <<<<<<<<<<<<<< - * assert length.value == 4 - * category = ['bulk', 'wall', 'tank', 'source'] -*/ - __pyx_t_6 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_6); - __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_lib); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 143, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_7); - __pyx_t_2 = __pyx_t_7; - __Pyx_INCREF(__pyx_t_2); - __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_handle); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 143, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __pyx_t_9 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 143, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_byref); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 143, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - __pyx_t_8 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_11))) { - __pyx_t_9 = PyMethod_GET_SELF(__pyx_t_11); - assert(__pyx_t_9); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_11); - __Pyx_INCREF(__pyx_t_9); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_11, __pyx__function); - __pyx_t_8 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_9, __pyx_v_values}; - __pyx_t_5 = __Pyx_PyObject_FastCall(__pyx_t_11, __pyx_callargs+__pyx_t_8, (2-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 143, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - } - __pyx_t_9 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 143, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - __pyx_t_12 = __Pyx_PyObject_GetAttrStr(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_byref); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 143, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_12); - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - __pyx_t_8 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_12))) { - __pyx_t_9 = PyMethod_GET_SELF(__pyx_t_12); - assert(__pyx_t_9); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_12); - __Pyx_INCREF(__pyx_t_9); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_12, __pyx__function); - __pyx_t_8 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_9, __pyx_v_length}; - __pyx_t_11 = __Pyx_PyObject_FastCall(__pyx_t_12, __pyx_callargs+__pyx_t_8, (2-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0; - __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0; - if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 143, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - } - __pyx_t_8 = 0; - { - PyObject *__pyx_callargs[4] = {__pyx_t_2, __pyx_t_4, __pyx_t_5, __pyx_t_11}; - __pyx_t_3 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_ENR_getNetReacts, __pyx_callargs+__pyx_t_8, (4-__pyx_t_8) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; - if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 143, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - } - __pyx_t_8 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_t_3}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_check, __pyx_callargs+__pyx_t_8, (2-__pyx_t_8) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 143, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - - /* "epanet/epanet.py":144 - * length = ctypes.c_int() - * self._check(self._lib.ENR_getNetReacts(self._handle, ctypes.byref(values), ctypes.byref(length))) - * assert length.value == 4 # <<<<<<<<<<<<<< - * category = ['bulk', 'wall', 'tank', 'source'] - * d = {} -*/ - #ifndef CYTHON_WITHOUT_ASSERTIONS - if (unlikely(__pyx_assertions_enabled())) { - __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_length, __pyx_mstate_global->__pyx_n_u_value); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 144, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_t_13 = (__Pyx_PyLong_BoolEqObjC(__pyx_t_1, __pyx_mstate_global->__pyx_int_4, 4, 0)); if (unlikely((__pyx_t_13 < 0))) __PYX_ERR(0, 144, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - if (unlikely(!__pyx_t_13)) { - __Pyx_Raise(__pyx_builtin_AssertionError, 0, 0, 0); - __PYX_ERR(0, 144, __pyx_L1_error) - } - } - #else - if ((1)); else __PYX_ERR(0, 144, __pyx_L1_error) - #endif - - /* "epanet/epanet.py":145 - * self._check(self._lib.ENR_getNetReacts(self._handle, ctypes.byref(values), ctypes.byref(length))) - * assert length.value == 4 - * category = ['bulk', 'wall', 'tank', 'source'] # <<<<<<<<<<<<<< - * d = {} - * for i in range(4): -*/ - __pyx_t_1 = PyList_New(4); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 145, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_bulk); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_bulk); - if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 0, __pyx_mstate_global->__pyx_n_u_bulk) != (0)) __PYX_ERR(0, 145, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_wall); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_wall); - if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 1, __pyx_mstate_global->__pyx_n_u_wall) != (0)) __PYX_ERR(0, 145, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_tank); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_tank); - if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 2, __pyx_mstate_global->__pyx_n_u_tank) != (0)) __PYX_ERR(0, 145, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_source); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_source); - if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 3, __pyx_mstate_global->__pyx_n_u_source) != (0)) __PYX_ERR(0, 145, __pyx_L1_error); - __pyx_v_category = ((PyObject*)__pyx_t_1); - __pyx_t_1 = 0; - - /* "epanet/epanet.py":146 - * assert length.value == 4 - * category = ['bulk', 'wall', 'tank', 'source'] - * d = {} # <<<<<<<<<<<<<< - * for i in range(4): - * d[category[i]] = values[i] -*/ - __pyx_t_1 = __Pyx_PyDict_NewPresized(0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 146, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_v_d = ((PyObject*)__pyx_t_1); - __pyx_t_1 = 0; - - /* "epanet/epanet.py":147 - * category = ['bulk', 'wall', 'tank', 'source'] - * d = {} - * for i in range(4): # <<<<<<<<<<<<<< - * d[category[i]] = values[i] - * self._lib.ENR_free(ctypes.byref(values)) -*/ - for (__pyx_t_14 = 0; __pyx_t_14 < 4; __pyx_t_14+=1) { - __pyx_v_i = __pyx_t_14; - - /* "epanet/epanet.py":148 - * d = {} - * for i in range(4): - * d[category[i]] = values[i] # <<<<<<<<<<<<<< - * self._lib.ENR_free(ctypes.byref(values)) - * return d -*/ - __pyx_t_1 = __Pyx_GetItemInt(__pyx_v_values, __pyx_v_i, long, 1, __Pyx_PyLong_From_long, 0, 1, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 148, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_t_3 = __Pyx_GetItemInt_List(__pyx_v_category, __pyx_v_i, long, 1, __Pyx_PyLong_From_long, 1, 1, 1); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 148, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - if (unlikely((PyDict_SetItem(__pyx_v_d, __pyx_t_3, __pyx_t_1) < 0))) __PYX_ERR(0, 148, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - } - - /* "epanet/epanet.py":149 - * for i in range(4): - * d[category[i]] = values[i] - * self._lib.ENR_free(ctypes.byref(values)) # <<<<<<<<<<<<<< - * return d - * -*/ - __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_lib); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 149, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __pyx_t_3 = __pyx_t_6; - __Pyx_INCREF(__pyx_t_3); - __pyx_t_11 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 149, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_byref); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 149, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - __pyx_t_8 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_4))) { - __pyx_t_11 = PyMethod_GET_SELF(__pyx_t_4); - assert(__pyx_t_11); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); - __Pyx_INCREF(__pyx_t_11); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); - __pyx_t_8 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_11, __pyx_v_values}; - __pyx_t_7 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_8, (2-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 149, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_7); - } - __pyx_t_8 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_t_7}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_ENR_free, __pyx_callargs+__pyx_t_8, (2-__pyx_t_8) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 149, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - - /* "epanet/epanet.py":150 - * d[category[i]] = values[i] - * self._lib.ENR_free(ctypes.byref(values)) - * return d # <<<<<<<<<<<<<< - * - * -*/ - __Pyx_XDECREF(__pyx_r); - __Pyx_INCREF(__pyx_v_d); - __pyx_r = __pyx_v_d; - goto __pyx_L0; - - /* "epanet/epanet.py":140 - * - * - * def reactions(self) -> dict[str, float]: # <<<<<<<<<<<<<< - * values = ctypes.POINTER(ctypes.c_float)() - * length = ctypes.c_int() -*/ - - /* function exit code */ - __pyx_L1_error:; - __Pyx_XDECREF(__pyx_t_1); - __Pyx_XDECREF(__pyx_t_2); - __Pyx_XDECREF(__pyx_t_3); - __Pyx_XDECREF(__pyx_t_4); - __Pyx_XDECREF(__pyx_t_5); - __Pyx_XDECREF(__pyx_t_6); - __Pyx_XDECREF(__pyx_t_7); - __Pyx_XDECREF(__pyx_t_9); - __Pyx_XDECREF(__pyx_t_10); - __Pyx_XDECREF(__pyx_t_11); - __Pyx_XDECREF(__pyx_t_12); - __Pyx_AddTraceback("epanet.epanet.Output.reactions", __pyx_clineno, __pyx_lineno, __pyx_filename); - __pyx_r = NULL; - __pyx_L0:; - __Pyx_XDECREF(__pyx_v_values); - __Pyx_XDECREF(__pyx_v_length); - __Pyx_XDECREF(__pyx_v_category); - __Pyx_XDECREF(__pyx_v_d); - __Pyx_XGIVEREF(__pyx_r); - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -/* "epanet/epanet.py":153 - * - * - * def node_results(self) -> list[dict[str, Any]]: # <<<<<<<<<<<<<< - * size = self.net_size()['node'] - * num_periods = self.times()['num_periods'] -*/ - -/* Python wrapper */ -static PyObject *__pyx_pw_6epanet_6epanet_6Output_21node_results(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -); /*proto*/ -static PyMethodDef __pyx_mdef_6epanet_6epanet_6Output_21node_results = {"node_results", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6epanet_6epanet_6Output_21node_results, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}; -static PyObject *__pyx_pw_6epanet_6epanet_6Output_21node_results(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -) { - PyObject *__pyx_v_self = 0; - #if !CYTHON_METH_FASTCALL - CYTHON_UNUSED Py_ssize_t __pyx_nargs; - #endif - CYTHON_UNUSED PyObject *const *__pyx_kwvalues; - PyObject* values[1] = {0}; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - PyObject *__pyx_r = 0; - __Pyx_RefNannyDeclarations - __Pyx_RefNannySetupContext("node_results (wrapper)", 0); - #if !CYTHON_METH_FASTCALL - #if CYTHON_ASSUME_SAFE_SIZE - __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); - #else - __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; - #endif - #endif - __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); - { - PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_self,0}; - const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; - if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 153, __pyx_L3_error) - if (__pyx_kwds_len > 0) { - switch (__pyx_nargs) { - case 1: - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 153, __pyx_L3_error) - CYTHON_FALLTHROUGH; - case 0: break; - default: goto __pyx_L5_argtuple_error; - } - const Py_ssize_t kwd_pos_args = __pyx_nargs; - if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "node_results", 0) < 0) __PYX_ERR(0, 153, __pyx_L3_error) - for (Py_ssize_t i = __pyx_nargs; i < 1; i++) { - if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("node_results", 1, 1, 1, i); __PYX_ERR(0, 153, __pyx_L3_error) } - } - } else if (unlikely(__pyx_nargs != 1)) { - goto __pyx_L5_argtuple_error; - } else { - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 153, __pyx_L3_error) - } - __pyx_v_self = values[0]; - } - goto __pyx_L6_skip; - __pyx_L5_argtuple_error:; - __Pyx_RaiseArgtupleInvalid("node_results", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 153, __pyx_L3_error) - __pyx_L6_skip:; - goto __pyx_L4_argument_unpacking_done; - __pyx_L3_error:; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_AddTraceback("epanet.epanet.Output.node_results", __pyx_clineno, __pyx_lineno, __pyx_filename); - __Pyx_RefNannyFinishContext(); - return NULL; - __pyx_L4_argument_unpacking_done:; - __pyx_r = __pyx_pf_6epanet_6epanet_6Output_20node_results(__pyx_self, __pyx_v_self); - - /* function exit code */ - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -static PyObject *__pyx_pf_6epanet_6epanet_6Output_20node_results(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self) { - PyObject *__pyx_v_size = NULL; - PyObject *__pyx_v_num_periods = NULL; - PyObject *__pyx_v_nodes = NULL; - PyObject *__pyx_v_category = NULL; - PyObject *__pyx_v_ds = NULL; - PyObject *__pyx_v_i = NULL; - PyObject *__pyx_v_d = NULL; - PyObject *__pyx_v_j = NULL; - PyObject *__pyx_v_values = NULL; - PyObject *__pyx_v_length = NULL; - PyObject *__pyx_v_attributes = NULL; - PyObject *__pyx_v_k = NULL; - PyObject *__pyx_r = NULL; - __Pyx_RefNannyDeclarations - PyObject *__pyx_t_1 = NULL; - PyObject *__pyx_t_2 = NULL; - size_t __pyx_t_3; - PyObject *__pyx_t_4 = NULL; - PyObject *__pyx_t_5 = NULL; - Py_ssize_t __pyx_t_6; - PyObject *(*__pyx_t_7)(PyObject *); - Py_ssize_t __pyx_t_8; - PyObject *(*__pyx_t_9)(PyObject *); - PyObject *__pyx_t_10 = NULL; - PyObject *__pyx_t_11 = NULL; - PyObject *__pyx_t_12 = NULL; - PyObject *__pyx_t_13 = NULL; - PyObject *__pyx_t_14 = NULL; - PyObject *__pyx_t_15 = NULL; - PyObject *__pyx_t_16 = NULL; - PyObject *__pyx_t_17 = NULL; - PyObject *__pyx_t_18 = NULL; - Py_ssize_t __pyx_t_19; - int __pyx_t_20; - PyObject *(*__pyx_t_21)(PyObject *); - int __pyx_t_22; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - __Pyx_RefNannySetupContext("node_results", 0); - - /* "epanet/epanet.py":154 - * - * def node_results(self) -> list[dict[str, Any]]: - * size = self.net_size()['node'] # <<<<<<<<<<<<<< - * num_periods = self.times()['num_periods'] - * nodes = self.element_name()['nodes'] -*/ - __pyx_t_2 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_2); - __pyx_t_3 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_2, NULL}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_net_size, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 154, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_t_2 = __Pyx_PyObject_Dict_GetItem(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_node); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 154, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __pyx_v_size = __pyx_t_2; - __pyx_t_2 = 0; - - /* "epanet/epanet.py":155 - * def node_results(self) -> list[dict[str, Any]]: - * size = self.net_size()['node'] - * num_periods = self.times()['num_periods'] # <<<<<<<<<<<<<< - * nodes = self.element_name()['nodes'] - * category = ['demand', 'head', 'pressure', 'quality'] -*/ - __pyx_t_1 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_1); - __pyx_t_3 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_1, NULL}; - __pyx_t_2 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_times, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 155, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - __pyx_t_1 = __Pyx_PyObject_Dict_GetItem(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_num_periods); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 155, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __pyx_v_num_periods = __pyx_t_1; - __pyx_t_1 = 0; - - /* "epanet/epanet.py":156 - * size = self.net_size()['node'] - * num_periods = self.times()['num_periods'] - * nodes = self.element_name()['nodes'] # <<<<<<<<<<<<<< - * category = ['demand', 'head', 'pressure', 'quality'] - * ds = [] -*/ - __pyx_t_2 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_2); - __pyx_t_3 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_2, NULL}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_element_name, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 156, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_t_2 = __Pyx_PyObject_Dict_GetItem(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_nodes); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 156, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __pyx_v_nodes = __pyx_t_2; - __pyx_t_2 = 0; - - /* "epanet/epanet.py":157 - * num_periods = self.times()['num_periods'] - * nodes = self.element_name()['nodes'] - * category = ['demand', 'head', 'pressure', 'quality'] # <<<<<<<<<<<<<< - * ds = [] - * for i in range(1, size + 1): -*/ - __pyx_t_2 = PyList_New(4); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 157, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_demand); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_demand); - if (__Pyx_PyList_SET_ITEM(__pyx_t_2, 0, __pyx_mstate_global->__pyx_n_u_demand) != (0)) __PYX_ERR(0, 157, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_head); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_head); - if (__Pyx_PyList_SET_ITEM(__pyx_t_2, 1, __pyx_mstate_global->__pyx_n_u_head) != (0)) __PYX_ERR(0, 157, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_pressure); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_pressure); - if (__Pyx_PyList_SET_ITEM(__pyx_t_2, 2, __pyx_mstate_global->__pyx_n_u_pressure) != (0)) __PYX_ERR(0, 157, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_quality); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_quality); - if (__Pyx_PyList_SET_ITEM(__pyx_t_2, 3, __pyx_mstate_global->__pyx_n_u_quality) != (0)) __PYX_ERR(0, 157, __pyx_L1_error); - __pyx_v_category = ((PyObject*)__pyx_t_2); - __pyx_t_2 = 0; - - /* "epanet/epanet.py":158 - * nodes = self.element_name()['nodes'] - * category = ['demand', 'head', 'pressure', 'quality'] - * ds = [] # <<<<<<<<<<<<<< - * for i in range(1, size + 1): - * d = { 'node' : nodes[i - 1], 'result' : [] } -*/ - __pyx_t_2 = PyList_New(0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 158, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_v_ds = ((PyObject*)__pyx_t_2); - __pyx_t_2 = 0; - - /* "epanet/epanet.py":159 - * category = ['demand', 'head', 'pressure', 'quality'] - * ds = [] - * for i in range(1, size + 1): # <<<<<<<<<<<<<< - * d = { 'node' : nodes[i - 1], 'result' : [] } - * for j in range(num_periods): -*/ - __pyx_t_1 = NULL; - __Pyx_INCREF(__pyx_builtin_range); - __pyx_t_4 = __pyx_builtin_range; - __pyx_t_5 = __Pyx_PyLong_AddObjC(__pyx_v_size, __pyx_mstate_global->__pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 159, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __pyx_t_3 = 1; - { - PyObject *__pyx_callargs[3] = {__pyx_t_1, __pyx_mstate_global->__pyx_int_1, __pyx_t_5}; - __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_3, (3-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 159, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - if (likely(PyList_CheckExact(__pyx_t_2)) || PyTuple_CheckExact(__pyx_t_2)) { - __pyx_t_4 = __pyx_t_2; __Pyx_INCREF(__pyx_t_4); - __pyx_t_6 = 0; - __pyx_t_7 = NULL; - } else { - __pyx_t_6 = -1; __pyx_t_4 = PyObject_GetIter(__pyx_t_2); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 159, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __pyx_t_7 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_4); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 159, __pyx_L1_error) - } - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - for (;;) { - if (likely(!__pyx_t_7)) { - if (likely(PyList_CheckExact(__pyx_t_4))) { - { - Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_4); - #if !CYTHON_ASSUME_SAFE_SIZE - if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 159, __pyx_L1_error) - #endif - if (__pyx_t_6 >= __pyx_temp) break; - } - __pyx_t_2 = __Pyx_PyList_GetItemRef(__pyx_t_4, __pyx_t_6); - ++__pyx_t_6; - } else { - { - Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_4); - #if !CYTHON_ASSUME_SAFE_SIZE - if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 159, __pyx_L1_error) - #endif - if (__pyx_t_6 >= __pyx_temp) break; - } - #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS - __pyx_t_2 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_4, __pyx_t_6)); - #else - __pyx_t_2 = __Pyx_PySequence_ITEM(__pyx_t_4, __pyx_t_6); - #endif - ++__pyx_t_6; - } - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 159, __pyx_L1_error) - } else { - __pyx_t_2 = __pyx_t_7(__pyx_t_4); - if (unlikely(!__pyx_t_2)) { - PyObject* exc_type = PyErr_Occurred(); - if (exc_type) { - if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 159, __pyx_L1_error) - PyErr_Clear(); - } - break; - } - } - __Pyx_GOTREF(__pyx_t_2); - __Pyx_XDECREF_SET(__pyx_v_i, __pyx_t_2); - __pyx_t_2 = 0; - - /* "epanet/epanet.py":160 - * ds = [] - * for i in range(1, size + 1): - * d = { 'node' : nodes[i - 1], 'result' : [] } # <<<<<<<<<<<<<< - * for j in range(num_periods): - * values = ctypes.POINTER(ctypes.c_float)() -*/ - __pyx_t_2 = __Pyx_PyDict_NewPresized(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 160, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_t_5 = __Pyx_PyLong_SubtractObjC(__pyx_v_i, __pyx_mstate_global->__pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 160, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __pyx_t_1 = __Pyx_PyObject_GetItem(__pyx_v_nodes, __pyx_t_5); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 160, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - if (PyDict_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_node, __pyx_t_1) < 0) __PYX_ERR(0, 160, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __pyx_t_1 = PyList_New(0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 160, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - if (PyDict_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_result, __pyx_t_1) < 0) __PYX_ERR(0, 160, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __Pyx_XDECREF_SET(__pyx_v_d, ((PyObject*)__pyx_t_2)); - __pyx_t_2 = 0; - - /* "epanet/epanet.py":161 - * for i in range(1, size + 1): - * d = { 'node' : nodes[i - 1], 'result' : [] } - * for j in range(num_periods): # <<<<<<<<<<<<<< - * values = ctypes.POINTER(ctypes.c_float)() - * length = ctypes.c_int() -*/ - __pyx_t_1 = NULL; - __Pyx_INCREF(__pyx_builtin_range); - __pyx_t_5 = __pyx_builtin_range; - __pyx_t_3 = 1; - { - PyObject *__pyx_callargs[2] = {__pyx_t_1, __pyx_v_num_periods}; - __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_5, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 161, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - if (likely(PyList_CheckExact(__pyx_t_2)) || PyTuple_CheckExact(__pyx_t_2)) { - __pyx_t_5 = __pyx_t_2; __Pyx_INCREF(__pyx_t_5); - __pyx_t_8 = 0; - __pyx_t_9 = NULL; - } else { - __pyx_t_8 = -1; __pyx_t_5 = PyObject_GetIter(__pyx_t_2); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 161, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __pyx_t_9 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_5); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 161, __pyx_L1_error) - } - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - for (;;) { - if (likely(!__pyx_t_9)) { - if (likely(PyList_CheckExact(__pyx_t_5))) { - { - Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_5); - #if !CYTHON_ASSUME_SAFE_SIZE - if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 161, __pyx_L1_error) - #endif - if (__pyx_t_8 >= __pyx_temp) break; - } - __pyx_t_2 = __Pyx_PyList_GetItemRef(__pyx_t_5, __pyx_t_8); - ++__pyx_t_8; - } else { - { - Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_5); - #if !CYTHON_ASSUME_SAFE_SIZE - if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 161, __pyx_L1_error) - #endif - if (__pyx_t_8 >= __pyx_temp) break; - } - #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS - __pyx_t_2 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_5, __pyx_t_8)); - #else - __pyx_t_2 = __Pyx_PySequence_ITEM(__pyx_t_5, __pyx_t_8); - #endif - ++__pyx_t_8; - } - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 161, __pyx_L1_error) - } else { - __pyx_t_2 = __pyx_t_9(__pyx_t_5); - if (unlikely(!__pyx_t_2)) { - PyObject* exc_type = PyErr_Occurred(); - if (exc_type) { - if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 161, __pyx_L1_error) - PyErr_Clear(); - } - break; - } - } - __Pyx_GOTREF(__pyx_t_2); - __Pyx_XDECREF_SET(__pyx_v_j, __pyx_t_2); - __pyx_t_2 = 0; - - /* "epanet/epanet.py":162 - * d = { 'node' : nodes[i - 1], 'result' : [] } - * for j in range(num_periods): - * values = ctypes.POINTER(ctypes.c_float)() # <<<<<<<<<<<<<< - * length = ctypes.c_int() - * self._check(self._lib.ENR_getNodeResult(self._handle, j, i, ctypes.byref(values), ctypes.byref(length))) -*/ - __pyx_t_1 = NULL; - __pyx_t_11 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_12, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 162, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_12); - __pyx_t_13 = __Pyx_PyObject_GetAttrStr(__pyx_t_12, __pyx_mstate_global->__pyx_n_u_POINTER); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 162, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_13); - __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0; - __Pyx_GetModuleGlobalName(__pyx_t_12, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 162, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_12); - __pyx_t_14 = __Pyx_PyObject_GetAttrStr(__pyx_t_12, __pyx_mstate_global->__pyx_n_u_c_float); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 162, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_14); - __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_13))) { - __pyx_t_11 = PyMethod_GET_SELF(__pyx_t_13); - assert(__pyx_t_11); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_13); - __Pyx_INCREF(__pyx_t_11); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_13, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_11, __pyx_t_14}; - __pyx_t_10 = __Pyx_PyObject_FastCall(__pyx_t_13, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; - __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; - __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0; - if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 162, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - } - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_10))) { - __pyx_t_1 = PyMethod_GET_SELF(__pyx_t_10); - assert(__pyx_t_1); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_10); - __Pyx_INCREF(__pyx_t_1); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_10, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_1, NULL}; - __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_10, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0; - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 162, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - __Pyx_XDECREF_SET(__pyx_v_values, __pyx_t_2); - __pyx_t_2 = 0; - - /* "epanet/epanet.py":163 - * for j in range(num_periods): - * values = ctypes.POINTER(ctypes.c_float)() - * length = ctypes.c_int() # <<<<<<<<<<<<<< - * self._check(self._lib.ENR_getNodeResult(self._handle, j, i, ctypes.byref(values), ctypes.byref(length))) - * assert length.value == len(category) -*/ - __pyx_t_10 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 163, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_t_13 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_c_int); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 163, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_13); - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_13))) { - __pyx_t_10 = PyMethod_GET_SELF(__pyx_t_13); - assert(__pyx_t_10); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_13); - __Pyx_INCREF(__pyx_t_10); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_13, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_10, NULL}; - __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_13, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0; - __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 163, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - __Pyx_XDECREF_SET(__pyx_v_length, __pyx_t_2); - __pyx_t_2 = 0; - - /* "epanet/epanet.py":164 - * values = ctypes.POINTER(ctypes.c_float)() - * length = ctypes.c_int() - * self._check(self._lib.ENR_getNodeResult(self._handle, j, i, ctypes.byref(values), ctypes.byref(length))) # <<<<<<<<<<<<<< - * assert length.value == len(category) - * attributes = {} -*/ - __pyx_t_13 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_13); - __pyx_t_14 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_lib); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 164, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_14); - __pyx_t_1 = __pyx_t_14; - __Pyx_INCREF(__pyx_t_1); - __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_handle); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 164, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __pyx_t_15 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_16, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_16)) __PYX_ERR(0, 164, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_16); - __pyx_t_17 = __Pyx_PyObject_GetAttrStr(__pyx_t_16, __pyx_mstate_global->__pyx_n_u_byref); if (unlikely(!__pyx_t_17)) __PYX_ERR(0, 164, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_17); - __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_17))) { - __pyx_t_15 = PyMethod_GET_SELF(__pyx_t_17); - assert(__pyx_t_15); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_17); - __Pyx_INCREF(__pyx_t_15); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_17, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_15, __pyx_v_values}; - __pyx_t_12 = __Pyx_PyObject_FastCall(__pyx_t_17, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_15); __pyx_t_15 = 0; - __Pyx_DECREF(__pyx_t_17); __pyx_t_17 = 0; - if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 164, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_12); - } - __pyx_t_15 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_16, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_16)) __PYX_ERR(0, 164, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_16); - __pyx_t_18 = __Pyx_PyObject_GetAttrStr(__pyx_t_16, __pyx_mstate_global->__pyx_n_u_byref); if (unlikely(!__pyx_t_18)) __PYX_ERR(0, 164, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_18); - __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_18))) { - __pyx_t_15 = PyMethod_GET_SELF(__pyx_t_18); - assert(__pyx_t_15); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_18); - __Pyx_INCREF(__pyx_t_15); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_18, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_15, __pyx_v_length}; - __pyx_t_17 = __Pyx_PyObject_FastCall(__pyx_t_18, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_15); __pyx_t_15 = 0; - __Pyx_DECREF(__pyx_t_18); __pyx_t_18 = 0; - if (unlikely(!__pyx_t_17)) __PYX_ERR(0, 164, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_17); - } - __pyx_t_3 = 0; - { - PyObject *__pyx_callargs[6] = {__pyx_t_1, __pyx_t_11, __pyx_v_j, __pyx_v_i, __pyx_t_12, __pyx_t_17}; - __pyx_t_10 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_ENR_getNodeResult, __pyx_callargs+__pyx_t_3, (6-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0; - __Pyx_DECREF(__pyx_t_17); __pyx_t_17 = 0; - __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; - if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 164, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - } - __pyx_t_3 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_13, __pyx_t_10}; - __pyx_t_2 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_check, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_13); __pyx_t_13 = 0; - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 164, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet.py":165 - * length = ctypes.c_int() - * self._check(self._lib.ENR_getNodeResult(self._handle, j, i, ctypes.byref(values), ctypes.byref(length))) - * assert length.value == len(category) # <<<<<<<<<<<<<< - * attributes = {} - * for k in range(length.value): -*/ - #ifndef CYTHON_WITHOUT_ASSERTIONS - if (unlikely(__pyx_assertions_enabled())) { - __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_length, __pyx_mstate_global->__pyx_n_u_value); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 165, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_t_19 = __Pyx_PyList_GET_SIZE(__pyx_v_category); if (unlikely(__pyx_t_19 == ((Py_ssize_t)-1))) __PYX_ERR(0, 165, __pyx_L1_error) - __pyx_t_10 = PyLong_FromSsize_t(__pyx_t_19); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 165, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - __pyx_t_13 = PyObject_RichCompare(__pyx_t_2, __pyx_t_10, Py_EQ); __Pyx_XGOTREF(__pyx_t_13); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 165, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - __pyx_t_20 = __Pyx_PyObject_IsTrue(__pyx_t_13); if (unlikely((__pyx_t_20 < 0))) __PYX_ERR(0, 165, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0; - if (unlikely(!__pyx_t_20)) { - __Pyx_Raise(__pyx_builtin_AssertionError, 0, 0, 0); - __PYX_ERR(0, 165, __pyx_L1_error) - } - } - #else - if ((1)); else __PYX_ERR(0, 165, __pyx_L1_error) - #endif - - /* "epanet/epanet.py":166 - * self._check(self._lib.ENR_getNodeResult(self._handle, j, i, ctypes.byref(values), ctypes.byref(length))) - * assert length.value == len(category) - * attributes = {} # <<<<<<<<<<<<<< - * for k in range(length.value): - * attributes[category[k]] = values[k] -*/ - __pyx_t_13 = __Pyx_PyDict_NewPresized(0); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 166, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_13); - __Pyx_XDECREF_SET(__pyx_v_attributes, ((PyObject*)__pyx_t_13)); - __pyx_t_13 = 0; - - /* "epanet/epanet.py":167 - * assert length.value == len(category) - * attributes = {} - * for k in range(length.value): # <<<<<<<<<<<<<< - * attributes[category[k]] = values[k] - * d['result'].append(attributes) -*/ - __pyx_t_10 = NULL; - __Pyx_INCREF(__pyx_builtin_range); - __pyx_t_2 = __pyx_builtin_range; - __pyx_t_14 = __Pyx_PyObject_GetAttrStr(__pyx_v_length, __pyx_mstate_global->__pyx_n_u_value); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 167, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_14); - __pyx_t_3 = 1; - { - PyObject *__pyx_callargs[2] = {__pyx_t_10, __pyx_t_14}; - __pyx_t_13 = __Pyx_PyObject_FastCall(__pyx_t_2, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0; - __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 167, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_13); - } - if (likely(PyList_CheckExact(__pyx_t_13)) || PyTuple_CheckExact(__pyx_t_13)) { - __pyx_t_2 = __pyx_t_13; __Pyx_INCREF(__pyx_t_2); - __pyx_t_19 = 0; - __pyx_t_21 = NULL; - } else { - __pyx_t_19 = -1; __pyx_t_2 = PyObject_GetIter(__pyx_t_13); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 167, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_t_21 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_2); if (unlikely(!__pyx_t_21)) __PYX_ERR(0, 167, __pyx_L1_error) - } - __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0; - for (;;) { - if (likely(!__pyx_t_21)) { - if (likely(PyList_CheckExact(__pyx_t_2))) { - { - Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_2); - #if !CYTHON_ASSUME_SAFE_SIZE - if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 167, __pyx_L1_error) - #endif - if (__pyx_t_19 >= __pyx_temp) break; - } - __pyx_t_13 = __Pyx_PyList_GetItemRef(__pyx_t_2, __pyx_t_19); - ++__pyx_t_19; - } else { - { - Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_2); - #if !CYTHON_ASSUME_SAFE_SIZE - if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 167, __pyx_L1_error) - #endif - if (__pyx_t_19 >= __pyx_temp) break; - } - #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS - __pyx_t_13 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_2, __pyx_t_19)); - #else - __pyx_t_13 = __Pyx_PySequence_ITEM(__pyx_t_2, __pyx_t_19); - #endif - ++__pyx_t_19; - } - if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 167, __pyx_L1_error) - } else { - __pyx_t_13 = __pyx_t_21(__pyx_t_2); - if (unlikely(!__pyx_t_13)) { - PyObject* exc_type = PyErr_Occurred(); - if (exc_type) { - if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 167, __pyx_L1_error) - PyErr_Clear(); - } - break; - } - } - __Pyx_GOTREF(__pyx_t_13); - __Pyx_XDECREF_SET(__pyx_v_k, __pyx_t_13); - __pyx_t_13 = 0; - - /* "epanet/epanet.py":168 - * attributes = {} - * for k in range(length.value): - * attributes[category[k]] = values[k] # <<<<<<<<<<<<<< - * d['result'].append(attributes) - * self._lib.ENR_free(ctypes.byref(values)) -*/ - __pyx_t_13 = __Pyx_PyObject_GetItem(__pyx_v_values, __pyx_v_k); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 168, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_13); - __pyx_t_14 = __Pyx_PyObject_GetItem(__pyx_v_category, __pyx_v_k); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 168, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_14); - if (unlikely((PyDict_SetItem(__pyx_v_attributes, __pyx_t_14, __pyx_t_13) < 0))) __PYX_ERR(0, 168, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; - __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0; - - /* "epanet/epanet.py":167 - * assert length.value == len(category) - * attributes = {} - * for k in range(length.value): # <<<<<<<<<<<<<< - * attributes[category[k]] = values[k] - * d['result'].append(attributes) -*/ - } - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet.py":169 - * for k in range(length.value): - * attributes[category[k]] = values[k] - * d['result'].append(attributes) # <<<<<<<<<<<<<< - * self._lib.ENR_free(ctypes.byref(values)) - * ds.append(d) -*/ - __pyx_t_2 = __Pyx_PyDict_GetItem(__pyx_v_d, __pyx_mstate_global->__pyx_n_u_result); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 169, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_t_22 = __Pyx_PyObject_Append(__pyx_t_2, __pyx_v_attributes); if (unlikely(__pyx_t_22 == ((int)-1))) __PYX_ERR(0, 169, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet.py":170 - * attributes[category[k]] = values[k] - * d['result'].append(attributes) - * self._lib.ENR_free(ctypes.byref(values)) # <<<<<<<<<<<<<< - * ds.append(d) - * return ds -*/ - __pyx_t_14 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_lib); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 170, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_14); - __pyx_t_13 = __pyx_t_14; - __Pyx_INCREF(__pyx_t_13); - __pyx_t_17 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_12, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 170, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_12); - __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_t_12, __pyx_mstate_global->__pyx_n_u_byref); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 170, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_11))) { - __pyx_t_17 = PyMethod_GET_SELF(__pyx_t_11); - assert(__pyx_t_17); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_11); - __Pyx_INCREF(__pyx_t_17); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_11, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_17, __pyx_v_values}; - __pyx_t_10 = __Pyx_PyObject_FastCall(__pyx_t_11, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_17); __pyx_t_17 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 170, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - } - __pyx_t_3 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_13, __pyx_t_10}; - __pyx_t_2 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_ENR_free, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_13); __pyx_t_13 = 0; - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 170, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet.py":161 - * for i in range(1, size + 1): - * d = { 'node' : nodes[i - 1], 'result' : [] } - * for j in range(num_periods): # <<<<<<<<<<<<<< - * values = ctypes.POINTER(ctypes.c_float)() - * length = ctypes.c_int() -*/ - } - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - - /* "epanet/epanet.py":171 - * d['result'].append(attributes) - * self._lib.ENR_free(ctypes.byref(values)) - * ds.append(d) # <<<<<<<<<<<<<< - * return ds - * -*/ - __pyx_t_22 = __Pyx_PyList_Append(__pyx_v_ds, __pyx_v_d); if (unlikely(__pyx_t_22 == ((int)-1))) __PYX_ERR(0, 171, __pyx_L1_error) - - /* "epanet/epanet.py":159 - * category = ['demand', 'head', 'pressure', 'quality'] - * ds = [] - * for i in range(1, size + 1): # <<<<<<<<<<<<<< - * d = { 'node' : nodes[i - 1], 'result' : [] } - * for j in range(num_periods): -*/ - } - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - - /* "epanet/epanet.py":172 - * self._lib.ENR_free(ctypes.byref(values)) - * ds.append(d) - * return ds # <<<<<<<<<<<<<< - * - * -*/ - __Pyx_XDECREF(__pyx_r); - __Pyx_INCREF(__pyx_v_ds); - __pyx_r = __pyx_v_ds; - goto __pyx_L0; - - /* "epanet/epanet.py":153 - * - * - * def node_results(self) -> list[dict[str, Any]]: # <<<<<<<<<<<<<< - * size = self.net_size()['node'] - * num_periods = self.times()['num_periods'] -*/ - - /* function exit code */ - __pyx_L1_error:; - __Pyx_XDECREF(__pyx_t_1); - __Pyx_XDECREF(__pyx_t_2); - __Pyx_XDECREF(__pyx_t_4); - __Pyx_XDECREF(__pyx_t_5); - __Pyx_XDECREF(__pyx_t_10); - __Pyx_XDECREF(__pyx_t_11); - __Pyx_XDECREF(__pyx_t_12); - __Pyx_XDECREF(__pyx_t_13); - __Pyx_XDECREF(__pyx_t_14); - __Pyx_XDECREF(__pyx_t_15); - __Pyx_XDECREF(__pyx_t_16); - __Pyx_XDECREF(__pyx_t_17); - __Pyx_XDECREF(__pyx_t_18); - __Pyx_AddTraceback("epanet.epanet.Output.node_results", __pyx_clineno, __pyx_lineno, __pyx_filename); - __pyx_r = NULL; - __pyx_L0:; - __Pyx_XDECREF(__pyx_v_size); - __Pyx_XDECREF(__pyx_v_num_periods); - __Pyx_XDECREF(__pyx_v_nodes); - __Pyx_XDECREF(__pyx_v_category); - __Pyx_XDECREF(__pyx_v_ds); - __Pyx_XDECREF(__pyx_v_i); - __Pyx_XDECREF(__pyx_v_d); - __Pyx_XDECREF(__pyx_v_j); - __Pyx_XDECREF(__pyx_v_values); - __Pyx_XDECREF(__pyx_v_length); - __Pyx_XDECREF(__pyx_v_attributes); - __Pyx_XDECREF(__pyx_v_k); - __Pyx_XGIVEREF(__pyx_r); - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -/* "epanet/epanet.py":175 - * - * - * def link_results(self) -> list[dict[str, Any]]: # <<<<<<<<<<<<<< - * size = self.net_size()['link'] - * num_periods = self.times()['num_periods'] -*/ - -/* Python wrapper */ -static PyObject *__pyx_pw_6epanet_6epanet_6Output_23link_results(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -); /*proto*/ -static PyMethodDef __pyx_mdef_6epanet_6epanet_6Output_23link_results = {"link_results", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6epanet_6epanet_6Output_23link_results, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}; -static PyObject *__pyx_pw_6epanet_6epanet_6Output_23link_results(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -) { - PyObject *__pyx_v_self = 0; - #if !CYTHON_METH_FASTCALL - CYTHON_UNUSED Py_ssize_t __pyx_nargs; - #endif - CYTHON_UNUSED PyObject *const *__pyx_kwvalues; - PyObject* values[1] = {0}; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - PyObject *__pyx_r = 0; - __Pyx_RefNannyDeclarations - __Pyx_RefNannySetupContext("link_results (wrapper)", 0); - #if !CYTHON_METH_FASTCALL - #if CYTHON_ASSUME_SAFE_SIZE - __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); - #else - __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; - #endif - #endif - __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); - { - PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_self,0}; - const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; - if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 175, __pyx_L3_error) - if (__pyx_kwds_len > 0) { - switch (__pyx_nargs) { - case 1: - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 175, __pyx_L3_error) - CYTHON_FALLTHROUGH; - case 0: break; - default: goto __pyx_L5_argtuple_error; - } - const Py_ssize_t kwd_pos_args = __pyx_nargs; - if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "link_results", 0) < 0) __PYX_ERR(0, 175, __pyx_L3_error) - for (Py_ssize_t i = __pyx_nargs; i < 1; i++) { - if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("link_results", 1, 1, 1, i); __PYX_ERR(0, 175, __pyx_L3_error) } - } - } else if (unlikely(__pyx_nargs != 1)) { - goto __pyx_L5_argtuple_error; - } else { - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 175, __pyx_L3_error) - } - __pyx_v_self = values[0]; - } - goto __pyx_L6_skip; - __pyx_L5_argtuple_error:; - __Pyx_RaiseArgtupleInvalid("link_results", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 175, __pyx_L3_error) - __pyx_L6_skip:; - goto __pyx_L4_argument_unpacking_done; - __pyx_L3_error:; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_AddTraceback("epanet.epanet.Output.link_results", __pyx_clineno, __pyx_lineno, __pyx_filename); - __Pyx_RefNannyFinishContext(); - return NULL; - __pyx_L4_argument_unpacking_done:; - __pyx_r = __pyx_pf_6epanet_6epanet_6Output_22link_results(__pyx_self, __pyx_v_self); - - /* function exit code */ - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -static PyObject *__pyx_pf_6epanet_6epanet_6Output_22link_results(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self) { - PyObject *__pyx_v_size = NULL; - PyObject *__pyx_v_num_periods = NULL; - PyObject *__pyx_v_links = NULL; - PyObject *__pyx_v_category = NULL; - PyObject *__pyx_v_ds = NULL; - PyObject *__pyx_v_i = NULL; - PyObject *__pyx_v_d = NULL; - PyObject *__pyx_v_j = NULL; - PyObject *__pyx_v_values = NULL; - PyObject *__pyx_v_length = NULL; - PyObject *__pyx_v_attributes = NULL; - PyObject *__pyx_v_k = NULL; - PyObject *__pyx_r = NULL; - __Pyx_RefNannyDeclarations - PyObject *__pyx_t_1 = NULL; - PyObject *__pyx_t_2 = NULL; - size_t __pyx_t_3; - PyObject *__pyx_t_4 = NULL; - PyObject *__pyx_t_5 = NULL; - Py_ssize_t __pyx_t_6; - PyObject *(*__pyx_t_7)(PyObject *); - Py_ssize_t __pyx_t_8; - PyObject *(*__pyx_t_9)(PyObject *); - PyObject *__pyx_t_10 = NULL; - PyObject *__pyx_t_11 = NULL; - PyObject *__pyx_t_12 = NULL; - PyObject *__pyx_t_13 = NULL; - PyObject *__pyx_t_14 = NULL; - PyObject *__pyx_t_15 = NULL; - PyObject *__pyx_t_16 = NULL; - PyObject *__pyx_t_17 = NULL; - PyObject *__pyx_t_18 = NULL; - Py_ssize_t __pyx_t_19; - int __pyx_t_20; - PyObject *(*__pyx_t_21)(PyObject *); - int __pyx_t_22; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - __Pyx_RefNannySetupContext("link_results", 0); - - /* "epanet/epanet.py":176 - * - * def link_results(self) -> list[dict[str, Any]]: - * size = self.net_size()['link'] # <<<<<<<<<<<<<< - * num_periods = self.times()['num_periods'] - * links = self.element_name()['links'] -*/ - __pyx_t_2 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_2); - __pyx_t_3 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_2, NULL}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_net_size, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 176, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_t_2 = __Pyx_PyObject_Dict_GetItem(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_link); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 176, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __pyx_v_size = __pyx_t_2; - __pyx_t_2 = 0; - - /* "epanet/epanet.py":177 - * def link_results(self) -> list[dict[str, Any]]: - * size = self.net_size()['link'] - * num_periods = self.times()['num_periods'] # <<<<<<<<<<<<<< - * links = self.element_name()['links'] - * category = ['flow', 'velocity', 'headloss', 'quality', 'status', 'setting', 'reaction', 'friction'] -*/ - __pyx_t_1 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_1); - __pyx_t_3 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_1, NULL}; - __pyx_t_2 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_times, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 177, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - __pyx_t_1 = __Pyx_PyObject_Dict_GetItem(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_num_periods); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 177, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __pyx_v_num_periods = __pyx_t_1; - __pyx_t_1 = 0; - - /* "epanet/epanet.py":178 - * size = self.net_size()['link'] - * num_periods = self.times()['num_periods'] - * links = self.element_name()['links'] # <<<<<<<<<<<<<< - * category = ['flow', 'velocity', 'headloss', 'quality', 'status', 'setting', 'reaction', 'friction'] - * ds = [] -*/ - __pyx_t_2 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_2); - __pyx_t_3 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_2, NULL}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_element_name, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 178, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_t_2 = __Pyx_PyObject_Dict_GetItem(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_links); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 178, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __pyx_v_links = __pyx_t_2; - __pyx_t_2 = 0; - - /* "epanet/epanet.py":179 - * num_periods = self.times()['num_periods'] - * links = self.element_name()['links'] - * category = ['flow', 'velocity', 'headloss', 'quality', 'status', 'setting', 'reaction', 'friction'] # <<<<<<<<<<<<<< - * ds = [] - * -*/ - __pyx_t_2 = PyList_New(8); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 179, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_flow); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_flow); - if (__Pyx_PyList_SET_ITEM(__pyx_t_2, 0, __pyx_mstate_global->__pyx_n_u_flow) != (0)) __PYX_ERR(0, 179, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_velocity); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_velocity); - if (__Pyx_PyList_SET_ITEM(__pyx_t_2, 1, __pyx_mstate_global->__pyx_n_u_velocity) != (0)) __PYX_ERR(0, 179, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_headloss); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_headloss); - if (__Pyx_PyList_SET_ITEM(__pyx_t_2, 2, __pyx_mstate_global->__pyx_n_u_headloss) != (0)) __PYX_ERR(0, 179, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_quality); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_quality); - if (__Pyx_PyList_SET_ITEM(__pyx_t_2, 3, __pyx_mstate_global->__pyx_n_u_quality) != (0)) __PYX_ERR(0, 179, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_status); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_status); - if (__Pyx_PyList_SET_ITEM(__pyx_t_2, 4, __pyx_mstate_global->__pyx_n_u_status) != (0)) __PYX_ERR(0, 179, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_setting); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_setting); - if (__Pyx_PyList_SET_ITEM(__pyx_t_2, 5, __pyx_mstate_global->__pyx_n_u_setting) != (0)) __PYX_ERR(0, 179, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_reaction); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_reaction); - if (__Pyx_PyList_SET_ITEM(__pyx_t_2, 6, __pyx_mstate_global->__pyx_n_u_reaction) != (0)) __PYX_ERR(0, 179, __pyx_L1_error); - __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_friction); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_friction); - if (__Pyx_PyList_SET_ITEM(__pyx_t_2, 7, __pyx_mstate_global->__pyx_n_u_friction) != (0)) __PYX_ERR(0, 179, __pyx_L1_error); - __pyx_v_category = ((PyObject*)__pyx_t_2); - __pyx_t_2 = 0; - - /* "epanet/epanet.py":180 - * links = self.element_name()['links'] - * category = ['flow', 'velocity', 'headloss', 'quality', 'status', 'setting', 'reaction', 'friction'] - * ds = [] # <<<<<<<<<<<<<< - * - * for i in range(1, size + 1): -*/ - __pyx_t_2 = PyList_New(0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 180, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_v_ds = ((PyObject*)__pyx_t_2); - __pyx_t_2 = 0; - - /* "epanet/epanet.py":182 - * ds = [] - * - * for i in range(1, size + 1): # <<<<<<<<<<<<<< - * d = { 'link' : links[i - 1], 'result' : [] } - * for j in range(num_periods): -*/ - __pyx_t_1 = NULL; - __Pyx_INCREF(__pyx_builtin_range); - __pyx_t_4 = __pyx_builtin_range; - __pyx_t_5 = __Pyx_PyLong_AddObjC(__pyx_v_size, __pyx_mstate_global->__pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 182, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __pyx_t_3 = 1; - { - PyObject *__pyx_callargs[3] = {__pyx_t_1, __pyx_mstate_global->__pyx_int_1, __pyx_t_5}; - __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_3, (3-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 182, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - if (likely(PyList_CheckExact(__pyx_t_2)) || PyTuple_CheckExact(__pyx_t_2)) { - __pyx_t_4 = __pyx_t_2; __Pyx_INCREF(__pyx_t_4); - __pyx_t_6 = 0; - __pyx_t_7 = NULL; - } else { - __pyx_t_6 = -1; __pyx_t_4 = PyObject_GetIter(__pyx_t_2); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 182, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __pyx_t_7 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_4); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 182, __pyx_L1_error) - } - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - for (;;) { - if (likely(!__pyx_t_7)) { - if (likely(PyList_CheckExact(__pyx_t_4))) { - { - Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_4); - #if !CYTHON_ASSUME_SAFE_SIZE - if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 182, __pyx_L1_error) - #endif - if (__pyx_t_6 >= __pyx_temp) break; - } - __pyx_t_2 = __Pyx_PyList_GetItemRef(__pyx_t_4, __pyx_t_6); - ++__pyx_t_6; - } else { - { - Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_4); - #if !CYTHON_ASSUME_SAFE_SIZE - if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 182, __pyx_L1_error) - #endif - if (__pyx_t_6 >= __pyx_temp) break; - } - #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS - __pyx_t_2 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_4, __pyx_t_6)); - #else - __pyx_t_2 = __Pyx_PySequence_ITEM(__pyx_t_4, __pyx_t_6); - #endif - ++__pyx_t_6; - } - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 182, __pyx_L1_error) - } else { - __pyx_t_2 = __pyx_t_7(__pyx_t_4); - if (unlikely(!__pyx_t_2)) { - PyObject* exc_type = PyErr_Occurred(); - if (exc_type) { - if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 182, __pyx_L1_error) - PyErr_Clear(); - } - break; - } - } - __Pyx_GOTREF(__pyx_t_2); - __Pyx_XDECREF_SET(__pyx_v_i, __pyx_t_2); - __pyx_t_2 = 0; - - /* "epanet/epanet.py":183 - * - * for i in range(1, size + 1): - * d = { 'link' : links[i - 1], 'result' : [] } # <<<<<<<<<<<<<< - * for j in range(num_periods): - * values = ctypes.POINTER(ctypes.c_float)() -*/ - __pyx_t_2 = __Pyx_PyDict_NewPresized(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 183, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_t_5 = __Pyx_PyLong_SubtractObjC(__pyx_v_i, __pyx_mstate_global->__pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 183, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __pyx_t_1 = __Pyx_PyObject_GetItem(__pyx_v_links, __pyx_t_5); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 183, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - if (PyDict_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_link, __pyx_t_1) < 0) __PYX_ERR(0, 183, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __pyx_t_1 = PyList_New(0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 183, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - if (PyDict_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_result, __pyx_t_1) < 0) __PYX_ERR(0, 183, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __Pyx_XDECREF_SET(__pyx_v_d, ((PyObject*)__pyx_t_2)); - __pyx_t_2 = 0; - - /* "epanet/epanet.py":184 - * for i in range(1, size + 1): - * d = { 'link' : links[i - 1], 'result' : [] } - * for j in range(num_periods): # <<<<<<<<<<<<<< - * values = ctypes.POINTER(ctypes.c_float)() - * length = ctypes.c_int() -*/ - __pyx_t_1 = NULL; - __Pyx_INCREF(__pyx_builtin_range); - __pyx_t_5 = __pyx_builtin_range; - __pyx_t_3 = 1; - { - PyObject *__pyx_callargs[2] = {__pyx_t_1, __pyx_v_num_periods}; - __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_5, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 184, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - if (likely(PyList_CheckExact(__pyx_t_2)) || PyTuple_CheckExact(__pyx_t_2)) { - __pyx_t_5 = __pyx_t_2; __Pyx_INCREF(__pyx_t_5); - __pyx_t_8 = 0; - __pyx_t_9 = NULL; - } else { - __pyx_t_8 = -1; __pyx_t_5 = PyObject_GetIter(__pyx_t_2); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 184, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __pyx_t_9 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_5); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 184, __pyx_L1_error) - } - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - for (;;) { - if (likely(!__pyx_t_9)) { - if (likely(PyList_CheckExact(__pyx_t_5))) { - { - Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_5); - #if !CYTHON_ASSUME_SAFE_SIZE - if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 184, __pyx_L1_error) - #endif - if (__pyx_t_8 >= __pyx_temp) break; - } - __pyx_t_2 = __Pyx_PyList_GetItemRef(__pyx_t_5, __pyx_t_8); - ++__pyx_t_8; - } else { - { - Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_5); - #if !CYTHON_ASSUME_SAFE_SIZE - if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 184, __pyx_L1_error) - #endif - if (__pyx_t_8 >= __pyx_temp) break; - } - #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS - __pyx_t_2 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_5, __pyx_t_8)); - #else - __pyx_t_2 = __Pyx_PySequence_ITEM(__pyx_t_5, __pyx_t_8); - #endif - ++__pyx_t_8; - } - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 184, __pyx_L1_error) - } else { - __pyx_t_2 = __pyx_t_9(__pyx_t_5); - if (unlikely(!__pyx_t_2)) { - PyObject* exc_type = PyErr_Occurred(); - if (exc_type) { - if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 184, __pyx_L1_error) - PyErr_Clear(); - } - break; - } - } - __Pyx_GOTREF(__pyx_t_2); - __Pyx_XDECREF_SET(__pyx_v_j, __pyx_t_2); - __pyx_t_2 = 0; - - /* "epanet/epanet.py":185 - * d = { 'link' : links[i - 1], 'result' : [] } - * for j in range(num_periods): - * values = ctypes.POINTER(ctypes.c_float)() # <<<<<<<<<<<<<< - * length = ctypes.c_int() - * self._check(self._lib.ENR_getLinkResult(self._handle, j, i, ctypes.byref(values), ctypes.byref(length))) -*/ - __pyx_t_1 = NULL; - __pyx_t_11 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_12, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 185, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_12); - __pyx_t_13 = __Pyx_PyObject_GetAttrStr(__pyx_t_12, __pyx_mstate_global->__pyx_n_u_POINTER); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 185, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_13); - __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0; - __Pyx_GetModuleGlobalName(__pyx_t_12, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 185, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_12); - __pyx_t_14 = __Pyx_PyObject_GetAttrStr(__pyx_t_12, __pyx_mstate_global->__pyx_n_u_c_float); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 185, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_14); - __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_13))) { - __pyx_t_11 = PyMethod_GET_SELF(__pyx_t_13); - assert(__pyx_t_11); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_13); - __Pyx_INCREF(__pyx_t_11); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_13, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_11, __pyx_t_14}; - __pyx_t_10 = __Pyx_PyObject_FastCall(__pyx_t_13, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; - __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; - __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0; - if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 185, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - } - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_10))) { - __pyx_t_1 = PyMethod_GET_SELF(__pyx_t_10); - assert(__pyx_t_1); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_10); - __Pyx_INCREF(__pyx_t_1); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_10, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_1, NULL}; - __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_10, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0; - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 185, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - __Pyx_XDECREF_SET(__pyx_v_values, __pyx_t_2); - __pyx_t_2 = 0; - - /* "epanet/epanet.py":186 - * for j in range(num_periods): - * values = ctypes.POINTER(ctypes.c_float)() - * length = ctypes.c_int() # <<<<<<<<<<<<<< - * self._check(self._lib.ENR_getLinkResult(self._handle, j, i, ctypes.byref(values), ctypes.byref(length))) - * assert length.value == len(category) -*/ - __pyx_t_10 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 186, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_t_13 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_c_int); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 186, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_13); - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_13))) { - __pyx_t_10 = PyMethod_GET_SELF(__pyx_t_13); - assert(__pyx_t_10); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_13); - __Pyx_INCREF(__pyx_t_10); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_13, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_10, NULL}; - __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_13, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0; - __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 186, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - __Pyx_XDECREF_SET(__pyx_v_length, __pyx_t_2); - __pyx_t_2 = 0; - - /* "epanet/epanet.py":187 - * values = ctypes.POINTER(ctypes.c_float)() - * length = ctypes.c_int() - * self._check(self._lib.ENR_getLinkResult(self._handle, j, i, ctypes.byref(values), ctypes.byref(length))) # <<<<<<<<<<<<<< - * assert length.value == len(category) - * attributes = {} -*/ - __pyx_t_13 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_13); - __pyx_t_14 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_lib); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 187, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_14); - __pyx_t_1 = __pyx_t_14; - __Pyx_INCREF(__pyx_t_1); - __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_handle); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 187, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __pyx_t_15 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_16, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_16)) __PYX_ERR(0, 187, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_16); - __pyx_t_17 = __Pyx_PyObject_GetAttrStr(__pyx_t_16, __pyx_mstate_global->__pyx_n_u_byref); if (unlikely(!__pyx_t_17)) __PYX_ERR(0, 187, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_17); - __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_17))) { - __pyx_t_15 = PyMethod_GET_SELF(__pyx_t_17); - assert(__pyx_t_15); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_17); - __Pyx_INCREF(__pyx_t_15); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_17, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_15, __pyx_v_values}; - __pyx_t_12 = __Pyx_PyObject_FastCall(__pyx_t_17, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_15); __pyx_t_15 = 0; - __Pyx_DECREF(__pyx_t_17); __pyx_t_17 = 0; - if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 187, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_12); - } - __pyx_t_15 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_16, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_16)) __PYX_ERR(0, 187, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_16); - __pyx_t_18 = __Pyx_PyObject_GetAttrStr(__pyx_t_16, __pyx_mstate_global->__pyx_n_u_byref); if (unlikely(!__pyx_t_18)) __PYX_ERR(0, 187, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_18); - __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_18))) { - __pyx_t_15 = PyMethod_GET_SELF(__pyx_t_18); - assert(__pyx_t_15); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_18); - __Pyx_INCREF(__pyx_t_15); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_18, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_15, __pyx_v_length}; - __pyx_t_17 = __Pyx_PyObject_FastCall(__pyx_t_18, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_15); __pyx_t_15 = 0; - __Pyx_DECREF(__pyx_t_18); __pyx_t_18 = 0; - if (unlikely(!__pyx_t_17)) __PYX_ERR(0, 187, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_17); - } - __pyx_t_3 = 0; - { - PyObject *__pyx_callargs[6] = {__pyx_t_1, __pyx_t_11, __pyx_v_j, __pyx_v_i, __pyx_t_12, __pyx_t_17}; - __pyx_t_10 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_ENR_getLinkResult, __pyx_callargs+__pyx_t_3, (6-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0; - __Pyx_DECREF(__pyx_t_17); __pyx_t_17 = 0; - __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; - if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 187, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - } - __pyx_t_3 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_13, __pyx_t_10}; - __pyx_t_2 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_check, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_13); __pyx_t_13 = 0; - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 187, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet.py":188 - * length = ctypes.c_int() - * self._check(self._lib.ENR_getLinkResult(self._handle, j, i, ctypes.byref(values), ctypes.byref(length))) - * assert length.value == len(category) # <<<<<<<<<<<<<< - * attributes = {} - * for k in range(length.value): -*/ - #ifndef CYTHON_WITHOUT_ASSERTIONS - if (unlikely(__pyx_assertions_enabled())) { - __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_length, __pyx_mstate_global->__pyx_n_u_value); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 188, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_t_19 = __Pyx_PyList_GET_SIZE(__pyx_v_category); if (unlikely(__pyx_t_19 == ((Py_ssize_t)-1))) __PYX_ERR(0, 188, __pyx_L1_error) - __pyx_t_10 = PyLong_FromSsize_t(__pyx_t_19); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 188, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - __pyx_t_13 = PyObject_RichCompare(__pyx_t_2, __pyx_t_10, Py_EQ); __Pyx_XGOTREF(__pyx_t_13); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 188, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - __pyx_t_20 = __Pyx_PyObject_IsTrue(__pyx_t_13); if (unlikely((__pyx_t_20 < 0))) __PYX_ERR(0, 188, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0; - if (unlikely(!__pyx_t_20)) { - __Pyx_Raise(__pyx_builtin_AssertionError, 0, 0, 0); - __PYX_ERR(0, 188, __pyx_L1_error) - } - } - #else - if ((1)); else __PYX_ERR(0, 188, __pyx_L1_error) - #endif - - /* "epanet/epanet.py":189 - * self._check(self._lib.ENR_getLinkResult(self._handle, j, i, ctypes.byref(values), ctypes.byref(length))) - * assert length.value == len(category) - * attributes = {} # <<<<<<<<<<<<<< - * for k in range(length.value): - * if category[k] == 'status': -*/ - __pyx_t_13 = __Pyx_PyDict_NewPresized(0); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 189, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_13); - __Pyx_XDECREF_SET(__pyx_v_attributes, ((PyObject*)__pyx_t_13)); - __pyx_t_13 = 0; - - /* "epanet/epanet.py":190 - * assert length.value == len(category) - * attributes = {} - * for k in range(length.value): # <<<<<<<<<<<<<< - * if category[k] == 'status': - * if values[k] == 2.0: -*/ - __pyx_t_10 = NULL; - __Pyx_INCREF(__pyx_builtin_range); - __pyx_t_2 = __pyx_builtin_range; - __pyx_t_14 = __Pyx_PyObject_GetAttrStr(__pyx_v_length, __pyx_mstate_global->__pyx_n_u_value); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 190, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_14); - __pyx_t_3 = 1; - { - PyObject *__pyx_callargs[2] = {__pyx_t_10, __pyx_t_14}; - __pyx_t_13 = __Pyx_PyObject_FastCall(__pyx_t_2, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0; - __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 190, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_13); - } - if (likely(PyList_CheckExact(__pyx_t_13)) || PyTuple_CheckExact(__pyx_t_13)) { - __pyx_t_2 = __pyx_t_13; __Pyx_INCREF(__pyx_t_2); - __pyx_t_19 = 0; - __pyx_t_21 = NULL; - } else { - __pyx_t_19 = -1; __pyx_t_2 = PyObject_GetIter(__pyx_t_13); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 190, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_t_21 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_2); if (unlikely(!__pyx_t_21)) __PYX_ERR(0, 190, __pyx_L1_error) - } - __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0; - for (;;) { - if (likely(!__pyx_t_21)) { - if (likely(PyList_CheckExact(__pyx_t_2))) { - { - Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_2); - #if !CYTHON_ASSUME_SAFE_SIZE - if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 190, __pyx_L1_error) - #endif - if (__pyx_t_19 >= __pyx_temp) break; - } - __pyx_t_13 = __Pyx_PyList_GetItemRef(__pyx_t_2, __pyx_t_19); - ++__pyx_t_19; - } else { - { - Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_2); - #if !CYTHON_ASSUME_SAFE_SIZE - if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 190, __pyx_L1_error) - #endif - if (__pyx_t_19 >= __pyx_temp) break; - } - #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS - __pyx_t_13 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_2, __pyx_t_19)); - #else - __pyx_t_13 = __Pyx_PySequence_ITEM(__pyx_t_2, __pyx_t_19); - #endif - ++__pyx_t_19; - } - if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 190, __pyx_L1_error) - } else { - __pyx_t_13 = __pyx_t_21(__pyx_t_2); - if (unlikely(!__pyx_t_13)) { - PyObject* exc_type = PyErr_Occurred(); - if (exc_type) { - if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 190, __pyx_L1_error) - PyErr_Clear(); - } - break; - } - } - __Pyx_GOTREF(__pyx_t_13); - __Pyx_XDECREF_SET(__pyx_v_k, __pyx_t_13); - __pyx_t_13 = 0; - - /* "epanet/epanet.py":191 - * attributes = {} - * for k in range(length.value): - * if category[k] == 'status': # <<<<<<<<<<<<<< - * if values[k] == 2.0: - * attributes[category[k]] = 'CLOSED' -*/ - __pyx_t_13 = __Pyx_PyObject_GetItem(__pyx_v_category, __pyx_v_k); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 191, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_13); - __pyx_t_20 = (__Pyx_PyUnicode_Equals(__pyx_t_13, __pyx_mstate_global->__pyx_n_u_status, Py_EQ)); if (unlikely((__pyx_t_20 < 0))) __PYX_ERR(0, 191, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0; - if (__pyx_t_20) { - - /* "epanet/epanet.py":192 - * for k in range(length.value): - * if category[k] == 'status': - * if values[k] == 2.0: # <<<<<<<<<<<<<< - * attributes[category[k]] = 'CLOSED' - * else: -*/ - __pyx_t_13 = __Pyx_PyObject_GetItem(__pyx_v_values, __pyx_v_k); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 192, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_13); - __pyx_t_20 = (__Pyx_PyFloat_BoolEqObjC(__pyx_t_13, __pyx_mstate_global->__pyx_float_2_0, 2.0, 0, 0)); if (unlikely((__pyx_t_20 < 0))) __PYX_ERR(0, 192, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0; - if (__pyx_t_20) { - - /* "epanet/epanet.py":193 - * if category[k] == 'status': - * if values[k] == 2.0: - * attributes[category[k]] = 'CLOSED' # <<<<<<<<<<<<<< - * else: - * attributes[category[k]] = 'OPEN' -*/ - __pyx_t_13 = __Pyx_PyObject_GetItem(__pyx_v_category, __pyx_v_k); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 193, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_13); - if (unlikely((PyDict_SetItem(__pyx_v_attributes, __pyx_t_13, __pyx_mstate_global->__pyx_n_u_CLOSED) < 0))) __PYX_ERR(0, 193, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0; - - /* "epanet/epanet.py":192 - * for k in range(length.value): - * if category[k] == 'status': - * if values[k] == 2.0: # <<<<<<<<<<<<<< - * attributes[category[k]] = 'CLOSED' - * else: -*/ - goto __pyx_L10; - } - - /* "epanet/epanet.py":195 - * attributes[category[k]] = 'CLOSED' - * else: - * attributes[category[k]] = 'OPEN' # <<<<<<<<<<<<<< - * continue - * attributes[category[k]] = values[k] -*/ - /*else*/ { - __pyx_t_13 = __Pyx_PyObject_GetItem(__pyx_v_category, __pyx_v_k); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 195, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_13); - if (unlikely((PyDict_SetItem(__pyx_v_attributes, __pyx_t_13, __pyx_mstate_global->__pyx_n_u_OPEN) < 0))) __PYX_ERR(0, 195, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0; - } - __pyx_L10:; - - /* "epanet/epanet.py":196 - * else: - * attributes[category[k]] = 'OPEN' - * continue # <<<<<<<<<<<<<< - * attributes[category[k]] = values[k] - * d['result'].append(attributes) -*/ - goto __pyx_L7_continue; - - /* "epanet/epanet.py":191 - * attributes = {} - * for k in range(length.value): - * if category[k] == 'status': # <<<<<<<<<<<<<< - * if values[k] == 2.0: - * attributes[category[k]] = 'CLOSED' -*/ - } - - /* "epanet/epanet.py":197 - * attributes[category[k]] = 'OPEN' - * continue - * attributes[category[k]] = values[k] # <<<<<<<<<<<<<< - * d['result'].append(attributes) - * self._lib.ENR_free(ctypes.byref(values)) -*/ - __pyx_t_13 = __Pyx_PyObject_GetItem(__pyx_v_values, __pyx_v_k); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 197, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_13); - __pyx_t_14 = __Pyx_PyObject_GetItem(__pyx_v_category, __pyx_v_k); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 197, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_14); - if (unlikely((PyDict_SetItem(__pyx_v_attributes, __pyx_t_14, __pyx_t_13) < 0))) __PYX_ERR(0, 197, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; - __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0; - - /* "epanet/epanet.py":190 - * assert length.value == len(category) - * attributes = {} - * for k in range(length.value): # <<<<<<<<<<<<<< - * if category[k] == 'status': - * if values[k] == 2.0: -*/ - __pyx_L7_continue:; - } - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet.py":198 - * continue - * attributes[category[k]] = values[k] - * d['result'].append(attributes) # <<<<<<<<<<<<<< - * self._lib.ENR_free(ctypes.byref(values)) - * ds.append(d) -*/ - __pyx_t_2 = __Pyx_PyDict_GetItem(__pyx_v_d, __pyx_mstate_global->__pyx_n_u_result); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 198, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_t_22 = __Pyx_PyObject_Append(__pyx_t_2, __pyx_v_attributes); if (unlikely(__pyx_t_22 == ((int)-1))) __PYX_ERR(0, 198, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet.py":199 - * attributes[category[k]] = values[k] - * d['result'].append(attributes) - * self._lib.ENR_free(ctypes.byref(values)) # <<<<<<<<<<<<<< - * ds.append(d) - * return ds -*/ - __pyx_t_14 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_lib); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 199, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_14); - __pyx_t_13 = __pyx_t_14; - __Pyx_INCREF(__pyx_t_13); - __pyx_t_17 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_12, __pyx_mstate_global->__pyx_n_u_ctypes); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 199, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_12); - __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_t_12, __pyx_mstate_global->__pyx_n_u_byref); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 199, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0; - __pyx_t_3 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_11))) { - __pyx_t_17 = PyMethod_GET_SELF(__pyx_t_11); - assert(__pyx_t_17); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_11); - __Pyx_INCREF(__pyx_t_17); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_11, __pyx__function); - __pyx_t_3 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_17, __pyx_v_values}; - __pyx_t_10 = __Pyx_PyObject_FastCall(__pyx_t_11, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_17); __pyx_t_17 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 199, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - } - __pyx_t_3 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_13, __pyx_t_10}; - __pyx_t_2 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_ENR_free, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_13); __pyx_t_13 = 0; - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 199, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet.py":184 - * for i in range(1, size + 1): - * d = { 'link' : links[i - 1], 'result' : [] } - * for j in range(num_periods): # <<<<<<<<<<<<<< - * values = ctypes.POINTER(ctypes.c_float)() - * length = ctypes.c_int() -*/ - } - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - - /* "epanet/epanet.py":200 - * d['result'].append(attributes) - * self._lib.ENR_free(ctypes.byref(values)) - * ds.append(d) # <<<<<<<<<<<<<< - * return ds - * -*/ - __pyx_t_22 = __Pyx_PyList_Append(__pyx_v_ds, __pyx_v_d); if (unlikely(__pyx_t_22 == ((int)-1))) __PYX_ERR(0, 200, __pyx_L1_error) - - /* "epanet/epanet.py":182 - * ds = [] - * - * for i in range(1, size + 1): # <<<<<<<<<<<<<< - * d = { 'link' : links[i - 1], 'result' : [] } - * for j in range(num_periods): -*/ - } - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - - /* "epanet/epanet.py":201 - * self._lib.ENR_free(ctypes.byref(values)) - * ds.append(d) - * return ds # <<<<<<<<<<<<<< - * - * -*/ - __Pyx_XDECREF(__pyx_r); - __Pyx_INCREF(__pyx_v_ds); - __pyx_r = __pyx_v_ds; - goto __pyx_L0; - - /* "epanet/epanet.py":175 - * - * - * def link_results(self) -> list[dict[str, Any]]: # <<<<<<<<<<<<<< - * size = self.net_size()['link'] - * num_periods = self.times()['num_periods'] -*/ - - /* function exit code */ - __pyx_L1_error:; - __Pyx_XDECREF(__pyx_t_1); - __Pyx_XDECREF(__pyx_t_2); - __Pyx_XDECREF(__pyx_t_4); - __Pyx_XDECREF(__pyx_t_5); - __Pyx_XDECREF(__pyx_t_10); - __Pyx_XDECREF(__pyx_t_11); - __Pyx_XDECREF(__pyx_t_12); - __Pyx_XDECREF(__pyx_t_13); - __Pyx_XDECREF(__pyx_t_14); - __Pyx_XDECREF(__pyx_t_15); - __Pyx_XDECREF(__pyx_t_16); - __Pyx_XDECREF(__pyx_t_17); - __Pyx_XDECREF(__pyx_t_18); - __Pyx_AddTraceback("epanet.epanet.Output.link_results", __pyx_clineno, __pyx_lineno, __pyx_filename); - __pyx_r = NULL; - __pyx_L0:; - __Pyx_XDECREF(__pyx_v_size); - __Pyx_XDECREF(__pyx_v_num_periods); - __Pyx_XDECREF(__pyx_v_links); - __Pyx_XDECREF(__pyx_v_category); - __Pyx_XDECREF(__pyx_v_ds); - __Pyx_XDECREF(__pyx_v_i); - __Pyx_XDECREF(__pyx_v_d); - __Pyx_XDECREF(__pyx_v_j); - __Pyx_XDECREF(__pyx_v_values); - __Pyx_XDECREF(__pyx_v_length); - __Pyx_XDECREF(__pyx_v_attributes); - __Pyx_XDECREF(__pyx_v_k); - __Pyx_XGIVEREF(__pyx_r); - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -/* "epanet/epanet.py":204 - * - * - * def dump(self) -> dict[str, Any]: # <<<<<<<<<<<<<< - * data = {} - * data |= { 'version' : self.version() } -*/ - -/* Python wrapper */ -static PyObject *__pyx_pw_6epanet_6epanet_6Output_25dump(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -); /*proto*/ -static PyMethodDef __pyx_mdef_6epanet_6epanet_6Output_25dump = {"dump", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6epanet_6epanet_6Output_25dump, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}; -static PyObject *__pyx_pw_6epanet_6epanet_6Output_25dump(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -) { - PyObject *__pyx_v_self = 0; - #if !CYTHON_METH_FASTCALL - CYTHON_UNUSED Py_ssize_t __pyx_nargs; - #endif - CYTHON_UNUSED PyObject *const *__pyx_kwvalues; - PyObject* values[1] = {0}; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - PyObject *__pyx_r = 0; - __Pyx_RefNannyDeclarations - __Pyx_RefNannySetupContext("dump (wrapper)", 0); - #if !CYTHON_METH_FASTCALL - #if CYTHON_ASSUME_SAFE_SIZE - __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); - #else - __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; - #endif - #endif - __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); - { - PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_self,0}; - const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; - if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 204, __pyx_L3_error) - if (__pyx_kwds_len > 0) { - switch (__pyx_nargs) { - case 1: - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 204, __pyx_L3_error) - CYTHON_FALLTHROUGH; - case 0: break; - default: goto __pyx_L5_argtuple_error; - } - const Py_ssize_t kwd_pos_args = __pyx_nargs; - if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "dump", 0) < 0) __PYX_ERR(0, 204, __pyx_L3_error) - for (Py_ssize_t i = __pyx_nargs; i < 1; i++) { - if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("dump", 1, 1, 1, i); __PYX_ERR(0, 204, __pyx_L3_error) } - } - } else if (unlikely(__pyx_nargs != 1)) { - goto __pyx_L5_argtuple_error; - } else { - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 204, __pyx_L3_error) - } - __pyx_v_self = values[0]; - } - goto __pyx_L6_skip; - __pyx_L5_argtuple_error:; - __Pyx_RaiseArgtupleInvalid("dump", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 204, __pyx_L3_error) - __pyx_L6_skip:; - goto __pyx_L4_argument_unpacking_done; - __pyx_L3_error:; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_AddTraceback("epanet.epanet.Output.dump", __pyx_clineno, __pyx_lineno, __pyx_filename); - __Pyx_RefNannyFinishContext(); - return NULL; - __pyx_L4_argument_unpacking_done:; - __pyx_r = __pyx_pf_6epanet_6epanet_6Output_24dump(__pyx_self, __pyx_v_self); - - /* function exit code */ - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -static PyObject *__pyx_pf_6epanet_6epanet_6Output_24dump(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self) { - PyObject *__pyx_v_data = NULL; - PyObject *__pyx_r = NULL; - __Pyx_RefNannyDeclarations - PyObject *__pyx_t_1 = NULL; - PyObject *__pyx_t_2 = NULL; - PyObject *__pyx_t_3 = NULL; - size_t __pyx_t_4; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - __Pyx_RefNannySetupContext("dump", 0); - - /* "epanet/epanet.py":205 - * - * def dump(self) -> dict[str, Any]: - * data = {} # <<<<<<<<<<<<<< - * data |= { 'version' : self.version() } - * data |= { 'net_size' : self.net_size() } -*/ - __pyx_t_1 = __Pyx_PyDict_NewPresized(0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 205, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_v_data = ((PyObject*)__pyx_t_1); - __pyx_t_1 = 0; - - /* "epanet/epanet.py":206 - * def dump(self) -> dict[str, Any]: - * data = {} - * data |= { 'version' : self.version() } # <<<<<<<<<<<<<< - * data |= { 'net_size' : self.net_size() } - * data |= { 'units' : self.units() } -*/ - __pyx_t_1 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 206, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_t_3 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_3); - __pyx_t_4 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL}; - __pyx_t_2 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_version, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 206, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - if (PyDict_SetItem(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_version, __pyx_t_2) < 0) __PYX_ERR(0, 206, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __pyx_t_2 = PyNumber_InPlaceOr(__pyx_v_data, __pyx_t_1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 206, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __Pyx_DECREF_SET(__pyx_v_data, ((PyObject*)__pyx_t_2)); - __pyx_t_2 = 0; - - /* "epanet/epanet.py":207 - * data = {} - * data |= { 'version' : self.version() } - * data |= { 'net_size' : self.net_size() } # <<<<<<<<<<<<<< - * data |= { 'units' : self.units() } - * data |= { 'times' : self.times() } -*/ - __pyx_t_2 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 207, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_t_3 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_3); - __pyx_t_4 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_net_size, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 207, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - if (PyDict_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_net_size, __pyx_t_1) < 0) __PYX_ERR(0, 207, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __pyx_t_1 = PyNumber_InPlaceOr(__pyx_v_data, __pyx_t_2); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 207, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF_SET(__pyx_v_data, ((PyObject*)__pyx_t_1)); - __pyx_t_1 = 0; - - /* "epanet/epanet.py":208 - * data |= { 'version' : self.version() } - * data |= { 'net_size' : self.net_size() } - * data |= { 'units' : self.units() } # <<<<<<<<<<<<<< - * data |= { 'times' : self.times() } - * data |= { 'element_name' : self.element_name() } -*/ - __pyx_t_1 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 208, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_t_3 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_3); - __pyx_t_4 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL}; - __pyx_t_2 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_units, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 208, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - if (PyDict_SetItem(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_units, __pyx_t_2) < 0) __PYX_ERR(0, 208, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __pyx_t_2 = PyNumber_InPlaceOr(__pyx_v_data, __pyx_t_1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 208, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __Pyx_DECREF_SET(__pyx_v_data, ((PyObject*)__pyx_t_2)); - __pyx_t_2 = 0; - - /* "epanet/epanet.py":209 - * data |= { 'net_size' : self.net_size() } - * data |= { 'units' : self.units() } - * data |= { 'times' : self.times() } # <<<<<<<<<<<<<< - * data |= { 'element_name' : self.element_name() } - * data |= { 'energy_usage' : self.energy_usage() } -*/ - __pyx_t_2 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 209, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_t_3 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_3); - __pyx_t_4 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_times, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 209, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - if (PyDict_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_times, __pyx_t_1) < 0) __PYX_ERR(0, 209, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __pyx_t_1 = PyNumber_InPlaceOr(__pyx_v_data, __pyx_t_2); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 209, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF_SET(__pyx_v_data, ((PyObject*)__pyx_t_1)); - __pyx_t_1 = 0; - - /* "epanet/epanet.py":210 - * data |= { 'units' : self.units() } - * data |= { 'times' : self.times() } - * data |= { 'element_name' : self.element_name() } # <<<<<<<<<<<<<< - * data |= { 'energy_usage' : self.energy_usage() } - * data |= { 'reactions' : self.reactions() } -*/ - __pyx_t_1 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 210, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_t_3 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_3); - __pyx_t_4 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL}; - __pyx_t_2 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_element_name, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 210, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - if (PyDict_SetItem(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_element_name, __pyx_t_2) < 0) __PYX_ERR(0, 210, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __pyx_t_2 = PyNumber_InPlaceOr(__pyx_v_data, __pyx_t_1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 210, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __Pyx_DECREF_SET(__pyx_v_data, ((PyObject*)__pyx_t_2)); - __pyx_t_2 = 0; - - /* "epanet/epanet.py":211 - * data |= { 'times' : self.times() } - * data |= { 'element_name' : self.element_name() } - * data |= { 'energy_usage' : self.energy_usage() } # <<<<<<<<<<<<<< - * data |= { 'reactions' : self.reactions() } - * data |= { 'node_results' : self.node_results() } -*/ - __pyx_t_2 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 211, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_t_3 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_3); - __pyx_t_4 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_energy_usage, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 211, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - if (PyDict_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_energy_usage, __pyx_t_1) < 0) __PYX_ERR(0, 211, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __pyx_t_1 = PyNumber_InPlaceOr(__pyx_v_data, __pyx_t_2); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 211, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF_SET(__pyx_v_data, ((PyObject*)__pyx_t_1)); - __pyx_t_1 = 0; - - /* "epanet/epanet.py":212 - * data |= { 'element_name' : self.element_name() } - * data |= { 'energy_usage' : self.energy_usage() } - * data |= { 'reactions' : self.reactions() } # <<<<<<<<<<<<<< - * data |= { 'node_results' : self.node_results() } - * data |= { 'link_results' : self.link_results() } -*/ - __pyx_t_1 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 212, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_t_3 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_3); - __pyx_t_4 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL}; - __pyx_t_2 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_reactions, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 212, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - if (PyDict_SetItem(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_reactions, __pyx_t_2) < 0) __PYX_ERR(0, 212, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __pyx_t_2 = PyNumber_InPlaceOr(__pyx_v_data, __pyx_t_1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 212, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __Pyx_DECREF_SET(__pyx_v_data, ((PyObject*)__pyx_t_2)); - __pyx_t_2 = 0; - - /* "epanet/epanet.py":213 - * data |= { 'energy_usage' : self.energy_usage() } - * data |= { 'reactions' : self.reactions() } - * data |= { 'node_results' : self.node_results() } # <<<<<<<<<<<<<< - * data |= { 'link_results' : self.link_results() } - * return data -*/ - __pyx_t_2 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 213, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_t_3 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_3); - __pyx_t_4 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_node_results, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 213, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - if (PyDict_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_node_results, __pyx_t_1) < 0) __PYX_ERR(0, 213, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __pyx_t_1 = PyNumber_InPlaceOr(__pyx_v_data, __pyx_t_2); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 213, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF_SET(__pyx_v_data, ((PyObject*)__pyx_t_1)); - __pyx_t_1 = 0; - - /* "epanet/epanet.py":214 - * data |= { 'reactions' : self.reactions() } - * data |= { 'node_results' : self.node_results() } - * data |= { 'link_results' : self.link_results() } # <<<<<<<<<<<<<< - * return data - * -*/ - __pyx_t_1 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 214, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_t_3 = __pyx_v_self; - __Pyx_INCREF(__pyx_t_3); - __pyx_t_4 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL}; - __pyx_t_2 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_link_results, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 214, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - if (PyDict_SetItem(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_link_results, __pyx_t_2) < 0) __PYX_ERR(0, 214, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __pyx_t_2 = PyNumber_InPlaceOr(__pyx_v_data, __pyx_t_1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 214, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __Pyx_DECREF_SET(__pyx_v_data, ((PyObject*)__pyx_t_2)); - __pyx_t_2 = 0; - - /* "epanet/epanet.py":215 - * data |= { 'node_results' : self.node_results() } - * data |= { 'link_results' : self.link_results() } - * return data # <<<<<<<<<<<<<< - * - * -*/ - __Pyx_XDECREF(__pyx_r); - __Pyx_INCREF(__pyx_v_data); - __pyx_r = __pyx_v_data; - goto __pyx_L0; - - /* "epanet/epanet.py":204 - * - * - * def dump(self) -> dict[str, Any]: # <<<<<<<<<<<<<< - * data = {} - * data |= { 'version' : self.version() } -*/ - - /* function exit code */ - __pyx_L1_error:; - __Pyx_XDECREF(__pyx_t_1); - __Pyx_XDECREF(__pyx_t_2); - __Pyx_XDECREF(__pyx_t_3); - __Pyx_AddTraceback("epanet.epanet.Output.dump", __pyx_clineno, __pyx_lineno, __pyx_filename); - __pyx_r = NULL; - __pyx_L0:; - __Pyx_XDECREF(__pyx_v_data); - __Pyx_XGIVEREF(__pyx_r); - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -/* "epanet/epanet.py":218 - * - * - * def _dump_output(path: str) -> dict[str, Any]: # <<<<<<<<<<<<<< - * opt = Output(path) - * data = opt.dump() -*/ - -/* Python wrapper */ -static PyObject *__pyx_pw_6epanet_6epanet_3_dump_output(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -); /*proto*/ -static PyMethodDef __pyx_mdef_6epanet_6epanet_3_dump_output = {"_dump_output", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6epanet_6epanet_3_dump_output, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}; -static PyObject *__pyx_pw_6epanet_6epanet_3_dump_output(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -) { - PyObject *__pyx_v_path = 0; - #if !CYTHON_METH_FASTCALL - CYTHON_UNUSED Py_ssize_t __pyx_nargs; - #endif - CYTHON_UNUSED PyObject *const *__pyx_kwvalues; - PyObject* values[1] = {0}; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - PyObject *__pyx_r = 0; - __Pyx_RefNannyDeclarations - __Pyx_RefNannySetupContext("_dump_output (wrapper)", 0); - #if !CYTHON_METH_FASTCALL - #if CYTHON_ASSUME_SAFE_SIZE - __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); - #else - __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; - #endif - #endif - __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); - { - PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_path,0}; - const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; - if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 218, __pyx_L3_error) - if (__pyx_kwds_len > 0) { - switch (__pyx_nargs) { - case 1: - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 218, __pyx_L3_error) - CYTHON_FALLTHROUGH; - case 0: break; - default: goto __pyx_L5_argtuple_error; - } - const Py_ssize_t kwd_pos_args = __pyx_nargs; - if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "_dump_output", 0) < 0) __PYX_ERR(0, 218, __pyx_L3_error) - for (Py_ssize_t i = __pyx_nargs; i < 1; i++) { - if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("_dump_output", 1, 1, 1, i); __PYX_ERR(0, 218, __pyx_L3_error) } - } - } else if (unlikely(__pyx_nargs != 1)) { - goto __pyx_L5_argtuple_error; - } else { - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 218, __pyx_L3_error) - } - __pyx_v_path = ((PyObject*)values[0]); - } - goto __pyx_L6_skip; - __pyx_L5_argtuple_error:; - __Pyx_RaiseArgtupleInvalid("_dump_output", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 218, __pyx_L3_error) - __pyx_L6_skip:; - goto __pyx_L4_argument_unpacking_done; - __pyx_L3_error:; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_AddTraceback("epanet.epanet._dump_output", __pyx_clineno, __pyx_lineno, __pyx_filename); - __Pyx_RefNannyFinishContext(); - return NULL; - __pyx_L4_argument_unpacking_done:; - if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_path), (&PyUnicode_Type), 0, "path", 2))) __PYX_ERR(0, 218, __pyx_L1_error) - __pyx_r = __pyx_pf_6epanet_6epanet_2_dump_output(__pyx_self, __pyx_v_path); - - /* function exit code */ - goto __pyx_L0; - __pyx_L1_error:; - __pyx_r = NULL; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - goto __pyx_L7_cleaned_up; - __pyx_L0:; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __pyx_L7_cleaned_up:; - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -static PyObject *__pyx_pf_6epanet_6epanet_2_dump_output(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_path) { - PyObject *__pyx_v_opt = NULL; - PyObject *__pyx_v_data = NULL; - PyObject *__pyx_v_f = NULL; - PyObject *__pyx_r = NULL; - __Pyx_RefNannyDeclarations - PyObject *__pyx_t_1 = NULL; - PyObject *__pyx_t_2 = NULL; - PyObject *__pyx_t_3 = NULL; - size_t __pyx_t_4; - PyObject *__pyx_t_5 = NULL; - PyObject *__pyx_t_6 = NULL; - PyObject *__pyx_t_7 = NULL; - PyObject *__pyx_t_8 = NULL; - PyObject *__pyx_t_9 = NULL; - PyObject *__pyx_t_10 = NULL; - int __pyx_t_11; - int __pyx_t_12; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - __Pyx_RefNannySetupContext("_dump_output", 0); - - /* "epanet/epanet.py":219 - * - * def _dump_output(path: str) -> dict[str, Any]: - * opt = Output(path) # <<<<<<<<<<<<<< - * data = opt.dump() - * with open(path + '.json', 'w') as f: -*/ - __pyx_t_2 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_Output); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 219, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __pyx_t_4 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_3))) { - __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_3); - assert(__pyx_t_2); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_3); - __Pyx_INCREF(__pyx_t_2); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_3, __pyx__function); - __pyx_t_4 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_v_path}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_3, __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 219, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_v_opt = __pyx_t_1; - __pyx_t_1 = 0; - - /* "epanet/epanet.py":220 - * def _dump_output(path: str) -> dict[str, Any]: - * opt = Output(path) - * data = opt.dump() # <<<<<<<<<<<<<< - * with open(path + '.json', 'w') as f: - * json.dump(data, f) -*/ - __pyx_t_3 = __pyx_v_opt; - __Pyx_INCREF(__pyx_t_3); - __pyx_t_4 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_dump, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 220, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_v_data = __pyx_t_1; - __pyx_t_1 = 0; - - /* "epanet/epanet.py":221 - * opt = Output(path) - * data = opt.dump() - * with open(path + '.json', 'w') as f: # <<<<<<<<<<<<<< - * json.dump(data, f) - * return data -*/ - /*with:*/ { - __pyx_t_3 = NULL; - __Pyx_INCREF(__pyx_builtin_open); - __pyx_t_2 = __pyx_builtin_open; - __pyx_t_5 = __Pyx_PyUnicode_Concat(__pyx_v_path, __pyx_mstate_global->__pyx_kp_u_json); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 221, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __pyx_t_4 = 1; - { - PyObject *__pyx_callargs[3] = {__pyx_t_3, __pyx_t_5, __pyx_mstate_global->__pyx_n_u_w}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_2, __pyx_callargs+__pyx_t_4, (3-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 221, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_t_6 = __Pyx_PyObject_LookupSpecial(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_exit); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 221, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __pyx_t_5 = NULL; - __pyx_t_3 = __Pyx_PyObject_LookupSpecial(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_enter); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 221, __pyx_L3_error) - __Pyx_GOTREF(__pyx_t_3); - __pyx_t_4 = 1; - #if CYTHON_UNPACK_METHODS - if (likely(PyMethod_Check(__pyx_t_3))) { - __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_3); - assert(__pyx_t_5); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_3); - __Pyx_INCREF(__pyx_t_5); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_3, __pyx__function); - __pyx_t_4 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_5, NULL}; - __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_3, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 221, __pyx_L3_error) - __Pyx_GOTREF(__pyx_t_2); - } - __pyx_t_3 = __pyx_t_2; - __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - /*try:*/ { - { - __Pyx_PyThreadState_declare - __Pyx_PyThreadState_assign - __Pyx_ExceptionSave(&__pyx_t_7, &__pyx_t_8, &__pyx_t_9); - __Pyx_XGOTREF(__pyx_t_7); - __Pyx_XGOTREF(__pyx_t_8); - __Pyx_XGOTREF(__pyx_t_9); - /*try:*/ { - __pyx_v_f = __pyx_t_3; - __pyx_t_3 = 0; - - /* "epanet/epanet.py":222 - * data = opt.dump() - * with open(path + '.json', 'w') as f: - * json.dump(data, f) # <<<<<<<<<<<<<< - * return data - * -*/ - __pyx_t_1 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_json_2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 222, __pyx_L7_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_dump); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 222, __pyx_L7_error) - __Pyx_GOTREF(__pyx_t_5); - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __pyx_t_4 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_5))) { - __pyx_t_1 = PyMethod_GET_SELF(__pyx_t_5); - assert(__pyx_t_1); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_5); - __Pyx_INCREF(__pyx_t_1); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_5, __pyx__function); - __pyx_t_4 = 0; - } - #endif - { - PyObject *__pyx_callargs[3] = {__pyx_t_1, __pyx_v_data, __pyx_v_f}; - __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_5, __pyx_callargs+__pyx_t_4, (3-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 222, __pyx_L7_error) - __Pyx_GOTREF(__pyx_t_3); - } - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - - /* "epanet/epanet.py":221 - * opt = Output(path) - * data = opt.dump() - * with open(path + '.json', 'w') as f: # <<<<<<<<<<<<<< - * json.dump(data, f) - * return data -*/ - } - __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; - __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0; - __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0; - goto __pyx_L12_try_end; - __pyx_L7_error:; - __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0; - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; - /*except:*/ { - __Pyx_AddTraceback("epanet.epanet._dump_output", __pyx_clineno, __pyx_lineno, __pyx_filename); - if (__Pyx_GetException(&__pyx_t_3, &__pyx_t_5, &__pyx_t_1) < 0) __PYX_ERR(0, 221, __pyx_L9_except_error) - __Pyx_XGOTREF(__pyx_t_3); - __Pyx_XGOTREF(__pyx_t_5); - __Pyx_XGOTREF(__pyx_t_1); - __pyx_t_2 = PyTuple_Pack(3, __pyx_t_3, __pyx_t_5, __pyx_t_1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 221, __pyx_L9_except_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_t_10 = __Pyx_PyObject_Call(__pyx_t_6, __pyx_t_2, NULL); - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 221, __pyx_L9_except_error) - __Pyx_GOTREF(__pyx_t_10); - __pyx_t_11 = __Pyx_PyObject_IsTrue(__pyx_t_10); - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - if (__pyx_t_11 < 0) __PYX_ERR(0, 221, __pyx_L9_except_error) - __pyx_t_12 = (!__pyx_t_11); - if (unlikely(__pyx_t_12)) { - __Pyx_GIVEREF(__pyx_t_3); - __Pyx_GIVEREF(__pyx_t_5); - __Pyx_XGIVEREF(__pyx_t_1); - __Pyx_ErrRestoreWithState(__pyx_t_3, __pyx_t_5, __pyx_t_1); - __pyx_t_3 = 0; __pyx_t_5 = 0; __pyx_t_1 = 0; - __PYX_ERR(0, 221, __pyx_L9_except_error) - } - __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0; - goto __pyx_L8_exception_handled; - } - __pyx_L9_except_error:; - __Pyx_XGIVEREF(__pyx_t_7); - __Pyx_XGIVEREF(__pyx_t_8); - __Pyx_XGIVEREF(__pyx_t_9); - __Pyx_ExceptionReset(__pyx_t_7, __pyx_t_8, __pyx_t_9); - goto __pyx_L1_error; - __pyx_L8_exception_handled:; - __Pyx_XGIVEREF(__pyx_t_7); - __Pyx_XGIVEREF(__pyx_t_8); - __Pyx_XGIVEREF(__pyx_t_9); - __Pyx_ExceptionReset(__pyx_t_7, __pyx_t_8, __pyx_t_9); - __pyx_L12_try_end:; - } - } - /*finally:*/ { - /*normal exit:*/{ - if (__pyx_t_6) { - __pyx_t_9 = __Pyx_PyObject_Call(__pyx_t_6, __pyx_mstate_global->__pyx_tuple[0], NULL); - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 221, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - } - goto __pyx_L6; - } - __pyx_L6:; - } - goto __pyx_L16; - __pyx_L3_error:; - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - goto __pyx_L1_error; - __pyx_L16:; - } - - /* "epanet/epanet.py":223 - * with open(path + '.json', 'w') as f: - * json.dump(data, f) - * return data # <<<<<<<<<<<<<< - * - * -*/ - __Pyx_XDECREF(__pyx_r); - if (!(likely(PyDict_CheckExact(__pyx_v_data))||((__pyx_v_data) == Py_None) || __Pyx_RaiseUnexpectedTypeError("dict", __pyx_v_data))) __PYX_ERR(0, 223, __pyx_L1_error) - __Pyx_INCREF(__pyx_v_data); - __pyx_r = ((PyObject*)__pyx_v_data); - goto __pyx_L0; - - /* "epanet/epanet.py":218 - * - * - * def _dump_output(path: str) -> dict[str, Any]: # <<<<<<<<<<<<<< - * opt = Output(path) - * data = opt.dump() -*/ - - /* function exit code */ - __pyx_L1_error:; - __Pyx_XDECREF(__pyx_t_1); - __Pyx_XDECREF(__pyx_t_2); - __Pyx_XDECREF(__pyx_t_3); - __Pyx_XDECREF(__pyx_t_5); - __Pyx_AddTraceback("epanet.epanet._dump_output", __pyx_clineno, __pyx_lineno, __pyx_filename); - __pyx_r = NULL; - __pyx_L0:; - __Pyx_XDECREF(__pyx_v_opt); - __Pyx_XDECREF(__pyx_v_data); - __Pyx_XDECREF(__pyx_v_f); - __Pyx_XGIVEREF(__pyx_r); - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -/* "epanet/epanet.py":226 - * - * - * def dump_output(path: str) -> str: # <<<<<<<<<<<<<< - * data = _dump_output(path) - * return json.dumps(data) -*/ - -/* Python wrapper */ -static PyObject *__pyx_pw_6epanet_6epanet_5dump_output(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -); /*proto*/ -static PyMethodDef __pyx_mdef_6epanet_6epanet_5dump_output = {"dump_output", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6epanet_6epanet_5dump_output, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}; -static PyObject *__pyx_pw_6epanet_6epanet_5dump_output(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -) { - PyObject *__pyx_v_path = 0; - #if !CYTHON_METH_FASTCALL - CYTHON_UNUSED Py_ssize_t __pyx_nargs; - #endif - CYTHON_UNUSED PyObject *const *__pyx_kwvalues; - PyObject* values[1] = {0}; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - PyObject *__pyx_r = 0; - __Pyx_RefNannyDeclarations - __Pyx_RefNannySetupContext("dump_output (wrapper)", 0); - #if !CYTHON_METH_FASTCALL - #if CYTHON_ASSUME_SAFE_SIZE - __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); - #else - __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; - #endif - #endif - __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); - { - PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_path,0}; - const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; - if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 226, __pyx_L3_error) - if (__pyx_kwds_len > 0) { - switch (__pyx_nargs) { - case 1: - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 226, __pyx_L3_error) - CYTHON_FALLTHROUGH; - case 0: break; - default: goto __pyx_L5_argtuple_error; - } - const Py_ssize_t kwd_pos_args = __pyx_nargs; - if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "dump_output", 0) < 0) __PYX_ERR(0, 226, __pyx_L3_error) - for (Py_ssize_t i = __pyx_nargs; i < 1; i++) { - if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("dump_output", 1, 1, 1, i); __PYX_ERR(0, 226, __pyx_L3_error) } - } - } else if (unlikely(__pyx_nargs != 1)) { - goto __pyx_L5_argtuple_error; - } else { - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 226, __pyx_L3_error) - } - __pyx_v_path = ((PyObject*)values[0]); - } - goto __pyx_L6_skip; - __pyx_L5_argtuple_error:; - __Pyx_RaiseArgtupleInvalid("dump_output", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 226, __pyx_L3_error) - __pyx_L6_skip:; - goto __pyx_L4_argument_unpacking_done; - __pyx_L3_error:; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_AddTraceback("epanet.epanet.dump_output", __pyx_clineno, __pyx_lineno, __pyx_filename); - __Pyx_RefNannyFinishContext(); - return NULL; - __pyx_L4_argument_unpacking_done:; - if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_path), (&PyUnicode_Type), 0, "path", 2))) __PYX_ERR(0, 226, __pyx_L1_error) - __pyx_r = __pyx_pf_6epanet_6epanet_4dump_output(__pyx_self, __pyx_v_path); - - /* function exit code */ - goto __pyx_L0; - __pyx_L1_error:; - __pyx_r = NULL; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - goto __pyx_L7_cleaned_up; - __pyx_L0:; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __pyx_L7_cleaned_up:; - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -static PyObject *__pyx_pf_6epanet_6epanet_4dump_output(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_path) { - PyObject *__pyx_v_data = NULL; - PyObject *__pyx_r = NULL; - __Pyx_RefNannyDeclarations - PyObject *__pyx_t_1 = NULL; - PyObject *__pyx_t_2 = NULL; - PyObject *__pyx_t_3 = NULL; - size_t __pyx_t_4; - PyObject *__pyx_t_5 = NULL; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - __Pyx_RefNannySetupContext("dump_output", 0); - - /* "epanet/epanet.py":227 - * - * def dump_output(path: str) -> str: - * data = _dump_output(path) # <<<<<<<<<<<<<< - * return json.dumps(data) - * -*/ - __pyx_t_2 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_dump_output); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 227, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __pyx_t_4 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_3))) { - __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_3); - assert(__pyx_t_2); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_3); - __Pyx_INCREF(__pyx_t_2); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_3, __pyx__function); - __pyx_t_4 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_v_path}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_3, __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 227, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_v_data = __pyx_t_1; - __pyx_t_1 = 0; - - /* "epanet/epanet.py":228 - * def dump_output(path: str) -> str: - * data = _dump_output(path) - * return json.dumps(data) # <<<<<<<<<<<<<< - * - * -*/ - __Pyx_XDECREF(__pyx_r); - __pyx_t_3 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_json_2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 228, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_dumps); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 228, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __pyx_t_4 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_5))) { - __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_5); - assert(__pyx_t_3); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_5); - __Pyx_INCREF(__pyx_t_3); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_5, __pyx__function); - __pyx_t_4 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_v_data}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_5, __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 228, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - if (!(likely(PyUnicode_CheckExact(__pyx_t_1))||((__pyx_t_1) == Py_None) || __Pyx_RaiseUnexpectedTypeError("str", __pyx_t_1))) __PYX_ERR(0, 228, __pyx_L1_error) - __pyx_r = ((PyObject*)__pyx_t_1); - __pyx_t_1 = 0; - goto __pyx_L0; - - /* "epanet/epanet.py":226 - * - * - * def dump_output(path: str) -> str: # <<<<<<<<<<<<<< - * data = _dump_output(path) - * return json.dumps(data) -*/ - - /* function exit code */ - __pyx_L1_error:; - __Pyx_XDECREF(__pyx_t_1); - __Pyx_XDECREF(__pyx_t_2); - __Pyx_XDECREF(__pyx_t_3); - __Pyx_XDECREF(__pyx_t_5); - __Pyx_AddTraceback("epanet.epanet.dump_output", __pyx_clineno, __pyx_lineno, __pyx_filename); - __pyx_r = NULL; - __pyx_L0:; - __Pyx_XDECREF(__pyx_v_data); - __Pyx_XGIVEREF(__pyx_r); - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -/* "epanet/epanet.py":231 - * - * - * def dump_report(path: str) -> str: # <<<<<<<<<<<<<< - * return open(path, 'r').read() - * -*/ - -/* Python wrapper */ -static PyObject *__pyx_pw_6epanet_6epanet_7dump_report(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -); /*proto*/ -static PyMethodDef __pyx_mdef_6epanet_6epanet_7dump_report = {"dump_report", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6epanet_6epanet_7dump_report, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}; -static PyObject *__pyx_pw_6epanet_6epanet_7dump_report(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -) { - PyObject *__pyx_v_path = 0; - #if !CYTHON_METH_FASTCALL - CYTHON_UNUSED Py_ssize_t __pyx_nargs; - #endif - CYTHON_UNUSED PyObject *const *__pyx_kwvalues; - PyObject* values[1] = {0}; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - PyObject *__pyx_r = 0; - __Pyx_RefNannyDeclarations - __Pyx_RefNannySetupContext("dump_report (wrapper)", 0); - #if !CYTHON_METH_FASTCALL - #if CYTHON_ASSUME_SAFE_SIZE - __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); - #else - __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; - #endif - #endif - __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); - { - PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_path,0}; - const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; - if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 231, __pyx_L3_error) - if (__pyx_kwds_len > 0) { - switch (__pyx_nargs) { - case 1: - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 231, __pyx_L3_error) - CYTHON_FALLTHROUGH; - case 0: break; - default: goto __pyx_L5_argtuple_error; - } - const Py_ssize_t kwd_pos_args = __pyx_nargs; - if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "dump_report", 0) < 0) __PYX_ERR(0, 231, __pyx_L3_error) - for (Py_ssize_t i = __pyx_nargs; i < 1; i++) { - if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("dump_report", 1, 1, 1, i); __PYX_ERR(0, 231, __pyx_L3_error) } - } - } else if (unlikely(__pyx_nargs != 1)) { - goto __pyx_L5_argtuple_error; - } else { - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 231, __pyx_L3_error) - } - __pyx_v_path = ((PyObject*)values[0]); - } - goto __pyx_L6_skip; - __pyx_L5_argtuple_error:; - __Pyx_RaiseArgtupleInvalid("dump_report", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 231, __pyx_L3_error) - __pyx_L6_skip:; - goto __pyx_L4_argument_unpacking_done; - __pyx_L3_error:; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_AddTraceback("epanet.epanet.dump_report", __pyx_clineno, __pyx_lineno, __pyx_filename); - __Pyx_RefNannyFinishContext(); - return NULL; - __pyx_L4_argument_unpacking_done:; - if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_path), (&PyUnicode_Type), 0, "path", 2))) __PYX_ERR(0, 231, __pyx_L1_error) - __pyx_r = __pyx_pf_6epanet_6epanet_6dump_report(__pyx_self, __pyx_v_path); - - /* function exit code */ - goto __pyx_L0; - __pyx_L1_error:; - __pyx_r = NULL; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - goto __pyx_L7_cleaned_up; - __pyx_L0:; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __pyx_L7_cleaned_up:; - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -static PyObject *__pyx_pf_6epanet_6epanet_6dump_report(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_path) { - PyObject *__pyx_r = NULL; - __Pyx_RefNannyDeclarations - PyObject *__pyx_t_1 = NULL; - PyObject *__pyx_t_2 = NULL; - PyObject *__pyx_t_3 = NULL; - PyObject *__pyx_t_4 = NULL; - PyObject *__pyx_t_5 = NULL; - size_t __pyx_t_6; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - __Pyx_RefNannySetupContext("dump_report", 0); - - /* "epanet/epanet.py":232 - * - * def dump_report(path: str) -> str: - * return open(path, 'r').read() # <<<<<<<<<<<<<< - * - * -*/ - __Pyx_XDECREF(__pyx_r); - __pyx_t_4 = NULL; - __Pyx_INCREF(__pyx_builtin_open); - __pyx_t_5 = __pyx_builtin_open; - __pyx_t_6 = 1; - { - PyObject *__pyx_callargs[3] = {__pyx_t_4, __pyx_v_path, __pyx_mstate_global->__pyx_n_u_r}; - __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_5, __pyx_callargs+__pyx_t_6, (3-__pyx_t_6) | (__pyx_t_6*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 232, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - } - __pyx_t_2 = __pyx_t_3; - __Pyx_INCREF(__pyx_t_2); - __pyx_t_6 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_2, NULL}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_read, __pyx_callargs+__pyx_t_6, (1-__pyx_t_6) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 232, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - if (!(likely(PyUnicode_CheckExact(__pyx_t_1))||((__pyx_t_1) == Py_None) || __Pyx_RaiseUnexpectedTypeError("str", __pyx_t_1))) __PYX_ERR(0, 232, __pyx_L1_error) - __pyx_r = ((PyObject*)__pyx_t_1); - __pyx_t_1 = 0; - goto __pyx_L0; - - /* "epanet/epanet.py":231 - * - * - * def dump_report(path: str) -> str: # <<<<<<<<<<<<<< - * return open(path, 'r').read() - * -*/ - - /* function exit code */ - __pyx_L1_error:; - __Pyx_XDECREF(__pyx_t_1); - __Pyx_XDECREF(__pyx_t_2); - __Pyx_XDECREF(__pyx_t_3); - __Pyx_XDECREF(__pyx_t_4); - __Pyx_XDECREF(__pyx_t_5); - __Pyx_AddTraceback("epanet.epanet.dump_report", __pyx_clineno, __pyx_lineno, __pyx_filename); - __pyx_r = NULL; - __pyx_L0:; - __Pyx_XGIVEREF(__pyx_r); - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -/* "epanet/epanet.py":235 - * - * - * def dump_output_binary(path: str) -> str: # <<<<<<<<<<<<<< - * with open(path, 'rb') as f: - * data = f.read() -*/ - -/* Python wrapper */ -static PyObject *__pyx_pw_6epanet_6epanet_9dump_output_binary(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -); /*proto*/ -static PyMethodDef __pyx_mdef_6epanet_6epanet_9dump_output_binary = {"dump_output_binary", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6epanet_6epanet_9dump_output_binary, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}; -static PyObject *__pyx_pw_6epanet_6epanet_9dump_output_binary(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -) { - PyObject *__pyx_v_path = 0; - #if !CYTHON_METH_FASTCALL - CYTHON_UNUSED Py_ssize_t __pyx_nargs; - #endif - CYTHON_UNUSED PyObject *const *__pyx_kwvalues; - PyObject* values[1] = {0}; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - PyObject *__pyx_r = 0; - __Pyx_RefNannyDeclarations - __Pyx_RefNannySetupContext("dump_output_binary (wrapper)", 0); - #if !CYTHON_METH_FASTCALL - #if CYTHON_ASSUME_SAFE_SIZE - __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); - #else - __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; - #endif - #endif - __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); - { - PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_path,0}; - const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; - if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 235, __pyx_L3_error) - if (__pyx_kwds_len > 0) { - switch (__pyx_nargs) { - case 1: - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 235, __pyx_L3_error) - CYTHON_FALLTHROUGH; - case 0: break; - default: goto __pyx_L5_argtuple_error; - } - const Py_ssize_t kwd_pos_args = __pyx_nargs; - if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "dump_output_binary", 0) < 0) __PYX_ERR(0, 235, __pyx_L3_error) - for (Py_ssize_t i = __pyx_nargs; i < 1; i++) { - if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("dump_output_binary", 1, 1, 1, i); __PYX_ERR(0, 235, __pyx_L3_error) } - } - } else if (unlikely(__pyx_nargs != 1)) { - goto __pyx_L5_argtuple_error; - } else { - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 235, __pyx_L3_error) - } - __pyx_v_path = ((PyObject*)values[0]); - } - goto __pyx_L6_skip; - __pyx_L5_argtuple_error:; - __Pyx_RaiseArgtupleInvalid("dump_output_binary", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 235, __pyx_L3_error) - __pyx_L6_skip:; - goto __pyx_L4_argument_unpacking_done; - __pyx_L3_error:; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_AddTraceback("epanet.epanet.dump_output_binary", __pyx_clineno, __pyx_lineno, __pyx_filename); - __Pyx_RefNannyFinishContext(); - return NULL; - __pyx_L4_argument_unpacking_done:; - if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_path), (&PyUnicode_Type), 0, "path", 2))) __PYX_ERR(0, 235, __pyx_L1_error) - __pyx_r = __pyx_pf_6epanet_6epanet_8dump_output_binary(__pyx_self, __pyx_v_path); - - /* function exit code */ - goto __pyx_L0; - __pyx_L1_error:; - __pyx_r = NULL; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - goto __pyx_L7_cleaned_up; - __pyx_L0:; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __pyx_L7_cleaned_up:; - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -static PyObject *__pyx_pf_6epanet_6epanet_8dump_output_binary(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_path) { - PyObject *__pyx_v_f = NULL; - PyObject *__pyx_v_data = NULL; - PyObject *__pyx_v_bast64_data = NULL; - PyObject *__pyx_r = NULL; - __Pyx_RefNannyDeclarations - PyObject *__pyx_t_1 = NULL; - PyObject *__pyx_t_2 = NULL; - PyObject *__pyx_t_3 = NULL; - size_t __pyx_t_4; - PyObject *__pyx_t_5 = NULL; - PyObject *__pyx_t_6 = NULL; - PyObject *__pyx_t_7 = NULL; - PyObject *__pyx_t_8 = NULL; - PyObject *__pyx_t_9 = NULL; - PyObject *__pyx_t_10 = NULL; - int __pyx_t_11; - int __pyx_t_12; - PyObject *__pyx_t_13 = NULL; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - __Pyx_RefNannySetupContext("dump_output_binary", 0); - - /* "epanet/epanet.py":236 - * - * def dump_output_binary(path: str) -> str: - * with open(path, 'rb') as f: # <<<<<<<<<<<<<< - * data = f.read() - * bast64_data = base64.b64encode(data) -*/ - /*with:*/ { - __pyx_t_2 = NULL; - __Pyx_INCREF(__pyx_builtin_open); - __pyx_t_3 = __pyx_builtin_open; - __pyx_t_4 = 1; - { - PyObject *__pyx_callargs[3] = {__pyx_t_2, __pyx_v_path, __pyx_mstate_global->__pyx_n_u_rb}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_3, __pyx_callargs+__pyx_t_4, (3-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 236, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_t_5 = __Pyx_PyObject_LookupSpecial(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_exit); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 236, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __pyx_t_2 = NULL; - __pyx_t_6 = __Pyx_PyObject_LookupSpecial(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_enter); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 236, __pyx_L3_error) - __Pyx_GOTREF(__pyx_t_6); - __pyx_t_4 = 1; - #if CYTHON_UNPACK_METHODS - if (likely(PyMethod_Check(__pyx_t_6))) { - __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_6); - assert(__pyx_t_2); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_6); - __Pyx_INCREF(__pyx_t_2); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_6, __pyx__function); - __pyx_t_4 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_2, NULL}; - __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_6, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 236, __pyx_L3_error) - __Pyx_GOTREF(__pyx_t_3); - } - __pyx_t_6 = __pyx_t_3; - __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - /*try:*/ { - { - __Pyx_PyThreadState_declare - __Pyx_PyThreadState_assign - __Pyx_ExceptionSave(&__pyx_t_7, &__pyx_t_8, &__pyx_t_9); - __Pyx_XGOTREF(__pyx_t_7); - __Pyx_XGOTREF(__pyx_t_8); - __Pyx_XGOTREF(__pyx_t_9); - /*try:*/ { - __pyx_v_f = __pyx_t_6; - __pyx_t_6 = 0; - - /* "epanet/epanet.py":237 - * def dump_output_binary(path: str) -> str: - * with open(path, 'rb') as f: - * data = f.read() # <<<<<<<<<<<<<< - * bast64_data = base64.b64encode(data) - * return str(bast64_data, 'utf-8') -*/ - __pyx_t_1 = __pyx_v_f; - __Pyx_INCREF(__pyx_t_1); - __pyx_t_4 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_1, NULL}; - __pyx_t_6 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_read, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0; - if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 237, __pyx_L7_error) - __Pyx_GOTREF(__pyx_t_6); - } - __pyx_v_data = __pyx_t_6; - __pyx_t_6 = 0; - - /* "epanet/epanet.py":238 - * with open(path, 'rb') as f: - * data = f.read() - * bast64_data = base64.b64encode(data) # <<<<<<<<<<<<<< - * return str(bast64_data, 'utf-8') - * -*/ - __pyx_t_1 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_base64); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 238, __pyx_L7_error) - __Pyx_GOTREF(__pyx_t_3); - __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_b64encode); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 238, __pyx_L7_error) - __Pyx_GOTREF(__pyx_t_2); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __pyx_t_4 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_2))) { - __pyx_t_1 = PyMethod_GET_SELF(__pyx_t_2); - assert(__pyx_t_1); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_2); - __Pyx_INCREF(__pyx_t_1); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_2, __pyx__function); - __pyx_t_4 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_1, __pyx_v_data}; - __pyx_t_6 = __Pyx_PyObject_FastCall(__pyx_t_2, __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0; - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 238, __pyx_L7_error) - __Pyx_GOTREF(__pyx_t_6); - } - __pyx_v_bast64_data = __pyx_t_6; - __pyx_t_6 = 0; - - /* "epanet/epanet.py":239 - * data = f.read() - * bast64_data = base64.b64encode(data) - * return str(bast64_data, 'utf-8') # <<<<<<<<<<<<<< - * - * #DingZQ, 2025-02-04, dict[str, Any] -*/ - __Pyx_XDECREF(__pyx_r); - __pyx_t_2 = NULL; - __Pyx_INCREF((PyObject *)(&PyUnicode_Type)); - __pyx_t_1 = ((PyObject *)(&PyUnicode_Type)); - __pyx_t_4 = 1; - { - PyObject *__pyx_callargs[3] = {__pyx_t_2, __pyx_v_bast64_data, __pyx_mstate_global->__pyx_kp_u_utf_8}; - __pyx_t_6 = __Pyx_PyObject_FastCall(__pyx_t_1, __pyx_callargs+__pyx_t_4, (3-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 239, __pyx_L7_error) - __Pyx_GOTREF(__pyx_t_6); - } - __pyx_r = ((PyObject*)__pyx_t_6); - __pyx_t_6 = 0; - goto __pyx_L11_try_return; - - /* "epanet/epanet.py":236 - * - * def dump_output_binary(path: str) -> str: - * with open(path, 'rb') as f: # <<<<<<<<<<<<<< - * data = f.read() - * bast64_data = base64.b64encode(data) -*/ - } - __pyx_L7_error:; - __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0; - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; - /*except:*/ { - __Pyx_AddTraceback("epanet.epanet.dump_output_binary", __pyx_clineno, __pyx_lineno, __pyx_filename); - if (__Pyx_GetException(&__pyx_t_6, &__pyx_t_1, &__pyx_t_2) < 0) __PYX_ERR(0, 236, __pyx_L9_except_error) - __Pyx_XGOTREF(__pyx_t_6); - __Pyx_XGOTREF(__pyx_t_1); - __Pyx_XGOTREF(__pyx_t_2); - __pyx_t_3 = PyTuple_Pack(3, __pyx_t_6, __pyx_t_1, __pyx_t_2); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 236, __pyx_L9_except_error) - __Pyx_GOTREF(__pyx_t_3); - __pyx_t_10 = __Pyx_PyObject_Call(__pyx_t_5, __pyx_t_3, NULL); - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 236, __pyx_L9_except_error) - __Pyx_GOTREF(__pyx_t_10); - __pyx_t_11 = __Pyx_PyObject_IsTrue(__pyx_t_10); - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - if (__pyx_t_11 < 0) __PYX_ERR(0, 236, __pyx_L9_except_error) - __pyx_t_12 = (!__pyx_t_11); - if (unlikely(__pyx_t_12)) { - __Pyx_GIVEREF(__pyx_t_6); - __Pyx_GIVEREF(__pyx_t_1); - __Pyx_XGIVEREF(__pyx_t_2); - __Pyx_ErrRestoreWithState(__pyx_t_6, __pyx_t_1, __pyx_t_2); - __pyx_t_6 = 0; __pyx_t_1 = 0; __pyx_t_2 = 0; - __PYX_ERR(0, 236, __pyx_L9_except_error) - } - __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; - __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0; - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - goto __pyx_L8_exception_handled; - } - __pyx_L9_except_error:; - __Pyx_XGIVEREF(__pyx_t_7); - __Pyx_XGIVEREF(__pyx_t_8); - __Pyx_XGIVEREF(__pyx_t_9); - __Pyx_ExceptionReset(__pyx_t_7, __pyx_t_8, __pyx_t_9); - goto __pyx_L1_error; - __pyx_L11_try_return:; - __Pyx_XGIVEREF(__pyx_t_7); - __Pyx_XGIVEREF(__pyx_t_8); - __Pyx_XGIVEREF(__pyx_t_9); - __Pyx_ExceptionReset(__pyx_t_7, __pyx_t_8, __pyx_t_9); - goto __pyx_L4_return; - __pyx_L8_exception_handled:; - __Pyx_XGIVEREF(__pyx_t_7); - __Pyx_XGIVEREF(__pyx_t_8); - __Pyx_XGIVEREF(__pyx_t_9); - __Pyx_ExceptionReset(__pyx_t_7, __pyx_t_8, __pyx_t_9); - } - } - /*finally:*/ { - /*normal exit:*/{ - if (__pyx_t_5) { - __pyx_t_9 = __Pyx_PyObject_Call(__pyx_t_5, __pyx_mstate_global->__pyx_tuple[0], NULL); - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 236, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - } - goto __pyx_L6; - } - __pyx_L4_return: { - __pyx_t_13 = __pyx_r; - __pyx_r = 0; - if (__pyx_t_5) { - __pyx_t_9 = __Pyx_PyObject_Call(__pyx_t_5, __pyx_mstate_global->__pyx_tuple[0], NULL); - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 236, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - } - __pyx_r = __pyx_t_13; - __pyx_t_13 = 0; - goto __pyx_L0; - } - __pyx_L6:; - } - goto __pyx_L16; - __pyx_L3_error:; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - goto __pyx_L1_error; - __pyx_L16:; - } - - /* "epanet/epanet.py":235 - * - * - * def dump_output_binary(path: str) -> str: # <<<<<<<<<<<<<< - * with open(path, 'rb') as f: - * data = f.read() -*/ - - /* function exit code */ - __pyx_r = ((PyObject*)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_6); - __Pyx_AddTraceback("epanet.epanet.dump_output_binary", __pyx_clineno, __pyx_lineno, __pyx_filename); - __pyx_r = NULL; - __pyx_L0:; - __Pyx_XDECREF(__pyx_v_f); - __Pyx_XDECREF(__pyx_v_data); - __Pyx_XDECREF(__pyx_v_bast64_data); - __Pyx_XGIVEREF(__pyx_r); - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -/* "epanet/epanet.py":242 - * - * #DingZQ, 2025-02-04, dict[str, Any] - * def run_project_return_dict(name: str, readable_output: bool = False) -> dict[str, Any]: # <<<<<<<<<<<<<< - * if not project.have_project(name): - * raise Exception(f'Not found project [{name}]') -*/ - -/* Python wrapper */ -static PyObject *__pyx_pw_6epanet_6epanet_11run_project_return_dict(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -); /*proto*/ -static PyMethodDef __pyx_mdef_6epanet_6epanet_11run_project_return_dict = {"run_project_return_dict", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6epanet_6epanet_11run_project_return_dict, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}; -static PyObject *__pyx_pw_6epanet_6epanet_11run_project_return_dict(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -) { - PyObject *__pyx_v_name = 0; - PyObject *__pyx_v_readable_output = 0; - #if !CYTHON_METH_FASTCALL - CYTHON_UNUSED Py_ssize_t __pyx_nargs; - #endif - CYTHON_UNUSED PyObject *const *__pyx_kwvalues; - PyObject* values[2] = {0,0}; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - PyObject *__pyx_r = 0; - __Pyx_RefNannyDeclarations - __Pyx_RefNannySetupContext("run_project_return_dict (wrapper)", 0); - #if !CYTHON_METH_FASTCALL - #if CYTHON_ASSUME_SAFE_SIZE - __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); - #else - __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; - #endif - #endif - __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); - { - PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_name,&__pyx_mstate_global->__pyx_n_u_readable_output,0}; - const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; - if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 242, __pyx_L3_error) - if (__pyx_kwds_len > 0) { - switch (__pyx_nargs) { - case 2: - values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 242, __pyx_L3_error) - CYTHON_FALLTHROUGH; - case 1: - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 242, __pyx_L3_error) - CYTHON_FALLTHROUGH; - case 0: break; - default: goto __pyx_L5_argtuple_error; - } - const Py_ssize_t kwd_pos_args = __pyx_nargs; - if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "run_project_return_dict", 0) < 0) __PYX_ERR(0, 242, __pyx_L3_error) - if (!values[1]) values[1] = __Pyx_NewRef(((PyObject *)((PyObject *)Py_False))); - for (Py_ssize_t i = __pyx_nargs; i < 1; i++) { - if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("run_project_return_dict", 0, 1, 2, i); __PYX_ERR(0, 242, __pyx_L3_error) } - } - } else { - switch (__pyx_nargs) { - case 2: - values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 242, __pyx_L3_error) - CYTHON_FALLTHROUGH; - case 1: - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 242, __pyx_L3_error) - break; - default: goto __pyx_L5_argtuple_error; - } - if (!values[1]) values[1] = __Pyx_NewRef(((PyObject *)((PyObject *)Py_False))); - } - __pyx_v_name = ((PyObject*)values[0]); - __pyx_v_readable_output = values[1]; - } - goto __pyx_L6_skip; - __pyx_L5_argtuple_error:; - __Pyx_RaiseArgtupleInvalid("run_project_return_dict", 0, 1, 2, __pyx_nargs); __PYX_ERR(0, 242, __pyx_L3_error) - __pyx_L6_skip:; - goto __pyx_L4_argument_unpacking_done; - __pyx_L3_error:; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_AddTraceback("epanet.epanet.run_project_return_dict", __pyx_clineno, __pyx_lineno, __pyx_filename); - __Pyx_RefNannyFinishContext(); - return NULL; - __pyx_L4_argument_unpacking_done:; - if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_name), (&PyUnicode_Type), 0, "name", 2))) __PYX_ERR(0, 242, __pyx_L1_error) - __pyx_r = __pyx_pf_6epanet_6epanet_10run_project_return_dict(__pyx_self, __pyx_v_name, __pyx_v_readable_output); - - /* function exit code */ - goto __pyx_L0; - __pyx_L1_error:; - __pyx_r = NULL; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - goto __pyx_L7_cleaned_up; - __pyx_L0:; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __pyx_L7_cleaned_up:; - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -static PyObject *__pyx_pf_6epanet_6epanet_10run_project_return_dict(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_name, PyObject *__pyx_v_readable_output) { - PyObject *__pyx_v_dir = NULL; - PyObject *__pyx_v_db_inp = NULL; - PyObject *__pyx_v_input = NULL; - PyObject *__pyx_v_exe = NULL; - PyObject *__pyx_v_inp = NULL; - PyObject *__pyx_v_rpt = NULL; - PyObject *__pyx_v_opt = NULL; - PyObject *__pyx_v_command = NULL; - PyObject *__pyx_v_data = NULL; - PyObject *__pyx_v_result = NULL; - PyObject *__pyx_r = NULL; - __Pyx_RefNannyDeclarations - PyObject *__pyx_t_1 = NULL; - PyObject *__pyx_t_2 = NULL; - PyObject *__pyx_t_3 = NULL; - PyObject *__pyx_t_4 = NULL; - size_t __pyx_t_5; - int __pyx_t_6; - int __pyx_t_7; - PyObject *__pyx_t_8[3]; - PyObject *__pyx_t_9 = NULL; - PyObject *__pyx_t_10 = NULL; - PyObject *__pyx_t_11 = NULL; - PyObject *__pyx_t_12[7]; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - __Pyx_RefNannySetupContext("run_project_return_dict", 0); - - /* "epanet/epanet.py":243 - * #DingZQ, 2025-02-04, dict[str, Any] - * def run_project_return_dict(name: str, readable_output: bool = False) -> dict[str, Any]: - * if not project.have_project(name): # <<<<<<<<<<<<<< - * raise Exception(f'Not found project [{name}]') - * -*/ - __pyx_t_2 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_project); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 243, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_have_project); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 243, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __pyx_t_5 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_4))) { - __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_4); - assert(__pyx_t_2); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); - __Pyx_INCREF(__pyx_t_2); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); - __pyx_t_5 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_v_name}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 243, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_t_6 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely((__pyx_t_6 < 0))) __PYX_ERR(0, 243, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __pyx_t_7 = (!__pyx_t_6); - if (unlikely(__pyx_t_7)) { - - /* "epanet/epanet.py":244 - * def run_project_return_dict(name: str, readable_output: bool = False) -> dict[str, Any]: - * if not project.have_project(name): - * raise Exception(f'Not found project [{name}]') # <<<<<<<<<<<<<< - * - * dir = os.path.abspath(os.getcwd()) -*/ - __pyx_t_4 = NULL; - __Pyx_INCREF((PyObject *)(((PyTypeObject*)PyExc_Exception))); - __pyx_t_2 = ((PyObject *)(((PyTypeObject*)PyExc_Exception))); - __pyx_t_8[0] = __pyx_mstate_global->__pyx_kp_u_Not_found_project; - __pyx_t_8[1] = __pyx_v_name; - __pyx_t_8[2] = __pyx_mstate_global->__pyx_kp_u_; - __pyx_t_3 = __Pyx_PyUnicode_Join(__pyx_t_8, 3, 19 + __Pyx_PyUnicode_GET_LENGTH(__pyx_v_name) + 1, 127 | __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_v_name)); - if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 244, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __pyx_t_5 = 1; - { - PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_t_3}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_2, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 244, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __Pyx_Raise(__pyx_t_1, 0, 0, 0); - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __PYX_ERR(0, 244, __pyx_L1_error) - - /* "epanet/epanet.py":243 - * #DingZQ, 2025-02-04, dict[str, Any] - * def run_project_return_dict(name: str, readable_output: bool = False) -> dict[str, Any]: - * if not project.have_project(name): # <<<<<<<<<<<<<< - * raise Exception(f'Not found project [{name}]') - * -*/ - } - - /* "epanet/epanet.py":246 - * raise Exception(f'Not found project [{name}]') - * - * dir = os.path.abspath(os.getcwd()) # <<<<<<<<<<<<<< - * - * db_inp = os.path.join(os.path.join(dir, 'db_inp'), name + '.db.inp') -*/ - __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 246, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 246, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __pyx_t_2 = __pyx_t_4; - __Pyx_INCREF(__pyx_t_2); - __pyx_t_9 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 246, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_getcwd); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 246, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - __pyx_t_5 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_11))) { - __pyx_t_9 = PyMethod_GET_SELF(__pyx_t_11); - assert(__pyx_t_9); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_11); - __Pyx_INCREF(__pyx_t_9); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_11, __pyx__function); - __pyx_t_5 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_9, NULL}; - __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_11, __pyx_callargs+__pyx_t_5, (1-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 246, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - } - __pyx_t_5 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_t_3}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_abspath, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 246, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_v_dir = __pyx_t_1; - __pyx_t_1 = 0; - - /* "epanet/epanet.py":248 - * dir = os.path.abspath(os.getcwd()) - * - * db_inp = os.path.join(os.path.join(dir, 'db_inp'), name + '.db.inp') # <<<<<<<<<<<<<< - * inp_out.dump_inp(name, db_inp, '2') - * -*/ - __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 248, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 248, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __pyx_t_4 = __pyx_t_2; - __Pyx_INCREF(__pyx_t_4); - __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 248, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 248, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - __pyx_t_11 = __pyx_t_10; - __Pyx_INCREF(__pyx_t_11); - __pyx_t_5 = 0; - { - PyObject *__pyx_callargs[3] = {__pyx_t_11, __pyx_v_dir, __pyx_mstate_global->__pyx_n_u_db_inp}; - __pyx_t_3 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_join, __pyx_callargs+__pyx_t_5, (3-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 248, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - } - __pyx_t_10 = __Pyx_PyUnicode_Concat(__pyx_v_name, __pyx_mstate_global->__pyx_kp_u_db_inp_2); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 248, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - __pyx_t_5 = 0; - { - PyObject *__pyx_callargs[3] = {__pyx_t_4, __pyx_t_3, __pyx_t_10}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_join, __pyx_callargs+__pyx_t_5, (3-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 248, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_v_db_inp = __pyx_t_1; - __pyx_t_1 = 0; - - /* "epanet/epanet.py":249 - * - * db_inp = os.path.join(os.path.join(dir, 'db_inp'), name + '.db.inp') - * inp_out.dump_inp(name, db_inp, '2') # <<<<<<<<<<<<<< - * - * input = name + '.db' -*/ - __pyx_t_2 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_inp_out); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 249, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_dump_inp); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 249, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - __pyx_t_5 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_3))) { - __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_3); - assert(__pyx_t_2); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_3); - __Pyx_INCREF(__pyx_t_2); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_3, __pyx__function); - __pyx_t_5 = 0; - } - #endif - { - PyObject *__pyx_callargs[4] = {__pyx_t_2, __pyx_v_name, __pyx_v_db_inp, __pyx_mstate_global->__pyx_kp_u_2}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_3, __pyx_callargs+__pyx_t_5, (4-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 249, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - - /* "epanet/epanet.py":251 - * inp_out.dump_inp(name, db_inp, '2') - * - * input = name + '.db' # <<<<<<<<<<<<<< - * exe = os.path.join(os.path.join(dir, 'epanet'), 'runepanet.exe') - * inp = os.path.join(os.path.join(dir, 'db_inp'), input + '.inp') -*/ - __pyx_t_1 = __Pyx_PyUnicode_Concat(__pyx_v_name, __pyx_mstate_global->__pyx_kp_u_db); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 251, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_v_input = ((PyObject*)__pyx_t_1); - __pyx_t_1 = 0; - - /* "epanet/epanet.py":252 - * - * input = name + '.db' - * exe = os.path.join(os.path.join(dir, 'epanet'), 'runepanet.exe') # <<<<<<<<<<<<<< - * inp = os.path.join(os.path.join(dir, 'db_inp'), input + '.inp') - * rpt = os.path.join(os.path.join(dir, 'temp'), input + '.rpt') -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 252, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 252, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __pyx_t_3 = __pyx_t_10; - __Pyx_INCREF(__pyx_t_3); - __Pyx_GetModuleGlobalName(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 252, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __pyx_t_9 = __Pyx_PyObject_GetAttrStr(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 252, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - __pyx_t_4 = __pyx_t_9; - __Pyx_INCREF(__pyx_t_4); - __pyx_t_5 = 0; - { - PyObject *__pyx_callargs[3] = {__pyx_t_4, __pyx_v_dir, __pyx_mstate_global->__pyx_n_u_epanet}; - __pyx_t_2 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_join, __pyx_callargs+__pyx_t_5, (3-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 252, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - __pyx_t_5 = 0; - { - PyObject *__pyx_callargs[3] = {__pyx_t_3, __pyx_t_2, __pyx_mstate_global->__pyx_kp_u_runepanet_exe}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_join, __pyx_callargs+__pyx_t_5, (3-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 252, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_v_exe = __pyx_t_1; - __pyx_t_1 = 0; - - /* "epanet/epanet.py":253 - * input = name + '.db' - * exe = os.path.join(os.path.join(dir, 'epanet'), 'runepanet.exe') - * inp = os.path.join(os.path.join(dir, 'db_inp'), input + '.inp') # <<<<<<<<<<<<<< - * rpt = os.path.join(os.path.join(dir, 'temp'), input + '.rpt') - * opt = os.path.join(os.path.join(dir, 'temp'), input + '.opt') -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 253, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 253, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __pyx_t_10 = __pyx_t_3; - __Pyx_INCREF(__pyx_t_10); - __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 253, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 253, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - __pyx_t_9 = __pyx_t_11; - __Pyx_INCREF(__pyx_t_9); - __pyx_t_5 = 0; - { - PyObject *__pyx_callargs[3] = {__pyx_t_9, __pyx_v_dir, __pyx_mstate_global->__pyx_n_u_db_inp}; - __pyx_t_2 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_join, __pyx_callargs+__pyx_t_5, (3-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 253, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - __pyx_t_11 = __Pyx_PyUnicode_Concat(__pyx_v_input, __pyx_mstate_global->__pyx_kp_u_inp); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 253, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __pyx_t_5 = 0; - { - PyObject *__pyx_callargs[3] = {__pyx_t_10, __pyx_t_2, __pyx_t_11}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_join, __pyx_callargs+__pyx_t_5, (3-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0; - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 253, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_v_inp = __pyx_t_1; - __pyx_t_1 = 0; - - /* "epanet/epanet.py":254 - * exe = os.path.join(os.path.join(dir, 'epanet'), 'runepanet.exe') - * inp = os.path.join(os.path.join(dir, 'db_inp'), input + '.inp') - * rpt = os.path.join(os.path.join(dir, 'temp'), input + '.rpt') # <<<<<<<<<<<<<< - * opt = os.path.join(os.path.join(dir, 'temp'), input + '.opt') - * command = f'{exe} {inp} {rpt} {opt}' -*/ - __Pyx_GetModuleGlobalName(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 254, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 254, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - __pyx_t_3 = __pyx_t_2; - __Pyx_INCREF(__pyx_t_3); - __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 254, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 254, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - __pyx_t_10 = __pyx_t_4; - __Pyx_INCREF(__pyx_t_10); - __pyx_t_5 = 0; - { - PyObject *__pyx_callargs[3] = {__pyx_t_10, __pyx_v_dir, __pyx_mstate_global->__pyx_n_u_temp}; - __pyx_t_11 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_join, __pyx_callargs+__pyx_t_5, (3-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 254, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - } - __pyx_t_4 = __Pyx_PyUnicode_Concat(__pyx_v_input, __pyx_mstate_global->__pyx_kp_u_rpt); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 254, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __pyx_t_5 = 0; - { - PyObject *__pyx_callargs[3] = {__pyx_t_3, __pyx_t_11, __pyx_t_4}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_join, __pyx_callargs+__pyx_t_5, (3-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 254, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_v_rpt = __pyx_t_1; - __pyx_t_1 = 0; - - /* "epanet/epanet.py":255 - * inp = os.path.join(os.path.join(dir, 'db_inp'), input + '.inp') - * rpt = os.path.join(os.path.join(dir, 'temp'), input + '.rpt') - * opt = os.path.join(os.path.join(dir, 'temp'), input + '.opt') # <<<<<<<<<<<<<< - * command = f'{exe} {inp} {rpt} {opt}' - * -*/ - __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 255, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 255, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - __pyx_t_2 = __pyx_t_11; - __Pyx_INCREF(__pyx_t_2); - __Pyx_GetModuleGlobalName(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 255, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - __pyx_t_9 = __Pyx_PyObject_GetAttrStr(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 255, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - __pyx_t_3 = __pyx_t_9; - __Pyx_INCREF(__pyx_t_3); - __pyx_t_5 = 0; - { - PyObject *__pyx_callargs[3] = {__pyx_t_3, __pyx_v_dir, __pyx_mstate_global->__pyx_n_u_temp}; - __pyx_t_4 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_join, __pyx_callargs+__pyx_t_5, (3-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 255, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - } - __pyx_t_9 = __Pyx_PyUnicode_Concat(__pyx_v_input, __pyx_mstate_global->__pyx_kp_u_opt); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 255, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - __pyx_t_5 = 0; - { - PyObject *__pyx_callargs[3] = {__pyx_t_2, __pyx_t_4, __pyx_t_9}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_join, __pyx_callargs+__pyx_t_5, (3-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 255, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_v_opt = __pyx_t_1; - __pyx_t_1 = 0; - - /* "epanet/epanet.py":256 - * rpt = os.path.join(os.path.join(dir, 'temp'), input + '.rpt') - * opt = os.path.join(os.path.join(dir, 'temp'), input + '.opt') - * command = f'{exe} {inp} {rpt} {opt}' # <<<<<<<<<<<<<< - * - * data = {} -*/ - __pyx_t_1 = __Pyx_PyObject_FormatSimple(__pyx_v_exe, __pyx_mstate_global->__pyx_empty_unicode); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 256, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_t_11 = __Pyx_PyObject_FormatSimple(__pyx_v_inp, __pyx_mstate_global->__pyx_empty_unicode); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 256, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __pyx_t_9 = __Pyx_PyObject_FormatSimple(__pyx_v_rpt, __pyx_mstate_global->__pyx_empty_unicode); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 256, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - __pyx_t_4 = __Pyx_PyObject_FormatSimple(__pyx_v_opt, __pyx_mstate_global->__pyx_empty_unicode); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 256, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __pyx_t_12[0] = __pyx_t_1; - __pyx_t_12[1] = __pyx_mstate_global->__pyx_kp_u__2; - __pyx_t_12[2] = __pyx_t_11; - __pyx_t_12[3] = __pyx_mstate_global->__pyx_kp_u__2; - __pyx_t_12[4] = __pyx_t_9; - __pyx_t_12[5] = __pyx_mstate_global->__pyx_kp_u__2; - __pyx_t_12[6] = __pyx_t_4; - __pyx_t_2 = __Pyx_PyUnicode_Join(__pyx_t_12, 7, __Pyx_PyUnicode_GET_LENGTH(__pyx_t_1) + 1 * 3 + __Pyx_PyUnicode_GET_LENGTH(__pyx_t_11) + __Pyx_PyUnicode_GET_LENGTH(__pyx_t_9) + __Pyx_PyUnicode_GET_LENGTH(__pyx_t_4), 127 | __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_1) | __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_11) | __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_9) | __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_4)); - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 256, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - __pyx_v_command = ((PyObject*)__pyx_t_2); - __pyx_t_2 = 0; - - /* "epanet/epanet.py":258 - * command = f'{exe} {inp} {rpt} {opt}' - * - * data = {} # <<<<<<<<<<<<<< - * - * result = os.system(command) -*/ - __pyx_t_2 = __Pyx_PyDict_NewPresized(0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 258, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_v_data = ((PyObject*)__pyx_t_2); - __pyx_t_2 = 0; - - /* "epanet/epanet.py":260 - * data = {} - * - * result = os.system(command) # <<<<<<<<<<<<<< - * if result != 0: - * data['simulation_result'] = 'failed' -*/ - __pyx_t_4 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 260, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_system); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 260, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - __pyx_t_5 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_11))) { - __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_11); - assert(__pyx_t_4); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_11); - __Pyx_INCREF(__pyx_t_4); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_11, __pyx__function); - __pyx_t_5 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_v_command}; - __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_11, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 260, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - __pyx_v_result = __pyx_t_2; - __pyx_t_2 = 0; - - /* "epanet/epanet.py":261 - * - * result = os.system(command) - * if result != 0: # <<<<<<<<<<<<<< - * data['simulation_result'] = 'failed' - * else: -*/ - __pyx_t_7 = (__Pyx_PyLong_BoolNeObjC(__pyx_v_result, __pyx_mstate_global->__pyx_int_0, 0, 0)); if (unlikely((__pyx_t_7 < 0))) __PYX_ERR(0, 261, __pyx_L1_error) - if (__pyx_t_7) { - - /* "epanet/epanet.py":262 - * result = os.system(command) - * if result != 0: - * data['simulation_result'] = 'failed' # <<<<<<<<<<<<<< - * else: - * data['simulation_result'] = 'successful' -*/ - if (unlikely((PyDict_SetItem(__pyx_v_data, __pyx_mstate_global->__pyx_n_u_simulation_result, __pyx_mstate_global->__pyx_n_u_failed) < 0))) __PYX_ERR(0, 262, __pyx_L1_error) - - /* "epanet/epanet.py":261 - * - * result = os.system(command) - * if result != 0: # <<<<<<<<<<<<<< - * data['simulation_result'] = 'failed' - * else: -*/ - goto __pyx_L4; - } - - /* "epanet/epanet.py":264 - * data['simulation_result'] = 'failed' - * else: - * data['simulation_result'] = 'successful' # <<<<<<<<<<<<<< - * if readable_output: - * data ['output'] = _dump_output(opt) -*/ - /*else*/ { - if (unlikely((PyDict_SetItem(__pyx_v_data, __pyx_mstate_global->__pyx_n_u_simulation_result, __pyx_mstate_global->__pyx_n_u_successful) < 0))) __PYX_ERR(0, 264, __pyx_L1_error) - - /* "epanet/epanet.py":265 - * else: - * data['simulation_result'] = 'successful' - * if readable_output: # <<<<<<<<<<<<<< - * data ['output'] = _dump_output(opt) - * else: -*/ - __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_v_readable_output); if (unlikely((__pyx_t_7 < 0))) __PYX_ERR(0, 265, __pyx_L1_error) - if (__pyx_t_7) { - - /* "epanet/epanet.py":266 - * data['simulation_result'] = 'successful' - * if readable_output: - * data ['output'] = _dump_output(opt) # <<<<<<<<<<<<<< - * else: - * data['output'] = dump_output_binary(opt) -*/ - __pyx_t_11 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_dump_output); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 266, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __pyx_t_5 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_4))) { - __pyx_t_11 = PyMethod_GET_SELF(__pyx_t_4); - assert(__pyx_t_11); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); - __Pyx_INCREF(__pyx_t_11); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); - __pyx_t_5 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_11, __pyx_v_opt}; - __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 266, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - if (unlikely((PyDict_SetItem(__pyx_v_data, __pyx_mstate_global->__pyx_n_u_output, __pyx_t_2) < 0))) __PYX_ERR(0, 266, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet.py":265 - * else: - * data['simulation_result'] = 'successful' - * if readable_output: # <<<<<<<<<<<<<< - * data ['output'] = _dump_output(opt) - * else: -*/ - goto __pyx_L5; - } - - /* "epanet/epanet.py":268 - * data ['output'] = _dump_output(opt) - * else: - * data['output'] = dump_output_binary(opt) # <<<<<<<<<<<<<< - * - * data['report'] = dump_report(rpt) -*/ - /*else*/ { - __pyx_t_4 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_dump_output_binary); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 268, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __pyx_t_5 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_11))) { - __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_11); - assert(__pyx_t_4); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_11); - __Pyx_INCREF(__pyx_t_4); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_11, __pyx__function); - __pyx_t_5 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_v_opt}; - __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_11, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 268, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - if (unlikely((PyDict_SetItem(__pyx_v_data, __pyx_mstate_global->__pyx_n_u_output, __pyx_t_2) < 0))) __PYX_ERR(0, 268, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - } - __pyx_L5:; - } - __pyx_L4:; - - /* "epanet/epanet.py":270 - * data['output'] = dump_output_binary(opt) - * - * data['report'] = dump_report(rpt) # <<<<<<<<<<<<<< - * - * return data -*/ - __pyx_t_11 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_dump_report); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 270, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __pyx_t_5 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_4))) { - __pyx_t_11 = PyMethod_GET_SELF(__pyx_t_4); - assert(__pyx_t_11); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); - __Pyx_INCREF(__pyx_t_11); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); - __pyx_t_5 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_11, __pyx_v_rpt}; - __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 270, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - if (unlikely((PyDict_SetItem(__pyx_v_data, __pyx_mstate_global->__pyx_n_u_report, __pyx_t_2) < 0))) __PYX_ERR(0, 270, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet.py":272 - * data['report'] = dump_report(rpt) - * - * return data # <<<<<<<<<<<<<< - * - * # original code -*/ - __Pyx_XDECREF(__pyx_r); - __Pyx_INCREF(__pyx_v_data); - __pyx_r = __pyx_v_data; - goto __pyx_L0; - - /* "epanet/epanet.py":242 - * - * #DingZQ, 2025-02-04, dict[str, Any] - * def run_project_return_dict(name: str, readable_output: bool = False) -> dict[str, Any]: # <<<<<<<<<<<<<< - * if not project.have_project(name): - * raise Exception(f'Not found project [{name}]') -*/ - - /* function exit code */ - __pyx_L1_error:; - __Pyx_XDECREF(__pyx_t_1); - __Pyx_XDECREF(__pyx_t_2); - __Pyx_XDECREF(__pyx_t_3); - __Pyx_XDECREF(__pyx_t_4); - __Pyx_XDECREF(__pyx_t_9); - __Pyx_XDECREF(__pyx_t_10); - __Pyx_XDECREF(__pyx_t_11); - __Pyx_AddTraceback("epanet.epanet.run_project_return_dict", __pyx_clineno, __pyx_lineno, __pyx_filename); - __pyx_r = NULL; - __pyx_L0:; - __Pyx_XDECREF(__pyx_v_dir); - __Pyx_XDECREF(__pyx_v_db_inp); - __Pyx_XDECREF(__pyx_v_input); - __Pyx_XDECREF(__pyx_v_exe); - __Pyx_XDECREF(__pyx_v_inp); - __Pyx_XDECREF(__pyx_v_rpt); - __Pyx_XDECREF(__pyx_v_opt); - __Pyx_XDECREF(__pyx_v_command); - __Pyx_XDECREF(__pyx_v_data); - __Pyx_XDECREF(__pyx_v_result); - __Pyx_XGIVEREF(__pyx_r); - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -/* "epanet/epanet.py":275 - * - * # original code - * def run_project(name: str, readable_output: bool = False) -> str: # <<<<<<<<<<<<<< - * if not project.have_project(name): - * raise Exception(f'Not found project [{name}]') -*/ - -/* Python wrapper */ -static PyObject *__pyx_pw_6epanet_6epanet_13run_project(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -); /*proto*/ -static PyMethodDef __pyx_mdef_6epanet_6epanet_13run_project = {"run_project", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6epanet_6epanet_13run_project, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}; -static PyObject *__pyx_pw_6epanet_6epanet_13run_project(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -) { - PyObject *__pyx_v_name = 0; - PyObject *__pyx_v_readable_output = 0; - #if !CYTHON_METH_FASTCALL - CYTHON_UNUSED Py_ssize_t __pyx_nargs; - #endif - CYTHON_UNUSED PyObject *const *__pyx_kwvalues; - PyObject* values[2] = {0,0}; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - PyObject *__pyx_r = 0; - __Pyx_RefNannyDeclarations - __Pyx_RefNannySetupContext("run_project (wrapper)", 0); - #if !CYTHON_METH_FASTCALL - #if CYTHON_ASSUME_SAFE_SIZE - __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); - #else - __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; - #endif - #endif - __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); - { - PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_name,&__pyx_mstate_global->__pyx_n_u_readable_output,0}; - const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; - if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 275, __pyx_L3_error) - if (__pyx_kwds_len > 0) { - switch (__pyx_nargs) { - case 2: - values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 275, __pyx_L3_error) - CYTHON_FALLTHROUGH; - case 1: - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 275, __pyx_L3_error) - CYTHON_FALLTHROUGH; - case 0: break; - default: goto __pyx_L5_argtuple_error; - } - const Py_ssize_t kwd_pos_args = __pyx_nargs; - if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "run_project", 0) < 0) __PYX_ERR(0, 275, __pyx_L3_error) - if (!values[1]) values[1] = __Pyx_NewRef(((PyObject *)((PyObject *)Py_False))); - for (Py_ssize_t i = __pyx_nargs; i < 1; i++) { - if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("run_project", 0, 1, 2, i); __PYX_ERR(0, 275, __pyx_L3_error) } - } - } else { - switch (__pyx_nargs) { - case 2: - values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 275, __pyx_L3_error) - CYTHON_FALLTHROUGH; - case 1: - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 275, __pyx_L3_error) - break; - default: goto __pyx_L5_argtuple_error; - } - if (!values[1]) values[1] = __Pyx_NewRef(((PyObject *)((PyObject *)Py_False))); - } - __pyx_v_name = ((PyObject*)values[0]); - __pyx_v_readable_output = values[1]; - } - goto __pyx_L6_skip; - __pyx_L5_argtuple_error:; - __Pyx_RaiseArgtupleInvalid("run_project", 0, 1, 2, __pyx_nargs); __PYX_ERR(0, 275, __pyx_L3_error) - __pyx_L6_skip:; - goto __pyx_L4_argument_unpacking_done; - __pyx_L3_error:; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_AddTraceback("epanet.epanet.run_project", __pyx_clineno, __pyx_lineno, __pyx_filename); - __Pyx_RefNannyFinishContext(); - return NULL; - __pyx_L4_argument_unpacking_done:; - if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_name), (&PyUnicode_Type), 0, "name", 2))) __PYX_ERR(0, 275, __pyx_L1_error) - __pyx_r = __pyx_pf_6epanet_6epanet_12run_project(__pyx_self, __pyx_v_name, __pyx_v_readable_output); - - /* function exit code */ - goto __pyx_L0; - __pyx_L1_error:; - __pyx_r = NULL; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - goto __pyx_L7_cleaned_up; - __pyx_L0:; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __pyx_L7_cleaned_up:; - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -static PyObject *__pyx_pf_6epanet_6epanet_12run_project(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_name, PyObject *__pyx_v_readable_output) { - PyObject *__pyx_v_dir = NULL; - PyObject *__pyx_v_db_inp = NULL; - PyObject *__pyx_v_input = NULL; - PyObject *__pyx_v_exe = NULL; - PyObject *__pyx_v_inp = NULL; - PyObject *__pyx_v_rpt = NULL; - PyObject *__pyx_v_opt = NULL; - PyObject *__pyx_v_command = NULL; - PyObject *__pyx_v_data = NULL; - PyObject *__pyx_v_result = NULL; - PyObject *__pyx_r = NULL; - __Pyx_RefNannyDeclarations - PyObject *__pyx_t_1 = NULL; - PyObject *__pyx_t_2 = NULL; - PyObject *__pyx_t_3 = NULL; - PyObject *__pyx_t_4 = NULL; - size_t __pyx_t_5; - int __pyx_t_6; - int __pyx_t_7; - PyObject *__pyx_t_8[3]; - PyObject *__pyx_t_9 = NULL; - PyObject *__pyx_t_10 = NULL; - PyObject *__pyx_t_11 = NULL; - PyObject *__pyx_t_12[7]; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - __Pyx_RefNannySetupContext("run_project", 0); - - /* "epanet/epanet.py":276 - * # original code - * def run_project(name: str, readable_output: bool = False) -> str: - * if not project.have_project(name): # <<<<<<<<<<<<<< - * raise Exception(f'Not found project [{name}]') - * -*/ - __pyx_t_2 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_project); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 276, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_have_project); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 276, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __pyx_t_5 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_4))) { - __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_4); - assert(__pyx_t_2); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); - __Pyx_INCREF(__pyx_t_2); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); - __pyx_t_5 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_v_name}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 276, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_t_6 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely((__pyx_t_6 < 0))) __PYX_ERR(0, 276, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __pyx_t_7 = (!__pyx_t_6); - if (unlikely(__pyx_t_7)) { - - /* "epanet/epanet.py":277 - * def run_project(name: str, readable_output: bool = False) -> str: - * if not project.have_project(name): - * raise Exception(f'Not found project [{name}]') # <<<<<<<<<<<<<< - * - * dir = os.path.abspath(os.getcwd()) -*/ - __pyx_t_4 = NULL; - __Pyx_INCREF((PyObject *)(((PyTypeObject*)PyExc_Exception))); - __pyx_t_2 = ((PyObject *)(((PyTypeObject*)PyExc_Exception))); - __pyx_t_8[0] = __pyx_mstate_global->__pyx_kp_u_Not_found_project; - __pyx_t_8[1] = __pyx_v_name; - __pyx_t_8[2] = __pyx_mstate_global->__pyx_kp_u_; - __pyx_t_3 = __Pyx_PyUnicode_Join(__pyx_t_8, 3, 19 + __Pyx_PyUnicode_GET_LENGTH(__pyx_v_name) + 1, 127 | __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_v_name)); - if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 277, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __pyx_t_5 = 1; - { - PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_t_3}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_2, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 277, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __Pyx_Raise(__pyx_t_1, 0, 0, 0); - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __PYX_ERR(0, 277, __pyx_L1_error) - - /* "epanet/epanet.py":276 - * # original code - * def run_project(name: str, readable_output: bool = False) -> str: - * if not project.have_project(name): # <<<<<<<<<<<<<< - * raise Exception(f'Not found project [{name}]') - * -*/ - } - - /* "epanet/epanet.py":279 - * raise Exception(f'Not found project [{name}]') - * - * dir = os.path.abspath(os.getcwd()) # <<<<<<<<<<<<<< - * - * db_inp = os.path.join(os.path.join(dir, 'db_inp'), name + '.db.inp') -*/ - __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 279, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 279, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __pyx_t_2 = __pyx_t_4; - __Pyx_INCREF(__pyx_t_2); - __pyx_t_9 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 279, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_getcwd); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 279, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - __pyx_t_5 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_11))) { - __pyx_t_9 = PyMethod_GET_SELF(__pyx_t_11); - assert(__pyx_t_9); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_11); - __Pyx_INCREF(__pyx_t_9); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_11, __pyx__function); - __pyx_t_5 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_9, NULL}; - __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_11, __pyx_callargs+__pyx_t_5, (1-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 279, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - } - __pyx_t_5 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_t_3}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_abspath, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 279, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_v_dir = __pyx_t_1; - __pyx_t_1 = 0; - - /* "epanet/epanet.py":281 - * dir = os.path.abspath(os.getcwd()) - * - * db_inp = os.path.join(os.path.join(dir, 'db_inp'), name + '.db.inp') # <<<<<<<<<<<<<< - * inp_out.dump_inp(name, db_inp, '2') - * -*/ - __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 281, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 281, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __pyx_t_4 = __pyx_t_2; - __Pyx_INCREF(__pyx_t_4); - __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 281, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 281, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - __pyx_t_11 = __pyx_t_10; - __Pyx_INCREF(__pyx_t_11); - __pyx_t_5 = 0; - { - PyObject *__pyx_callargs[3] = {__pyx_t_11, __pyx_v_dir, __pyx_mstate_global->__pyx_n_u_db_inp}; - __pyx_t_3 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_join, __pyx_callargs+__pyx_t_5, (3-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 281, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - } - __pyx_t_10 = __Pyx_PyUnicode_Concat(__pyx_v_name, __pyx_mstate_global->__pyx_kp_u_db_inp_2); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 281, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - __pyx_t_5 = 0; - { - PyObject *__pyx_callargs[3] = {__pyx_t_4, __pyx_t_3, __pyx_t_10}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_join, __pyx_callargs+__pyx_t_5, (3-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 281, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_v_db_inp = __pyx_t_1; - __pyx_t_1 = 0; - - /* "epanet/epanet.py":282 - * - * db_inp = os.path.join(os.path.join(dir, 'db_inp'), name + '.db.inp') - * inp_out.dump_inp(name, db_inp, '2') # <<<<<<<<<<<<<< - * - * input = name + '.db' -*/ - __pyx_t_2 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_inp_out); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 282, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_dump_inp); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 282, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - __pyx_t_5 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_3))) { - __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_3); - assert(__pyx_t_2); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_3); - __Pyx_INCREF(__pyx_t_2); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_3, __pyx__function); - __pyx_t_5 = 0; - } - #endif - { - PyObject *__pyx_callargs[4] = {__pyx_t_2, __pyx_v_name, __pyx_v_db_inp, __pyx_mstate_global->__pyx_kp_u_2}; - __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_3, __pyx_callargs+__pyx_t_5, (4-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 282, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - - /* "epanet/epanet.py":284 - * inp_out.dump_inp(name, db_inp, '2') - * - * input = name + '.db' # <<<<<<<<<<<<<< - * exe = os.path.join(os.path.join(dir, 'epanet'), 'runepanet.exe') - * inp = os.path.join(os.path.join(dir, 'db_inp'), input + '.inp') -*/ - __pyx_t_1 = __Pyx_PyUnicode_Concat(__pyx_v_name, __pyx_mstate_global->__pyx_kp_u_db); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 284, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_v_input = ((PyObject*)__pyx_t_1); - __pyx_t_1 = 0; - - /* "epanet/epanet.py":285 - * - * input = name + '.db' - * exe = os.path.join(os.path.join(dir, 'epanet'), 'runepanet.exe') # <<<<<<<<<<<<<< - * inp = os.path.join(os.path.join(dir, 'db_inp'), input + '.inp') - * rpt = os.path.join(os.path.join(dir, 'temp'), input + '.rpt') -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 285, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 285, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __pyx_t_3 = __pyx_t_10; - __Pyx_INCREF(__pyx_t_3); - __Pyx_GetModuleGlobalName(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 285, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __pyx_t_9 = __Pyx_PyObject_GetAttrStr(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 285, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - __pyx_t_4 = __pyx_t_9; - __Pyx_INCREF(__pyx_t_4); - __pyx_t_5 = 0; - { - PyObject *__pyx_callargs[3] = {__pyx_t_4, __pyx_v_dir, __pyx_mstate_global->__pyx_n_u_epanet}; - __pyx_t_2 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_join, __pyx_callargs+__pyx_t_5, (3-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 285, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - __pyx_t_5 = 0; - { - PyObject *__pyx_callargs[3] = {__pyx_t_3, __pyx_t_2, __pyx_mstate_global->__pyx_kp_u_runepanet_exe}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_join, __pyx_callargs+__pyx_t_5, (3-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 285, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_v_exe = __pyx_t_1; - __pyx_t_1 = 0; - - /* "epanet/epanet.py":286 - * input = name + '.db' - * exe = os.path.join(os.path.join(dir, 'epanet'), 'runepanet.exe') - * inp = os.path.join(os.path.join(dir, 'db_inp'), input + '.inp') # <<<<<<<<<<<<<< - * rpt = os.path.join(os.path.join(dir, 'temp'), input + '.rpt') - * opt = os.path.join(os.path.join(dir, 'temp'), input + '.opt') -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 286, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 286, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __pyx_t_10 = __pyx_t_3; - __Pyx_INCREF(__pyx_t_10); - __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 286, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 286, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - __pyx_t_9 = __pyx_t_11; - __Pyx_INCREF(__pyx_t_9); - __pyx_t_5 = 0; - { - PyObject *__pyx_callargs[3] = {__pyx_t_9, __pyx_v_dir, __pyx_mstate_global->__pyx_n_u_db_inp}; - __pyx_t_2 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_join, __pyx_callargs+__pyx_t_5, (3-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 286, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - __pyx_t_11 = __Pyx_PyUnicode_Concat(__pyx_v_input, __pyx_mstate_global->__pyx_kp_u_inp); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 286, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __pyx_t_5 = 0; - { - PyObject *__pyx_callargs[3] = {__pyx_t_10, __pyx_t_2, __pyx_t_11}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_join, __pyx_callargs+__pyx_t_5, (3-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0; - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 286, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_v_inp = __pyx_t_1; - __pyx_t_1 = 0; - - /* "epanet/epanet.py":287 - * exe = os.path.join(os.path.join(dir, 'epanet'), 'runepanet.exe') - * inp = os.path.join(os.path.join(dir, 'db_inp'), input + '.inp') - * rpt = os.path.join(os.path.join(dir, 'temp'), input + '.rpt') # <<<<<<<<<<<<<< - * opt = os.path.join(os.path.join(dir, 'temp'), input + '.opt') - * command = f'{exe} {inp} {rpt} {opt}' -*/ - __Pyx_GetModuleGlobalName(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 287, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 287, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - __pyx_t_3 = __pyx_t_2; - __Pyx_INCREF(__pyx_t_3); - __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 287, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 287, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - __pyx_t_10 = __pyx_t_4; - __Pyx_INCREF(__pyx_t_10); - __pyx_t_5 = 0; - { - PyObject *__pyx_callargs[3] = {__pyx_t_10, __pyx_v_dir, __pyx_mstate_global->__pyx_n_u_temp}; - __pyx_t_11 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_join, __pyx_callargs+__pyx_t_5, (3-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 287, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - } - __pyx_t_4 = __Pyx_PyUnicode_Concat(__pyx_v_input, __pyx_mstate_global->__pyx_kp_u_rpt); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 287, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __pyx_t_5 = 0; - { - PyObject *__pyx_callargs[3] = {__pyx_t_3, __pyx_t_11, __pyx_t_4}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_join, __pyx_callargs+__pyx_t_5, (3-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 287, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_v_rpt = __pyx_t_1; - __pyx_t_1 = 0; - - /* "epanet/epanet.py":288 - * inp = os.path.join(os.path.join(dir, 'db_inp'), input + '.inp') - * rpt = os.path.join(os.path.join(dir, 'temp'), input + '.rpt') - * opt = os.path.join(os.path.join(dir, 'temp'), input + '.opt') # <<<<<<<<<<<<<< - * command = f'{exe} {inp} {rpt} {opt}' - * -*/ - __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 288, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 288, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - __pyx_t_2 = __pyx_t_11; - __Pyx_INCREF(__pyx_t_2); - __Pyx_GetModuleGlobalName(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 288, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_10); - __pyx_t_9 = __Pyx_PyObject_GetAttrStr(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 288, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; - __pyx_t_3 = __pyx_t_9; - __Pyx_INCREF(__pyx_t_3); - __pyx_t_5 = 0; - { - PyObject *__pyx_callargs[3] = {__pyx_t_3, __pyx_v_dir, __pyx_mstate_global->__pyx_n_u_temp}; - __pyx_t_4 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_join, __pyx_callargs+__pyx_t_5, (3-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 288, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - } - __pyx_t_9 = __Pyx_PyUnicode_Concat(__pyx_v_input, __pyx_mstate_global->__pyx_kp_u_opt); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 288, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - __pyx_t_5 = 0; - { - PyObject *__pyx_callargs[3] = {__pyx_t_2, __pyx_t_4, __pyx_t_9}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_join, __pyx_callargs+__pyx_t_5, (3-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 288, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_v_opt = __pyx_t_1; - __pyx_t_1 = 0; - - /* "epanet/epanet.py":289 - * rpt = os.path.join(os.path.join(dir, 'temp'), input + '.rpt') - * opt = os.path.join(os.path.join(dir, 'temp'), input + '.opt') - * command = f'{exe} {inp} {rpt} {opt}' # <<<<<<<<<<<<<< - * - * data = {} -*/ - __pyx_t_1 = __Pyx_PyObject_FormatSimple(__pyx_v_exe, __pyx_mstate_global->__pyx_empty_unicode); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 289, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_t_11 = __Pyx_PyObject_FormatSimple(__pyx_v_inp, __pyx_mstate_global->__pyx_empty_unicode); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 289, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __pyx_t_9 = __Pyx_PyObject_FormatSimple(__pyx_v_rpt, __pyx_mstate_global->__pyx_empty_unicode); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 289, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - __pyx_t_4 = __Pyx_PyObject_FormatSimple(__pyx_v_opt, __pyx_mstate_global->__pyx_empty_unicode); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 289, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __pyx_t_12[0] = __pyx_t_1; - __pyx_t_12[1] = __pyx_mstate_global->__pyx_kp_u__2; - __pyx_t_12[2] = __pyx_t_11; - __pyx_t_12[3] = __pyx_mstate_global->__pyx_kp_u__2; - __pyx_t_12[4] = __pyx_t_9; - __pyx_t_12[5] = __pyx_mstate_global->__pyx_kp_u__2; - __pyx_t_12[6] = __pyx_t_4; - __pyx_t_2 = __Pyx_PyUnicode_Join(__pyx_t_12, 7, __Pyx_PyUnicode_GET_LENGTH(__pyx_t_1) + 1 * 3 + __Pyx_PyUnicode_GET_LENGTH(__pyx_t_11) + __Pyx_PyUnicode_GET_LENGTH(__pyx_t_9) + __Pyx_PyUnicode_GET_LENGTH(__pyx_t_4), 127 | __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_1) | __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_11) | __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_9) | __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_4)); - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 289, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - __pyx_v_command = ((PyObject*)__pyx_t_2); - __pyx_t_2 = 0; - - /* "epanet/epanet.py":291 - * command = f'{exe} {inp} {rpt} {opt}' - * - * data = {} # <<<<<<<<<<<<<< - * - * result = os.system(command) -*/ - __pyx_t_2 = __Pyx_PyDict_NewPresized(0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 291, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_v_data = __pyx_t_2; - __pyx_t_2 = 0; - - /* "epanet/epanet.py":293 - * data = {} - * - * result = os.system(command) # <<<<<<<<<<<<<< - * if result != 0: - * data['simulation_result'] = 'failed' -*/ - __pyx_t_4 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 293, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_system); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 293, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - __pyx_t_5 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_11))) { - __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_11); - assert(__pyx_t_4); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_11); - __Pyx_INCREF(__pyx_t_4); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_11, __pyx__function); - __pyx_t_5 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_v_command}; - __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_11, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 293, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - __pyx_v_result = __pyx_t_2; - __pyx_t_2 = 0; - - /* "epanet/epanet.py":294 - * - * result = os.system(command) - * if result != 0: # <<<<<<<<<<<<<< - * data['simulation_result'] = 'failed' - * else: -*/ - __pyx_t_7 = (__Pyx_PyLong_BoolNeObjC(__pyx_v_result, __pyx_mstate_global->__pyx_int_0, 0, 0)); if (unlikely((__pyx_t_7 < 0))) __PYX_ERR(0, 294, __pyx_L1_error) - if (__pyx_t_7) { - - /* "epanet/epanet.py":295 - * result = os.system(command) - * if result != 0: - * data['simulation_result'] = 'failed' # <<<<<<<<<<<<<< - * else: - * data['simulation_result'] = 'successful' -*/ - if (unlikely((PyObject_SetItem(__pyx_v_data, __pyx_mstate_global->__pyx_n_u_simulation_result, __pyx_mstate_global->__pyx_n_u_failed) < 0))) __PYX_ERR(0, 295, __pyx_L1_error) - - /* "epanet/epanet.py":294 - * - * result = os.system(command) - * if result != 0: # <<<<<<<<<<<<<< - * data['simulation_result'] = 'failed' - * else: -*/ - goto __pyx_L4; - } - - /* "epanet/epanet.py":297 - * data['simulation_result'] = 'failed' - * else: - * data['simulation_result'] = 'successful' # <<<<<<<<<<<<<< - * if readable_output: - * data |= _dump_output(opt) -*/ - /*else*/ { - if (unlikely((PyObject_SetItem(__pyx_v_data, __pyx_mstate_global->__pyx_n_u_simulation_result, __pyx_mstate_global->__pyx_n_u_successful) < 0))) __PYX_ERR(0, 297, __pyx_L1_error) - - /* "epanet/epanet.py":298 - * else: - * data['simulation_result'] = 'successful' - * if readable_output: # <<<<<<<<<<<<<< - * data |= _dump_output(opt) - * else: -*/ - __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_v_readable_output); if (unlikely((__pyx_t_7 < 0))) __PYX_ERR(0, 298, __pyx_L1_error) - if (__pyx_t_7) { - - /* "epanet/epanet.py":299 - * data['simulation_result'] = 'successful' - * if readable_output: - * data |= _dump_output(opt) # <<<<<<<<<<<<<< - * else: - * data['output'] = dump_output_binary(opt) -*/ - __pyx_t_11 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_dump_output); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 299, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __pyx_t_5 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_4))) { - __pyx_t_11 = PyMethod_GET_SELF(__pyx_t_4); - assert(__pyx_t_11); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); - __Pyx_INCREF(__pyx_t_11); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); - __pyx_t_5 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_11, __pyx_v_opt}; - __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 299, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - __pyx_t_4 = PyNumber_InPlaceOr(__pyx_v_data, __pyx_t_2); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 299, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF_SET(__pyx_v_data, __pyx_t_4); - __pyx_t_4 = 0; - - /* "epanet/epanet.py":298 - * else: - * data['simulation_result'] = 'successful' - * if readable_output: # <<<<<<<<<<<<<< - * data |= _dump_output(opt) - * else: -*/ - goto __pyx_L5; - } - - /* "epanet/epanet.py":301 - * data |= _dump_output(opt) - * else: - * data['output'] = dump_output_binary(opt) # <<<<<<<<<<<<<< - * - * data['report'] = dump_report(rpt) -*/ - /*else*/ { - __pyx_t_2 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_dump_output_binary); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 301, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __pyx_t_5 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_11))) { - __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_11); - assert(__pyx_t_2); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_11); - __Pyx_INCREF(__pyx_t_2); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_11, __pyx__function); - __pyx_t_5 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_v_opt}; - __pyx_t_4 = __Pyx_PyObject_FastCall(__pyx_t_11, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 301, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - } - if (unlikely((PyObject_SetItem(__pyx_v_data, __pyx_mstate_global->__pyx_n_u_output, __pyx_t_4) < 0))) __PYX_ERR(0, 301, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - } - __pyx_L5:; - } - __pyx_L4:; - - /* "epanet/epanet.py":303 - * data['output'] = dump_output_binary(opt) - * - * data['report'] = dump_report(rpt) # <<<<<<<<<<<<<< - * - * return json.dumps(data) -*/ - __pyx_t_11 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_dump_report); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 303, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_t_5 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_2))) { - __pyx_t_11 = PyMethod_GET_SELF(__pyx_t_2); - assert(__pyx_t_11); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_2); - __Pyx_INCREF(__pyx_t_11); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_2, __pyx__function); - __pyx_t_5 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_11, __pyx_v_rpt}; - __pyx_t_4 = __Pyx_PyObject_FastCall(__pyx_t_2, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 303, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - } - if (unlikely((PyObject_SetItem(__pyx_v_data, __pyx_mstate_global->__pyx_n_u_report, __pyx_t_4) < 0))) __PYX_ERR(0, 303, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - - /* "epanet/epanet.py":305 - * data['report'] = dump_report(rpt) - * - * return json.dumps(data) # <<<<<<<<<<<<<< - * - * -*/ - __Pyx_XDECREF(__pyx_r); - __pyx_t_2 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_json_2); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 305, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_11); - __pyx_t_9 = __Pyx_PyObject_GetAttrStr(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_dumps); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 305, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_9); - __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; - __pyx_t_5 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_9))) { - __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_9); - assert(__pyx_t_2); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_9); - __Pyx_INCREF(__pyx_t_2); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_9, __pyx__function); - __pyx_t_5 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_v_data}; - __pyx_t_4 = __Pyx_PyObject_FastCall(__pyx_t_9, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; - if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 305, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - } - if (!(likely(PyUnicode_CheckExact(__pyx_t_4))||((__pyx_t_4) == Py_None) || __Pyx_RaiseUnexpectedTypeError("str", __pyx_t_4))) __PYX_ERR(0, 305, __pyx_L1_error) - __pyx_r = ((PyObject*)__pyx_t_4); - __pyx_t_4 = 0; - goto __pyx_L0; - - /* "epanet/epanet.py":275 - * - * # original code - * def run_project(name: str, readable_output: bool = False) -> str: # <<<<<<<<<<<<<< - * if not project.have_project(name): - * raise Exception(f'Not found project [{name}]') -*/ - - /* function exit code */ - __pyx_L1_error:; - __Pyx_XDECREF(__pyx_t_1); - __Pyx_XDECREF(__pyx_t_2); - __Pyx_XDECREF(__pyx_t_3); - __Pyx_XDECREF(__pyx_t_4); - __Pyx_XDECREF(__pyx_t_9); - __Pyx_XDECREF(__pyx_t_10); - __Pyx_XDECREF(__pyx_t_11); - __Pyx_AddTraceback("epanet.epanet.run_project", __pyx_clineno, __pyx_lineno, __pyx_filename); - __pyx_r = NULL; - __pyx_L0:; - __Pyx_XDECREF(__pyx_v_dir); - __Pyx_XDECREF(__pyx_v_db_inp); - __Pyx_XDECREF(__pyx_v_input); - __Pyx_XDECREF(__pyx_v_exe); - __Pyx_XDECREF(__pyx_v_inp); - __Pyx_XDECREF(__pyx_v_rpt); - __Pyx_XDECREF(__pyx_v_opt); - __Pyx_XDECREF(__pyx_v_command); - __Pyx_XDECREF(__pyx_v_data); - __Pyx_XDECREF(__pyx_v_result); - __Pyx_XGIVEREF(__pyx_r); - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -/* "epanet/epanet.py":308 - * - * - * def run_inp(name: str) -> str: # <<<<<<<<<<<<<< - * dir = os.path.abspath(os.getcwd()) - * -*/ - -/* Python wrapper */ -static PyObject *__pyx_pw_6epanet_6epanet_15run_inp(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -); /*proto*/ -static PyMethodDef __pyx_mdef_6epanet_6epanet_15run_inp = {"run_inp", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6epanet_6epanet_15run_inp, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}; -static PyObject *__pyx_pw_6epanet_6epanet_15run_inp(PyObject *__pyx_self, -#if CYTHON_METH_FASTCALL -PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds -#else -PyObject *__pyx_args, PyObject *__pyx_kwds -#endif -) { - PyObject *__pyx_v_name = 0; - #if !CYTHON_METH_FASTCALL - CYTHON_UNUSED Py_ssize_t __pyx_nargs; - #endif - CYTHON_UNUSED PyObject *const *__pyx_kwvalues; - PyObject* values[1] = {0}; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - PyObject *__pyx_r = 0; - __Pyx_RefNannyDeclarations - __Pyx_RefNannySetupContext("run_inp (wrapper)", 0); - #if !CYTHON_METH_FASTCALL - #if CYTHON_ASSUME_SAFE_SIZE - __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); - #else - __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; - #endif - #endif - __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); - { - PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_name,0}; - const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; - if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 308, __pyx_L3_error) - if (__pyx_kwds_len > 0) { - switch (__pyx_nargs) { - case 1: - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 308, __pyx_L3_error) - CYTHON_FALLTHROUGH; - case 0: break; - default: goto __pyx_L5_argtuple_error; - } - const Py_ssize_t kwd_pos_args = __pyx_nargs; - if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "run_inp", 0) < 0) __PYX_ERR(0, 308, __pyx_L3_error) - for (Py_ssize_t i = __pyx_nargs; i < 1; i++) { - if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("run_inp", 1, 1, 1, i); __PYX_ERR(0, 308, __pyx_L3_error) } - } - } else if (unlikely(__pyx_nargs != 1)) { - goto __pyx_L5_argtuple_error; - } else { - values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); - if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 308, __pyx_L3_error) - } - __pyx_v_name = ((PyObject*)values[0]); - } - goto __pyx_L6_skip; - __pyx_L5_argtuple_error:; - __Pyx_RaiseArgtupleInvalid("run_inp", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 308, __pyx_L3_error) - __pyx_L6_skip:; - goto __pyx_L4_argument_unpacking_done; - __pyx_L3_error:; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __Pyx_AddTraceback("epanet.epanet.run_inp", __pyx_clineno, __pyx_lineno, __pyx_filename); - __Pyx_RefNannyFinishContext(); - return NULL; - __pyx_L4_argument_unpacking_done:; - if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_name), (&PyUnicode_Type), 0, "name", 2))) __PYX_ERR(0, 308, __pyx_L1_error) - __pyx_r = __pyx_pf_6epanet_6epanet_14run_inp(__pyx_self, __pyx_v_name); - - /* function exit code */ - goto __pyx_L0; - __pyx_L1_error:; - __pyx_r = NULL; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - goto __pyx_L7_cleaned_up; - __pyx_L0:; - for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { - Py_XDECREF(values[__pyx_temp]); - } - __pyx_L7_cleaned_up:; - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} - -static PyObject *__pyx_pf_6epanet_6epanet_14run_inp(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_name) { - PyObject *__pyx_v_dir = NULL; - PyObject *__pyx_v_exe = NULL; - PyObject *__pyx_v_inp = NULL; - PyObject *__pyx_v_rpt = NULL; - PyObject *__pyx_v_opt = NULL; - PyObject *__pyx_v_command = NULL; - PyObject *__pyx_v_data = NULL; - PyObject *__pyx_v_result = NULL; - PyObject *__pyx_r = NULL; - __Pyx_RefNannyDeclarations - PyObject *__pyx_t_1 = NULL; - PyObject *__pyx_t_2 = NULL; - PyObject *__pyx_t_3 = NULL; - PyObject *__pyx_t_4 = NULL; - PyObject *__pyx_t_5 = NULL; - PyObject *__pyx_t_6 = NULL; - PyObject *__pyx_t_7 = NULL; - size_t __pyx_t_8; - PyObject *__pyx_t_9[7]; - int __pyx_t_10; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - __Pyx_RefNannySetupContext("run_inp", 0); - - /* "epanet/epanet.py":309 - * - * def run_inp(name: str) -> str: - * dir = os.path.abspath(os.getcwd()) # <<<<<<<<<<<<<< - * - * exe = os.path.join(os.path.join(dir, 'epanet'), 'runepanet.exe') -*/ - __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 309, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 309, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __pyx_t_2 = __pyx_t_4; - __Pyx_INCREF(__pyx_t_2); - __pyx_t_5 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 309, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_getcwd); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 309, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_7); - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - __pyx_t_8 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_7))) { - __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_7); - assert(__pyx_t_5); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_7); - __Pyx_INCREF(__pyx_t_5); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_7, __pyx__function); - __pyx_t_8 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_5, NULL}; - __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_7, __pyx_callargs+__pyx_t_8, (1-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; - if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 309, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - } - __pyx_t_8 = 0; - { - PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_t_3}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_abspath, __pyx_callargs+__pyx_t_8, (2-__pyx_t_8) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 309, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_v_dir = __pyx_t_1; - __pyx_t_1 = 0; - - /* "epanet/epanet.py":311 - * dir = os.path.abspath(os.getcwd()) - * - * exe = os.path.join(os.path.join(dir, 'epanet'), 'runepanet.exe') # <<<<<<<<<<<<<< - * inp = os.path.join(os.path.join(dir, 'inp'), name + '.inp') - * rpt = os.path.join(os.path.join(dir, 'temp'), name + '.rpt') -*/ - __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 311, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 311, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __pyx_t_4 = __pyx_t_2; - __Pyx_INCREF(__pyx_t_4); - __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 311, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 311, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - __pyx_t_7 = __pyx_t_6; - __Pyx_INCREF(__pyx_t_7); - __pyx_t_8 = 0; - { - PyObject *__pyx_callargs[3] = {__pyx_t_7, __pyx_v_dir, __pyx_mstate_global->__pyx_n_u_epanet}; - __pyx_t_3 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_join, __pyx_callargs+__pyx_t_8, (3-__pyx_t_8) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 311, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - } - __pyx_t_8 = 0; - { - PyObject *__pyx_callargs[3] = {__pyx_t_4, __pyx_t_3, __pyx_mstate_global->__pyx_kp_u_runepanet_exe}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_join, __pyx_callargs+__pyx_t_8, (3-__pyx_t_8) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 311, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_v_exe = __pyx_t_1; - __pyx_t_1 = 0; - - /* "epanet/epanet.py":312 - * - * exe = os.path.join(os.path.join(dir, 'epanet'), 'runepanet.exe') - * inp = os.path.join(os.path.join(dir, 'inp'), name + '.inp') # <<<<<<<<<<<<<< - * rpt = os.path.join(os.path.join(dir, 'temp'), name + '.rpt') - * opt = os.path.join(os.path.join(dir, 'temp'), name + '.opt') -*/ - __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 312, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 312, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_4); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __pyx_t_2 = __pyx_t_4; - __Pyx_INCREF(__pyx_t_2); - __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 312, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_7); - __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 312, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; - __pyx_t_6 = __pyx_t_5; - __Pyx_INCREF(__pyx_t_6); - __pyx_t_8 = 0; - { - PyObject *__pyx_callargs[3] = {__pyx_t_6, __pyx_v_dir, __pyx_mstate_global->__pyx_n_u_inp_2}; - __pyx_t_3 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_join, __pyx_callargs+__pyx_t_8, (3-__pyx_t_8) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 312, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - } - __pyx_t_5 = __Pyx_PyUnicode_Concat(__pyx_v_name, __pyx_mstate_global->__pyx_kp_u_inp); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 312, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __pyx_t_8 = 0; - { - PyObject *__pyx_callargs[3] = {__pyx_t_2, __pyx_t_3, __pyx_t_5}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_join, __pyx_callargs+__pyx_t_8, (3-__pyx_t_8) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 312, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_v_inp = __pyx_t_1; - __pyx_t_1 = 0; - - /* "epanet/epanet.py":313 - * exe = os.path.join(os.path.join(dir, 'epanet'), 'runepanet.exe') - * inp = os.path.join(os.path.join(dir, 'inp'), name + '.inp') - * rpt = os.path.join(os.path.join(dir, 'temp'), name + '.rpt') # <<<<<<<<<<<<<< - * opt = os.path.join(os.path.join(dir, 'temp'), name + '.opt') - * command = f'{exe} {inp} {rpt} {opt}' -*/ - __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 313, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 313, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - __pyx_t_4 = __pyx_t_3; - __Pyx_INCREF(__pyx_t_4); - __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 313, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 313, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_7); - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - __pyx_t_2 = __pyx_t_7; - __Pyx_INCREF(__pyx_t_2); - __pyx_t_8 = 0; - { - PyObject *__pyx_callargs[3] = {__pyx_t_2, __pyx_v_dir, __pyx_mstate_global->__pyx_n_u_temp}; - __pyx_t_5 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_join, __pyx_callargs+__pyx_t_8, (3-__pyx_t_8) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; - if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 313, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - } - __pyx_t_7 = __Pyx_PyUnicode_Concat(__pyx_v_name, __pyx_mstate_global->__pyx_kp_u_rpt); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 313, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_7); - __pyx_t_8 = 0; - { - PyObject *__pyx_callargs[3] = {__pyx_t_4, __pyx_t_5, __pyx_t_7}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_join, __pyx_callargs+__pyx_t_8, (3-__pyx_t_8) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 313, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_v_rpt = __pyx_t_1; - __pyx_t_1 = 0; - - /* "epanet/epanet.py":314 - * inp = os.path.join(os.path.join(dir, 'inp'), name + '.inp') - * rpt = os.path.join(os.path.join(dir, 'temp'), name + '.rpt') - * opt = os.path.join(os.path.join(dir, 'temp'), name + '.opt') # <<<<<<<<<<<<<< - * command = f'{exe} {inp} {rpt} {opt}' - * -*/ - __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 314, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_7); - __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 314, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; - __pyx_t_3 = __pyx_t_5; - __Pyx_INCREF(__pyx_t_3); - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 314, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 314, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __pyx_t_4 = __pyx_t_6; - __Pyx_INCREF(__pyx_t_4); - __pyx_t_8 = 0; - { - PyObject *__pyx_callargs[3] = {__pyx_t_4, __pyx_v_dir, __pyx_mstate_global->__pyx_n_u_temp}; - __pyx_t_7 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_join, __pyx_callargs+__pyx_t_8, (3-__pyx_t_8) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 314, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_7); - } - __pyx_t_6 = __Pyx_PyUnicode_Concat(__pyx_v_name, __pyx_mstate_global->__pyx_kp_u_opt); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 314, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __pyx_t_8 = 0; - { - PyObject *__pyx_callargs[3] = {__pyx_t_3, __pyx_t_7, __pyx_t_6}; - __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_join, __pyx_callargs+__pyx_t_8, (3-__pyx_t_8) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 314, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - } - __pyx_v_opt = __pyx_t_1; - __pyx_t_1 = 0; - - /* "epanet/epanet.py":315 - * rpt = os.path.join(os.path.join(dir, 'temp'), name + '.rpt') - * opt = os.path.join(os.path.join(dir, 'temp'), name + '.opt') - * command = f'{exe} {inp} {rpt} {opt}' # <<<<<<<<<<<<<< - * - * data = {} -*/ - __pyx_t_1 = __Pyx_PyObject_FormatSimple(__pyx_v_exe, __pyx_mstate_global->__pyx_empty_unicode); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 315, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_1); - __pyx_t_5 = __Pyx_PyObject_FormatSimple(__pyx_v_inp, __pyx_mstate_global->__pyx_empty_unicode); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 315, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __pyx_t_6 = __Pyx_PyObject_FormatSimple(__pyx_v_rpt, __pyx_mstate_global->__pyx_empty_unicode); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 315, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __pyx_t_7 = __Pyx_PyObject_FormatSimple(__pyx_v_opt, __pyx_mstate_global->__pyx_empty_unicode); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 315, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_7); - __pyx_t_9[0] = __pyx_t_1; - __pyx_t_9[1] = __pyx_mstate_global->__pyx_kp_u__2; - __pyx_t_9[2] = __pyx_t_5; - __pyx_t_9[3] = __pyx_mstate_global->__pyx_kp_u__2; - __pyx_t_9[4] = __pyx_t_6; - __pyx_t_9[5] = __pyx_mstate_global->__pyx_kp_u__2; - __pyx_t_9[6] = __pyx_t_7; - __pyx_t_3 = __Pyx_PyUnicode_Join(__pyx_t_9, 7, __Pyx_PyUnicode_GET_LENGTH(__pyx_t_1) + 1 * 3 + __Pyx_PyUnicode_GET_LENGTH(__pyx_t_5) + __Pyx_PyUnicode_GET_LENGTH(__pyx_t_6) + __Pyx_PyUnicode_GET_LENGTH(__pyx_t_7), 127 | __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_1) | __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_5) | __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_6) | __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_7)); - if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 315, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; - __pyx_v_command = ((PyObject*)__pyx_t_3); - __pyx_t_3 = 0; - - /* "epanet/epanet.py":317 - * command = f'{exe} {inp} {rpt} {opt}' - * - * data = {} # <<<<<<<<<<<<<< - * - * result = os.system(command) -*/ - __pyx_t_3 = __Pyx_PyDict_NewPresized(0); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 317, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __pyx_v_data = ((PyObject*)__pyx_t_3); - __pyx_t_3 = 0; - - /* "epanet/epanet.py":319 - * data = {} - * - * result = os.system(command) # <<<<<<<<<<<<<< - * if result != 0: - * data['simulation_result'] = 'failed' -*/ - __pyx_t_7 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_os); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 319, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_system); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 319, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - __pyx_t_8 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_5))) { - __pyx_t_7 = PyMethod_GET_SELF(__pyx_t_5); - assert(__pyx_t_7); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_5); - __Pyx_INCREF(__pyx_t_7); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_5, __pyx__function); - __pyx_t_8 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_7, __pyx_v_command}; - __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_5, __pyx_callargs+__pyx_t_8, (2-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 319, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - } - __pyx_v_result = __pyx_t_3; - __pyx_t_3 = 0; - - /* "epanet/epanet.py":320 - * - * result = os.system(command) - * if result != 0: # <<<<<<<<<<<<<< - * data['simulation_result'] = 'failed' - * else: -*/ - __pyx_t_10 = (__Pyx_PyLong_BoolNeObjC(__pyx_v_result, __pyx_mstate_global->__pyx_int_0, 0, 0)); if (unlikely((__pyx_t_10 < 0))) __PYX_ERR(0, 320, __pyx_L1_error) - if (__pyx_t_10) { - - /* "epanet/epanet.py":321 - * result = os.system(command) - * if result != 0: - * data['simulation_result'] = 'failed' # <<<<<<<<<<<<<< - * else: - * data['simulation_result'] = 'successful' -*/ - if (unlikely((PyDict_SetItem(__pyx_v_data, __pyx_mstate_global->__pyx_n_u_simulation_result, __pyx_mstate_global->__pyx_n_u_failed) < 0))) __PYX_ERR(0, 321, __pyx_L1_error) - - /* "epanet/epanet.py":320 - * - * result = os.system(command) - * if result != 0: # <<<<<<<<<<<<<< - * data['simulation_result'] = 'failed' - * else: -*/ - goto __pyx_L3; - } - - /* "epanet/epanet.py":323 - * data['simulation_result'] = 'failed' - * else: - * data['simulation_result'] = 'successful' # <<<<<<<<<<<<<< - * # data |= _dump_output(opt) - * data['output'] = dump_output_binary(opt) -*/ - /*else*/ { - if (unlikely((PyDict_SetItem(__pyx_v_data, __pyx_mstate_global->__pyx_n_u_simulation_result, __pyx_mstate_global->__pyx_n_u_successful) < 0))) __PYX_ERR(0, 323, __pyx_L1_error) - - /* "epanet/epanet.py":325 - * data['simulation_result'] = 'successful' - * # data |= _dump_output(opt) - * data['output'] = dump_output_binary(opt) # <<<<<<<<<<<<<< - * - * data['report'] = dump_report(rpt) -*/ - __pyx_t_5 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_dump_output_binary); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 325, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_7); - __pyx_t_8 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_7))) { - __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_7); - assert(__pyx_t_5); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_7); - __Pyx_INCREF(__pyx_t_5); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_7, __pyx__function); - __pyx_t_8 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_5, __pyx_v_opt}; - __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_7, __pyx_callargs+__pyx_t_8, (2-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; - if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 325, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - } - if (unlikely((PyDict_SetItem(__pyx_v_data, __pyx_mstate_global->__pyx_n_u_output, __pyx_t_3) < 0))) __PYX_ERR(0, 325, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - } - __pyx_L3:; - - /* "epanet/epanet.py":327 - * data['output'] = dump_output_binary(opt) - * - * data['report'] = dump_report(rpt) # <<<<<<<<<<<<<< - * - * return json.dumps(data) -*/ - __pyx_t_7 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_dump_report); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 327, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_5); - __pyx_t_8 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_5))) { - __pyx_t_7 = PyMethod_GET_SELF(__pyx_t_5); - assert(__pyx_t_7); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_5); - __Pyx_INCREF(__pyx_t_7); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_5, __pyx__function); - __pyx_t_8 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_7, __pyx_v_rpt}; - __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_5, __pyx_callargs+__pyx_t_8, (2-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; - __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; - if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 327, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - } - if (unlikely((PyDict_SetItem(__pyx_v_data, __pyx_mstate_global->__pyx_n_u_report, __pyx_t_3) < 0))) __PYX_ERR(0, 327, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - - /* "epanet/epanet.py":329 - * data['report'] = dump_report(rpt) - * - * return json.dumps(data) # <<<<<<<<<<<<<< -*/ - __Pyx_XDECREF(__pyx_r); - __pyx_t_5 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_json_2); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 329, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_7); - __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_dumps); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 329, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; - __pyx_t_8 = 1; - #if CYTHON_UNPACK_METHODS - if (unlikely(PyMethod_Check(__pyx_t_6))) { - __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_6); - assert(__pyx_t_5); - PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_6); - __Pyx_INCREF(__pyx_t_5); - __Pyx_INCREF(__pyx__function); - __Pyx_DECREF_SET(__pyx_t_6, __pyx__function); - __pyx_t_8 = 0; - } - #endif - { - PyObject *__pyx_callargs[2] = {__pyx_t_5, __pyx_v_data}; - __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_6, __pyx_callargs+__pyx_t_8, (2-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 329, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - } - if (!(likely(PyUnicode_CheckExact(__pyx_t_3))||((__pyx_t_3) == Py_None) || __Pyx_RaiseUnexpectedTypeError("str", __pyx_t_3))) __PYX_ERR(0, 329, __pyx_L1_error) - __pyx_r = ((PyObject*)__pyx_t_3); - __pyx_t_3 = 0; - goto __pyx_L0; - - /* "epanet/epanet.py":308 - * - * - * def run_inp(name: str) -> str: # <<<<<<<<<<<<<< - * dir = os.path.abspath(os.getcwd()) - * -*/ - - /* function exit code */ - __pyx_L1_error:; - __Pyx_XDECREF(__pyx_t_1); - __Pyx_XDECREF(__pyx_t_2); - __Pyx_XDECREF(__pyx_t_3); - __Pyx_XDECREF(__pyx_t_4); - __Pyx_XDECREF(__pyx_t_5); - __Pyx_XDECREF(__pyx_t_6); - __Pyx_XDECREF(__pyx_t_7); - __Pyx_AddTraceback("epanet.epanet.run_inp", __pyx_clineno, __pyx_lineno, __pyx_filename); - __pyx_r = NULL; - __pyx_L0:; - __Pyx_XDECREF(__pyx_v_dir); - __Pyx_XDECREF(__pyx_v_exe); - __Pyx_XDECREF(__pyx_v_inp); - __Pyx_XDECREF(__pyx_v_rpt); - __Pyx_XDECREF(__pyx_v_opt); - __Pyx_XDECREF(__pyx_v_command); - __Pyx_XDECREF(__pyx_v_data); - __Pyx_XDECREF(__pyx_v_result); - __Pyx_XGIVEREF(__pyx_r); - __Pyx_RefNannyFinishContext(); - return __pyx_r; -} -/* #### Code section: module_exttypes ### */ - -static PyMethodDef __pyx_methods[] = { - {0, 0, 0, 0} -}; -/* #### Code section: initfunc_declarations ### */ -static CYTHON_SMALL_CODE int __Pyx_InitCachedBuiltins(__pyx_mstatetype *__pyx_mstate); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_InitCachedConstants(__pyx_mstatetype *__pyx_mstate); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_InitGlobals(void); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_InitConstants(__pyx_mstatetype *__pyx_mstate); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_modinit_global_init_code(__pyx_mstatetype *__pyx_mstate); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_modinit_variable_export_code(__pyx_mstatetype *__pyx_mstate); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_modinit_function_export_code(__pyx_mstatetype *__pyx_mstate); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_modinit_type_init_code(__pyx_mstatetype *__pyx_mstate); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_modinit_type_import_code(__pyx_mstatetype *__pyx_mstate); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_modinit_variable_import_code(__pyx_mstatetype *__pyx_mstate); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_modinit_function_import_code(__pyx_mstatetype *__pyx_mstate); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_CreateCodeObjects(__pyx_mstatetype *__pyx_mstate); /*proto*/ -/* #### Code section: init_module ### */ - -static int __Pyx_modinit_global_init_code(__pyx_mstatetype *__pyx_mstate) { - __Pyx_RefNannyDeclarations - CYTHON_UNUSED_VAR(__pyx_mstate); - __Pyx_RefNannySetupContext("__Pyx_modinit_global_init_code", 0); - /*--- Global init code ---*/ - __Pyx_RefNannyFinishContext(); - return 0; -} - -static int __Pyx_modinit_variable_export_code(__pyx_mstatetype *__pyx_mstate) { - __Pyx_RefNannyDeclarations - CYTHON_UNUSED_VAR(__pyx_mstate); - __Pyx_RefNannySetupContext("__Pyx_modinit_variable_export_code", 0); - /*--- Variable export code ---*/ - __Pyx_RefNannyFinishContext(); - return 0; -} - -static int __Pyx_modinit_function_export_code(__pyx_mstatetype *__pyx_mstate) { - __Pyx_RefNannyDeclarations - CYTHON_UNUSED_VAR(__pyx_mstate); - __Pyx_RefNannySetupContext("__Pyx_modinit_function_export_code", 0); - /*--- Function export code ---*/ - __Pyx_RefNannyFinishContext(); - return 0; -} - -static int __Pyx_modinit_type_init_code(__pyx_mstatetype *__pyx_mstate) { - __Pyx_RefNannyDeclarations - CYTHON_UNUSED_VAR(__pyx_mstate); - __Pyx_RefNannySetupContext("__Pyx_modinit_type_init_code", 0); - /*--- Type init code ---*/ - __Pyx_RefNannyFinishContext(); - return 0; -} - -static int __Pyx_modinit_type_import_code(__pyx_mstatetype *__pyx_mstate) { - __Pyx_RefNannyDeclarations - CYTHON_UNUSED_VAR(__pyx_mstate); - __Pyx_RefNannySetupContext("__Pyx_modinit_type_import_code", 0); - /*--- Type import code ---*/ - __Pyx_RefNannyFinishContext(); - return 0; -} - -static int __Pyx_modinit_variable_import_code(__pyx_mstatetype *__pyx_mstate) { - __Pyx_RefNannyDeclarations - CYTHON_UNUSED_VAR(__pyx_mstate); - __Pyx_RefNannySetupContext("__Pyx_modinit_variable_import_code", 0); - /*--- Variable import code ---*/ - __Pyx_RefNannyFinishContext(); - return 0; -} - -static int __Pyx_modinit_function_import_code(__pyx_mstatetype *__pyx_mstate) { - __Pyx_RefNannyDeclarations - CYTHON_UNUSED_VAR(__pyx_mstate); - __Pyx_RefNannySetupContext("__Pyx_modinit_function_import_code", 0); - /*--- Function import code ---*/ - __Pyx_RefNannyFinishContext(); - return 0; -} - -#if CYTHON_PEP489_MULTI_PHASE_INIT -static PyObject* __pyx_pymod_create(PyObject *spec, PyModuleDef *def); /*proto*/ -static int __pyx_pymod_exec_epanet(PyObject* module); /*proto*/ -static PyModuleDef_Slot __pyx_moduledef_slots[] = { - {Py_mod_create, (void*)__pyx_pymod_create}, - {Py_mod_exec, (void*)__pyx_pymod_exec_epanet}, - #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - {Py_mod_gil, Py_MOD_GIL_USED}, - #endif - #if PY_VERSION_HEX >= 0x030C0000 && CYTHON_USE_MODULE_STATE - {Py_mod_multiple_interpreters, Py_MOD_MULTIPLE_INTERPRETERS_NOT_SUPPORTED}, - #endif - {0, NULL} -}; -#endif - -#ifdef __cplusplus -namespace { - struct PyModuleDef __pyx_moduledef = - #else - static struct PyModuleDef __pyx_moduledef = - #endif - { - PyModuleDef_HEAD_INIT, - "epanet", - 0, /* m_doc */ - #if CYTHON_USE_MODULE_STATE - sizeof(__pyx_mstatetype), /* m_size */ - #else - (CYTHON_PEP489_MULTI_PHASE_INIT) ? 0 : -1, /* m_size */ - #endif - __pyx_methods /* m_methods */, - #if CYTHON_PEP489_MULTI_PHASE_INIT - __pyx_moduledef_slots, /* m_slots */ - #else - NULL, /* m_reload */ - #endif - #if CYTHON_USE_MODULE_STATE - __pyx_m_traverse, /* m_traverse */ - __pyx_m_clear, /* m_clear */ - NULL /* m_free */ - #else - NULL, /* m_traverse */ - NULL, /* m_clear */ - NULL /* m_free */ - #endif - }; - #ifdef __cplusplus -} /* anonymous namespace */ -#endif - -/* PyModInitFuncType */ -#ifndef CYTHON_NO_PYINIT_EXPORT - #define __Pyx_PyMODINIT_FUNC PyMODINIT_FUNC -#else - #ifdef __cplusplus - #define __Pyx_PyMODINIT_FUNC extern "C" PyObject * - #else - #define __Pyx_PyMODINIT_FUNC PyObject * - #endif -#endif - -__Pyx_PyMODINIT_FUNC PyInit_epanet(void) CYTHON_SMALL_CODE; /*proto*/ -__Pyx_PyMODINIT_FUNC PyInit_epanet(void) -#if CYTHON_PEP489_MULTI_PHASE_INIT -{ - return PyModuleDef_Init(&__pyx_moduledef); -} -/* ModuleCreationPEP489 */ -#if CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX < 0x03090000 -static PY_INT64_T __Pyx_GetCurrentInterpreterId(void) { - { - PyObject *module = PyImport_ImportModule("_interpreters"); // 3.13+ I think - if (!module) { - PyErr_Clear(); // just try the 3.8-3.12 version - module = PyImport_ImportModule("_xxsubinterpreters"); - if (!module) goto bad; - } - PyObject *current = PyObject_CallMethod(module, "get_current", NULL); - Py_DECREF(module); - if (!current) goto bad; - if (PyTuple_Check(current)) { - PyObject *new_current = PySequence_GetItem(current, 0); - Py_DECREF(current); - current = new_current; - if (!new_current) goto bad; - } - long long as_c_int = PyLong_AsLongLong(current); - Py_DECREF(current); - return as_c_int; - } - bad: - PySys_WriteStderr("__Pyx_GetCurrentInterpreterId failed. Try setting the C define CYTHON_PEP489_MULTI_PHASE_INIT=0\n"); - return -1; -} -#endif -#if !CYTHON_USE_MODULE_STATE -static CYTHON_SMALL_CODE int __Pyx_check_single_interpreter(void) { - static PY_INT64_T main_interpreter_id = -1; -#if CYTHON_COMPILING_IN_GRAAL - PY_INT64_T current_id = PyInterpreterState_GetIDFromThreadState(PyThreadState_Get()); -#elif CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX >= 0x03090000 - PY_INT64_T current_id = PyInterpreterState_GetID(PyInterpreterState_Get()); -#elif CYTHON_COMPILING_IN_LIMITED_API - PY_INT64_T current_id = __Pyx_GetCurrentInterpreterId(); -#else - PY_INT64_T current_id = PyInterpreterState_GetID(PyThreadState_Get()->interp); -#endif - if (unlikely(current_id == -1)) { - return -1; - } - if (main_interpreter_id == -1) { - main_interpreter_id = current_id; - return 0; - } else if (unlikely(main_interpreter_id != current_id)) { - PyErr_SetString( - PyExc_ImportError, - "Interpreter change detected - this module can only be loaded into one interpreter per process."); - return -1; - } - return 0; -} -#endif -static CYTHON_SMALL_CODE int __Pyx_copy_spec_to_module(PyObject *spec, PyObject *moddict, const char* from_name, const char* to_name, int allow_none) -{ - PyObject *value = PyObject_GetAttrString(spec, from_name); - int result = 0; - if (likely(value)) { - if (allow_none || value != Py_None) { - result = PyDict_SetItemString(moddict, to_name, value); - } - Py_DECREF(value); - } else if (PyErr_ExceptionMatches(PyExc_AttributeError)) { - PyErr_Clear(); - } else { - result = -1; - } - return result; -} -static CYTHON_SMALL_CODE PyObject* __pyx_pymod_create(PyObject *spec, PyModuleDef *def) { - PyObject *module = NULL, *moddict, *modname; - CYTHON_UNUSED_VAR(def); - #if !CYTHON_USE_MODULE_STATE - if (__Pyx_check_single_interpreter()) - return NULL; - #endif - if (__pyx_m) - return __Pyx_NewRef(__pyx_m); - modname = PyObject_GetAttrString(spec, "name"); - if (unlikely(!modname)) goto bad; - module = PyModule_NewObject(modname); - Py_DECREF(modname); - if (unlikely(!module)) goto bad; - moddict = PyModule_GetDict(module); - if (unlikely(!moddict)) goto bad; - if (unlikely(__Pyx_copy_spec_to_module(spec, moddict, "loader", "__loader__", 1) < 0)) goto bad; - if (unlikely(__Pyx_copy_spec_to_module(spec, moddict, "origin", "__file__", 1) < 0)) goto bad; - if (unlikely(__Pyx_copy_spec_to_module(spec, moddict, "parent", "__package__", 1) < 0)) goto bad; - if (unlikely(__Pyx_copy_spec_to_module(spec, moddict, "submodule_search_locations", "__path__", 0) < 0)) goto bad; - return module; -bad: - Py_XDECREF(module); - return NULL; -} - - -static CYTHON_SMALL_CODE int __pyx_pymod_exec_epanet(PyObject *__pyx_pyinit_module) -#endif -{ - int stringtab_initialized = 0; - #if CYTHON_USE_MODULE_STATE - int pystate_addmodule_run = 0; - #endif - __pyx_mstatetype *__pyx_mstate = NULL; - PyObject *__pyx_t_1 = NULL; - PyObject *__pyx_t_2 = NULL; - PyObject *__pyx_t_3 = NULL; - int __pyx_t_4; - int __pyx_t_5; - PyObject *__pyx_t_6 = NULL; - size_t __pyx_t_7; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - __Pyx_RefNannyDeclarations - #if CYTHON_PEP489_MULTI_PHASE_INIT - if (__pyx_m) { - if (__pyx_m == __pyx_pyinit_module) return 0; - PyErr_SetString(PyExc_RuntimeError, "Module 'epanet' has already been imported. Re-initialisation is not supported."); - return -1; - } - #else - if (__pyx_m) return __Pyx_NewRef(__pyx_m); - #endif - /*--- Module creation code ---*/ - #if CYTHON_PEP489_MULTI_PHASE_INIT - __pyx_t_1 = __pyx_pyinit_module; - Py_INCREF(__pyx_t_1); - #else - __pyx_t_1 = PyModule_Create(&__pyx_moduledef); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1, __pyx_L1_error) - #endif - #if CYTHON_USE_MODULE_STATE - { - int add_module_result = __Pyx_State_AddModule(__pyx_t_1, &__pyx_moduledef); - __pyx_t_1 = 0; /* transfer ownership from __pyx_t_1 to "epanet" pseudovariable */ - if (unlikely((add_module_result < 0))) __PYX_ERR(0, 1, __pyx_L1_error) - pystate_addmodule_run = 1; - } - #else - __pyx_m = __pyx_t_1; - #endif - #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - PyUnstable_Module_SetGIL(__pyx_m, Py_MOD_GIL_USED); - #endif - __pyx_mstate = __pyx_mstate_global; - CYTHON_UNUSED_VAR(__pyx_t_1); - __pyx_mstate->__pyx_d = PyModule_GetDict(__pyx_m); if (unlikely(!__pyx_mstate->__pyx_d)) __PYX_ERR(0, 1, __pyx_L1_error) - Py_INCREF(__pyx_mstate->__pyx_d); - __pyx_mstate->__pyx_b = __Pyx_PyImport_AddModuleRef(__Pyx_BUILTIN_MODULE_NAME); if (unlikely(!__pyx_mstate->__pyx_b)) __PYX_ERR(0, 1, __pyx_L1_error) - __pyx_mstate->__pyx_cython_runtime = __Pyx_PyImport_AddModuleRef("cython_runtime"); if (unlikely(!__pyx_mstate->__pyx_cython_runtime)) __PYX_ERR(0, 1, __pyx_L1_error) - if (PyObject_SetAttrString(__pyx_m, "__builtins__", __pyx_mstate->__pyx_b) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - /* ImportRefnannyAPI */ - #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("PyInit_epanet", 0); - if (__Pyx_check_binary_version(__PYX_LIMITED_VERSION_HEX, __Pyx_get_runtime_version(), CYTHON_COMPILING_IN_LIMITED_API) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - #ifdef __Pxy_PyFrame_Initialize_Offsets - __Pxy_PyFrame_Initialize_Offsets(); - #endif - __pyx_mstate->__pyx_empty_tuple = PyTuple_New(0); if (unlikely(!__pyx_mstate->__pyx_empty_tuple)) __PYX_ERR(0, 1, __pyx_L1_error) - __pyx_mstate->__pyx_empty_bytes = PyBytes_FromStringAndSize("", 0); if (unlikely(!__pyx_mstate->__pyx_empty_bytes)) __PYX_ERR(0, 1, __pyx_L1_error) - __pyx_mstate->__pyx_empty_unicode = PyUnicode_FromStringAndSize("", 0); if (unlikely(!__pyx_mstate->__pyx_empty_unicode)) __PYX_ERR(0, 1, __pyx_L1_error) - #ifdef __Pyx_CyFunction_USED - if (__pyx_CyFunction_init(__pyx_m) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - #endif - #ifdef __Pyx_FusedFunction_USED - if (__pyx_FusedFunction_init(__pyx_m) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - #endif - #ifdef __Pyx_Coroutine_USED - if (__pyx_Coroutine_init(__pyx_m) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - #endif - #ifdef __Pyx_Generator_USED - if (__pyx_Generator_init(__pyx_m) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - #endif - #ifdef __Pyx_AsyncGen_USED - if (__pyx_AsyncGen_init(__pyx_m) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - #endif - /*--- Library function declarations ---*/ - /*--- Initialize various global constants etc. ---*/ - if (__Pyx_InitConstants(__pyx_mstate) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - stringtab_initialized = 1; - if (__Pyx_InitGlobals() < 0) __PYX_ERR(0, 1, __pyx_L1_error) - if (__pyx_module_is_main_epanet__epanet) { - if (PyObject_SetAttr(__pyx_m, __pyx_mstate_global->__pyx_n_u_name_2, __pyx_mstate_global->__pyx_n_u_main) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - } - { - PyObject *modules = PyImport_GetModuleDict(); if (unlikely(!modules)) __PYX_ERR(0, 1, __pyx_L1_error) - if (!PyDict_GetItemString(modules, "epanet.epanet")) { - if (unlikely((PyDict_SetItemString(modules, "epanet.epanet", __pyx_m) < 0))) __PYX_ERR(0, 1, __pyx_L1_error) - } - } - /*--- Builtin init code ---*/ - if (__Pyx_InitCachedBuiltins(__pyx_mstate) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - /*--- Constants init code ---*/ - if (__Pyx_InitCachedConstants(__pyx_mstate) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - if (__Pyx_CreateCodeObjects(__pyx_mstate) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - /*--- Global type/function init code ---*/ - (void)__Pyx_modinit_global_init_code(__pyx_mstate); - (void)__Pyx_modinit_variable_export_code(__pyx_mstate); - (void)__Pyx_modinit_function_export_code(__pyx_mstate); - (void)__Pyx_modinit_type_init_code(__pyx_mstate); - (void)__Pyx_modinit_type_import_code(__pyx_mstate); - (void)__Pyx_modinit_variable_import_code(__pyx_mstate); - (void)__Pyx_modinit_function_import_code(__pyx_mstate); - /*--- Execution code ---*/ - - /* "epanet/epanet.py":1 - * import ctypes # <<<<<<<<<<<<<< - * import platform - * import os -*/ - __pyx_t_2 = __Pyx_ImportDottedModule(__pyx_mstate_global->__pyx_n_u_ctypes, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_ctypes, __pyx_t_2) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet.py":2 - * import ctypes - * import platform # <<<<<<<<<<<<<< - * import os - * import sys -*/ - __pyx_t_2 = __Pyx_ImportDottedModule(__pyx_mstate_global->__pyx_n_u_platform, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 2, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_platform, __pyx_t_2) < 0) __PYX_ERR(0, 2, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet.py":3 - * import ctypes - * import platform - * import os # <<<<<<<<<<<<<< - * import sys - * import json -*/ - __pyx_t_2 = __Pyx_ImportDottedModule(__pyx_mstate_global->__pyx_n_u_os, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 3, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_os, __pyx_t_2) < 0) __PYX_ERR(0, 3, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet.py":4 - * import platform - * import os - * import sys # <<<<<<<<<<<<<< - * import json - * import base64 -*/ - __pyx_t_2 = __Pyx_ImportDottedModule(__pyx_mstate_global->__pyx_n_u_sys, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 4, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_sys, __pyx_t_2) < 0) __PYX_ERR(0, 4, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet.py":5 - * import os - * import sys - * import json # <<<<<<<<<<<<<< - * import base64 - * from typing import Any -*/ - __pyx_t_2 = __Pyx_ImportDottedModule(__pyx_mstate_global->__pyx_n_u_json_2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 5, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_json_2, __pyx_t_2) < 0) __PYX_ERR(0, 5, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet.py":6 - * import sys - * import json - * import base64 # <<<<<<<<<<<<<< - * from typing import Any - * sys.path.append("..") -*/ - __pyx_t_2 = __Pyx_ImportDottedModule(__pyx_mstate_global->__pyx_n_u_base64, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_base64, __pyx_t_2) < 0) __PYX_ERR(0, 6, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet.py":7 - * import json - * import base64 - * from typing import Any # <<<<<<<<<<<<<< - * sys.path.append("..") - * from api import project -*/ - __pyx_t_2 = __Pyx_PyList_Pack(1, __pyx_mstate_global->__pyx_n_u_Any); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_t_3 = __Pyx_Import(__pyx_mstate_global->__pyx_n_u_typing, __pyx_t_2, 0); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 7, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __pyx_t_2 = __Pyx_ImportFrom(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_Any); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_Any, __pyx_t_2) < 0) __PYX_ERR(0, 7, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - - /* "epanet/epanet.py":8 - * import base64 - * from typing import Any - * sys.path.append("..") # <<<<<<<<<<<<<< - * from api import project - * from api import inp_out -*/ - __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_sys); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 8, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_path); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __pyx_t_4 = __Pyx_PyObject_Append(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u__4); if (unlikely(__pyx_t_4 == ((int)-1))) __PYX_ERR(0, 8, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet.py":9 - * from typing import Any - * sys.path.append("..") - * from api import project # <<<<<<<<<<<<<< - * from api import inp_out - * -*/ - __pyx_t_2 = __Pyx_PyList_Pack(1, __pyx_mstate_global->__pyx_n_u_project); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 9, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_t_3 = __Pyx_Import(__pyx_mstate_global->__pyx_n_u_api, __pyx_t_2, 0); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 9, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __pyx_t_2 = __Pyx_ImportFrom(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_project); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 9, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_project, __pyx_t_2) < 0) __PYX_ERR(0, 9, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - - /* "epanet/epanet.py":10 - * sys.path.append("..") - * from api import project - * from api import inp_out # <<<<<<<<<<<<<< - * - * -*/ - __pyx_t_3 = __Pyx_PyList_Pack(1, __pyx_mstate_global->__pyx_n_u_inp_out); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 10, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __pyx_t_2 = __Pyx_Import(__pyx_mstate_global->__pyx_n_u_api, __pyx_t_3, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 10, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __pyx_t_3 = __Pyx_ImportFrom(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_inp_out); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 10, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_inp_out, __pyx_t_3) < 0) __PYX_ERR(0, 10, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet.py":13 - * - * - * def _verify_platform(): # <<<<<<<<<<<<<< - * _platform = platform.system() - * if _platform != "Windows": -*/ - __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_6epanet_6epanet_1_verify_platform, 0, __pyx_mstate_global->__pyx_n_u_verify_platform, NULL, __pyx_mstate_global->__pyx_n_u_epanet_epanet, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[0])); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 13, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_verify_platform, __pyx_t_2) < 0) __PYX_ERR(0, 13, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet.py":19 - * - * - * if __name__ == '__main__': # <<<<<<<<<<<<<< - * _verify_platform() - * -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_name_2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 19, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __pyx_t_5 = (__Pyx_PyUnicode_Equals(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_main, Py_EQ)); if (unlikely((__pyx_t_5 < 0))) __PYX_ERR(0, 19, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - if (__pyx_t_5) { - - /* "epanet/epanet.py":20 - * - * if __name__ == '__main__': - * _verify_platform() # <<<<<<<<<<<<<< - * - * -*/ - __pyx_t_3 = NULL; - __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_verify_platform); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 20, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __pyx_t_7 = 1; - { - PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL}; - __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_6, __pyx_callargs+__pyx_t_7, (1-__pyx_t_7) | (__pyx_t_7*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); - __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 20, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - } - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet.py":19 - * - * - * if __name__ == '__main__': # <<<<<<<<<<<<<< - * _verify_platform() - * -*/ - } - - /* "epanet/epanet.py":23 - * - * - * class Output: # <<<<<<<<<<<<<< - * def __init__(self, path: str) -> None: - * self._path = path -*/ - __pyx_t_2 = __Pyx_Py3MetaclassPrepare((PyObject *) NULL, __pyx_mstate_global->__pyx_empty_tuple, __pyx_mstate_global->__pyx_n_u_Output, __pyx_mstate_global->__pyx_n_u_Output, (PyObject *) NULL, __pyx_mstate_global->__pyx_n_u_epanet_epanet, (PyObject *) NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 23, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - - /* "epanet/epanet.py":24 - * - * class Output: - * def __init__(self, path: str) -> None: # <<<<<<<<<<<<<< - * self._path = path - * -*/ - __pyx_t_6 = __Pyx_PyDict_NewPresized(2); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 24, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_path, __pyx_mstate_global->__pyx_n_u_str) < 0) __PYX_ERR(0, 24, __pyx_L1_error) - if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_return, __pyx_mstate_global->__pyx_n_u_None) < 0) __PYX_ERR(0, 24, __pyx_L1_error) - __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_6epanet_6epanet_6Output_1__init__, 0, __pyx_mstate_global->__pyx_n_u_Output___init, NULL, __pyx_mstate_global->__pyx_n_u_epanet_epanet, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[1])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 24, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_3, __pyx_t_6); - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - if (__Pyx_SetNameInClass(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_init, __pyx_t_3) < 0) __PYX_ERR(0, 24, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - - /* "epanet/epanet.py":35 - * - * - * def __del__(self): # <<<<<<<<<<<<<< - * # throw exception in destructor ? :) - * self._check(self._lib.ENR_close(ctypes.byref(self._handle))) -*/ - __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_6epanet_6epanet_6Output_3__del__, 0, __pyx_mstate_global->__pyx_n_u_Output___del, NULL, __pyx_mstate_global->__pyx_n_u_epanet_epanet, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[2])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 35, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - if (__Pyx_SetNameInClass(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_del, __pyx_t_3) < 0) __PYX_ERR(0, 35, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - - /* "epanet/epanet.py":40 - * - * - * def _check(self, result): # <<<<<<<<<<<<<< - * if result != 0 and result != 10: - * msg = ctypes.c_char_p() -*/ - __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_6epanet_6epanet_6Output_5_check, 0, __pyx_mstate_global->__pyx_n_u_Output__check, NULL, __pyx_mstate_global->__pyx_n_u_epanet_epanet, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[3])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 40, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - if (__Pyx_SetNameInClass(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_check, __pyx_t_3) < 0) __PYX_ERR(0, 40, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - - /* "epanet/epanet.py":53 - * - * - * def version(self) -> int: # <<<<<<<<<<<<<< - * v = ctypes.c_int() - * self._check(self._lib.ENR_getVersion(self._handle, ctypes.byref(v))) -*/ - __pyx_t_3 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 53, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - if (PyDict_SetItem(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_return, __pyx_mstate_global->__pyx_n_u_int) < 0) __PYX_ERR(0, 53, __pyx_L1_error) - __pyx_t_6 = __Pyx_CyFunction_New(&__pyx_mdef_6epanet_6epanet_6Output_7version, 0, __pyx_mstate_global->__pyx_n_u_Output_version, NULL, __pyx_mstate_global->__pyx_n_u_epanet_epanet, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[4])); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 53, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_6, __pyx_t_3); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - if (__Pyx_SetNameInClass(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_version, __pyx_t_6) < 0) __PYX_ERR(0, 53, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - - /* "epanet/epanet.py":59 - * - * - * def net_size(self) -> dict[str, int]: # <<<<<<<<<<<<<< - * element_count = ctypes.POINTER(ctypes.c_int)() - * length = ctypes.c_int() -*/ - __pyx_t_6 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 59, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_return, __pyx_mstate_global->__pyx_kp_u_dict_str_int) < 0) __PYX_ERR(0, 59, __pyx_L1_error) - __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_6epanet_6epanet_6Output_9net_size, 0, __pyx_mstate_global->__pyx_n_u_Output_net_size, NULL, __pyx_mstate_global->__pyx_n_u_epanet_epanet, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[5])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 59, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_3, __pyx_t_6); - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - if (__Pyx_SetNameInClass(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_net_size, __pyx_t_3) < 0) __PYX_ERR(0, 59, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - - /* "epanet/epanet.py":72 - * - * - * def units(self) -> dict[str, str]: # <<<<<<<<<<<<<< - * f_us = ['CFS', 'GPM', 'MGD', 'IMGD', 'AFD', 'LPS', 'LPM', 'MLD', 'CMH', 'CMD'] - * p_us = ['PSI', 'MTR', 'KPA'] -*/ - __pyx_t_3 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 72, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - if (PyDict_SetItem(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_return, __pyx_mstate_global->__pyx_kp_u_dict_str_str) < 0) __PYX_ERR(0, 72, __pyx_L1_error) - __pyx_t_6 = __Pyx_CyFunction_New(&__pyx_mdef_6epanet_6epanet_6Output_11units, 0, __pyx_mstate_global->__pyx_n_u_Output_units, NULL, __pyx_mstate_global->__pyx_n_u_epanet_epanet, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[6])); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 72, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_6, __pyx_t_3); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - if (__Pyx_SetNameInClass(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_units, __pyx_t_6) < 0) __PYX_ERR(0, 72, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - - /* "epanet/epanet.py":84 - * - * - * def times(self) -> dict[str, int]: # <<<<<<<<<<<<<< - * ts = [] - * for i in range(1, 5): -*/ - __pyx_t_6 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 84, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_return, __pyx_mstate_global->__pyx_kp_u_dict_str_int) < 0) __PYX_ERR(0, 84, __pyx_L1_error) - __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_6epanet_6epanet_6Output_13times, 0, __pyx_mstate_global->__pyx_n_u_Output_times, NULL, __pyx_mstate_global->__pyx_n_u_epanet_epanet, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[7])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 84, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_3, __pyx_t_6); - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - if (__Pyx_SetNameInClass(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_times, __pyx_t_3) < 0) __PYX_ERR(0, 84, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - - /* "epanet/epanet.py":97 - * - * - * def element_name(self) -> dict[str, list[str]]: # <<<<<<<<<<<<<< - * sizes = self.net_size() - * -*/ - __pyx_t_3 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 97, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - if (PyDict_SetItem(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_return, __pyx_mstate_global->__pyx_kp_u_dict_str_list_str) < 0) __PYX_ERR(0, 97, __pyx_L1_error) - __pyx_t_6 = __Pyx_CyFunction_New(&__pyx_mdef_6epanet_6epanet_6Output_15element_name, 0, __pyx_mstate_global->__pyx_n_u_Output_element_name, NULL, __pyx_mstate_global->__pyx_n_u_epanet_epanet, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[8])); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 97, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_6, __pyx_t_3); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - if (__Pyx_SetNameInClass(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_element_name, __pyx_t_6) < 0) __PYX_ERR(0, 97, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - - /* "epanet/epanet.py":121 - * - * - * def energy_usage(self) -> list[dict[str, Any]]: # <<<<<<<<<<<<<< - * size = self.net_size()['pump'] - * usages = [] -*/ - __pyx_t_6 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 121, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_return, __pyx_mstate_global->__pyx_kp_u_list_dict_str_Any) < 0) __PYX_ERR(0, 121, __pyx_L1_error) - __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_6epanet_6epanet_6Output_17energy_usage, 0, __pyx_mstate_global->__pyx_n_u_Output_energy_usage, NULL, __pyx_mstate_global->__pyx_n_u_epanet_epanet, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[9])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 121, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_3, __pyx_t_6); - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - if (__Pyx_SetNameInClass(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_energy_usage, __pyx_t_3) < 0) __PYX_ERR(0, 121, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - - /* "epanet/epanet.py":140 - * - * - * def reactions(self) -> dict[str, float]: # <<<<<<<<<<<<<< - * values = ctypes.POINTER(ctypes.c_float)() - * length = ctypes.c_int() -*/ - __pyx_t_3 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 140, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - if (PyDict_SetItem(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_return, __pyx_mstate_global->__pyx_kp_u_dict_str_float) < 0) __PYX_ERR(0, 140, __pyx_L1_error) - __pyx_t_6 = __Pyx_CyFunction_New(&__pyx_mdef_6epanet_6epanet_6Output_19reactions, 0, __pyx_mstate_global->__pyx_n_u_Output_reactions, NULL, __pyx_mstate_global->__pyx_n_u_epanet_epanet, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[10])); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 140, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_6, __pyx_t_3); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - if (__Pyx_SetNameInClass(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_reactions, __pyx_t_6) < 0) __PYX_ERR(0, 140, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - - /* "epanet/epanet.py":153 - * - * - * def node_results(self) -> list[dict[str, Any]]: # <<<<<<<<<<<<<< - * size = self.net_size()['node'] - * num_periods = self.times()['num_periods'] -*/ - __pyx_t_6 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 153, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_return, __pyx_mstate_global->__pyx_kp_u_list_dict_str_Any) < 0) __PYX_ERR(0, 153, __pyx_L1_error) - __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_6epanet_6epanet_6Output_21node_results, 0, __pyx_mstate_global->__pyx_n_u_Output_node_results, NULL, __pyx_mstate_global->__pyx_n_u_epanet_epanet, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[11])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 153, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_3, __pyx_t_6); - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - if (__Pyx_SetNameInClass(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_node_results, __pyx_t_3) < 0) __PYX_ERR(0, 153, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - - /* "epanet/epanet.py":175 - * - * - * def link_results(self) -> list[dict[str, Any]]: # <<<<<<<<<<<<<< - * size = self.net_size()['link'] - * num_periods = self.times()['num_periods'] -*/ - __pyx_t_3 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 175, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - if (PyDict_SetItem(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_return, __pyx_mstate_global->__pyx_kp_u_list_dict_str_Any) < 0) __PYX_ERR(0, 175, __pyx_L1_error) - __pyx_t_6 = __Pyx_CyFunction_New(&__pyx_mdef_6epanet_6epanet_6Output_23link_results, 0, __pyx_mstate_global->__pyx_n_u_Output_link_results, NULL, __pyx_mstate_global->__pyx_n_u_epanet_epanet, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[12])); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 175, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_6, __pyx_t_3); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - if (__Pyx_SetNameInClass(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_link_results, __pyx_t_6) < 0) __PYX_ERR(0, 175, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - - /* "epanet/epanet.py":204 - * - * - * def dump(self) -> dict[str, Any]: # <<<<<<<<<<<<<< - * data = {} - * data |= { 'version' : self.version() } -*/ - __pyx_t_6 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 204, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_6); - if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_return, __pyx_mstate_global->__pyx_kp_u_dict_str_Any) < 0) __PYX_ERR(0, 204, __pyx_L1_error) - __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_6epanet_6epanet_6Output_25dump, 0, __pyx_mstate_global->__pyx_n_u_Output_dump, NULL, __pyx_mstate_global->__pyx_n_u_epanet_epanet, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[13])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 204, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_3, __pyx_t_6); - __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; - if (__Pyx_SetNameInClass(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_dump, __pyx_t_3) < 0) __PYX_ERR(0, 204, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - - /* "epanet/epanet.py":23 - * - * - * class Output: # <<<<<<<<<<<<<< - * def __init__(self, path: str) -> None: - * self._path = path -*/ - __pyx_t_3 = __Pyx_Py3ClassCreate(((PyObject*)&PyType_Type), __pyx_mstate_global->__pyx_n_u_Output, __pyx_mstate_global->__pyx_empty_tuple, __pyx_t_2, NULL, 0, 0); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 23, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_Output, __pyx_t_3) < 0) __PYX_ERR(0, 23, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet.py":218 - * - * - * def _dump_output(path: str) -> dict[str, Any]: # <<<<<<<<<<<<<< - * opt = Output(path) - * data = opt.dump() -*/ - __pyx_t_2 = __Pyx_PyDict_NewPresized(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 218, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (PyDict_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_path, __pyx_mstate_global->__pyx_n_u_str) < 0) __PYX_ERR(0, 218, __pyx_L1_error) - if (PyDict_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_return, __pyx_mstate_global->__pyx_kp_u_dict_str_Any) < 0) __PYX_ERR(0, 218, __pyx_L1_error) - __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_6epanet_6epanet_3_dump_output, 0, __pyx_mstate_global->__pyx_n_u_dump_output, NULL, __pyx_mstate_global->__pyx_n_u_epanet_epanet, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[14])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 218, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_3, __pyx_t_2); - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_dump_output, __pyx_t_3) < 0) __PYX_ERR(0, 218, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - - /* "epanet/epanet.py":226 - * - * - * def dump_output(path: str) -> str: # <<<<<<<<<<<<<< - * data = _dump_output(path) - * return json.dumps(data) -*/ - __pyx_t_3 = __Pyx_PyDict_NewPresized(2); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 226, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - if (PyDict_SetItem(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_path, __pyx_mstate_global->__pyx_n_u_str) < 0) __PYX_ERR(0, 226, __pyx_L1_error) - if (PyDict_SetItem(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_return, __pyx_mstate_global->__pyx_n_u_str) < 0) __PYX_ERR(0, 226, __pyx_L1_error) - __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_6epanet_6epanet_5dump_output, 0, __pyx_mstate_global->__pyx_n_u_dump_output_2, NULL, __pyx_mstate_global->__pyx_n_u_epanet_epanet, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[15])); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 226, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_2, __pyx_t_3); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_dump_output_2, __pyx_t_2) < 0) __PYX_ERR(0, 226, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet.py":231 - * - * - * def dump_report(path: str) -> str: # <<<<<<<<<<<<<< - * return open(path, 'r').read() - * -*/ - __pyx_t_2 = __Pyx_PyDict_NewPresized(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 231, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (PyDict_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_path, __pyx_mstate_global->__pyx_n_u_str) < 0) __PYX_ERR(0, 231, __pyx_L1_error) - if (PyDict_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_return, __pyx_mstate_global->__pyx_n_u_str) < 0) __PYX_ERR(0, 231, __pyx_L1_error) - __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_6epanet_6epanet_7dump_report, 0, __pyx_mstate_global->__pyx_n_u_dump_report, NULL, __pyx_mstate_global->__pyx_n_u_epanet_epanet, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[16])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 231, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_3, __pyx_t_2); - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_dump_report, __pyx_t_3) < 0) __PYX_ERR(0, 231, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - - /* "epanet/epanet.py":235 - * - * - * def dump_output_binary(path: str) -> str: # <<<<<<<<<<<<<< - * with open(path, 'rb') as f: - * data = f.read() -*/ - __pyx_t_3 = __Pyx_PyDict_NewPresized(2); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 235, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - if (PyDict_SetItem(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_path, __pyx_mstate_global->__pyx_n_u_str) < 0) __PYX_ERR(0, 235, __pyx_L1_error) - if (PyDict_SetItem(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_return, __pyx_mstate_global->__pyx_n_u_str) < 0) __PYX_ERR(0, 235, __pyx_L1_error) - __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_6epanet_6epanet_9dump_output_binary, 0, __pyx_mstate_global->__pyx_n_u_dump_output_binary, NULL, __pyx_mstate_global->__pyx_n_u_epanet_epanet, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[17])); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 235, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_2, __pyx_t_3); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_dump_output_binary, __pyx_t_2) < 0) __PYX_ERR(0, 235, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet.py":242 - * - * #DingZQ, 2025-02-04, dict[str, Any] - * def run_project_return_dict(name: str, readable_output: bool = False) -> dict[str, Any]: # <<<<<<<<<<<<<< - * if not project.have_project(name): - * raise Exception(f'Not found project [{name}]') -*/ - __pyx_t_2 = __Pyx_PyDict_NewPresized(3); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 242, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (PyDict_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_name, __pyx_mstate_global->__pyx_n_u_str) < 0) __PYX_ERR(0, 242, __pyx_L1_error) - if (PyDict_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_readable_output, __pyx_mstate_global->__pyx_n_u_bool) < 0) __PYX_ERR(0, 242, __pyx_L1_error) - if (PyDict_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_return, __pyx_mstate_global->__pyx_kp_u_dict_str_Any) < 0) __PYX_ERR(0, 242, __pyx_L1_error) - __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_6epanet_6epanet_11run_project_return_dict, 0, __pyx_mstate_global->__pyx_n_u_run_project_return_dict, NULL, __pyx_mstate_global->__pyx_n_u_epanet_epanet, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[18])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 242, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __Pyx_CyFunction_SetDefaultsTuple(__pyx_t_3, __pyx_mstate_global->__pyx_tuple[1]); - __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_3, __pyx_t_2); - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_run_project_return_dict, __pyx_t_3) < 0) __PYX_ERR(0, 242, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - - /* "epanet/epanet.py":275 - * - * # original code - * def run_project(name: str, readable_output: bool = False) -> str: # <<<<<<<<<<<<<< - * if not project.have_project(name): - * raise Exception(f'Not found project [{name}]') -*/ - __pyx_t_3 = __Pyx_PyDict_NewPresized(3); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 275, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - if (PyDict_SetItem(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_name, __pyx_mstate_global->__pyx_n_u_str) < 0) __PYX_ERR(0, 275, __pyx_L1_error) - if (PyDict_SetItem(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_readable_output, __pyx_mstate_global->__pyx_n_u_bool) < 0) __PYX_ERR(0, 275, __pyx_L1_error) - if (PyDict_SetItem(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_return, __pyx_mstate_global->__pyx_n_u_str) < 0) __PYX_ERR(0, 275, __pyx_L1_error) - __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_6epanet_6epanet_13run_project, 0, __pyx_mstate_global->__pyx_n_u_run_project, NULL, __pyx_mstate_global->__pyx_n_u_epanet_epanet, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[19])); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 275, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - __Pyx_CyFunction_SetDefaultsTuple(__pyx_t_2, __pyx_mstate_global->__pyx_tuple[1]); - __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_2, __pyx_t_3); - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_run_project, __pyx_t_2) < 0) __PYX_ERR(0, 275, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet.py":308 - * - * - * def run_inp(name: str) -> str: # <<<<<<<<<<<<<< - * dir = os.path.abspath(os.getcwd()) - * -*/ - __pyx_t_2 = __Pyx_PyDict_NewPresized(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 308, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (PyDict_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_name, __pyx_mstate_global->__pyx_n_u_str) < 0) __PYX_ERR(0, 308, __pyx_L1_error) - if (PyDict_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_return, __pyx_mstate_global->__pyx_n_u_str) < 0) __PYX_ERR(0, 308, __pyx_L1_error) - __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_6epanet_6epanet_15run_inp, 0, __pyx_mstate_global->__pyx_n_u_run_inp, NULL, __pyx_mstate_global->__pyx_n_u_epanet_epanet, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[20])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 308, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_3, __pyx_t_2); - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_run_inp, __pyx_t_3) < 0) __PYX_ERR(0, 308, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - - /* "epanet/epanet.py":1 - * import ctypes # <<<<<<<<<<<<<< - * import platform - * import os -*/ - __pyx_t_3 = __Pyx_PyDict_NewPresized(0); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_3); - if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_test, __pyx_t_3) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; - - /*--- Wrapped vars code ---*/ - - goto __pyx_L0; - __pyx_L1_error:; - __Pyx_XDECREF(__pyx_t_2); - __Pyx_XDECREF(__pyx_t_3); - __Pyx_XDECREF(__pyx_t_6); - if (__pyx_m) { - if (__pyx_mstate->__pyx_d && stringtab_initialized) { - __Pyx_AddTraceback("init epanet.epanet", __pyx_clineno, __pyx_lineno, __pyx_filename); - } - #if !CYTHON_USE_MODULE_STATE - Py_CLEAR(__pyx_m); - #else - Py_DECREF(__pyx_m); - if (pystate_addmodule_run) { - PyObject *tp, *value, *tb; - PyErr_Fetch(&tp, &value, &tb); - PyState_RemoveModule(&__pyx_moduledef); - PyErr_Restore(tp, value, tb); - } - #endif - } else if (!PyErr_Occurred()) { - PyErr_SetString(PyExc_ImportError, "init epanet.epanet"); - } - __pyx_L0:; - __Pyx_RefNannyFinishContext(); - #if CYTHON_PEP489_MULTI_PHASE_INIT - return (__pyx_m != NULL) ? 0 : -1; - #else - return __pyx_m; - #endif -} -/* #### Code section: pystring_table ### */ - -typedef struct { - const char *s; -#if 179 <= 65535 - const unsigned short n; -#elif 179 / 2 < INT_MAX - const unsigned int n; -#elif 179 / 2 < LONG_MAX - const unsigned long n; -#else - const Py_ssize_t n; -#endif -#if 1 <= 31 - const unsigned int encoding : 5; -#elif 1 <= 255 - const unsigned char encoding; -#elif 1 <= 65535 - const unsigned short encoding; -#else - const Py_ssize_t encoding; -#endif - const unsigned int is_unicode : 1; - const unsigned int intern : 1; -} __Pyx_StringTabEntry; -static const char * const __pyx_string_tab_encodings[] = { 0 }; -static const __Pyx_StringTabEntry __pyx_string_tab[] = { - {__pyx_k_, sizeof(__pyx_k_), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_ */ - {__pyx_k_2, sizeof(__pyx_k_2), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_2 */ - {__pyx_k_AFD, sizeof(__pyx_k_AFD), 0, 1, 1}, /* PyObject cname: __pyx_n_u_AFD */ - {__pyx_k_Any, sizeof(__pyx_k_Any), 0, 1, 1}, /* PyObject cname: __pyx_n_u_Any */ - {__pyx_k_AssertionError, sizeof(__pyx_k_AssertionError), 0, 1, 1}, /* PyObject cname: __pyx_n_u_AssertionError */ - {__pyx_k_CDLL, sizeof(__pyx_k_CDLL), 0, 1, 1}, /* PyObject cname: __pyx_n_u_CDLL */ - {__pyx_k_CFS, sizeof(__pyx_k_CFS), 0, 1, 1}, /* PyObject cname: __pyx_n_u_CFS */ - {__pyx_k_CLOSED, sizeof(__pyx_k_CLOSED), 0, 1, 1}, /* PyObject cname: __pyx_n_u_CLOSED */ - {__pyx_k_CMD, sizeof(__pyx_k_CMD), 0, 1, 1}, /* PyObject cname: __pyx_n_u_CMD */ - {__pyx_k_CMH, sizeof(__pyx_k_CMH), 0, 1, 1}, /* PyObject cname: __pyx_n_u_CMH */ - {__pyx_k_ENR_checkError, sizeof(__pyx_k_ENR_checkError), 0, 1, 1}, /* PyObject cname: __pyx_n_u_ENR_checkError */ - {__pyx_k_ENR_close, sizeof(__pyx_k_ENR_close), 0, 1, 1}, /* PyObject cname: __pyx_n_u_ENR_close */ - {__pyx_k_ENR_free, sizeof(__pyx_k_ENR_free), 0, 1, 1}, /* PyObject cname: __pyx_n_u_ENR_free */ - {__pyx_k_ENR_getElementName, sizeof(__pyx_k_ENR_getElementName), 0, 1, 1}, /* PyObject cname: __pyx_n_u_ENR_getElementName */ - {__pyx_k_ENR_getEnergyUsage, sizeof(__pyx_k_ENR_getEnergyUsage), 0, 1, 1}, /* PyObject cname: __pyx_n_u_ENR_getEnergyUsage */ - {__pyx_k_ENR_getLinkResult, sizeof(__pyx_k_ENR_getLinkResult), 0, 1, 1}, /* PyObject cname: __pyx_n_u_ENR_getLinkResult */ - {__pyx_k_ENR_getNetReacts, sizeof(__pyx_k_ENR_getNetReacts), 0, 1, 1}, /* PyObject cname: __pyx_n_u_ENR_getNetReacts */ - {__pyx_k_ENR_getNetSize, sizeof(__pyx_k_ENR_getNetSize), 0, 1, 1}, /* PyObject cname: __pyx_n_u_ENR_getNetSize */ - {__pyx_k_ENR_getNodeResult, sizeof(__pyx_k_ENR_getNodeResult), 0, 1, 1}, /* PyObject cname: __pyx_n_u_ENR_getNodeResult */ - {__pyx_k_ENR_getTimes, sizeof(__pyx_k_ENR_getTimes), 0, 1, 1}, /* PyObject cname: __pyx_n_u_ENR_getTimes */ - {__pyx_k_ENR_getUnits, sizeof(__pyx_k_ENR_getUnits), 0, 1, 1}, /* PyObject cname: __pyx_n_u_ENR_getUnits */ - {__pyx_k_ENR_getVersion, sizeof(__pyx_k_ENR_getVersion), 0, 1, 1}, /* PyObject cname: __pyx_n_u_ENR_getVersion */ - {__pyx_k_ENR_init, sizeof(__pyx_k_ENR_init), 0, 1, 1}, /* PyObject cname: __pyx_n_u_ENR_init */ - {__pyx_k_ENR_open, sizeof(__pyx_k_ENR_open), 0, 1, 1}, /* PyObject cname: __pyx_n_u_ENR_open */ - {__pyx_k_Failed_to_read_project, sizeof(__pyx_k_Failed_to_read_project), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_Failed_to_read_project */ - {__pyx_k_GPM, sizeof(__pyx_k_GPM), 0, 1, 1}, /* PyObject cname: __pyx_n_u_GPM */ - {__pyx_k_HOURS, sizeof(__pyx_k_HOURS), 0, 1, 1}, /* PyObject cname: __pyx_n_u_HOURS */ - {__pyx_k_IMGD, sizeof(__pyx_k_IMGD), 0, 1, 1}, /* PyObject cname: __pyx_n_u_IMGD */ - {__pyx_k_KPA, sizeof(__pyx_k_KPA), 0, 1, 1}, /* PyObject cname: __pyx_n_u_KPA */ - {__pyx_k_LPM, sizeof(__pyx_k_LPM), 0, 1, 1}, /* PyObject cname: __pyx_n_u_LPM */ - {__pyx_k_LPS, sizeof(__pyx_k_LPS), 0, 1, 1}, /* PyObject cname: __pyx_n_u_LPS */ - {__pyx_k_MGD, sizeof(__pyx_k_MGD), 0, 1, 1}, /* PyObject cname: __pyx_n_u_MGD */ - {__pyx_k_MGL, sizeof(__pyx_k_MGL), 0, 1, 1}, /* PyObject cname: __pyx_n_u_MGL */ - {__pyx_k_MLD, sizeof(__pyx_k_MLD), 0, 1, 1}, /* PyObject cname: __pyx_n_u_MLD */ - {__pyx_k_MTR, sizeof(__pyx_k_MTR), 0, 1, 1}, /* PyObject cname: __pyx_n_u_MTR */ - {__pyx_k_NONE, sizeof(__pyx_k_NONE), 0, 1, 1}, /* PyObject cname: __pyx_n_u_NONE */ - {__pyx_k_None, sizeof(__pyx_k_None), 0, 1, 1}, /* PyObject cname: __pyx_n_u_None */ - {__pyx_k_Not_found_project, sizeof(__pyx_k_Not_found_project), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_Not_found_project */ - {__pyx_k_Note_that_Cython_is_deliberately, sizeof(__pyx_k_Note_that_Cython_is_deliberately), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_Note_that_Cython_is_deliberately */ - {__pyx_k_OPEN, sizeof(__pyx_k_OPEN), 0, 1, 1}, /* PyObject cname: __pyx_n_u_OPEN */ - {__pyx_k_Output, sizeof(__pyx_k_Output), 0, 1, 1}, /* PyObject cname: __pyx_n_u_Output */ - {__pyx_k_Output___del, sizeof(__pyx_k_Output___del), 0, 1, 1}, /* PyObject cname: __pyx_n_u_Output___del */ - {__pyx_k_Output___init, sizeof(__pyx_k_Output___init), 0, 1, 1}, /* PyObject cname: __pyx_n_u_Output___init */ - {__pyx_k_Output__check, sizeof(__pyx_k_Output__check), 0, 1, 1}, /* PyObject cname: __pyx_n_u_Output__check */ - {__pyx_k_Output_dump, sizeof(__pyx_k_Output_dump), 0, 1, 1}, /* PyObject cname: __pyx_n_u_Output_dump */ - {__pyx_k_Output_element_name, sizeof(__pyx_k_Output_element_name), 0, 1, 1}, /* PyObject cname: __pyx_n_u_Output_element_name */ - {__pyx_k_Output_energy_usage, sizeof(__pyx_k_Output_energy_usage), 0, 1, 1}, /* PyObject cname: __pyx_n_u_Output_energy_usage */ - {__pyx_k_Output_link_results, sizeof(__pyx_k_Output_link_results), 0, 1, 1}, /* PyObject cname: __pyx_n_u_Output_link_results */ - {__pyx_k_Output_net_size, sizeof(__pyx_k_Output_net_size), 0, 1, 1}, /* PyObject cname: __pyx_n_u_Output_net_size */ - {__pyx_k_Output_node_results, sizeof(__pyx_k_Output_node_results), 0, 1, 1}, /* PyObject cname: __pyx_n_u_Output_node_results */ - {__pyx_k_Output_reactions, sizeof(__pyx_k_Output_reactions), 0, 1, 1}, /* PyObject cname: __pyx_n_u_Output_reactions */ - {__pyx_k_Output_times, sizeof(__pyx_k_Output_times), 0, 1, 1}, /* PyObject cname: __pyx_n_u_Output_times */ - {__pyx_k_Output_units, sizeof(__pyx_k_Output_units), 0, 1, 1}, /* PyObject cname: __pyx_n_u_Output_units */ - {__pyx_k_Output_version, sizeof(__pyx_k_Output_version), 0, 1, 1}, /* PyObject cname: __pyx_n_u_Output_version */ - {__pyx_k_POINTER, sizeof(__pyx_k_POINTER), 0, 1, 1}, /* PyObject cname: __pyx_n_u_POINTER */ - {__pyx_k_PRCNT, sizeof(__pyx_k_PRCNT), 0, 1, 1}, /* PyObject cname: __pyx_n_u_PRCNT */ - {__pyx_k_PSI, sizeof(__pyx_k_PSI), 0, 1, 1}, /* PyObject cname: __pyx_n_u_PSI */ - {__pyx_k_Platform, sizeof(__pyx_k_Platform), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_Platform */ - {__pyx_k_UGL, sizeof(__pyx_k_UGL), 0, 1, 1}, /* PyObject cname: __pyx_n_u_UGL */ - {__pyx_k_Windows, sizeof(__pyx_k_Windows), 0, 1, 1}, /* PyObject cname: __pyx_n_u_Windows */ - {__pyx_k__2, sizeof(__pyx_k__2), 0, 1, 0}, /* PyObject cname: __pyx_kp_u__2 */ - {__pyx_k__3, sizeof(__pyx_k__3), 0, 1, 0}, /* PyObject cname: __pyx_kp_u__3 */ - {__pyx_k__4, sizeof(__pyx_k__4), 0, 1, 0}, /* PyObject cname: __pyx_kp_u__4 */ - {__pyx_k__5, sizeof(__pyx_k__5), 0, 1, 0}, /* PyObject cname: __pyx_kp_u__5 */ - {__pyx_k_abspath, sizeof(__pyx_k_abspath), 0, 1, 1}, /* PyObject cname: __pyx_n_u_abspath */ - {__pyx_k_add_note, sizeof(__pyx_k_add_note), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_add_note */ - {__pyx_k_api, sizeof(__pyx_k_api), 0, 1, 1}, /* PyObject cname: __pyx_n_u_api */ - {__pyx_k_append, sizeof(__pyx_k_append), 0, 1, 1}, /* PyObject cname: __pyx_n_u_append */ - {__pyx_k_asyncio_coroutines, sizeof(__pyx_k_asyncio_coroutines), 0, 1, 1}, /* PyObject cname: __pyx_n_u_asyncio_coroutines */ - {__pyx_k_attributes, sizeof(__pyx_k_attributes), 0, 1, 1}, /* PyObject cname: __pyx_n_u_attributes */ - {__pyx_k_avg_efficiency, sizeof(__pyx_k_avg_efficiency), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_avg_efficiency */ - {__pyx_k_avg_kW_flow, sizeof(__pyx_k_avg_kW_flow), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_avg_kW_flow */ - {__pyx_k_avg_kwatts, sizeof(__pyx_k_avg_kwatts), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_avg_kwatts */ - {__pyx_k_b64encode, sizeof(__pyx_k_b64encode), 0, 1, 1}, /* PyObject cname: __pyx_n_u_b64encode */ - {__pyx_k_base64, sizeof(__pyx_k_base64), 0, 1, 1}, /* PyObject cname: __pyx_n_u_base64 */ - {__pyx_k_bast64_data, sizeof(__pyx_k_bast64_data), 0, 1, 1}, /* PyObject cname: __pyx_n_u_bast64_data */ - {__pyx_k_bool, sizeof(__pyx_k_bool), 0, 1, 1}, /* PyObject cname: __pyx_n_u_bool */ - {__pyx_k_bulk, sizeof(__pyx_k_bulk), 0, 1, 1}, /* PyObject cname: __pyx_n_u_bulk */ - {__pyx_k_byref, sizeof(__pyx_k_byref), 0, 1, 1}, /* PyObject cname: __pyx_n_u_byref */ - {__pyx_k_c_char_p, sizeof(__pyx_k_c_char_p), 0, 1, 1}, /* PyObject cname: __pyx_n_u_c_char_p */ - {__pyx_k_c_float, sizeof(__pyx_k_c_float), 0, 1, 1}, /* PyObject cname: __pyx_n_u_c_float */ - {__pyx_k_c_int, sizeof(__pyx_k_c_int), 0, 1, 1}, /* PyObject cname: __pyx_n_u_c_int */ - {__pyx_k_c_void_p, sizeof(__pyx_k_c_void_p), 0, 1, 1}, /* PyObject cname: __pyx_n_u_c_void_p */ - {__pyx_k_category, sizeof(__pyx_k_category), 0, 1, 1}, /* PyObject cname: __pyx_n_u_category */ - {__pyx_k_check, sizeof(__pyx_k_check), 0, 1, 1}, /* PyObject cname: __pyx_n_u_check */ - {__pyx_k_class_getitem, sizeof(__pyx_k_class_getitem), 0, 1, 1}, /* PyObject cname: __pyx_n_u_class_getitem */ - {__pyx_k_cline_in_traceback, sizeof(__pyx_k_cline_in_traceback), 0, 1, 1}, /* PyObject cname: __pyx_n_u_cline_in_traceback */ - {__pyx_k_code, sizeof(__pyx_k_code), 0, 1, 1}, /* PyObject cname: __pyx_n_u_code */ - {__pyx_k_command, sizeof(__pyx_k_command), 0, 1, 1}, /* PyObject cname: __pyx_n_u_command */ - {__pyx_k_cost_day, sizeof(__pyx_k_cost_day), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_cost_day */ - {__pyx_k_ctypes, sizeof(__pyx_k_ctypes), 0, 1, 1}, /* PyObject cname: __pyx_n_u_ctypes */ - {__pyx_k_d, sizeof(__pyx_k_d), 0, 1, 1}, /* PyObject cname: __pyx_n_u_d */ - {__pyx_k_data, sizeof(__pyx_k_data), 0, 1, 1}, /* PyObject cname: __pyx_n_u_data */ - {__pyx_k_db, sizeof(__pyx_k_db), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_db */ - {__pyx_k_db_inp, sizeof(__pyx_k_db_inp), 0, 1, 1}, /* PyObject cname: __pyx_n_u_db_inp */ - {__pyx_k_db_inp_2, sizeof(__pyx_k_db_inp_2), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_db_inp_2 */ - {__pyx_k_decode, sizeof(__pyx_k_decode), 0, 1, 1}, /* PyObject cname: __pyx_n_u_decode */ - {__pyx_k_del, sizeof(__pyx_k_del), 0, 1, 1}, /* PyObject cname: __pyx_n_u_del */ - {__pyx_k_demand, sizeof(__pyx_k_demand), 0, 1, 1}, /* PyObject cname: __pyx_n_u_demand */ - {__pyx_k_dict_str_Any, sizeof(__pyx_k_dict_str_Any), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_dict_str_Any */ - {__pyx_k_dict_str_float, sizeof(__pyx_k_dict_str_float), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_dict_str_float */ - {__pyx_k_dict_str_int, sizeof(__pyx_k_dict_str_int), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_dict_str_int */ - {__pyx_k_dict_str_list_str, sizeof(__pyx_k_dict_str_list_str), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_dict_str_list_str */ - {__pyx_k_dict_str_str, sizeof(__pyx_k_dict_str_str), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_dict_str_str */ - {__pyx_k_dir, sizeof(__pyx_k_dir), 0, 1, 1}, /* PyObject cname: __pyx_n_u_dir */ - {__pyx_k_doc, sizeof(__pyx_k_doc), 0, 1, 1}, /* PyObject cname: __pyx_n_u_doc */ - {__pyx_k_ds, sizeof(__pyx_k_ds), 0, 1, 1}, /* PyObject cname: __pyx_n_u_ds */ - {__pyx_k_dump, sizeof(__pyx_k_dump), 0, 1, 1}, /* PyObject cname: __pyx_n_u_dump */ - {__pyx_k_dump_inp, sizeof(__pyx_k_dump_inp), 0, 1, 1}, /* PyObject cname: __pyx_n_u_dump_inp */ - {__pyx_k_dump_output, sizeof(__pyx_k_dump_output), 0, 1, 1}, /* PyObject cname: __pyx_n_u_dump_output */ - {__pyx_k_dump_output_2, sizeof(__pyx_k_dump_output_2), 0, 1, 1}, /* PyObject cname: __pyx_n_u_dump_output_2 */ - {__pyx_k_dump_output_binary, sizeof(__pyx_k_dump_output_binary), 0, 1, 1}, /* PyObject cname: __pyx_n_u_dump_output_binary */ - {__pyx_k_dump_report, sizeof(__pyx_k_dump_report), 0, 1, 1}, /* PyObject cname: __pyx_n_u_dump_report */ - {__pyx_k_dumps, sizeof(__pyx_k_dumps), 0, 1, 1}, /* PyObject cname: __pyx_n_u_dumps */ - {__pyx_k_element_count, sizeof(__pyx_k_element_count), 0, 1, 1}, /* PyObject cname: __pyx_n_u_element_count */ - {__pyx_k_element_name, sizeof(__pyx_k_element_name), 0, 1, 1}, /* PyObject cname: __pyx_n_u_element_name */ - {__pyx_k_encode, sizeof(__pyx_k_encode), 0, 1, 1}, /* PyObject cname: __pyx_n_u_encode */ - {__pyx_k_energy_usage, sizeof(__pyx_k_energy_usage), 0, 1, 1}, /* PyObject cname: __pyx_n_u_energy_usage */ - {__pyx_k_enter, sizeof(__pyx_k_enter), 0, 1, 1}, /* PyObject cname: __pyx_n_u_enter */ - {__pyx_k_epanet, sizeof(__pyx_k_epanet), 0, 1, 1}, /* PyObject cname: __pyx_n_u_epanet */ - {__pyx_k_epanet_epanet, sizeof(__pyx_k_epanet_epanet), 0, 1, 1}, /* PyObject cname: __pyx_n_u_epanet_epanet */ - {__pyx_k_epanet_epanet_py, sizeof(__pyx_k_epanet_epanet_py), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_epanet_epanet_py */ - {__pyx_k_epanet_output_dll, sizeof(__pyx_k_epanet_output_dll), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_epanet_output_dll */ - {__pyx_k_error, sizeof(__pyx_k_error), 0, 1, 1}, /* PyObject cname: __pyx_n_u_error */ - {__pyx_k_exe, sizeof(__pyx_k_exe), 0, 1, 1}, /* PyObject cname: __pyx_n_u_exe */ - {__pyx_k_exit, sizeof(__pyx_k_exit), 0, 1, 1}, /* PyObject cname: __pyx_n_u_exit */ - {__pyx_k_f, sizeof(__pyx_k_f), 0, 1, 1}, /* PyObject cname: __pyx_n_u_f */ - {__pyx_k_f_u, sizeof(__pyx_k_f_u), 0, 1, 1}, /* PyObject cname: __pyx_n_u_f_u */ - {__pyx_k_f_us, sizeof(__pyx_k_f_us), 0, 1, 1}, /* PyObject cname: __pyx_n_u_f_us */ - {__pyx_k_failed, sizeof(__pyx_k_failed), 0, 1, 1}, /* PyObject cname: __pyx_n_u_failed */ - {__pyx_k_flow, sizeof(__pyx_k_flow), 0, 1, 1}, /* PyObject cname: __pyx_n_u_flow */ - {__pyx_k_friction, sizeof(__pyx_k_friction), 0, 1, 1}, /* PyObject cname: __pyx_n_u_friction */ - {__pyx_k_func, sizeof(__pyx_k_func), 0, 1, 1}, /* PyObject cname: __pyx_n_u_func */ - {__pyx_k_getcwd, sizeof(__pyx_k_getcwd), 0, 1, 1}, /* PyObject cname: __pyx_n_u_getcwd */ - {__pyx_k_handle, sizeof(__pyx_k_handle), 0, 1, 1}, /* PyObject cname: __pyx_n_u_handle */ - {__pyx_k_have_project, sizeof(__pyx_k_have_project), 0, 1, 1}, /* PyObject cname: __pyx_n_u_have_project */ - {__pyx_k_head, sizeof(__pyx_k_head), 0, 1, 1}, /* PyObject cname: __pyx_n_u_head */ - {__pyx_k_headloss, sizeof(__pyx_k_headloss), 0, 1, 1}, /* PyObject cname: __pyx_n_u_headloss */ - {__pyx_k_i, sizeof(__pyx_k_i), 0, 1, 1}, /* PyObject cname: __pyx_n_u_i */ - {__pyx_k_index, sizeof(__pyx_k_index), 0, 1, 1}, /* PyObject cname: __pyx_n_u_index */ - {__pyx_k_init, sizeof(__pyx_k_init), 0, 1, 1}, /* PyObject cname: __pyx_n_u_init */ - {__pyx_k_initializing, sizeof(__pyx_k_initializing), 0, 1, 1}, /* PyObject cname: __pyx_n_u_initializing */ - {__pyx_k_inp, sizeof(__pyx_k_inp), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_inp */ - {__pyx_k_inp_2, sizeof(__pyx_k_inp_2), 0, 1, 1}, /* PyObject cname: __pyx_n_u_inp_2 */ - {__pyx_k_inp_out, sizeof(__pyx_k_inp_out), 0, 1, 1}, /* PyObject cname: __pyx_n_u_inp_out */ - {__pyx_k_input, sizeof(__pyx_k_input), 0, 1, 1}, /* PyObject cname: __pyx_n_u_input */ - {__pyx_k_int, sizeof(__pyx_k_int), 0, 1, 1}, /* PyObject cname: __pyx_n_u_int */ - {__pyx_k_is_coroutine, sizeof(__pyx_k_is_coroutine), 0, 1, 1}, /* PyObject cname: __pyx_n_u_is_coroutine */ - {__pyx_k_j, sizeof(__pyx_k_j), 0, 1, 1}, /* PyObject cname: __pyx_n_u_j */ - {__pyx_k_join, sizeof(__pyx_k_join), 0, 1, 1}, /* PyObject cname: __pyx_n_u_join */ - {__pyx_k_json, sizeof(__pyx_k_json), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_json */ - {__pyx_k_json_2, sizeof(__pyx_k_json_2), 0, 1, 1}, /* PyObject cname: __pyx_n_u_json_2 */ - {__pyx_k_k, sizeof(__pyx_k_k), 0, 1, 1}, /* PyObject cname: __pyx_n_u_k */ - {__pyx_k_length, sizeof(__pyx_k_length), 0, 1, 1}, /* PyObject cname: __pyx_n_u_length */ - {__pyx_k_lib, sizeof(__pyx_k_lib), 0, 1, 1}, /* PyObject cname: __pyx_n_u_lib */ - {__pyx_k_link, sizeof(__pyx_k_link), 0, 1, 1}, /* PyObject cname: __pyx_n_u_link */ - {__pyx_k_link_results, sizeof(__pyx_k_link_results), 0, 1, 1}, /* PyObject cname: __pyx_n_u_link_results */ - {__pyx_k_link_type, sizeof(__pyx_k_link_type), 0, 1, 1}, /* PyObject cname: __pyx_n_u_link_type */ - {__pyx_k_links, sizeof(__pyx_k_links), 0, 1, 1}, /* PyObject cname: __pyx_n_u_links */ - {__pyx_k_list_dict_str_Any, sizeof(__pyx_k_list_dict_str_Any), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_list_dict_str_Any */ - {__pyx_k_main, sizeof(__pyx_k_main), 0, 1, 1}, /* PyObject cname: __pyx_n_u_main */ - {__pyx_k_max_kwatts, sizeof(__pyx_k_max_kwatts), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_max_kwatts */ - {__pyx_k_metaclass, sizeof(__pyx_k_metaclass), 0, 1, 1}, /* PyObject cname: __pyx_n_u_metaclass */ - {__pyx_k_module, sizeof(__pyx_k_module), 0, 1, 1}, /* PyObject cname: __pyx_n_u_module */ - {__pyx_k_msg, sizeof(__pyx_k_msg), 0, 1, 1}, /* PyObject cname: __pyx_n_u_msg */ - {__pyx_k_name, sizeof(__pyx_k_name), 0, 1, 1}, /* PyObject cname: __pyx_n_u_name */ - {__pyx_k_name_2, sizeof(__pyx_k_name_2), 0, 1, 1}, /* PyObject cname: __pyx_n_u_name_2 */ - {__pyx_k_name_len, sizeof(__pyx_k_name_len), 0, 1, 1}, /* PyObject cname: __pyx_n_u_name_len */ - {__pyx_k_net_size, sizeof(__pyx_k_net_size), 0, 1, 1}, /* PyObject cname: __pyx_n_u_net_size */ - {__pyx_k_node, sizeof(__pyx_k_node), 0, 1, 1}, /* PyObject cname: __pyx_n_u_node */ - {__pyx_k_node_results, sizeof(__pyx_k_node_results), 0, 1, 1}, /* PyObject cname: __pyx_n_u_node_results */ - {__pyx_k_node_type, sizeof(__pyx_k_node_type), 0, 1, 1}, /* PyObject cname: __pyx_n_u_node_type */ - {__pyx_k_nodes, sizeof(__pyx_k_nodes), 0, 1, 1}, /* PyObject cname: __pyx_n_u_nodes */ - {__pyx_k_num_periods, sizeof(__pyx_k_num_periods), 0, 1, 1}, /* PyObject cname: __pyx_n_u_num_periods */ - {__pyx_k_open, sizeof(__pyx_k_open), 0, 1, 1}, /* PyObject cname: __pyx_n_u_open */ - {__pyx_k_opt, sizeof(__pyx_k_opt), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_opt */ - {__pyx_k_opt_2, sizeof(__pyx_k_opt_2), 0, 1, 1}, /* PyObject cname: __pyx_n_u_opt_2 */ - {__pyx_k_os, sizeof(__pyx_k_os), 0, 1, 1}, /* PyObject cname: __pyx_n_u_os */ - {__pyx_k_output, sizeof(__pyx_k_output), 0, 1, 1}, /* PyObject cname: __pyx_n_u_output */ - {__pyx_k_output_message, sizeof(__pyx_k_output_message), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_output_message */ - {__pyx_k_p, sizeof(__pyx_k_p), 0, 1, 1}, /* PyObject cname: __pyx_n_u_p */ - {__pyx_k_p_u, sizeof(__pyx_k_p_u), 0, 1, 1}, /* PyObject cname: __pyx_n_u_p_u */ - {__pyx_k_p_us, sizeof(__pyx_k_p_us), 0, 1, 1}, /* PyObject cname: __pyx_n_u_p_us */ - {__pyx_k_path, sizeof(__pyx_k_path), 0, 1, 1}, /* PyObject cname: __pyx_n_u_path */ - {__pyx_k_path_2, sizeof(__pyx_k_path_2), 0, 1, 1}, /* PyObject cname: __pyx_n_u_path_2 */ - {__pyx_k_platform, sizeof(__pyx_k_platform), 0, 1, 1}, /* PyObject cname: __pyx_n_u_platform */ - {__pyx_k_platform_2, sizeof(__pyx_k_platform_2), 0, 1, 1}, /* PyObject cname: __pyx_n_u_platform_2 */ - {__pyx_k_pop, sizeof(__pyx_k_pop), 0, 1, 1}, /* PyObject cname: __pyx_n_u_pop */ - {__pyx_k_prepare, sizeof(__pyx_k_prepare), 0, 1, 1}, /* PyObject cname: __pyx_n_u_prepare */ - {__pyx_k_pressure, sizeof(__pyx_k_pressure), 0, 1, 1}, /* PyObject cname: __pyx_n_u_pressure */ - {__pyx_k_project, sizeof(__pyx_k_project), 0, 1, 1}, /* PyObject cname: __pyx_n_u_project */ - {__pyx_k_pump, sizeof(__pyx_k_pump), 0, 1, 1}, /* PyObject cname: __pyx_n_u_pump */ - {__pyx_k_q, sizeof(__pyx_k_q), 0, 1, 1}, /* PyObject cname: __pyx_n_u_q */ - {__pyx_k_q_u, sizeof(__pyx_k_q_u), 0, 1, 1}, /* PyObject cname: __pyx_n_u_q_u */ - {__pyx_k_q_us, sizeof(__pyx_k_q_us), 0, 1, 1}, /* PyObject cname: __pyx_n_u_q_us */ - {__pyx_k_quality, sizeof(__pyx_k_quality), 0, 1, 1}, /* PyObject cname: __pyx_n_u_quality */ - {__pyx_k_qualname, sizeof(__pyx_k_qualname), 0, 1, 1}, /* PyObject cname: __pyx_n_u_qualname */ - {__pyx_k_r, sizeof(__pyx_k_r), 0, 1, 1}, /* PyObject cname: __pyx_n_u_r */ - {__pyx_k_range, sizeof(__pyx_k_range), 0, 1, 1}, /* PyObject cname: __pyx_n_u_range */ - {__pyx_k_rb, sizeof(__pyx_k_rb), 0, 1, 1}, /* PyObject cname: __pyx_n_u_rb */ - {__pyx_k_reaction, sizeof(__pyx_k_reaction), 0, 1, 1}, /* PyObject cname: __pyx_n_u_reaction */ - {__pyx_k_reactions, sizeof(__pyx_k_reactions), 0, 1, 1}, /* PyObject cname: __pyx_n_u_reactions */ - {__pyx_k_read, sizeof(__pyx_k_read), 0, 1, 1}, /* PyObject cname: __pyx_n_u_read */ - {__pyx_k_readable_output, sizeof(__pyx_k_readable_output), 0, 1, 1}, /* PyObject cname: __pyx_n_u_readable_output */ - {__pyx_k_report, sizeof(__pyx_k_report), 0, 1, 1}, /* PyObject cname: __pyx_n_u_report */ - {__pyx_k_report_start, sizeof(__pyx_k_report_start), 0, 1, 1}, /* PyObject cname: __pyx_n_u_report_start */ - {__pyx_k_report_step, sizeof(__pyx_k_report_step), 0, 1, 1}, /* PyObject cname: __pyx_n_u_report_step */ - {__pyx_k_result, sizeof(__pyx_k_result), 0, 1, 1}, /* PyObject cname: __pyx_n_u_result */ - {__pyx_k_return, sizeof(__pyx_k_return), 0, 1, 1}, /* PyObject cname: __pyx_n_u_return */ - {__pyx_k_rpt, sizeof(__pyx_k_rpt), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_rpt */ - {__pyx_k_rpt_2, sizeof(__pyx_k_rpt_2), 0, 1, 1}, /* PyObject cname: __pyx_n_u_rpt_2 */ - {__pyx_k_run_inp, sizeof(__pyx_k_run_inp), 0, 1, 1}, /* PyObject cname: __pyx_n_u_run_inp */ - {__pyx_k_run_project, sizeof(__pyx_k_run_project), 0, 1, 1}, /* PyObject cname: __pyx_n_u_run_project */ - {__pyx_k_run_project_return_dict, sizeof(__pyx_k_run_project_return_dict), 0, 1, 1}, /* PyObject cname: __pyx_n_u_run_project_return_dict */ - {__pyx_k_runepanet_exe, sizeof(__pyx_k_runepanet_exe), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_runepanet_exe */ - {__pyx_k_self, sizeof(__pyx_k_self), 0, 1, 1}, /* PyObject cname: __pyx_n_u_self */ - {__pyx_k_setting, sizeof(__pyx_k_setting), 0, 1, 1}, /* PyObject cname: __pyx_n_u_setting */ - {__pyx_k_sim_duration, sizeof(__pyx_k_sim_duration), 0, 1, 1}, /* PyObject cname: __pyx_n_u_sim_duration */ - {__pyx_k_simulation_result, sizeof(__pyx_k_simulation_result), 0, 1, 1}, /* PyObject cname: __pyx_n_u_simulation_result */ - {__pyx_k_size, sizeof(__pyx_k_size), 0, 1, 1}, /* PyObject cname: __pyx_n_u_size */ - {__pyx_k_sizes, sizeof(__pyx_k_sizes), 0, 1, 1}, /* PyObject cname: __pyx_n_u_sizes */ - {__pyx_k_source, sizeof(__pyx_k_source), 0, 1, 1}, /* PyObject cname: __pyx_n_u_source */ - {__pyx_k_spec, sizeof(__pyx_k_spec), 0, 1, 1}, /* PyObject cname: __pyx_n_u_spec */ - {__pyx_k_status, sizeof(__pyx_k_status), 0, 1, 1}, /* PyObject cname: __pyx_n_u_status */ - {__pyx_k_str, sizeof(__pyx_k_str), 0, 1, 1}, /* PyObject cname: __pyx_n_u_str */ - {__pyx_k_successful, sizeof(__pyx_k_successful), 0, 1, 1}, /* PyObject cname: __pyx_n_u_successful */ - {__pyx_k_sys, sizeof(__pyx_k_sys), 0, 1, 1}, /* PyObject cname: __pyx_n_u_sys */ - {__pyx_k_system, sizeof(__pyx_k_system), 0, 1, 1}, /* PyObject cname: __pyx_n_u_system */ - {__pyx_k_t, sizeof(__pyx_k_t), 0, 1, 1}, /* PyObject cname: __pyx_n_u_t */ - {__pyx_k_tank, sizeof(__pyx_k_tank), 0, 1, 1}, /* PyObject cname: __pyx_n_u_tank */ - {__pyx_k_temp, sizeof(__pyx_k_temp), 0, 1, 1}, /* PyObject cname: __pyx_n_u_temp */ - {__pyx_k_test, sizeof(__pyx_k_test), 0, 1, 1}, /* PyObject cname: __pyx_n_u_test */ - {__pyx_k_times, sizeof(__pyx_k_times), 0, 1, 1}, /* PyObject cname: __pyx_n_u_times */ - {__pyx_k_ts, sizeof(__pyx_k_ts), 0, 1, 1}, /* PyObject cname: __pyx_n_u_ts */ - {__pyx_k_typing, sizeof(__pyx_k_typing), 0, 1, 1}, /* PyObject cname: __pyx_n_u_typing */ - {__pyx_k_units, sizeof(__pyx_k_units), 0, 1, 1}, /* PyObject cname: __pyx_n_u_units */ - {__pyx_k_unsupported_not_yet, sizeof(__pyx_k_unsupported_not_yet), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_unsupported_not_yet */ - {__pyx_k_usages, sizeof(__pyx_k_usages), 0, 1, 1}, /* PyObject cname: __pyx_n_u_usages */ - {__pyx_k_utf_8, sizeof(__pyx_k_utf_8), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_utf_8 */ - {__pyx_k_utilization, sizeof(__pyx_k_utilization), 0, 1, 1}, /* PyObject cname: __pyx_n_u_utilization */ - {__pyx_k_v, sizeof(__pyx_k_v), 0, 1, 1}, /* PyObject cname: __pyx_n_u_v */ - {__pyx_k_value, sizeof(__pyx_k_value), 0, 1, 1}, /* PyObject cname: __pyx_n_u_value */ - {__pyx_k_values, sizeof(__pyx_k_values), 0, 1, 1}, /* PyObject cname: __pyx_n_u_values */ - {__pyx_k_valve, sizeof(__pyx_k_valve), 0, 1, 1}, /* PyObject cname: __pyx_n_u_valve */ - {__pyx_k_velocity, sizeof(__pyx_k_velocity), 0, 1, 1}, /* PyObject cname: __pyx_n_u_velocity */ - {__pyx_k_verify_platform, sizeof(__pyx_k_verify_platform), 0, 1, 1}, /* PyObject cname: __pyx_n_u_verify_platform */ - {__pyx_k_version, sizeof(__pyx_k_version), 0, 1, 1}, /* PyObject cname: __pyx_n_u_version */ - {__pyx_k_w, sizeof(__pyx_k_w), 0, 1, 1}, /* PyObject cname: __pyx_n_u_w */ - {__pyx_k_wall, sizeof(__pyx_k_wall), 0, 1, 1}, /* PyObject cname: __pyx_n_u_wall */ - {0, 0, 0, 0, 0} -}; -/* InitStrings.proto */ -static int __Pyx_InitStrings(__Pyx_StringTabEntry const *t, PyObject **target, const char* const* encoding_names); - -/* #### Code section: cached_builtins ### */ - -static int __Pyx_InitCachedBuiltins(__pyx_mstatetype *__pyx_mstate) { - CYTHON_UNUSED_VAR(__pyx_mstate); - __pyx_builtin_AssertionError = __Pyx_GetBuiltinName(__pyx_mstate->__pyx_n_u_AssertionError); if (!__pyx_builtin_AssertionError) __PYX_ERR(0, 44, __pyx_L1_error) - __pyx_builtin_range = __Pyx_GetBuiltinName(__pyx_mstate->__pyx_n_u_range); if (!__pyx_builtin_range) __PYX_ERR(0, 66, __pyx_L1_error) - __pyx_builtin_open = __Pyx_GetBuiltinName(__pyx_mstate->__pyx_n_u_open); if (!__pyx_builtin_open) __PYX_ERR(0, 221, __pyx_L1_error) - return 0; - __pyx_L1_error:; - return -1; -} -/* #### Code section: cached_constants ### */ - -static int __Pyx_InitCachedConstants(__pyx_mstatetype *__pyx_mstate) { - __Pyx_RefNannyDeclarations - CYTHON_UNUSED_VAR(__pyx_mstate); - __Pyx_RefNannySetupContext("__Pyx_InitCachedConstants", 0); - - /* "epanet/epanet.py":221 - * opt = Output(path) - * data = opt.dump() - * with open(path + '.json', 'w') as f: # <<<<<<<<<<<<<< - * json.dump(data, f) - * return data -*/ - __pyx_mstate_global->__pyx_tuple[0] = PyTuple_Pack(3, Py_None, Py_None, Py_None); if (unlikely(!__pyx_mstate_global->__pyx_tuple[0])) __PYX_ERR(0, 221, __pyx_L1_error) - __Pyx_GOTREF(__pyx_mstate_global->__pyx_tuple[0]); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_tuple[0]); - - /* "epanet/epanet.py":242 - * - * #DingZQ, 2025-02-04, dict[str, Any] - * def run_project_return_dict(name: str, readable_output: bool = False) -> dict[str, Any]: # <<<<<<<<<<<<<< - * if not project.have_project(name): - * raise Exception(f'Not found project [{name}]') -*/ - __pyx_mstate_global->__pyx_tuple[1] = PyTuple_Pack(1, ((PyObject *)Py_False)); if (unlikely(!__pyx_mstate_global->__pyx_tuple[1])) __PYX_ERR(0, 242, __pyx_L1_error) - __Pyx_GOTREF(__pyx_mstate_global->__pyx_tuple[1]); - __Pyx_GIVEREF(__pyx_mstate_global->__pyx_tuple[1]); - __Pyx_RefNannyFinishContext(); - return 0; - __pyx_L1_error:; - __Pyx_RefNannyFinishContext(); - return -1; -} -/* #### Code section: init_constants ### */ - -static int __Pyx_InitConstants(__pyx_mstatetype *__pyx_mstate) { - CYTHON_UNUSED_VAR(__pyx_mstate); - __pyx_mstate->__pyx_umethod_PyDict_Type_pop.type = (PyObject*)&PyDict_Type; - __pyx_mstate->__pyx_umethod_PyDict_Type_pop.method_name = &__pyx_mstate->__pyx_n_u_pop; - if (__Pyx_InitStrings(__pyx_string_tab, __pyx_mstate->__pyx_string_tab, __pyx_string_tab_encodings) < 0) __PYX_ERR(0, 1, __pyx_L1_error); - __pyx_mstate->__pyx_float_2_0 = PyFloat_FromDouble(2.0); if (unlikely(!__pyx_mstate->__pyx_float_2_0)) __PYX_ERR(0, 1, __pyx_L1_error) - __pyx_mstate->__pyx_int_0 = PyLong_FromLong(0); if (unlikely(!__pyx_mstate->__pyx_int_0)) __PYX_ERR(0, 1, __pyx_L1_error) - __pyx_mstate->__pyx_int_1 = PyLong_FromLong(1); if (unlikely(!__pyx_mstate->__pyx_int_1)) __PYX_ERR(0, 1, __pyx_L1_error) - __pyx_mstate->__pyx_int_2 = PyLong_FromLong(2); if (unlikely(!__pyx_mstate->__pyx_int_2)) __PYX_ERR(0, 1, __pyx_L1_error) - __pyx_mstate->__pyx_int_3 = PyLong_FromLong(3); if (unlikely(!__pyx_mstate->__pyx_int_3)) __PYX_ERR(0, 1, __pyx_L1_error) - __pyx_mstate->__pyx_int_4 = PyLong_FromLong(4); if (unlikely(!__pyx_mstate->__pyx_int_4)) __PYX_ERR(0, 1, __pyx_L1_error) - __pyx_mstate->__pyx_int_5 = PyLong_FromLong(5); if (unlikely(!__pyx_mstate->__pyx_int_5)) __PYX_ERR(0, 1, __pyx_L1_error) - __pyx_mstate->__pyx_int_6 = PyLong_FromLong(6); if (unlikely(!__pyx_mstate->__pyx_int_6)) __PYX_ERR(0, 1, __pyx_L1_error) - __pyx_mstate->__pyx_int_10 = PyLong_FromLong(10); if (unlikely(!__pyx_mstate->__pyx_int_10)) __PYX_ERR(0, 1, __pyx_L1_error) - return 0; - __pyx_L1_error:; - return -1; -} -/* #### Code section: init_codeobjects ### */ -\ - typedef struct { - unsigned int argcount : 2; - unsigned int num_posonly_args : 1; - unsigned int num_kwonly_args : 1; - unsigned int nlocals : 4; - unsigned int flags : 10; - unsigned int first_line : 9; - unsigned int line_table_length : 13; - } __Pyx_PyCode_New_function_description; -/* NewCodeObj.proto */ -static PyObject* __Pyx_PyCode_New( - __Pyx_PyCode_New_function_description descr, - PyObject **varnames, - PyObject *filename, - PyObject *funcname, - const char *line_table, - PyObject *tuple_dedup_map -); - - -static int __Pyx_CreateCodeObjects(__pyx_mstatetype *__pyx_mstate) { - PyObject* tuple_dedup_map = PyDict_New(); - if (unlikely(!tuple_dedup_map)) return -1; - { - __Pyx_PyCode_New_function_description descr = {0, 0, 0, 1, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 13, 33}; - PyObject* varnames[] = {__pyx_mstate->__pyx_n_u_platform_2}; - __pyx_mstate_global->__pyx_codeobj_tab[0] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_epanet_epanet_py, __pyx_mstate->__pyx_n_u_verify_platform, __pyx_k_q_z_A_iq_q, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[0])) goto bad; - } - { - __Pyx_PyCode_New_function_description descr = {2, 0, 0, 2, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 24, 113}; - PyObject* varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_path}; - __pyx_mstate_global->__pyx_codeobj_tab[1] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_epanet_epanet_py, __pyx_mstate->__pyx_n_u_init, __pyx_k_XQ_IQ_HF_q_uARwd_A_KvYa_G1D_Yav, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[1])) goto bad; - } - { - __Pyx_PyCode_New_function_description descr = {1, 0, 0, 1, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 35, 27}; - PyObject* varnames[] = {__pyx_mstate->__pyx_n_u_self}; - __pyx_mstate_global->__pyx_codeobj_tab[2] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_epanet_epanet_py, __pyx_mstate->__pyx_n_u_del, __pyx_k_A_G1D_Zq_fAT, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[2])) goto bad; - } - { - __Pyx_PyCode_New_function_description descr = {2, 0, 0, 5, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 40, 111}; - PyObject* varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_result, __pyx_mstate->__pyx_n_u_msg, __pyx_mstate->__pyx_n_u_code, __pyx_mstate->__pyx_n_u_error}; - __pyx_mstate_global->__pyx_codeobj_tab[3] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_epanet_epanet_py, __pyx_mstate->__pyx_n_u_check, __pyx_k_A_7_Rt7_Q_4uO1D_aq_5_1_B_2_6QQTT, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[3])) goto bad; - } - { - __Pyx_PyCode_New_function_description descr = {1, 0, 0, 2, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 53, 48}; - PyObject* varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_v}; - __pyx_mstate_global->__pyx_codeobj_tab[4] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_epanet_epanet_py, __pyx_mstate->__pyx_n_u_version, __pyx_k_F_G1D__AT_6_q_q, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[4])) goto bad; - } - { - __Pyx_PyCode_New_function_description descr = {1, 0, 0, 6, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 59, 152}; - PyObject* varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_element_count, __pyx_mstate->__pyx_n_u_length, __pyx_mstate->__pyx_n_u_category, __pyx_mstate->__pyx_n_u_sizes, __pyx_mstate->__pyx_n_u_i}; - __pyx_mstate_global->__pyx_codeobj_tab[5] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_epanet_epanet_py, __pyx_mstate->__pyx_n_u_net_size, __pyx_k_havWA_vQ_G1D__AT_6_qHXX_ddeef_v, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[5])) goto bad; - } - { - __Pyx_PyCode_New_function_description descr = {1, 0, 0, 10, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 72, 237}; - PyObject* varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_f_us, __pyx_mstate->__pyx_n_u_p_us, __pyx_mstate->__pyx_n_u_q_us, __pyx_mstate->__pyx_n_u_f, __pyx_mstate->__pyx_n_u_p, __pyx_mstate->__pyx_n_u_q, __pyx_mstate->__pyx_n_u_f_u, __pyx_mstate->__pyx_n_u_p_u, __pyx_mstate->__pyx_n_u_q_u}; - __pyx_mstate_global->__pyx_codeobj_tab[6] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_epanet_epanet_py, __pyx_mstate->__pyx_n_u_units, __pyx_k_q_q_wgXWG7_PQ_q_wa_q_wiq_3d_at6, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[6])) goto bad; - } - { - __Pyx_PyCode_New_function_description descr = {1, 0, 0, 6, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 84, 136}; - PyObject* varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_ts, __pyx_mstate->__pyx_n_u_i, __pyx_mstate->__pyx_n_u_t, __pyx_mstate->__pyx_n_u_d, __pyx_mstate->__pyx_n_u_category}; - __pyx_mstate_global->__pyx_codeobj_tab[7] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_epanet_epanet_py, __pyx_mstate->__pyx_n_u_times, __pyx_k_q_Q_E_as_fAQ_q_E_at_V6_fTZZ_gQa, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[7])) goto bad; - } - { - __Pyx_PyCode_New_function_description descr = {1, 0, 0, 9, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 97, 329}; - PyObject* varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_sizes, __pyx_mstate->__pyx_n_u_node_type, __pyx_mstate->__pyx_n_u_nodes, __pyx_mstate->__pyx_n_u_i, __pyx_mstate->__pyx_n_u_name, __pyx_mstate->__pyx_n_u_name_len, __pyx_mstate->__pyx_n_u_link_type, __pyx_mstate->__pyx_n_u_links}; - __pyx_mstate_global->__pyx_codeobj_tab[8] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_epanet_epanet_py, __pyx_mstate->__pyx_n_u_element_name, __pyx_k_a_IQ_F_E_as_q_6_vV1_q_E_4AT_fTZ, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[8])) goto bad; - } - { - __Pyx_PyCode_New_function_description descr = {1, 0, 0, 11, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 121, 274}; - PyObject* varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_size, __pyx_mstate->__pyx_n_u_usages, __pyx_mstate->__pyx_n_u_category, __pyx_mstate->__pyx_n_u_links, __pyx_mstate->__pyx_n_u_i, __pyx_mstate->__pyx_n_u_index, __pyx_mstate->__pyx_n_u_values, __pyx_mstate->__pyx_n_u_length, __pyx_mstate->__pyx_n_u_d, __pyx_mstate->__pyx_n_u_j}; - __pyx_mstate_global->__pyx_codeobj_tab[9] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_epanet_epanet_py, __pyx_mstate->__pyx_n_u_energy_usage, __pyx_k_a_t9Baq_1O_5_NR_a_M_1A_E_as_r_F, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[9])) goto bad; - } - { - __Pyx_PyCode_New_function_description descr = {1, 0, 0, 6, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 140, 148}; - PyObject* varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_values, __pyx_mstate->__pyx_n_u_length, __pyx_mstate->__pyx_n_u_category, __pyx_mstate->__pyx_n_u_d, __pyx_mstate->__pyx_n_u_i}; - __pyx_mstate_global->__pyx_codeobj_tab[10] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_epanet_epanet_py, __pyx_mstate->__pyx_n_u_reactions, __pyx_k_1_xq_iq_vQ_G1D_at_V6_SYY___a_vW, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[10])) goto bad; - } - { - __Pyx_PyCode_New_function_description descr = {1, 0, 0, 13, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 153, 274}; - PyObject* varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_size, __pyx_mstate->__pyx_n_u_num_periods, __pyx_mstate->__pyx_n_u_nodes, __pyx_mstate->__pyx_n_u_category, __pyx_mstate->__pyx_n_u_ds, __pyx_mstate->__pyx_n_u_i, __pyx_mstate->__pyx_n_u_d, __pyx_mstate->__pyx_n_u_j, __pyx_mstate->__pyx_n_u_values, __pyx_mstate->__pyx_n_u_length, __pyx_mstate->__pyx_n_u_attributes, __pyx_mstate->__pyx_n_u_k}; - __pyx_mstate_global->__pyx_codeobj_tab[11] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_epanet_epanet_py, __pyx_mstate->__pyx_n_u_node_results, __pyx_k_a_t9Baq_d_1_M_1A_1Jhl_Q_E_as_r, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[11])) goto bad; - } - { - __Pyx_PyCode_New_function_description descr = {1, 0, 0, 13, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 175, 339}; - PyObject* varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_size, __pyx_mstate->__pyx_n_u_num_periods, __pyx_mstate->__pyx_n_u_links, __pyx_mstate->__pyx_n_u_category, __pyx_mstate->__pyx_n_u_ds, __pyx_mstate->__pyx_n_u_i, __pyx_mstate->__pyx_n_u_d, __pyx_mstate->__pyx_n_u_j, __pyx_mstate->__pyx_n_u_values, __pyx_mstate->__pyx_n_u_length, __pyx_mstate->__pyx_n_u_attributes, __pyx_mstate->__pyx_n_u_k}; - __pyx_mstate_global->__pyx_codeobj_tab[12] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_epanet_epanet_py, __pyx_mstate->__pyx_n_u_link_results, __pyx_k_a_t9Baq_d_1_M_1A_1HL_Kz_T_a_Q_E, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[12])) goto bad; - } - { - __Pyx_PyCode_New_function_description descr = {1, 0, 0, 2, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 204, 118}; - PyObject* varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_data}; - __pyx_mstate_global->__pyx_codeobj_tab[13] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_epanet_epanet_py, __pyx_mstate->__pyx_n_u_dump, __pyx_k_a_q_d_t9A_D_a_D_a_4_A_4_A_Ja_4, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[13])) goto bad; - } - { - __Pyx_PyCode_New_function_description descr = {1, 0, 0, 4, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 218, 56}; - PyObject* varnames[] = {__pyx_mstate->__pyx_n_u_path, __pyx_mstate->__pyx_n_u_opt_2, __pyx_mstate->__pyx_n_u_data, __pyx_mstate->__pyx_n_u_f}; - __pyx_mstate_global->__pyx_codeobj_tab[14] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_epanet_epanet_py, __pyx_mstate->__pyx_n_u_dump_output, __pyx_k_xq_3e1_Qe2Yha_E_1, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[14])) goto bad; - } - { - __Pyx_PyCode_New_function_description descr = {1, 0, 0, 2, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 226, 27}; - PyObject* varnames[] = {__pyx_mstate->__pyx_n_u_path, __pyx_mstate->__pyx_n_u_data}; - __pyx_mstate_global->__pyx_codeobj_tab[15] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_epanet_epanet_py, __pyx_mstate->__pyx_n_u_dump_output_2, __pyx_k_ha_q_4vQa, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[15])) goto bad; - } - { - __Pyx_PyCode_New_function_description descr = {1, 0, 0, 1, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 231, 22}; - PyObject* varnames[] = {__pyx_mstate->__pyx_n_u_path}; - __pyx_mstate_global->__pyx_codeobj_tab[16] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_epanet_epanet_py, __pyx_mstate->__pyx_n_u_dump_report, __pyx_k_ha_4q_d_q, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[16])) goto bad; - } - { - __Pyx_PyCode_New_function_description descr = {1, 0, 0, 4, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 235, 49}; - PyObject* varnames[] = {__pyx_mstate->__pyx_n_u_path, __pyx_mstate->__pyx_n_u_f, __pyx_mstate->__pyx_n_u_data, __pyx_mstate->__pyx_n_u_bast64_data}; - __pyx_mstate_global->__pyx_codeobj_tab[17] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_epanet_epanet_py, __pyx_mstate->__pyx_n_u_dump_output_binary, __pyx_k_XQ_QfIQ_q_Q_fJaq_s, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[17])) goto bad; - } - { - __Pyx_PyCode_New_function_description descr = {2, 0, 0, 12, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 242, 330}; - PyObject* varnames[] = {__pyx_mstate->__pyx_n_u_name, __pyx_mstate->__pyx_n_u_readable_output, __pyx_mstate->__pyx_n_u_dir, __pyx_mstate->__pyx_n_u_db_inp, __pyx_mstate->__pyx_n_u_input, __pyx_mstate->__pyx_n_u_exe, __pyx_mstate->__pyx_n_u_inp_2, __pyx_mstate->__pyx_n_u_rpt_2, __pyx_mstate->__pyx_n_u_opt_2, __pyx_mstate->__pyx_n_u_command, __pyx_mstate->__pyx_n_u_data, __pyx_mstate->__pyx_n_u_result}; - __pyx_mstate_global->__pyx_codeobj_tab[18] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_epanet_epanet_py, __pyx_mstate->__pyx_n_u_run_project_return_dict, __pyx_k_88I_t7_q_iq_1_E_G1_RuE_E_auKuBa, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[18])) goto bad; - } - { - __Pyx_PyCode_New_function_description descr = {2, 0, 0, 12, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 275, 332}; - PyObject* varnames[] = {__pyx_mstate->__pyx_n_u_name, __pyx_mstate->__pyx_n_u_readable_output, __pyx_mstate->__pyx_n_u_dir, __pyx_mstate->__pyx_n_u_db_inp, __pyx_mstate->__pyx_n_u_input, __pyx_mstate->__pyx_n_u_exe, __pyx_mstate->__pyx_n_u_inp_2, __pyx_mstate->__pyx_n_u_rpt_2, __pyx_mstate->__pyx_n_u_opt_2, __pyx_mstate->__pyx_n_u_command, __pyx_mstate->__pyx_n_u_data, __pyx_mstate->__pyx_n_u_result}; - __pyx_mstate_global->__pyx_codeobj_tab[19] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_epanet_epanet_py, __pyx_mstate->__pyx_n_u_run_project, __pyx_k_e_Q_t7_q_iq_1_E_G1_RuE_E_auKuBa, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[19])) goto bad; - } - { - __Pyx_PyCode_New_function_description descr = {1, 0, 0, 9, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 308, 234}; - PyObject* varnames[] = {__pyx_mstate->__pyx_n_u_name, __pyx_mstate->__pyx_n_u_dir, __pyx_mstate->__pyx_n_u_exe, __pyx_mstate->__pyx_n_u_inp_2, __pyx_mstate->__pyx_n_u_rpt_2, __pyx_mstate->__pyx_n_u_opt_2, __pyx_mstate->__pyx_n_u_command, __pyx_mstate->__pyx_n_u_data, __pyx_mstate->__pyx_n_u_result}; - __pyx_mstate_global->__pyx_codeobj_tab[20] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_epanet_epanet_py, __pyx_mstate->__pyx_n_u_run_inp, __pyx_k_E_G1_E_ar_e1E_A_E_ar_e1E_b_E_ar, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[20])) goto bad; - } - Py_DECREF(tuple_dedup_map); - return 0; - bad: - Py_DECREF(tuple_dedup_map); - return -1; -} -/* #### Code section: init_globals ### */ - -static int __Pyx_InitGlobals(void) { - /* PythonCompatibility.init */ - if (likely(__Pyx_init_co_variables() == 0)); else - -if (unlikely(PyErr_Occurred())) __PYX_ERR(0, 1, __pyx_L1_error) - - /* AssertionsEnabled.init */ - if (likely(__Pyx_init_assertions_enabled() == 0)); else - -if (unlikely(PyErr_Occurred())) __PYX_ERR(0, 1, __pyx_L1_error) - - /* CachedMethodType.init */ - #if CYTHON_COMPILING_IN_LIMITED_API -{ - PyObject *typesModule=NULL; - typesModule = PyImport_ImportModule("types"); - if (typesModule) { - __pyx_mstate_global->__Pyx_CachedMethodType = PyObject_GetAttrString(typesModule, "MethodType"); - Py_DECREF(typesModule); - } -} // error handling follows -#endif - -if (unlikely(PyErr_Occurred())) __PYX_ERR(0, 1, __pyx_L1_error) - - return 0; - __pyx_L1_error:; - return -1; -} -/* #### Code section: cleanup_globals ### */ -/* #### Code section: cleanup_module ### */ -/* #### Code section: main_method ### */ -/* #### Code section: utility_code_pragmas ### */ -#ifdef _MSC_VER -#pragma warning( push ) -/* Warning 4127: conditional expression is constant - * Cython uses constant conditional expressions to allow in inline functions to be optimized at - * compile-time, so this warning is not useful - */ -#pragma warning( disable : 4127 ) -#endif - - - -/* #### Code section: utility_code_def ### */ - -/* --- Runtime support code --- */ -/* Refnanny */ -#if CYTHON_REFNANNY -static __Pyx_RefNannyAPIStruct *__Pyx_RefNannyImportAPI(const char *modname) { - PyObject *m = NULL, *p = NULL; - void *r = NULL; - m = PyImport_ImportModule(modname); - if (!m) goto end; - p = PyObject_GetAttrString(m, "RefNannyAPI"); - if (!p) goto end; - r = PyLong_AsVoidPtr(p); -end: - Py_XDECREF(p); - Py_XDECREF(m); - return (__Pyx_RefNannyAPIStruct *)r; -} -#endif - -/* PyErrExceptionMatches */ -#if CYTHON_FAST_THREAD_STATE -static int __Pyx_PyErr_ExceptionMatchesTuple(PyObject *exc_type, PyObject *tuple) { - Py_ssize_t i, n; - n = PyTuple_GET_SIZE(tuple); - for (i=0; i= 0x030C00A6 - PyObject *current_exception = tstate->current_exception; - if (unlikely(!current_exception)) return 0; - exc_type = (PyObject*) Py_TYPE(current_exception); - if (exc_type == err) return 1; -#else - exc_type = tstate->curexc_type; - if (exc_type == err) return 1; - if (unlikely(!exc_type)) return 0; -#endif - #if CYTHON_AVOID_BORROWED_REFS - Py_INCREF(exc_type); - #endif - if (unlikely(PyTuple_Check(err))) { - result = __Pyx_PyErr_ExceptionMatchesTuple(exc_type, err); - } else { - result = __Pyx_PyErr_GivenExceptionMatches(exc_type, err); - } - #if CYTHON_AVOID_BORROWED_REFS - Py_DECREF(exc_type); - #endif - return result; -} -#endif - -/* PyErrFetchRestore */ -#if CYTHON_FAST_THREAD_STATE -static CYTHON_INLINE void __Pyx_ErrRestoreInState(PyThreadState *tstate, PyObject *type, PyObject *value, PyObject *tb) { -#if PY_VERSION_HEX >= 0x030C00A6 - PyObject *tmp_value; - assert(type == NULL || (value != NULL && type == (PyObject*) Py_TYPE(value))); - if (value) { - #if CYTHON_COMPILING_IN_CPYTHON - if (unlikely(((PyBaseExceptionObject*) value)->traceback != tb)) - #endif - PyException_SetTraceback(value, tb); - } - tmp_value = tstate->current_exception; - tstate->current_exception = value; - Py_XDECREF(tmp_value); - Py_XDECREF(type); - Py_XDECREF(tb); -#else - PyObject *tmp_type, *tmp_value, *tmp_tb; - tmp_type = tstate->curexc_type; - tmp_value = tstate->curexc_value; - tmp_tb = tstate->curexc_traceback; - tstate->curexc_type = type; - tstate->curexc_value = value; - tstate->curexc_traceback = tb; - Py_XDECREF(tmp_type); - Py_XDECREF(tmp_value); - Py_XDECREF(tmp_tb); -#endif -} -static CYTHON_INLINE void __Pyx_ErrFetchInState(PyThreadState *tstate, PyObject **type, PyObject **value, PyObject **tb) { -#if PY_VERSION_HEX >= 0x030C00A6 - PyObject* exc_value; - exc_value = tstate->current_exception; - tstate->current_exception = 0; - *value = exc_value; - *type = NULL; - *tb = NULL; - if (exc_value) { - *type = (PyObject*) Py_TYPE(exc_value); - Py_INCREF(*type); - #if CYTHON_COMPILING_IN_CPYTHON - *tb = ((PyBaseExceptionObject*) exc_value)->traceback; - Py_XINCREF(*tb); - #else - *tb = PyException_GetTraceback(exc_value); - #endif - } -#else - *type = tstate->curexc_type; - *value = tstate->curexc_value; - *tb = tstate->curexc_traceback; - tstate->curexc_type = 0; - tstate->curexc_value = 0; - tstate->curexc_traceback = 0; -#endif -} -#endif - -/* PyObjectGetAttrStr */ -#if CYTHON_USE_TYPE_SLOTS -static CYTHON_INLINE PyObject* __Pyx_PyObject_GetAttrStr(PyObject* obj, PyObject* attr_name) { - PyTypeObject* tp = Py_TYPE(obj); - if (likely(tp->tp_getattro)) - return tp->tp_getattro(obj, attr_name); - return PyObject_GetAttr(obj, attr_name); -} -#endif - -/* PyObjectGetAttrStrNoError */ -#if __PYX_LIMITED_VERSION_HEX < 0x030d0000 -static void __Pyx_PyObject_GetAttrStr_ClearAttributeError(void) { - __Pyx_PyThreadState_declare - __Pyx_PyThreadState_assign - if (likely(__Pyx_PyErr_ExceptionMatches(PyExc_AttributeError))) - __Pyx_PyErr_Clear(); -} -#endif -static CYTHON_INLINE PyObject* __Pyx_PyObject_GetAttrStrNoError(PyObject* obj, PyObject* attr_name) { - PyObject *result; -#if __PYX_LIMITED_VERSION_HEX >= 0x030d0000 - (void) PyObject_GetOptionalAttr(obj, attr_name, &result); - return result; -#else -#if CYTHON_COMPILING_IN_CPYTHON && CYTHON_USE_TYPE_SLOTS - PyTypeObject* tp = Py_TYPE(obj); - if (likely(tp->tp_getattro == PyObject_GenericGetAttr)) { - return _PyObject_GenericGetAttrWithDict(obj, attr_name, NULL, 1); - } -#endif - result = __Pyx_PyObject_GetAttrStr(obj, attr_name); - if (unlikely(!result)) { - __Pyx_PyObject_GetAttrStr_ClearAttributeError(); - } - return result; -#endif -} - -/* GetBuiltinName */ -static PyObject *__Pyx_GetBuiltinName(PyObject *name) { - PyObject* result = __Pyx_PyObject_GetAttrStrNoError(__pyx_mstate_global->__pyx_b, name); - if (unlikely(!result) && !PyErr_Occurred()) { - PyErr_Format(PyExc_NameError, - "name '%U' is not defined", name); - } - return result; -} - -/* TupleAndListFromArray */ -#if !CYTHON_COMPILING_IN_CPYTHON && CYTHON_METH_FASTCALL -static CYTHON_INLINE PyObject * -__Pyx_PyTuple_FromArray(PyObject *const *src, Py_ssize_t n) -{ - PyObject *res; - Py_ssize_t i; - if (n <= 0) { - return __Pyx_NewRef(__pyx_mstate_global->__pyx_empty_tuple); - } - res = PyTuple_New(n); - if (unlikely(res == NULL)) return NULL; - for (i = 0; i < n; i++) { - if (unlikely(__Pyx_PyTuple_SET_ITEM(res, i, src[i]) < 0)) { - Py_DECREF(res); - return NULL; - } - Py_INCREF(src[i]); - } - return res; -} -#elif CYTHON_COMPILING_IN_CPYTHON -static CYTHON_INLINE void __Pyx_copy_object_array(PyObject *const *CYTHON_RESTRICT src, PyObject** CYTHON_RESTRICT dest, Py_ssize_t length) { - PyObject *v; - Py_ssize_t i; - for (i = 0; i < length; i++) { - v = dest[i] = src[i]; - Py_INCREF(v); - } -} -static CYTHON_INLINE PyObject * -__Pyx_PyTuple_FromArray(PyObject *const *src, Py_ssize_t n) -{ - PyObject *res; - if (n <= 0) { - return __Pyx_NewRef(__pyx_mstate_global->__pyx_empty_tuple); - } - res = PyTuple_New(n); - if (unlikely(res == NULL)) return NULL; - __Pyx_copy_object_array(src, ((PyTupleObject*)res)->ob_item, n); - return res; -} -static CYTHON_INLINE PyObject * -__Pyx_PyList_FromArray(PyObject *const *src, Py_ssize_t n) -{ - PyObject *res; - if (n <= 0) { - return PyList_New(0); - } - res = PyList_New(n); - if (unlikely(res == NULL)) return NULL; - __Pyx_copy_object_array(src, ((PyListObject*)res)->ob_item, n); - return res; -} -#endif - -/* BytesEquals */ -static CYTHON_INLINE int __Pyx_PyBytes_Equals(PyObject* s1, PyObject* s2, int equals) { -#if CYTHON_COMPILING_IN_PYPY || CYTHON_COMPILING_IN_LIMITED_API || CYTHON_COMPILING_IN_GRAAL ||\ - !(CYTHON_ASSUME_SAFE_SIZE && CYTHON_ASSUME_SAFE_MACROS) - return PyObject_RichCompareBool(s1, s2, equals); -#else - if (s1 == s2) { - return (equals == Py_EQ); - } else if (PyBytes_CheckExact(s1) & PyBytes_CheckExact(s2)) { - const char *ps1, *ps2; - Py_ssize_t length = PyBytes_GET_SIZE(s1); - if (length != PyBytes_GET_SIZE(s2)) - return (equals == Py_NE); - ps1 = PyBytes_AS_STRING(s1); - ps2 = PyBytes_AS_STRING(s2); - if (ps1[0] != ps2[0]) { - return (equals == Py_NE); - } else if (length == 1) { - return (equals == Py_EQ); - } else { - int result; -#if CYTHON_USE_UNICODE_INTERNALS && (PY_VERSION_HEX < 0x030B0000) - Py_hash_t hash1, hash2; - hash1 = ((PyBytesObject*)s1)->ob_shash; - hash2 = ((PyBytesObject*)s2)->ob_shash; - if (hash1 != hash2 && hash1 != -1 && hash2 != -1) { - return (equals == Py_NE); - } -#endif - result = memcmp(ps1, ps2, (size_t)length); - 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; - } -#endif -} - -/* UnicodeEquals */ -static CYTHON_INLINE int __Pyx_PyUnicode_Equals(PyObject* s1, PyObject* s2, int equals) { -#if CYTHON_COMPILING_IN_PYPY || CYTHON_COMPILING_IN_LIMITED_API || CYTHON_COMPILING_IN_GRAAL - return PyObject_RichCompareBool(s1, s2, equals); -#else - int s1_is_unicode, s2_is_unicode; - if (s1 == s2) { - goto return_eq; - } - s1_is_unicode = PyUnicode_CheckExact(s1); - s2_is_unicode = PyUnicode_CheckExact(s2); - if (s1_is_unicode & s2_is_unicode) { - Py_ssize_t length, length2; - int kind; - void *data1, *data2; - #if !CYTHON_COMPILING_IN_LIMITED_API - if (unlikely(__Pyx_PyUnicode_READY(s1) < 0) || unlikely(__Pyx_PyUnicode_READY(s2) < 0)) - return -1; - #endif - length = __Pyx_PyUnicode_GET_LENGTH(s1); - #if !CYTHON_ASSUME_SAFE_SIZE - if (unlikely(length < 0)) return -1; - #endif - length2 = __Pyx_PyUnicode_GET_LENGTH(s2); - #if !CYTHON_ASSUME_SAFE_SIZE - if (unlikely(length2 < 0)) return -1; - #endif - if (length != length2) { - goto return_ne; - } -#if CYTHON_USE_UNICODE_INTERNALS - { - Py_hash_t hash1, hash2; - hash1 = ((PyASCIIObject*)s1)->hash; - hash2 = ((PyASCIIObject*)s2)->hash; - if (hash1 != hash2 && hash1 != -1 && hash2 != -1) { - goto return_ne; - } - } -#endif - kind = __Pyx_PyUnicode_KIND(s1); - if (kind != __Pyx_PyUnicode_KIND(s2)) { - goto return_ne; - } - data1 = __Pyx_PyUnicode_DATA(s1); - data2 = __Pyx_PyUnicode_DATA(s2); - if (__Pyx_PyUnicode_READ(kind, data1, 0) != __Pyx_PyUnicode_READ(kind, data2, 0)) { - goto return_ne; - } else if (length == 1) { - goto return_eq; - } else { - int result = memcmp(data1, data2, (size_t)(length * kind)); - return (equals == Py_EQ) ? (result == 0) : (result != 0); - } - } else if ((s1 == Py_None) & s2_is_unicode) { - goto return_ne; - } else if ((s2 == Py_None) & s1_is_unicode) { - goto return_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; - } -return_eq: - return (equals == Py_EQ); -return_ne: - return (equals == Py_NE); -#endif -} - -/* fastcall */ -#if CYTHON_METH_FASTCALL -static CYTHON_INLINE PyObject * __Pyx_GetKwValue_FASTCALL(PyObject *kwnames, PyObject *const *kwvalues, PyObject *s) -{ - Py_ssize_t i, n = __Pyx_PyTuple_GET_SIZE(kwnames); - #if !CYTHON_ASSUME_SAFE_SIZE - if (unlikely(n == -1)) return NULL; - #endif - for (i = 0; i < n; i++) - { - PyObject *namei = __Pyx_PyTuple_GET_ITEM(kwnames, i); - #if !CYTHON_ASSUME_SAFE_MACROS - if (unlikely(!namei)) return NULL; - #endif - if (s == namei) return kwvalues[i]; - } - for (i = 0; i < n; i++) - { - PyObject *namei = __Pyx_PyTuple_GET_ITEM(kwnames, i); - #if !CYTHON_ASSUME_SAFE_MACROS - if (unlikely(!namei)) return NULL; - #endif - int eq = __Pyx_PyUnicode_Equals(s, namei, Py_EQ); - if (unlikely(eq != 0)) { - if (unlikely(eq < 0)) return NULL; - return kwvalues[i]; - } - } - return NULL; -} -#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030d0000 || CYTHON_COMPILING_IN_LIMITED_API -CYTHON_UNUSED static PyObject *__Pyx_KwargsAsDict_FASTCALL(PyObject *kwnames, PyObject *const *kwvalues) { - Py_ssize_t i, nkwargs; - PyObject *dict; -#if !CYTHON_ASSUME_SAFE_SIZE - nkwargs = PyTuple_Size(kwnames); - if (unlikely(nkwargs < 0)) return NULL; -#else - nkwargs = PyTuple_GET_SIZE(kwnames); -#endif - dict = PyDict_New(); - if (unlikely(!dict)) - return NULL; - for (i=0; itp_dict; - return likely(dict) ? __PYX_GET_DICT_VERSION(dict) : 0; -} -static CYTHON_INLINE PY_UINT64_T __Pyx_get_object_dict_version(PyObject *obj) { - PyObject **dictptr = NULL; - Py_ssize_t offset = Py_TYPE(obj)->tp_dictoffset; - if (offset) { -#if CYTHON_COMPILING_IN_CPYTHON - dictptr = (likely(offset > 0)) ? (PyObject **) ((char *)obj + offset) : _PyObject_GetDictPtr(obj); -#else - dictptr = _PyObject_GetDictPtr(obj); -#endif - } - return (dictptr && *dictptr) ? __PYX_GET_DICT_VERSION(*dictptr) : 0; -} -static CYTHON_INLINE int __Pyx_object_dict_version_matches(PyObject* obj, PY_UINT64_T tp_dict_version, PY_UINT64_T obj_dict_version) { - PyObject *dict = Py_TYPE(obj)->tp_dict; - if (unlikely(!dict) || unlikely(tp_dict_version != __PYX_GET_DICT_VERSION(dict))) - return 0; - return obj_dict_version == __Pyx_get_object_dict_version(obj); -} -#endif - -/* GetModuleGlobalName */ -#if CYTHON_USE_DICT_VERSIONS -static PyObject *__Pyx__GetModuleGlobalName(PyObject *name, PY_UINT64_T *dict_version, PyObject **dict_cached_value) -#else -static CYTHON_INLINE PyObject *__Pyx__GetModuleGlobalName(PyObject *name) -#endif -{ - PyObject *result; -#if CYTHON_COMPILING_IN_LIMITED_API - if (unlikely(!__pyx_m)) { - if (!PyErr_Occurred()) - PyErr_SetNone(PyExc_NameError); - return NULL; - } - result = PyObject_GetAttr(__pyx_m, name); - if (likely(result)) { - return result; - } - PyErr_Clear(); -#elif CYTHON_AVOID_BORROWED_REFS || CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS - if (unlikely(__Pyx_PyDict_GetItemRef(__pyx_mstate_global->__pyx_d, name, &result) == -1)) PyErr_Clear(); - __PYX_UPDATE_DICT_CACHE(__pyx_mstate_global->__pyx_d, result, *dict_cached_value, *dict_version) - if (likely(result)) { - return result; - } -#else - result = _PyDict_GetItem_KnownHash(__pyx_mstate_global->__pyx_d, name, ((PyASCIIObject *) name)->hash); - __PYX_UPDATE_DICT_CACHE(__pyx_mstate_global->__pyx_d, result, *dict_cached_value, *dict_version) - if (likely(result)) { - return __Pyx_NewRef(result); - } - PyErr_Clear(); -#endif - return __Pyx_GetBuiltinName(name); -} - -/* PyFunctionFastCall */ -#if CYTHON_FAST_PYCALL && !CYTHON_VECTORCALL -static PyObject* __Pyx_PyFunction_FastCallNoKw(PyCodeObject *co, PyObject *const *args, Py_ssize_t na, - PyObject *globals) { - PyFrameObject *f; - PyThreadState *tstate = __Pyx_PyThreadState_Current; - PyObject **fastlocals; - Py_ssize_t i; - PyObject *result; - assert(globals != NULL); - /* XXX Perhaps we should create a specialized - PyFrame_New() that doesn't take locals, but does - take builtins without sanity checking them. - */ - assert(tstate != NULL); - f = PyFrame_New(tstate, co, globals, NULL); - if (f == NULL) { - return NULL; - } - fastlocals = __Pyx_PyFrame_GetLocalsplus(f); - for (i = 0; i < na; i++) { - Py_INCREF(*args); - fastlocals[i] = *args++; - } - result = PyEval_EvalFrameEx(f,0); - ++tstate->recursion_depth; - Py_DECREF(f); - --tstate->recursion_depth; - return result; -} -static PyObject *__Pyx_PyFunction_FastCallDict(PyObject *func, PyObject *const *args, Py_ssize_t nargs, PyObject *kwargs) { - PyCodeObject *co = (PyCodeObject *)PyFunction_GET_CODE(func); - PyObject *globals = PyFunction_GET_GLOBALS(func); - PyObject *argdefs = PyFunction_GET_DEFAULTS(func); - PyObject *closure; - PyObject *kwdefs; - PyObject *kwtuple, **k; - PyObject **d; - Py_ssize_t nd; - Py_ssize_t nk; - PyObject *result; - assert(kwargs == NULL || PyDict_Check(kwargs)); - nk = kwargs ? PyDict_Size(kwargs) : 0; - if (unlikely(Py_EnterRecursiveCall(" while calling a Python object"))) { - return NULL; - } - if ( - co->co_kwonlyargcount == 0 && - likely(kwargs == NULL || nk == 0) && - co->co_flags == (CO_OPTIMIZED | CO_NEWLOCALS | CO_NOFREE)) { - if (argdefs == NULL && co->co_argcount == nargs) { - result = __Pyx_PyFunction_FastCallNoKw(co, args, nargs, globals); - goto done; - } - else if (nargs == 0 && argdefs != NULL - && co->co_argcount == Py_SIZE(argdefs)) { - /* function called with no arguments, but all parameters have - a default value: use default values as arguments .*/ - args = &PyTuple_GET_ITEM(argdefs, 0); - result =__Pyx_PyFunction_FastCallNoKw(co, args, Py_SIZE(argdefs), globals); - goto done; - } - } - if (kwargs != NULL) { - Py_ssize_t pos, i; - kwtuple = PyTuple_New(2 * nk); - if (kwtuple == NULL) { - result = NULL; - goto done; - } - k = &PyTuple_GET_ITEM(kwtuple, 0); - pos = i = 0; - while (PyDict_Next(kwargs, &pos, &k[i], &k[i+1])) { - Py_INCREF(k[i]); - Py_INCREF(k[i+1]); - i += 2; - } - nk = i / 2; - } - else { - kwtuple = NULL; - k = NULL; - } - closure = PyFunction_GET_CLOSURE(func); - kwdefs = PyFunction_GET_KW_DEFAULTS(func); - if (argdefs != NULL) { - d = &PyTuple_GET_ITEM(argdefs, 0); - nd = Py_SIZE(argdefs); - } - else { - d = NULL; - nd = 0; - } - result = PyEval_EvalCodeEx((PyObject*)co, globals, (PyObject *)NULL, - args, (int)nargs, - k, (int)nk, - d, (int)nd, kwdefs, closure); - Py_XDECREF(kwtuple); -done: - Py_LeaveRecursiveCall(); - return result; -} -#endif - -/* PyObjectCall */ -#if CYTHON_COMPILING_IN_CPYTHON -static CYTHON_INLINE PyObject* __Pyx_PyObject_Call(PyObject *func, PyObject *arg, PyObject *kw) { - PyObject *result; - ternaryfunc call = Py_TYPE(func)->tp_call; - if (unlikely(!call)) - return PyObject_Call(func, arg, kw); - if (unlikely(Py_EnterRecursiveCall(" while calling a Python object"))) - return NULL; - result = (*call)(func, arg, kw); - Py_LeaveRecursiveCall(); - if (unlikely(!result) && unlikely(!PyErr_Occurred())) { - PyErr_SetString( - PyExc_SystemError, - "NULL result without error in PyObject_Call"); - } - return result; -} -#endif - -/* PyObjectCallMethO */ -#if CYTHON_COMPILING_IN_CPYTHON -static CYTHON_INLINE PyObject* __Pyx_PyObject_CallMethO(PyObject *func, PyObject *arg) { - PyObject *self, *result; - PyCFunction cfunc; - cfunc = __Pyx_CyOrPyCFunction_GET_FUNCTION(func); - self = __Pyx_CyOrPyCFunction_GET_SELF(func); - if (unlikely(Py_EnterRecursiveCall(" while calling a Python object"))) - return NULL; - result = cfunc(self, arg); - Py_LeaveRecursiveCall(); - if (unlikely(!result) && unlikely(!PyErr_Occurred())) { - PyErr_SetString( - PyExc_SystemError, - "NULL result without error in PyObject_Call"); - } - return result; -} -#endif - -/* PyObjectFastCall */ -#if PY_VERSION_HEX < 0x03090000 || CYTHON_COMPILING_IN_LIMITED_API -static PyObject* __Pyx_PyObject_FastCall_fallback(PyObject *func, PyObject * const*args, size_t nargs, PyObject *kwargs) { - PyObject *argstuple; - PyObject *result = 0; - size_t i; - argstuple = PyTuple_New((Py_ssize_t)nargs); - if (unlikely(!argstuple)) return NULL; - for (i = 0; i < nargs; i++) { - Py_INCREF(args[i]); - if (__Pyx_PyTuple_SET_ITEM(argstuple, (Py_ssize_t)i, args[i]) != (0)) goto bad; - } - result = __Pyx_PyObject_Call(func, argstuple, kwargs); - bad: - Py_DECREF(argstuple); - return result; -} -#endif -#if CYTHON_VECTORCALL && !CYTHON_COMPILING_IN_LIMITED_API - #if PY_VERSION_HEX < 0x03090000 - #define __Pyx_PyVectorcall_Function(callable) _PyVectorcall_Function(callable) - #elif CYTHON_COMPILING_IN_CPYTHON -static CYTHON_INLINE vectorcallfunc __Pyx_PyVectorcall_Function(PyObject *callable) { - PyTypeObject *tp = Py_TYPE(callable); - #if defined(__Pyx_CyFunction_USED) - if (__Pyx_CyFunction_CheckExact(callable)) { - return __Pyx_CyFunction_func_vectorcall(callable); - } - #endif - if (!PyType_HasFeature(tp, Py_TPFLAGS_HAVE_VECTORCALL)) { - return NULL; - } - assert(PyCallable_Check(callable)); - Py_ssize_t offset = tp->tp_vectorcall_offset; - assert(offset > 0); - vectorcallfunc ptr; - memcpy(&ptr, (char *) callable + offset, sizeof(ptr)); - return ptr; -} - #else - #define __Pyx_PyVectorcall_Function(callable) PyVectorcall_Function(callable) - #endif -#endif -static CYTHON_INLINE PyObject* __Pyx_PyObject_FastCallDict(PyObject *func, PyObject *const *args, size_t _nargs, PyObject *kwargs) { - Py_ssize_t nargs = __Pyx_PyVectorcall_NARGS(_nargs); -#if CYTHON_COMPILING_IN_CPYTHON - if (nargs == 0 && kwargs == NULL) { - if (__Pyx_CyOrPyCFunction_Check(func) && likely( __Pyx_CyOrPyCFunction_GET_FLAGS(func) & METH_NOARGS)) - return __Pyx_PyObject_CallMethO(func, NULL); - } - else if (nargs == 1 && kwargs == NULL) { - if (__Pyx_CyOrPyCFunction_Check(func) && likely( __Pyx_CyOrPyCFunction_GET_FLAGS(func) & METH_O)) - return __Pyx_PyObject_CallMethO(func, args[0]); - } -#endif - #if PY_VERSION_HEX < 0x030800B1 - #if CYTHON_FAST_PYCCALL - if (PyCFunction_Check(func)) { - if (kwargs) { - return _PyCFunction_FastCallDict(func, args, nargs, kwargs); - } else { - return _PyCFunction_FastCallKeywords(func, args, nargs, NULL); - } - } - if (!kwargs && __Pyx_IS_TYPE(func, &PyMethodDescr_Type)) { - return _PyMethodDescr_FastCallKeywords(func, args, nargs, NULL); - } - #endif - #if CYTHON_FAST_PYCALL - if (PyFunction_Check(func)) { - return __Pyx_PyFunction_FastCallDict(func, args, nargs, kwargs); - } - #endif - #endif - if (kwargs == NULL) { - #if CYTHON_VECTORCALL && !CYTHON_COMPILING_IN_LIMITED_API - vectorcallfunc f = __Pyx_PyVectorcall_Function(func); - if (f) { - return f(func, args, _nargs, NULL); - } - #elif defined(__Pyx_CyFunction_USED) && CYTHON_BACKPORT_VECTORCALL - if (__Pyx_CyFunction_CheckExact(func)) { - __pyx_vectorcallfunc f = __Pyx_CyFunction_func_vectorcall(func); - if (f) return f(func, args, _nargs, NULL); - } - #elif CYTHON_COMPILING_IN_LIMITED_API && CYTHON_VECTORCALL - return PyObject_Vectorcall(func, args, _nargs, NULL); - #endif - } - if (nargs == 0) { - return __Pyx_PyObject_Call(func, __pyx_mstate_global->__pyx_empty_tuple, kwargs); - } - #if PY_VERSION_HEX >= 0x03090000 && !CYTHON_COMPILING_IN_LIMITED_API - return PyObject_VectorcallDict(func, args, (size_t)nargs, kwargs); - #else - return __Pyx_PyObject_FastCall_fallback(func, args, (size_t)nargs, kwargs); - #endif -} - -/* JoinPyUnicode */ -static PyObject* __Pyx_PyUnicode_Join(PyObject** values, Py_ssize_t value_count, Py_ssize_t result_ulength, - Py_UCS4 max_char) { -#if CYTHON_USE_UNICODE_INTERNALS && CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS - PyObject *result_uval; - int result_ukind, kind_shift; - Py_ssize_t i, char_pos; - void *result_udata; - if (max_char > 1114111) max_char = 1114111; - result_uval = PyUnicode_New(result_ulength, max_char); - if (unlikely(!result_uval)) return NULL; - result_ukind = (max_char <= 255) ? PyUnicode_1BYTE_KIND : (max_char <= 65535) ? PyUnicode_2BYTE_KIND : PyUnicode_4BYTE_KIND; - kind_shift = (result_ukind == PyUnicode_4BYTE_KIND) ? 2 : result_ukind - 1; - result_udata = PyUnicode_DATA(result_uval); - assert(kind_shift == 2 || kind_shift == 1 || kind_shift == 0); - if (unlikely((PY_SSIZE_T_MAX >> kind_shift) - result_ulength < 0)) - goto overflow; - char_pos = 0; - for (i=0; i < value_count; i++) { - int ukind; - Py_ssize_t ulength; - void *udata; - PyObject *uval = values[i]; - #if !CYTHON_COMPILING_IN_LIMITED_API - if (__Pyx_PyUnicode_READY(uval) == (-1)) - goto bad; - #endif - ulength = __Pyx_PyUnicode_GET_LENGTH(uval); - #if !CYTHON_ASSUME_SAFE_SIZE - if (unlikely(ulength < 0)) goto bad; - #endif - if (unlikely(!ulength)) - continue; - if (unlikely((PY_SSIZE_T_MAX >> kind_shift) - ulength < char_pos)) - goto overflow; - ukind = __Pyx_PyUnicode_KIND(uval); - udata = __Pyx_PyUnicode_DATA(uval); - if (ukind == result_ukind) { - memcpy((char *)result_udata + (char_pos << kind_shift), udata, (size_t) (ulength << kind_shift)); - } else { - #if PY_VERSION_HEX >= 0x030d0000 - if (unlikely(PyUnicode_CopyCharacters(result_uval, char_pos, uval, 0, ulength) < 0)) goto bad; - #elif CYTHON_COMPILING_IN_CPYTHON || defined(_PyUnicode_FastCopyCharacters) - _PyUnicode_FastCopyCharacters(result_uval, char_pos, uval, 0, ulength); - #else - Py_ssize_t j; - for (j=0; j < ulength; j++) { - Py_UCS4 uchar = __Pyx_PyUnicode_READ(ukind, udata, j); - __Pyx_PyUnicode_WRITE(result_ukind, result_udata, char_pos+j, uchar); - } - #endif - } - char_pos += ulength; - } - return result_uval; -overflow: - PyErr_SetString(PyExc_OverflowError, "join() result is too long for a Python string"); -bad: - Py_DECREF(result_uval); - return NULL; -#else - Py_ssize_t i; - PyObject *result = NULL; - PyObject *value_tuple = PyTuple_New(value_count); - if (unlikely(!value_tuple)) return NULL; - CYTHON_UNUSED_VAR(max_char); - CYTHON_UNUSED_VAR(result_ulength); - for (i=0; i__pyx_empty_unicode, value_tuple); -bad: - Py_DECREF(value_tuple); - return result; -#endif -} - -/* RaiseException */ -static void __Pyx_Raise(PyObject *type, PyObject *value, PyObject *tb, PyObject *cause) { - PyObject* owned_instance = NULL; - if (tb == Py_None) { - tb = 0; - } else if (tb && !PyTraceBack_Check(tb)) { - PyErr_SetString(PyExc_TypeError, - "raise: arg 3 must be a traceback or None"); - goto bad; - } - if (value == Py_None) - value = 0; - if (PyExceptionInstance_Check(type)) { - if (value) { - PyErr_SetString(PyExc_TypeError, - "instance exception may not have a separate value"); - goto bad; - } - value = type; - type = (PyObject*) Py_TYPE(value); - } else if (PyExceptionClass_Check(type)) { - PyObject *instance_class = NULL; - if (value && PyExceptionInstance_Check(value)) { - instance_class = (PyObject*) Py_TYPE(value); - if (instance_class != type) { - int is_subclass = PyObject_IsSubclass(instance_class, type); - if (!is_subclass) { - instance_class = NULL; - } else if (unlikely(is_subclass == -1)) { - goto bad; - } else { - type = instance_class; - } - } - } - if (!instance_class) { - PyObject *args; - if (!value) - args = PyTuple_New(0); - else if (PyTuple_Check(value)) { - Py_INCREF(value); - args = value; - } else - args = PyTuple_Pack(1, value); - if (!args) - goto bad; - owned_instance = PyObject_Call(type, args, NULL); - Py_DECREF(args); - if (!owned_instance) - goto bad; - value = owned_instance; - if (!PyExceptionInstance_Check(value)) { - PyErr_Format(PyExc_TypeError, - "calling %R should have returned an instance of " - "BaseException, not %R", - type, Py_TYPE(value)); - goto bad; - } - } - } else { - PyErr_SetString(PyExc_TypeError, - "raise: exception class must be a subclass of BaseException"); - goto bad; - } - if (cause) { - PyObject *fixed_cause; - if (cause == Py_None) { - fixed_cause = NULL; - } else if (PyExceptionClass_Check(cause)) { - fixed_cause = PyObject_CallObject(cause, NULL); - if (fixed_cause == NULL) - goto bad; - } else if (PyExceptionInstance_Check(cause)) { - fixed_cause = cause; - Py_INCREF(fixed_cause); - } else { - PyErr_SetString(PyExc_TypeError, - "exception causes must derive from " - "BaseException"); - goto bad; - } - PyException_SetCause(value, fixed_cause); - } - PyErr_SetObject(type, value); - if (tb) { -#if PY_VERSION_HEX >= 0x030C00A6 - PyException_SetTraceback(value, tb); -#elif CYTHON_FAST_THREAD_STATE - PyThreadState *tstate = __Pyx_PyThreadState_Current; - PyObject* tmp_tb = tstate->curexc_traceback; - if (tb != tmp_tb) { - Py_INCREF(tb); - tstate->curexc_traceback = tb; - Py_XDECREF(tmp_tb); - } -#else - PyObject *tmp_type, *tmp_value, *tmp_tb; - PyErr_Fetch(&tmp_type, &tmp_value, &tmp_tb); - Py_INCREF(tb); - PyErr_Restore(tmp_type, tmp_value, tb); - Py_XDECREF(tmp_tb); -#endif - } -bad: - Py_XDECREF(owned_instance); - return; -} - -/* RaiseDoubleKeywords */ -static void __Pyx_RaiseDoubleKeywordsError( - const char* func_name, - PyObject* kw_name) -{ - PyErr_Format(PyExc_TypeError, - "%s() got multiple values for keyword argument '%U'", func_name, kw_name); -} - -/* UnpackUnboundCMethod */ -#if CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX < 0x030C0000 -static PyObject *__Pyx_SelflessCall(PyObject *method, PyObject *args, PyObject *kwargs) { - PyObject *result; - PyObject *selfless_args = PyTuple_GetSlice(args, 1, PyTuple_Size(args)); - if (unlikely(!selfless_args)) return NULL; - result = PyObject_Call(method, selfless_args, kwargs); - Py_DECREF(selfless_args); - return result; -} -#else -static PyObject *__Pyx_SelflessCall(PyObject *method, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames) { - return -#if PY_VERSION_HEX < 0x03090000 - _PyObject_Vectorcall -#else - PyObject_Vectorcall -#endif - (method, args ? args+1 : NULL, nargs ? (size_t) nargs-1 : 0, kwnames); -} -#endif -static PyMethodDef __Pyx_UnboundCMethod_Def = { - "CythonUnboundCMethod", - __PYX_REINTERPRET_FUNCION(PyCFunction, __Pyx_SelflessCall), -#if CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX < 0x030C0000 - METH_VARARGS | METH_KEYWORDS, -#else - METH_FASTCALL | METH_KEYWORDS, -#endif - NULL -}; -static int __Pyx_TryUnpackUnboundCMethod(__Pyx_CachedCFunction* target) { - PyObject *method, *result=NULL; - method = __Pyx_PyObject_GetAttrStr(target->type, *target->method_name); - if (unlikely(!method)) - return -1; - result = method; -#if CYTHON_COMPILING_IN_CPYTHON - if (likely(__Pyx_TypeCheck(method, &PyMethodDescr_Type))) - { - PyMethodDescrObject *descr = (PyMethodDescrObject*) method; - target->func = descr->d_method->ml_meth; - target->flag = descr->d_method->ml_flags & ~(METH_CLASS | METH_STATIC | METH_COEXIST | METH_STACKLESS); - } else -#endif -#if CYTHON_COMPILING_IN_PYPY -#else - if (PyCFunction_Check(method)) -#endif - { - PyObject *self; - int self_found; -#if CYTHON_COMPILING_IN_LIMITED_API || CYTHON_COMPILING_IN_PYPY - self = PyObject_GetAttrString(method, "__self__"); - if (!self) { - PyErr_Clear(); - } -#else - self = PyCFunction_GET_SELF(method); -#endif - self_found = (self && self != Py_None); -#if CYTHON_COMPILING_IN_LIMITED_API || CYTHON_COMPILING_IN_PYPY - Py_XDECREF(self); -#endif - if (self_found) { - PyObject *unbound_method = PyCFunction_New(&__Pyx_UnboundCMethod_Def, method); - if (unlikely(!unbound_method)) return -1; - Py_DECREF(method); - result = unbound_method; - } - } -#if !CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - if (unlikely(target->method)) { - Py_DECREF(result); - } else -#endif - target->method = result; - return 0; -} - -/* CallUnboundCMethod2 */ -#if CYTHON_COMPILING_IN_CPYTHON -static CYTHON_INLINE PyObject *__Pyx_CallUnboundCMethod2(__Pyx_CachedCFunction *cfunc, PyObject *self, PyObject *arg1, PyObject *arg2) { - int was_initialized = __Pyx_CachedCFunction_GetAndSetInitializing(cfunc); - if (likely(was_initialized == 2 && cfunc->func)) { - PyObject *args[2] = {arg1, arg2}; - if (cfunc->flag == METH_FASTCALL) { - return __Pyx_CallCFunctionFast(cfunc, self, args, 2); - } - if (cfunc->flag == (METH_FASTCALL | METH_KEYWORDS)) - return __Pyx_CallCFunctionFastWithKeywords(cfunc, self, args, 2, NULL); - } -#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - else if (unlikely(was_initialized == 1)) { - __Pyx_CachedCFunction tmp_cfunc = { -#ifndef __cplusplus - 0 -#endif - }; - tmp_cfunc.type = cfunc->type; - tmp_cfunc.method_name = cfunc->method_name; - return __Pyx__CallUnboundCMethod2(&tmp_cfunc, self, arg1, arg2); - } -#endif - PyObject *result = __Pyx__CallUnboundCMethod2(cfunc, self, arg1, arg2); - __Pyx_CachedCFunction_SetFinishedInitializing(cfunc); - return result; -} -#endif -static PyObject* __Pyx__CallUnboundCMethod2(__Pyx_CachedCFunction* cfunc, PyObject* self, PyObject* arg1, PyObject* arg2){ - if (unlikely(!cfunc->func && !cfunc->method) && unlikely(__Pyx_TryUnpackUnboundCMethod(cfunc) < 0)) return NULL; -#if CYTHON_COMPILING_IN_CPYTHON - if (cfunc->func && (cfunc->flag & METH_VARARGS)) { - PyObject *result = NULL; - PyObject *args = PyTuple_New(2); - if (unlikely(!args)) return NULL; - Py_INCREF(arg1); - PyTuple_SET_ITEM(args, 0, arg1); - Py_INCREF(arg2); - PyTuple_SET_ITEM(args, 1, arg2); - if (cfunc->flag & METH_KEYWORDS) - result = __Pyx_CallCFunctionWithKeywords(cfunc, self, args, NULL); - else - result = __Pyx_CallCFunction(cfunc, self, args); - Py_DECREF(args); - return result; - } -#endif - { - PyObject *args[4] = {NULL, self, arg1, arg2}; - return __Pyx_PyObject_FastCall(cfunc->method, args+1, 3 | __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET); - } -} - -/* ParseKeywords */ -static int __Pyx_ValidateDuplicatePosArgs( - PyObject *kwds, - PyObject ** const argnames[], - PyObject ** const *first_kw_arg, - const char* function_name) -{ - PyObject ** const *name = argnames; - while (name != first_kw_arg) { - PyObject *key = **name; - int found = PyDict_Contains(kwds, key); - if (unlikely(found)) { - if (found == 1) __Pyx_RaiseDoubleKeywordsError(function_name, key); - goto bad; - } - name++; - } - return 0; -bad: - return -1; -} -#if CYTHON_USE_UNICODE_INTERNALS -static CYTHON_INLINE int __Pyx_UnicodeKeywordsEqual(PyObject *s1, PyObject *s2) { - int kind; - Py_ssize_t len = PyUnicode_GET_LENGTH(s1); - if (len != PyUnicode_GET_LENGTH(s2)) return 0; - kind = PyUnicode_KIND(s1); - if (kind != PyUnicode_KIND(s2)) return 0; - const void *data1 = PyUnicode_DATA(s1); - const void *data2 = PyUnicode_DATA(s2); - return (memcmp(data1, data2, (size_t) len * (size_t) kind) == 0); -} -#endif -static int __Pyx_MatchKeywordArg_str( - PyObject *key, - PyObject ** const argnames[], - PyObject ** const *first_kw_arg, - size_t *index_found, - const char *function_name) -{ - PyObject ** const *name; - #if CYTHON_USE_UNICODE_INTERNALS - Py_hash_t key_hash = ((PyASCIIObject*)key)->hash; - if (unlikely(key_hash == -1)) { - key_hash = PyObject_Hash(key); - if (unlikely(key_hash == -1)) - goto bad; - } - #endif - name = first_kw_arg; - while (*name) { - PyObject *name_str = **name; - #if CYTHON_USE_UNICODE_INTERNALS - if (key_hash == ((PyASCIIObject*)name_str)->hash && __Pyx_UnicodeKeywordsEqual(name_str, key)) { - *index_found = (size_t) (name - argnames); - return 1; - } - #else - #if CYTHON_ASSUME_SAFE_SIZE - if (PyUnicode_GET_LENGTH(name_str) == PyUnicode_GET_LENGTH(key)) - #endif - { - int cmp = PyUnicode_Compare(name_str, key); - if (cmp < 0 && unlikely(PyErr_Occurred())) goto bad; - if (cmp == 0) { - *index_found = (size_t) (name - argnames); - return 1; - } - } - #endif - name++; - } - name = argnames; - while (name != first_kw_arg) { - PyObject *name_str = **name; - #if CYTHON_USE_UNICODE_INTERNALS - if (unlikely(key_hash == ((PyASCIIObject*)name_str)->hash)) { - if (__Pyx_UnicodeKeywordsEqual(name_str, key)) - goto arg_passed_twice; - } - #else - #if CYTHON_ASSUME_SAFE_SIZE - if (PyUnicode_GET_LENGTH(name_str) == PyUnicode_GET_LENGTH(key)) - #endif - { - if (unlikely(name_str == key)) goto arg_passed_twice; - int cmp = PyUnicode_Compare(name_str, key); - if (cmp < 0 && unlikely(PyErr_Occurred())) goto bad; - if (cmp == 0) goto arg_passed_twice; - } - #endif - name++; - } - return 0; -arg_passed_twice: - __Pyx_RaiseDoubleKeywordsError(function_name, key); - goto bad; -bad: - return -1; -} -static int __Pyx_MatchKeywordArg_nostr( - PyObject *key, - PyObject ** const argnames[], - PyObject ** const *first_kw_arg, - size_t *index_found, - const char *function_name) -{ - PyObject ** const *name; - if (unlikely(!PyUnicode_Check(key))) goto invalid_keyword_type; - name = first_kw_arg; - while (*name) { - int cmp = PyObject_RichCompareBool(**name, key, Py_EQ); - if (cmp == 1) { - *index_found = (size_t) (name - argnames); - return 1; - } - if (unlikely(cmp == -1)) goto bad; - name++; - } - name = argnames; - while (name != first_kw_arg) { - int cmp = PyObject_RichCompareBool(**name, key, Py_EQ); - if (unlikely(cmp != 0)) { - if (cmp == 1) goto arg_passed_twice; - else goto bad; - } - name++; - } - return 0; -arg_passed_twice: - __Pyx_RaiseDoubleKeywordsError(function_name, key); - goto bad; -invalid_keyword_type: - PyErr_Format(PyExc_TypeError, - "%.200s() keywords must be strings", function_name); - goto bad; -bad: - return -1; -} -static CYTHON_INLINE int __Pyx_MatchKeywordArg( - PyObject *key, - PyObject ** const argnames[], - PyObject ** const *first_kw_arg, - size_t *index_found, - const char *function_name) -{ - return likely(PyUnicode_CheckExact(key)) ? - __Pyx_MatchKeywordArg_str(key, argnames, first_kw_arg, index_found, function_name) : - __Pyx_MatchKeywordArg_nostr(key, argnames, first_kw_arg, index_found, function_name); -} -static void __Pyx_RejectUnknownKeyword( - PyObject *kwds, - PyObject ** const argnames[], - PyObject ** const *first_kw_arg, - const char *function_name) -{ - Py_ssize_t pos = 0; - PyObject *key = NULL; - __Pyx_BEGIN_CRITICAL_SECTION(kwds); - while (PyDict_Next(kwds, &pos, &key, NULL)) { - PyObject** const *name = first_kw_arg; - while (*name && (**name != key)) name++; - if (!*name) { - #if CYTHON_AVOID_BORROWED_REFS - Py_INCREF(key); - #endif - size_t index_found = 0; - int cmp = __Pyx_MatchKeywordArg(key, argnames, first_kw_arg, &index_found, function_name); - if (cmp != 1) { - if (cmp == 0) { - PyErr_Format(PyExc_TypeError, - "%s() got an unexpected keyword argument '%U'", - function_name, key); - } - #if CYTHON_AVOID_BORROWED_REFS - Py_DECREF(key); - #endif - break; - } - #if CYTHON_AVOID_BORROWED_REFS - Py_DECREF(key); - #endif - } - } - __Pyx_END_CRITICAL_SECTION(); - assert(PyErr_Occurred()); -} -static int __Pyx_ParseKeywordDict( - PyObject *kwds, - PyObject ** const argnames[], - PyObject *values[], - Py_ssize_t num_pos_args, - Py_ssize_t num_kwargs, - const char* function_name, - int ignore_unknown_kwargs) -{ - PyObject** const *name; - PyObject** const *first_kw_arg = argnames + num_pos_args; - Py_ssize_t extracted = 0; - if (unlikely(!PyArg_ValidateKeywordArguments(kwds))) return -1; - name = first_kw_arg; - while (*name && num_kwargs > extracted) { - PyObject * key = **name; - PyObject *value; - int found = 0; - #if __PYX_LIMITED_VERSION_HEX >= 0x030d0000 - found = PyDict_GetItemRef(kwds, key, &value); - #else - value = PyDict_GetItemWithError(kwds, key); - if (value) { - Py_INCREF(value); - found = 1; - } else { - if (unlikely(PyErr_Occurred())) goto bad; - } - #endif - if (found) { - if (unlikely(found < 0)) goto bad; - values[name-argnames] = value; - extracted++; - } - name++; - } - if (num_kwargs > extracted) { - if (ignore_unknown_kwargs) { - if (unlikely(__Pyx_ValidateDuplicatePosArgs(kwds, argnames, first_kw_arg, function_name) == -1)) - goto bad; - } else { - __Pyx_RejectUnknownKeyword(kwds, argnames, first_kw_arg, function_name); - goto bad; - } - } - return 0; -bad: - return -1; -} -static int __Pyx_ParseKeywordDictToDict( - PyObject *kwds, - PyObject ** const argnames[], - PyObject *kwds2, - PyObject *values[], - Py_ssize_t num_pos_args, - const char* function_name) -{ - PyObject** const *name; - PyObject** const *first_kw_arg = argnames + num_pos_args; - Py_ssize_t len; - if (unlikely(!PyArg_ValidateKeywordArguments(kwds))) return -1; - if (PyDict_Update(kwds2, kwds) < 0) goto bad; - name = first_kw_arg; - while (*name) { - PyObject *key = **name; - PyObject *value; -#if !CYTHON_COMPILING_IN_LIMITED_API && (PY_VERSION_HEX >= 0x030d00A2 || defined(PyDict_Pop)) - int found = PyDict_Pop(kwds2, key, &value); - if (found) { - if (unlikely(found < 0)) goto bad; - values[name-argnames] = value; - } -#elif __PYX_LIMITED_VERSION_HEX >= 0x030d0000 - int found = PyDict_GetItemRef(kwds2, key, &value); - if (found) { - if (unlikely(found < 0)) goto bad; - values[name-argnames] = value; - if (unlikely(PyDict_DelItem(kwds2, key) < 0)) goto bad; - } -#else - #if CYTHON_COMPILING_IN_CPYTHON - value = _PyDict_Pop(kwds2, key, kwds2); - #else - value = __Pyx_CallUnboundCMethod2(&__pyx_mstate_global->__pyx_umethod_PyDict_Type_pop, kwds2, key, kwds2); - #endif - if (value == kwds2) { - Py_DECREF(value); - } else { - if (unlikely(!value)) goto bad; - values[name-argnames] = value; - } -#endif - name++; - } - len = PyDict_Size(kwds2); - if (len > 0) { - return __Pyx_ValidateDuplicatePosArgs(kwds, argnames, first_kw_arg, function_name); - } else if (unlikely(len == -1)) { - goto bad; - } - return 0; -bad: - return -1; -} -static int __Pyx_ParseKeywordsTuple( - PyObject *kwds, - PyObject * const *kwvalues, - PyObject ** const argnames[], - PyObject *kwds2, - PyObject *values[], - Py_ssize_t num_pos_args, - Py_ssize_t num_kwargs, - const char* function_name, - int ignore_unknown_kwargs) -{ - PyObject *key = NULL; - PyObject** const * name; - PyObject** const *first_kw_arg = argnames + num_pos_args; - for (Py_ssize_t pos = 0; pos < num_kwargs; pos++) { -#if CYTHON_AVOID_BORROWED_REFS - key = __Pyx_PySequence_ITEM(kwds, pos); -#else - key = __Pyx_PyTuple_GET_ITEM(kwds, pos); -#endif -#if !CYTHON_ASSUME_SAFE_MACROS - if (unlikely(!key)) goto bad; -#endif - name = first_kw_arg; - while (*name && (**name != key)) name++; - if (*name) { - PyObject *value = kwvalues[pos]; - values[name-argnames] = __Pyx_NewRef(value); - } else { - size_t index_found = 0; - int cmp = __Pyx_MatchKeywordArg(key, argnames, first_kw_arg, &index_found, function_name); - if (cmp == 1) { - PyObject *value = kwvalues[pos]; - values[index_found] = __Pyx_NewRef(value); - } else { - if (unlikely(cmp == -1)) goto bad; - if (kwds2) { - PyObject *value = kwvalues[pos]; - if (unlikely(PyDict_SetItem(kwds2, key, value))) goto bad; - } else if (!ignore_unknown_kwargs) { - goto invalid_keyword; - } - } - } - #if CYTHON_AVOID_BORROWED_REFS - Py_DECREF(key); - key = NULL; - #endif - } - return 0; -invalid_keyword: - PyErr_Format(PyExc_TypeError, - "%s() got an unexpected keyword argument '%U'", - function_name, key); - goto bad; -bad: - #if CYTHON_AVOID_BORROWED_REFS - Py_XDECREF(key); - #endif - return -1; -} -static int __Pyx_ParseKeywords( - PyObject *kwds, - PyObject * const *kwvalues, - PyObject ** const argnames[], - PyObject *kwds2, - PyObject *values[], - Py_ssize_t num_pos_args, - Py_ssize_t num_kwargs, - const char* function_name, - int ignore_unknown_kwargs) -{ - if (CYTHON_METH_FASTCALL && likely(PyTuple_Check(kwds))) - return __Pyx_ParseKeywordsTuple(kwds, kwvalues, argnames, kwds2, values, num_pos_args, num_kwargs, function_name, ignore_unknown_kwargs); - else if (kwds2) - return __Pyx_ParseKeywordDictToDict(kwds, argnames, kwds2, values, num_pos_args, function_name); - else - return __Pyx_ParseKeywordDict(kwds, argnames, values, num_pos_args, num_kwargs, function_name, ignore_unknown_kwargs); -} - -/* RaiseArgTupleInvalid */ -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, - "%.200s() takes %.8s %" CYTHON_FORMAT_SSIZE_T "d positional argument%.1s (%" CYTHON_FORMAT_SSIZE_T "d given)", - func_name, more_or_less, num_expected, - (num_expected == 1) ? "" : "s", num_found); -} - -/* ArgTypeTest */ -static int __Pyx__ArgTypeTest(PyObject *obj, PyTypeObject *type, const char *name, int exact) -{ - __Pyx_TypeName type_name; - __Pyx_TypeName obj_type_name; - PyObject *extra_info = __pyx_mstate_global->__pyx_empty_unicode; - int from_annotation_subclass = 0; - if (unlikely(!type)) { - PyErr_SetString(PyExc_SystemError, "Missing type object"); - return 0; - } - else if (!exact) { - if (likely(__Pyx_TypeCheck(obj, type))) return 1; - } else if (exact == 2) { - if (__Pyx_TypeCheck(obj, type)) { - from_annotation_subclass = 1; - extra_info = __pyx_mstate_global->__pyx_kp_u_Note_that_Cython_is_deliberately; - } - } - type_name = __Pyx_PyType_GetFullyQualifiedName(type); - obj_type_name = __Pyx_PyType_GetFullyQualifiedName(Py_TYPE(obj)); - PyErr_Format(PyExc_TypeError, - "Argument '%.200s' has incorrect type (expected " __Pyx_FMT_TYPENAME - ", got " __Pyx_FMT_TYPENAME ")" -#if __PYX_LIMITED_VERSION_HEX < 0x030C0000 - "%s%U" -#endif - , name, type_name, obj_type_name -#if __PYX_LIMITED_VERSION_HEX < 0x030C0000 - , (from_annotation_subclass ? ". " : ""), extra_info -#endif - ); -#if __PYX_LIMITED_VERSION_HEX >= 0x030C0000 - if (exact == 2 && from_annotation_subclass) { - PyObject *res; - PyObject *vargs[2]; - vargs[0] = PyErr_GetRaisedException(); - vargs[1] = extra_info; - res = PyObject_VectorcallMethod(__pyx_mstate_global->__pyx_kp_u_add_note, vargs, 2, NULL); - Py_XDECREF(res); - PyErr_SetRaisedException(vargs[0]); - } -#endif - __Pyx_DECREF_TypeName(type_name); - __Pyx_DECREF_TypeName(obj_type_name); - return 0; -} - -/* PyObjectSetAttrStr */ -#if CYTHON_USE_TYPE_SLOTS -static CYTHON_INLINE int __Pyx_PyObject_SetAttrStr(PyObject* obj, PyObject* attr_name, PyObject* value) { - PyTypeObject* tp = Py_TYPE(obj); - if (likely(tp->tp_setattro)) - return tp->tp_setattro(obj, attr_name, value); - return PyObject_SetAttr(obj, attr_name, value); -} -#endif - -/* PyObjectFastCallMethod */ -#if !CYTHON_VECTORCALL || PY_VERSION_HEX < 0x03090000 -static PyObject *__Pyx_PyObject_FastCallMethod(PyObject *name, PyObject *const *args, size_t nargsf) { - PyObject *result; - PyObject *attr = PyObject_GetAttr(args[0], name); - if (unlikely(!attr)) - return NULL; - result = __Pyx_PyObject_FastCall(attr, args+1, nargsf - 1); - Py_DECREF(attr); - return result; -} -#endif - -/* PyLongCompare */ -static CYTHON_INLINE int __Pyx_PyLong_BoolNeObjC(PyObject *op1, PyObject *op2, long intval, long inplace) { - CYTHON_MAYBE_UNUSED_VAR(intval); - CYTHON_UNUSED_VAR(inplace); - if (op1 == op2) { - return 0; - } - #if CYTHON_USE_PYLONG_INTERNALS - if (likely(PyLong_CheckExact(op1))) { - int unequal; - unsigned long uintval; - Py_ssize_t size = __Pyx_PyLong_DigitCount(op1); - const digit* digits = __Pyx_PyLong_Digits(op1); - if (intval == 0) { - return (__Pyx_PyLong_IsZero(op1) != 1); - } else if (intval < 0) { - if (__Pyx_PyLong_IsNonNeg(op1)) - return 1; - intval = -intval; - } else { - if (__Pyx_PyLong_IsNeg(op1)) - return 1; - } - uintval = (unsigned long) intval; -#if PyLong_SHIFT * 4 < SIZEOF_LONG*8 - if (uintval >> (PyLong_SHIFT * 4)) { - unequal = (size != 5) || (digits[0] != (uintval & (unsigned long) PyLong_MASK)) - | (digits[1] != ((uintval >> (1 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)) | (digits[2] != ((uintval >> (2 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)) | (digits[3] != ((uintval >> (3 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)) | (digits[4] != ((uintval >> (4 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)); - } else -#endif -#if PyLong_SHIFT * 3 < SIZEOF_LONG*8 - if (uintval >> (PyLong_SHIFT * 3)) { - unequal = (size != 4) || (digits[0] != (uintval & (unsigned long) PyLong_MASK)) - | (digits[1] != ((uintval >> (1 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)) | (digits[2] != ((uintval >> (2 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)) | (digits[3] != ((uintval >> (3 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)); - } else -#endif -#if PyLong_SHIFT * 2 < SIZEOF_LONG*8 - if (uintval >> (PyLong_SHIFT * 2)) { - unequal = (size != 3) || (digits[0] != (uintval & (unsigned long) PyLong_MASK)) - | (digits[1] != ((uintval >> (1 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)) | (digits[2] != ((uintval >> (2 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)); - } else -#endif -#if PyLong_SHIFT * 1 < SIZEOF_LONG*8 - if (uintval >> (PyLong_SHIFT * 1)) { - unequal = (size != 2) || (digits[0] != (uintval & (unsigned long) PyLong_MASK)) - | (digits[1] != ((uintval >> (1 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)); - } else -#endif - unequal = (size != 1) || (((unsigned long) digits[0]) != (uintval & (unsigned long) PyLong_MASK)); - return (unequal != 0); - } - #endif - if (PyFloat_CheckExact(op1)) { - const long b = intval; - double a = __Pyx_PyFloat_AS_DOUBLE(op1); - return ((double)a != (double)b); - } - return __Pyx_PyObject_IsTrueAndDecref( - PyObject_RichCompare(op1, op2, Py_NE)); -} - -/* PyObjectCallNoArg */ -static CYTHON_INLINE PyObject* __Pyx_PyObject_CallNoArg(PyObject *func) { - PyObject *arg[2] = {NULL, NULL}; - return __Pyx_PyObject_FastCall(func, arg + 1, 0 | __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET); -} - -/* RaiseUnexpectedTypeError */ -static int -__Pyx_RaiseUnexpectedTypeError(const char *expected, PyObject *obj) -{ - __Pyx_TypeName obj_type_name = __Pyx_PyType_GetFullyQualifiedName(Py_TYPE(obj)); - PyErr_Format(PyExc_TypeError, "Expected %s, got " __Pyx_FMT_TYPENAME, - expected, obj_type_name); - __Pyx_DECREF_TypeName(obj_type_name); - return 0; -} - -/* PyLongCompare */ -static CYTHON_INLINE int __Pyx_PyLong_BoolEqObjC(PyObject *op1, PyObject *op2, long intval, long inplace) { - CYTHON_MAYBE_UNUSED_VAR(intval); - CYTHON_UNUSED_VAR(inplace); - if (op1 == op2) { - return 1; - } - #if CYTHON_USE_PYLONG_INTERNALS - if (likely(PyLong_CheckExact(op1))) { - int unequal; - unsigned long uintval; - Py_ssize_t size = __Pyx_PyLong_DigitCount(op1); - const digit* digits = __Pyx_PyLong_Digits(op1); - if (intval == 0) { - return (__Pyx_PyLong_IsZero(op1) == 1); - } else if (intval < 0) { - if (__Pyx_PyLong_IsNonNeg(op1)) - return 0; - intval = -intval; - } else { - if (__Pyx_PyLong_IsNeg(op1)) - return 0; - } - uintval = (unsigned long) intval; -#if PyLong_SHIFT * 4 < SIZEOF_LONG*8 - if (uintval >> (PyLong_SHIFT * 4)) { - unequal = (size != 5) || (digits[0] != (uintval & (unsigned long) PyLong_MASK)) - | (digits[1] != ((uintval >> (1 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)) | (digits[2] != ((uintval >> (2 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)) | (digits[3] != ((uintval >> (3 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)) | (digits[4] != ((uintval >> (4 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)); - } else -#endif -#if PyLong_SHIFT * 3 < SIZEOF_LONG*8 - if (uintval >> (PyLong_SHIFT * 3)) { - unequal = (size != 4) || (digits[0] != (uintval & (unsigned long) PyLong_MASK)) - | (digits[1] != ((uintval >> (1 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)) | (digits[2] != ((uintval >> (2 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)) | (digits[3] != ((uintval >> (3 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)); - } else -#endif -#if PyLong_SHIFT * 2 < SIZEOF_LONG*8 - if (uintval >> (PyLong_SHIFT * 2)) { - unequal = (size != 3) || (digits[0] != (uintval & (unsigned long) PyLong_MASK)) - | (digits[1] != ((uintval >> (1 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)) | (digits[2] != ((uintval >> (2 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)); - } else -#endif -#if PyLong_SHIFT * 1 < SIZEOF_LONG*8 - if (uintval >> (PyLong_SHIFT * 1)) { - unequal = (size != 2) || (digits[0] != (uintval & (unsigned long) PyLong_MASK)) - | (digits[1] != ((uintval >> (1 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)); - } else -#endif - unequal = (size != 1) || (((unsigned long) digits[0]) != (uintval & (unsigned long) PyLong_MASK)); - return (unequal == 0); - } - #endif - if (PyFloat_CheckExact(op1)) { - const long b = intval; - double a = __Pyx_PyFloat_AS_DOUBLE(op1); - return ((double)a == (double)b); - } - return __Pyx_PyObject_IsTrueAndDecref( - PyObject_RichCompare(op1, op2, Py_EQ)); -} - -/* GetItemInt */ -static PyObject *__Pyx_GetItemInt_Generic(PyObject *o, PyObject* j) { - PyObject *r; - if (unlikely(!j)) return NULL; - r = PyObject_GetItem(o, j); - Py_DECREF(j); - return r; -} -static CYTHON_INLINE PyObject *__Pyx_GetItemInt_List_Fast(PyObject *o, Py_ssize_t i, - CYTHON_NCP_UNUSED int wraparound, - CYTHON_NCP_UNUSED int boundscheck) { -#if CYTHON_ASSUME_SAFE_MACROS && CYTHON_ASSUME_SAFE_SIZE && !CYTHON_AVOID_BORROWED_REFS && !CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS - Py_ssize_t wrapped_i = i; - if (wraparound & unlikely(i < 0)) { - wrapped_i += PyList_GET_SIZE(o); - } - if ((!boundscheck) || likely(__Pyx_is_valid_index(wrapped_i, PyList_GET_SIZE(o)))) { - PyObject *r = PyList_GET_ITEM(o, wrapped_i); - Py_INCREF(r); - return r; - } - return __Pyx_GetItemInt_Generic(o, PyLong_FromSsize_t(i)); -#else - return PySequence_GetItem(o, i); -#endif -} -static CYTHON_INLINE PyObject *__Pyx_GetItemInt_Tuple_Fast(PyObject *o, Py_ssize_t i, - CYTHON_NCP_UNUSED int wraparound, - CYTHON_NCP_UNUSED int boundscheck) { -#if CYTHON_ASSUME_SAFE_MACROS && CYTHON_ASSUME_SAFE_SIZE && !CYTHON_AVOID_BORROWED_REFS - Py_ssize_t wrapped_i = i; - if (wraparound & unlikely(i < 0)) { - wrapped_i += PyTuple_GET_SIZE(o); - } - if ((!boundscheck) || likely(__Pyx_is_valid_index(wrapped_i, PyTuple_GET_SIZE(o)))) { - PyObject *r = PyTuple_GET_ITEM(o, wrapped_i); - Py_INCREF(r); - return r; - } - return __Pyx_GetItemInt_Generic(o, PyLong_FromSsize_t(i)); -#else - return PySequence_GetItem(o, i); -#endif -} -static CYTHON_INLINE PyObject *__Pyx_GetItemInt_Fast(PyObject *o, Py_ssize_t i, int is_list, - CYTHON_NCP_UNUSED int wraparound, - CYTHON_NCP_UNUSED int boundscheck) { -#if CYTHON_ASSUME_SAFE_MACROS && CYTHON_ASSUME_SAFE_SIZE && !CYTHON_AVOID_BORROWED_REFS && CYTHON_USE_TYPE_SLOTS - if (is_list || PyList_CheckExact(o)) { - Py_ssize_t n = ((!wraparound) | likely(i >= 0)) ? i : i + PyList_GET_SIZE(o); - if ((!boundscheck) || (likely(__Pyx_is_valid_index(n, PyList_GET_SIZE(o))))) { - return __Pyx_PyList_GetItemRef(o, n); - } - } - else if (PyTuple_CheckExact(o)) { - Py_ssize_t n = ((!wraparound) | likely(i >= 0)) ? i : i + PyTuple_GET_SIZE(o); - if ((!boundscheck) || likely(__Pyx_is_valid_index(n, PyTuple_GET_SIZE(o)))) { - PyObject *r = PyTuple_GET_ITEM(o, n); - Py_INCREF(r); - return r; - } - } else { - PyMappingMethods *mm = Py_TYPE(o)->tp_as_mapping; - PySequenceMethods *sm = Py_TYPE(o)->tp_as_sequence; - if (mm && mm->mp_subscript) { - PyObject *r, *key = PyLong_FromSsize_t(i); - if (unlikely(!key)) return NULL; - r = mm->mp_subscript(o, key); - Py_DECREF(key); - return r; - } - if (likely(sm && sm->sq_item)) { - if (wraparound && unlikely(i < 0) && likely(sm->sq_length)) { - Py_ssize_t l = sm->sq_length(o); - if (likely(l >= 0)) { - i += l; - } else { - if (!PyErr_ExceptionMatches(PyExc_OverflowError)) - return NULL; - PyErr_Clear(); - } - } - return sm->sq_item(o, i); - } - } -#else - if (is_list || !PyMapping_Check(o)) { - return PySequence_GetItem(o, i); - } -#endif - return __Pyx_GetItemInt_Generic(o, PyLong_FromSsize_t(i)); -} - -/* PyObjectCallOneArg */ -static CYTHON_INLINE PyObject* __Pyx_PyObject_CallOneArg(PyObject *func, PyObject *arg) { - PyObject *args[2] = {NULL, arg}; - return __Pyx_PyObject_FastCall(func, args+1, 1 | __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET); -} - -/* ObjectGetItem */ -#if CYTHON_USE_TYPE_SLOTS -static PyObject *__Pyx_PyObject_GetIndex(PyObject *obj, PyObject *index) { - PyObject *runerr = NULL; - Py_ssize_t key_value; - key_value = __Pyx_PyIndex_AsSsize_t(index); - if (likely(key_value != -1 || !(runerr = PyErr_Occurred()))) { - return __Pyx_GetItemInt_Fast(obj, key_value, 0, 1, 1); - } - if (PyErr_GivenExceptionMatches(runerr, PyExc_OverflowError)) { - __Pyx_TypeName index_type_name = __Pyx_PyType_GetFullyQualifiedName(Py_TYPE(index)); - PyErr_Clear(); - PyErr_Format(PyExc_IndexError, - "cannot fit '" __Pyx_FMT_TYPENAME "' into an index-sized integer", index_type_name); - __Pyx_DECREF_TypeName(index_type_name); - } - return NULL; -} -static PyObject *__Pyx_PyObject_GetItem_Slow(PyObject *obj, PyObject *key) { - __Pyx_TypeName obj_type_name; - if (likely(PyType_Check(obj))) { - PyObject *meth = __Pyx_PyObject_GetAttrStrNoError(obj, __pyx_mstate_global->__pyx_n_u_class_getitem); - if (!meth) { - PyErr_Clear(); - } else { - PyObject *result = __Pyx_PyObject_CallOneArg(meth, key); - Py_DECREF(meth); - return result; - } - } - obj_type_name = __Pyx_PyType_GetFullyQualifiedName(Py_TYPE(obj)); - PyErr_Format(PyExc_TypeError, - "'" __Pyx_FMT_TYPENAME "' object is not subscriptable", obj_type_name); - __Pyx_DECREF_TypeName(obj_type_name); - return NULL; -} -static PyObject *__Pyx_PyObject_GetItem(PyObject *obj, PyObject *key) { - PyTypeObject *tp = Py_TYPE(obj); - PyMappingMethods *mm = tp->tp_as_mapping; - PySequenceMethods *sm = tp->tp_as_sequence; - if (likely(mm && mm->mp_subscript)) { - return mm->mp_subscript(obj, key); - } - if (likely(sm && sm->sq_item)) { - return __Pyx_PyObject_GetIndex(obj, key); - } - return __Pyx_PyObject_GetItem_Slow(obj, key); -} -#endif - -/* PyLongBinop */ -#if !CYTHON_COMPILING_IN_PYPY -static PyObject* __Pyx_Fallback___Pyx_PyLong_AddObjC(PyObject *op1, PyObject *op2, int inplace) { - return (inplace ? PyNumber_InPlaceAdd : PyNumber_Add)(op1, op2); -} -#if CYTHON_USE_PYLONG_INTERNALS -static PyObject* __Pyx_Unpacked___Pyx_PyLong_AddObjC(PyObject *op1, PyObject *op2, long intval, int inplace, int zerodivision_check) { - CYTHON_MAYBE_UNUSED_VAR(inplace); - CYTHON_UNUSED_VAR(zerodivision_check); - const long b = intval; - long a, x; -#ifdef HAVE_LONG_LONG - const PY_LONG_LONG llb = intval; - PY_LONG_LONG lla, llx; -#endif - if (unlikely(__Pyx_PyLong_IsZero(op1))) { - return __Pyx_NewRef(op2); - } - if (likely(__Pyx_PyLong_IsCompact(op1))) { - a = __Pyx_PyLong_CompactValue(op1); - } else { - const digit* digits = __Pyx_PyLong_Digits(op1); - const Py_ssize_t size = __Pyx_PyLong_SignedDigitCount(op1); - switch (size) { - case -2: - if (8 * sizeof(long) - 1 > 2 * PyLong_SHIFT) { - a = -(long) (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])); - break; - #ifdef HAVE_LONG_LONG - } else if (8 * sizeof(PY_LONG_LONG) - 1 > 2 * PyLong_SHIFT) { - lla = -(PY_LONG_LONG) (((((unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0])); - goto long_long; - #endif - } - CYTHON_FALLTHROUGH; - case 2: - if (8 * sizeof(long) - 1 > 2 * PyLong_SHIFT) { - a = (long) (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])); - break; - #ifdef HAVE_LONG_LONG - } else if (8 * sizeof(PY_LONG_LONG) - 1 > 2 * PyLong_SHIFT) { - lla = (PY_LONG_LONG) (((((unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0])); - goto long_long; - #endif - } - CYTHON_FALLTHROUGH; - case -3: - if (8 * sizeof(long) - 1 > 3 * PyLong_SHIFT) { - a = -(long) (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])); - break; - #ifdef HAVE_LONG_LONG - } else if (8 * sizeof(PY_LONG_LONG) - 1 > 3 * PyLong_SHIFT) { - lla = -(PY_LONG_LONG) (((((((unsigned PY_LONG_LONG)digits[2]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0])); - goto long_long; - #endif - } - CYTHON_FALLTHROUGH; - case 3: - if (8 * sizeof(long) - 1 > 3 * PyLong_SHIFT) { - a = (long) (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])); - break; - #ifdef HAVE_LONG_LONG - } else if (8 * sizeof(PY_LONG_LONG) - 1 > 3 * PyLong_SHIFT) { - lla = (PY_LONG_LONG) (((((((unsigned PY_LONG_LONG)digits[2]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0])); - goto long_long; - #endif - } - CYTHON_FALLTHROUGH; - case -4: - if (8 * sizeof(long) - 1 > 4 * PyLong_SHIFT) { - a = -(long) (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])); - break; - #ifdef HAVE_LONG_LONG - } else if (8 * sizeof(PY_LONG_LONG) - 1 > 4 * PyLong_SHIFT) { - lla = -(PY_LONG_LONG) (((((((((unsigned PY_LONG_LONG)digits[3]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[2]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0])); - goto long_long; - #endif - } - CYTHON_FALLTHROUGH; - case 4: - if (8 * sizeof(long) - 1 > 4 * PyLong_SHIFT) { - a = (long) (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])); - break; - #ifdef HAVE_LONG_LONG - } else if (8 * sizeof(PY_LONG_LONG) - 1 > 4 * PyLong_SHIFT) { - lla = (PY_LONG_LONG) (((((((((unsigned PY_LONG_LONG)digits[3]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[2]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0])); - goto long_long; - #endif - } - CYTHON_FALLTHROUGH; - default: return PyLong_Type.tp_as_number->nb_add(op1, op2); - } - } - x = a + b; - return PyLong_FromLong(x); -#ifdef HAVE_LONG_LONG - long_long: - llx = lla + llb; - return PyLong_FromLongLong(llx); -#endif - return __Pyx_Fallback___Pyx_PyLong_AddObjC(op1, op2, inplace); - - -} -#endif -static PyObject* __Pyx_Float___Pyx_PyLong_AddObjC(PyObject *float_val, long intval, int zerodivision_check) { - CYTHON_UNUSED_VAR(zerodivision_check); - const long b = intval; - double a = __Pyx_PyFloat_AS_DOUBLE(float_val); - double result; - - result = ((double)a) + (double)b; - return PyFloat_FromDouble(result); -} -static CYTHON_INLINE PyObject* __Pyx_PyLong_AddObjC(PyObject *op1, PyObject *op2, long intval, int inplace, int zerodivision_check) { - CYTHON_MAYBE_UNUSED_VAR(intval); - CYTHON_UNUSED_VAR(zerodivision_check); - #if CYTHON_USE_PYLONG_INTERNALS - if (likely(PyLong_CheckExact(op1))) { - return __Pyx_Unpacked___Pyx_PyLong_AddObjC(op1, op2, intval, inplace, zerodivision_check); - } - #endif - if (PyFloat_CheckExact(op1)) { - return __Pyx_Float___Pyx_PyLong_AddObjC(op1, intval, zerodivision_check); - } - return __Pyx_Fallback___Pyx_PyLong_AddObjC(op1, op2, inplace); -} -#endif - -/* DictGetItem */ -#if !CYTHON_COMPILING_IN_PYPY -static PyObject *__Pyx_PyDict_GetItem(PyObject *d, PyObject* key) { - PyObject *value; - if (unlikely(__Pyx_PyDict_GetItemRef(d, key, &value) == 0)) { // no value, no error - if (unlikely(PyTuple_Check(key))) { - PyObject* args = PyTuple_Pack(1, key); - if (likely(args)) { - PyErr_SetObject(PyExc_KeyError, args); - Py_DECREF(args); - } - } else { - PyErr_SetObject(PyExc_KeyError, key); - } - } - return value; -} -#endif - -/* PyLongBinop */ -#if !CYTHON_COMPILING_IN_PYPY -static PyObject* __Pyx_Fallback___Pyx_PyLong_SubtractObjC(PyObject *op1, PyObject *op2, int inplace) { - return (inplace ? PyNumber_InPlaceSubtract : PyNumber_Subtract)(op1, op2); -} -#if CYTHON_USE_PYLONG_INTERNALS -static PyObject* __Pyx_Unpacked___Pyx_PyLong_SubtractObjC(PyObject *op1, PyObject *op2, long intval, int inplace, int zerodivision_check) { - CYTHON_MAYBE_UNUSED_VAR(inplace); - CYTHON_UNUSED_VAR(zerodivision_check); - const long b = intval; - long a, x; -#ifdef HAVE_LONG_LONG - const PY_LONG_LONG llb = intval; - PY_LONG_LONG lla, llx; -#endif - if (unlikely(__Pyx_PyLong_IsZero(op1))) { - return PyLong_FromLong(-intval); - } - if (likely(__Pyx_PyLong_IsCompact(op1))) { - a = __Pyx_PyLong_CompactValue(op1); - } else { - const digit* digits = __Pyx_PyLong_Digits(op1); - const Py_ssize_t size = __Pyx_PyLong_SignedDigitCount(op1); - switch (size) { - case -2: - if (8 * sizeof(long) - 1 > 2 * PyLong_SHIFT) { - a = -(long) (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])); - break; - #ifdef HAVE_LONG_LONG - } else if (8 * sizeof(PY_LONG_LONG) - 1 > 2 * PyLong_SHIFT) { - lla = -(PY_LONG_LONG) (((((unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0])); - goto long_long; - #endif - } - CYTHON_FALLTHROUGH; - case 2: - if (8 * sizeof(long) - 1 > 2 * PyLong_SHIFT) { - a = (long) (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])); - break; - #ifdef HAVE_LONG_LONG - } else if (8 * sizeof(PY_LONG_LONG) - 1 > 2 * PyLong_SHIFT) { - lla = (PY_LONG_LONG) (((((unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0])); - goto long_long; - #endif - } - CYTHON_FALLTHROUGH; - case -3: - if (8 * sizeof(long) - 1 > 3 * PyLong_SHIFT) { - a = -(long) (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])); - break; - #ifdef HAVE_LONG_LONG - } else if (8 * sizeof(PY_LONG_LONG) - 1 > 3 * PyLong_SHIFT) { - lla = -(PY_LONG_LONG) (((((((unsigned PY_LONG_LONG)digits[2]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0])); - goto long_long; - #endif - } - CYTHON_FALLTHROUGH; - case 3: - if (8 * sizeof(long) - 1 > 3 * PyLong_SHIFT) { - a = (long) (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])); - break; - #ifdef HAVE_LONG_LONG - } else if (8 * sizeof(PY_LONG_LONG) - 1 > 3 * PyLong_SHIFT) { - lla = (PY_LONG_LONG) (((((((unsigned PY_LONG_LONG)digits[2]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0])); - goto long_long; - #endif - } - CYTHON_FALLTHROUGH; - case -4: - if (8 * sizeof(long) - 1 > 4 * PyLong_SHIFT) { - a = -(long) (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])); - break; - #ifdef HAVE_LONG_LONG - } else if (8 * sizeof(PY_LONG_LONG) - 1 > 4 * PyLong_SHIFT) { - lla = -(PY_LONG_LONG) (((((((((unsigned PY_LONG_LONG)digits[3]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[2]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0])); - goto long_long; - #endif - } - CYTHON_FALLTHROUGH; - case 4: - if (8 * sizeof(long) - 1 > 4 * PyLong_SHIFT) { - a = (long) (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])); - break; - #ifdef HAVE_LONG_LONG - } else if (8 * sizeof(PY_LONG_LONG) - 1 > 4 * PyLong_SHIFT) { - lla = (PY_LONG_LONG) (((((((((unsigned PY_LONG_LONG)digits[3]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[2]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0])); - goto long_long; - #endif - } - CYTHON_FALLTHROUGH; - default: return PyLong_Type.tp_as_number->nb_subtract(op1, op2); - } - } - x = a - b; - return PyLong_FromLong(x); -#ifdef HAVE_LONG_LONG - long_long: - llx = lla - llb; - return PyLong_FromLongLong(llx); -#endif - return __Pyx_Fallback___Pyx_PyLong_SubtractObjC(op1, op2, inplace); - - -} -#endif -static PyObject* __Pyx_Float___Pyx_PyLong_SubtractObjC(PyObject *float_val, long intval, int zerodivision_check) { - CYTHON_UNUSED_VAR(zerodivision_check); - const long b = intval; - double a = __Pyx_PyFloat_AS_DOUBLE(float_val); - double result; - - result = ((double)a) - (double)b; - return PyFloat_FromDouble(result); -} -static CYTHON_INLINE PyObject* __Pyx_PyLong_SubtractObjC(PyObject *op1, PyObject *op2, long intval, int inplace, int zerodivision_check) { - CYTHON_MAYBE_UNUSED_VAR(intval); - CYTHON_UNUSED_VAR(zerodivision_check); - #if CYTHON_USE_PYLONG_INTERNALS - if (likely(PyLong_CheckExact(op1))) { - return __Pyx_Unpacked___Pyx_PyLong_SubtractObjC(op1, op2, intval, inplace, zerodivision_check); - } - #endif - if (PyFloat_CheckExact(op1)) { - return __Pyx_Float___Pyx_PyLong_SubtractObjC(op1, intval, zerodivision_check); - } - return __Pyx_Fallback___Pyx_PyLong_SubtractObjC(op1, op2, inplace); -} -#endif - -/* PyObjectCall2Args */ -static CYTHON_INLINE PyObject* __Pyx_PyObject_Call2Args(PyObject* function, PyObject* arg1, PyObject* arg2) { - PyObject *args[3] = {NULL, arg1, arg2}; - return __Pyx_PyObject_FastCall(function, args+1, 2 | __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET); -} - -/* PyObjectGetMethod */ -static int __Pyx_PyObject_GetMethod(PyObject *obj, PyObject *name, PyObject **method) { - PyObject *attr; -#if CYTHON_UNPACK_METHODS && CYTHON_COMPILING_IN_CPYTHON && CYTHON_USE_PYTYPE_LOOKUP - __Pyx_TypeName type_name; - PyTypeObject *tp = Py_TYPE(obj); - PyObject *descr; - descrgetfunc f = NULL; - PyObject **dictptr, *dict; - int meth_found = 0; - assert (*method == NULL); - if (unlikely(tp->tp_getattro != PyObject_GenericGetAttr)) { - attr = __Pyx_PyObject_GetAttrStr(obj, name); - goto try_unpack; - } - if (unlikely(tp->tp_dict == NULL) && unlikely(PyType_Ready(tp) < 0)) { - return 0; - } - descr = _PyType_Lookup(tp, name); - if (likely(descr != NULL)) { - Py_INCREF(descr); -#if defined(Py_TPFLAGS_METHOD_DESCRIPTOR) && Py_TPFLAGS_METHOD_DESCRIPTOR - if (__Pyx_PyType_HasFeature(Py_TYPE(descr), Py_TPFLAGS_METHOD_DESCRIPTOR)) -#else - #ifdef __Pyx_CyFunction_USED - if (likely(PyFunction_Check(descr) || __Pyx_IS_TYPE(descr, &PyMethodDescr_Type) || __Pyx_CyFunction_Check(descr))) - #else - if (likely(PyFunction_Check(descr) || __Pyx_IS_TYPE(descr, &PyMethodDescr_Type))) - #endif -#endif - { - meth_found = 1; - } else { - f = Py_TYPE(descr)->tp_descr_get; - if (f != NULL && PyDescr_IsData(descr)) { - attr = f(descr, obj, (PyObject *)Py_TYPE(obj)); - Py_DECREF(descr); - goto try_unpack; - } - } - } - dictptr = _PyObject_GetDictPtr(obj); - if (dictptr != NULL && (dict = *dictptr) != NULL) { - Py_INCREF(dict); - attr = __Pyx_PyDict_GetItemStr(dict, name); - if (attr != NULL) { - Py_INCREF(attr); - Py_DECREF(dict); - Py_XDECREF(descr); - goto try_unpack; - } - Py_DECREF(dict); - } - if (meth_found) { - *method = descr; - return 1; - } - if (f != NULL) { - attr = f(descr, obj, (PyObject *)Py_TYPE(obj)); - Py_DECREF(descr); - goto try_unpack; - } - if (likely(descr != NULL)) { - *method = descr; - return 0; - } - type_name = __Pyx_PyType_GetFullyQualifiedName(tp); - PyErr_Format(PyExc_AttributeError, - "'" __Pyx_FMT_TYPENAME "' object has no attribute '%U'", - type_name, name); - __Pyx_DECREF_TypeName(type_name); - return 0; -#else - attr = __Pyx_PyObject_GetAttrStr(obj, name); - goto try_unpack; -#endif -try_unpack: -#if CYTHON_UNPACK_METHODS - if (likely(attr) && PyMethod_Check(attr) && likely(PyMethod_GET_SELF(attr) == obj)) { - PyObject *function = PyMethod_GET_FUNCTION(attr); - Py_INCREF(function); - Py_DECREF(attr); - *method = function; - return 1; - } -#endif - *method = attr; - return 0; -} - -/* PyObjectCallMethod1 */ -#if !(CYTHON_VECTORCALL && __PYX_LIMITED_VERSION_HEX >= 0x030C0000) -static PyObject* __Pyx__PyObject_CallMethod1(PyObject* method, PyObject* arg) { - PyObject *result = __Pyx_PyObject_CallOneArg(method, arg); - Py_DECREF(method); - return result; -} -#endif -static PyObject* __Pyx_PyObject_CallMethod1(PyObject* obj, PyObject* method_name, PyObject* arg) { -#if CYTHON_VECTORCALL && __PYX_LIMITED_VERSION_HEX >= 0x030C0000 - PyObject *args[2] = {obj, arg}; - (void) __Pyx_PyObject_GetMethod; - (void) __Pyx_PyObject_CallOneArg; - (void) __Pyx_PyObject_Call2Args; - return PyObject_VectorcallMethod(method_name, args, 2 | PY_VECTORCALL_ARGUMENTS_OFFSET, NULL); -#else - PyObject *method = NULL, *result; - int is_method = __Pyx_PyObject_GetMethod(obj, method_name, &method); - if (likely(is_method)) { - result = __Pyx_PyObject_Call2Args(method, obj, arg); - Py_DECREF(method); - return result; - } - if (unlikely(!method)) return NULL; - return __Pyx__PyObject_CallMethod1(method, arg); -#endif -} - -/* append */ -static CYTHON_INLINE int __Pyx_PyObject_Append(PyObject* L, PyObject* x) { - if (likely(PyList_CheckExact(L))) { - if (unlikely(__Pyx_PyList_Append(L, x) < 0)) return -1; - } else { - PyObject* retval = __Pyx_PyObject_CallMethod1(L, __pyx_mstate_global->__pyx_n_u_append, x); - if (unlikely(!retval)) - return -1; - Py_DECREF(retval); - } - return 0; -} - -/* PyFloatBinop */ -#if !CYTHON_COMPILING_IN_PYPY -static int __Pyx_PyFloat_BoolEqObjC(PyObject *op1, PyObject *op2, double floatval, int inplace, int zerodivision_check) { - const double b = floatval; - double a; - CYTHON_UNUSED_VAR(inplace); - CYTHON_UNUSED_VAR(zerodivision_check); - if (op1 == op2) { - return 1; - } - if (likely(PyFloat_CheckExact(op1))) { - a = __Pyx_PyFloat_AS_DOUBLE(op1); - - } else - if (likely(PyLong_CheckExact(op1))) { - #if CYTHON_USE_PYLONG_INTERNALS - if (__Pyx_PyLong_IsZero(op1)) { - a = 0.0; - - } else if (__Pyx_PyLong_IsCompact(op1)) { - a = (double) __Pyx_PyLong_CompactValue(op1); - } else { - const digit* digits = __Pyx_PyLong_Digits(op1); - const Py_ssize_t size = __Pyx_PyLong_SignedDigitCount(op1); - switch (size) { - case -2: - case 2: - if (8 * sizeof(unsigned long) > 2 * PyLong_SHIFT && ((8 * sizeof(unsigned long) < 53) || (1 * PyLong_SHIFT < 53))) { - a = (double) (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])); - if ((8 * sizeof(unsigned long) < 53) || (2 * PyLong_SHIFT < 53) || (a < (double) ((PY_LONG_LONG)1 << 53))) { - if (size == -2) - a = -a; - break; - } - } - CYTHON_FALLTHROUGH; - case -3: - case 3: - if (8 * sizeof(unsigned long) > 3 * PyLong_SHIFT && ((8 * sizeof(unsigned long) < 53) || (2 * PyLong_SHIFT < 53))) { - a = (double) (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])); - if ((8 * sizeof(unsigned long) < 53) || (3 * PyLong_SHIFT < 53) || (a < (double) ((PY_LONG_LONG)1 << 53))) { - if (size == -3) - a = -a; - break; - } - } - CYTHON_FALLTHROUGH; - case -4: - case 4: - if (8 * sizeof(unsigned long) > 4 * PyLong_SHIFT && ((8 * sizeof(unsigned long) < 53) || (3 * PyLong_SHIFT < 53))) { - a = (double) (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])); - if ((8 * sizeof(unsigned long) < 53) || (4 * PyLong_SHIFT < 53) || (a < (double) ((PY_LONG_LONG)1 << 53))) { - if (size == -4) - a = -a; - break; - } - } - CYTHON_FALLTHROUGH; - default: - #endif - { - PyObject *res = - #if CYTHON_USE_TYPE_SLOTS || __PYX_LIMITED_VERSION_HEX >= 0x030A0000 - __Pyx_PyType_GetSlot((&PyFloat_Type), tp_richcompare, richcmpfunc) - #else - PyObject_RichCompare - #endif - (op2, op1, - Py_EQ); - return __Pyx_PyObject_IsTrueAndDecref( - res); - } - #if CYTHON_USE_PYLONG_INTERNALS - } - } - #endif - } else { - return __Pyx_PyObject_IsTrueAndDecref( - PyObject_RichCompare(op1, op2, Py_EQ)); - } - if (a == b) { - return 1; - } else { - return 0; - } -} -#endif - -/* PyObjectLookupSpecial */ -#if CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS -static CYTHON_INLINE PyObject* __Pyx__PyObject_LookupSpecial(PyObject* obj, PyObject* attr_name, int with_error) { - PyObject *res; - PyTypeObject *tp = Py_TYPE(obj); - res = _PyType_Lookup(tp, attr_name); - if (likely(res)) { - descrgetfunc f = Py_TYPE(res)->tp_descr_get; - if (!f) { - Py_INCREF(res); - } else { - res = f(res, obj, (PyObject *)tp); - } - } else if (with_error) { - PyErr_SetObject(PyExc_AttributeError, attr_name); - } - return res; -} -#endif - -/* GetTopmostException */ -#if CYTHON_USE_EXC_INFO_STACK && CYTHON_FAST_THREAD_STATE -static _PyErr_StackItem * -__Pyx_PyErr_GetTopmostException(PyThreadState *tstate) -{ - _PyErr_StackItem *exc_info = tstate->exc_info; - while ((exc_info->exc_value == NULL || exc_info->exc_value == Py_None) && - exc_info->previous_item != NULL) - { - exc_info = exc_info->previous_item; - } - return exc_info; -} -#endif - -/* SaveResetException */ -#if CYTHON_FAST_THREAD_STATE -static CYTHON_INLINE void __Pyx__ExceptionSave(PyThreadState *tstate, PyObject **type, PyObject **value, PyObject **tb) { - #if CYTHON_USE_EXC_INFO_STACK && PY_VERSION_HEX >= 0x030B00a4 - _PyErr_StackItem *exc_info = __Pyx_PyErr_GetTopmostException(tstate); - PyObject *exc_value = exc_info->exc_value; - if (exc_value == NULL || exc_value == Py_None) { - *value = NULL; - *type = NULL; - *tb = NULL; - } else { - *value = exc_value; - Py_INCREF(*value); - *type = (PyObject*) Py_TYPE(exc_value); - Py_INCREF(*type); - *tb = PyException_GetTraceback(exc_value); - } - #elif CYTHON_USE_EXC_INFO_STACK - _PyErr_StackItem *exc_info = __Pyx_PyErr_GetTopmostException(tstate); - *type = exc_info->exc_type; - *value = exc_info->exc_value; - *tb = exc_info->exc_traceback; - Py_XINCREF(*type); - Py_XINCREF(*value); - Py_XINCREF(*tb); - #else - *type = tstate->exc_type; - *value = tstate->exc_value; - *tb = tstate->exc_traceback; - Py_XINCREF(*type); - Py_XINCREF(*value); - Py_XINCREF(*tb); - #endif -} -static CYTHON_INLINE void __Pyx__ExceptionReset(PyThreadState *tstate, PyObject *type, PyObject *value, PyObject *tb) { - #if CYTHON_USE_EXC_INFO_STACK && PY_VERSION_HEX >= 0x030B00a4 - _PyErr_StackItem *exc_info = tstate->exc_info; - PyObject *tmp_value = exc_info->exc_value; - exc_info->exc_value = value; - Py_XDECREF(tmp_value); - Py_XDECREF(type); - Py_XDECREF(tb); - #else - PyObject *tmp_type, *tmp_value, *tmp_tb; - #if CYTHON_USE_EXC_INFO_STACK - _PyErr_StackItem *exc_info = tstate->exc_info; - tmp_type = exc_info->exc_type; - tmp_value = exc_info->exc_value; - tmp_tb = exc_info->exc_traceback; - exc_info->exc_type = type; - exc_info->exc_value = value; - exc_info->exc_traceback = tb; - #else - 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; - #endif - Py_XDECREF(tmp_type); - Py_XDECREF(tmp_value); - Py_XDECREF(tmp_tb); - #endif -} -#endif - -/* GetException */ -#if CYTHON_FAST_THREAD_STATE -static int __Pyx__GetException(PyThreadState *tstate, PyObject **type, PyObject **value, PyObject **tb) -#else -static int __Pyx_GetException(PyObject **type, PyObject **value, PyObject **tb) -#endif -{ - PyObject *local_type = NULL, *local_value, *local_tb = NULL; -#if CYTHON_FAST_THREAD_STATE - PyObject *tmp_type, *tmp_value, *tmp_tb; - #if PY_VERSION_HEX >= 0x030C0000 - local_value = tstate->current_exception; - tstate->current_exception = 0; - #else - 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; - #endif -#elif __PYX_LIMITED_VERSION_HEX > 0x030C0000 - local_value = PyErr_GetRaisedException(); -#else - PyErr_Fetch(&local_type, &local_value, &local_tb); -#endif -#if __PYX_LIMITED_VERSION_HEX > 0x030C0000 - if (likely(local_value)) { - local_type = (PyObject*) Py_TYPE(local_value); - Py_INCREF(local_type); - local_tb = PyException_GetTraceback(local_value); - } -#else - PyErr_NormalizeException(&local_type, &local_value, &local_tb); -#if CYTHON_FAST_THREAD_STATE - if (unlikely(tstate->curexc_type)) -#else - if (unlikely(PyErr_Occurred())) -#endif - goto bad; - if (local_tb) { - if (unlikely(PyException_SetTraceback(local_value, local_tb) < 0)) - goto bad; - } -#endif // __PYX_LIMITED_VERSION_HEX > 0x030C0000 - Py_XINCREF(local_tb); - Py_XINCREF(local_type); - Py_XINCREF(local_value); - *type = local_type; - *value = local_value; - *tb = local_tb; -#if CYTHON_FAST_THREAD_STATE - #if CYTHON_USE_EXC_INFO_STACK - { - _PyErr_StackItem *exc_info = tstate->exc_info; - #if PY_VERSION_HEX >= 0x030B00a4 - tmp_value = exc_info->exc_value; - exc_info->exc_value = local_value; - tmp_type = NULL; - tmp_tb = NULL; - Py_XDECREF(local_type); - Py_XDECREF(local_tb); - #else - tmp_type = exc_info->exc_type; - tmp_value = exc_info->exc_value; - tmp_tb = exc_info->exc_traceback; - exc_info->exc_type = local_type; - exc_info->exc_value = local_value; - exc_info->exc_traceback = local_tb; - #endif - } - #else - 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; - #endif - Py_XDECREF(tmp_type); - Py_XDECREF(tmp_value); - Py_XDECREF(tmp_tb); -#elif __PYX_LIMITED_VERSION_HEX >= 0x030b0000 - PyErr_SetHandledException(local_value); - Py_XDECREF(local_value); - Py_XDECREF(local_type); - Py_XDECREF(local_tb); -#else - PyErr_SetExcInfo(local_type, local_value, local_tb); -#endif - return 0; -#if __PYX_LIMITED_VERSION_HEX <= 0x030C0000 -bad: - *type = 0; - *value = 0; - *tb = 0; - Py_XDECREF(local_type); - Py_XDECREF(local_value); - Py_XDECREF(local_tb); - return -1; -#endif -} - -/* Import */ -static PyObject *__Pyx_Import(PyObject *name, PyObject *from_list, int level) { - PyObject *module = 0; - PyObject *empty_dict = 0; - PyObject *empty_list = 0; - empty_dict = PyDict_New(); - if (unlikely(!empty_dict)) - goto bad; - if (level == -1) { - if (strchr(__Pyx_MODULE_NAME, '.') != (0)) { - module = PyImport_ImportModuleLevelObject( - name, __pyx_mstate_global->__pyx_d, empty_dict, from_list, 1); - if (unlikely(!module)) { - if (unlikely(!PyErr_ExceptionMatches(PyExc_ImportError))) - goto bad; - PyErr_Clear(); - } - } - level = 0; - } - if (!module) { - module = PyImport_ImportModuleLevelObject( - name, __pyx_mstate_global->__pyx_d, empty_dict, from_list, level); - } -bad: - Py_XDECREF(empty_dict); - Py_XDECREF(empty_list); - return module; -} - -/* ImportDottedModule */ -static PyObject *__Pyx__ImportDottedModule_Error(PyObject *name, PyObject *parts_tuple, Py_ssize_t count) { - PyObject *partial_name = NULL, *slice = NULL, *sep = NULL; - Py_ssize_t size; - if (unlikely(PyErr_Occurred())) { - PyErr_Clear(); - } -#if CYTHON_ASSUME_SAFE_SIZE - size = PyTuple_GET_SIZE(parts_tuple); -#else - size = PyTuple_Size(parts_tuple); - if (size < 0) goto bad; -#endif - if (likely(size == count)) { - partial_name = name; - } else { - slice = PySequence_GetSlice(parts_tuple, 0, count); - if (unlikely(!slice)) - goto bad; - sep = PyUnicode_FromStringAndSize(".", 1); - if (unlikely(!sep)) - goto bad; - partial_name = PyUnicode_Join(sep, slice); - } - PyErr_Format( - PyExc_ModuleNotFoundError, - "No module named '%U'", partial_name); -bad: - Py_XDECREF(sep); - Py_XDECREF(slice); - Py_XDECREF(partial_name); - return NULL; -} -static PyObject *__Pyx__ImportDottedModule_Lookup(PyObject *name) { - PyObject *imported_module; -#if (CYTHON_COMPILING_IN_PYPY && PYPY_VERSION_NUM < 0x07030400) ||\ - CYTHON_COMPILING_IN_GRAAL - PyObject *modules = PyImport_GetModuleDict(); - if (unlikely(!modules)) - return NULL; - imported_module = __Pyx_PyDict_GetItemStr(modules, name); - Py_XINCREF(imported_module); -#else - imported_module = PyImport_GetModule(name); -#endif - return imported_module; -} -static PyObject *__Pyx_ImportDottedModule_WalkParts(PyObject *module, PyObject *name, PyObject *parts_tuple) { - Py_ssize_t i, nparts; -#if CYTHON_ASSUME_SAFE_SIZE - nparts = PyTuple_GET_SIZE(parts_tuple); -#else - nparts = PyTuple_Size(parts_tuple); - if (nparts < 0) return NULL; -#endif - for (i=1; i < nparts && module; i++) { - PyObject *part, *submodule; -#if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS - part = PyTuple_GET_ITEM(parts_tuple, i); -#else - part = __Pyx_PySequence_ITEM(parts_tuple, i); - if (!part) return NULL; -#endif - submodule = __Pyx_PyObject_GetAttrStrNoError(module, part); -#if !(CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS) - Py_DECREF(part); -#endif - Py_DECREF(module); - module = submodule; - } - if (unlikely(!module)) { - return __Pyx__ImportDottedModule_Error(name, parts_tuple, i); - } - return module; -} -static PyObject *__Pyx__ImportDottedModule(PyObject *name, PyObject *parts_tuple) { - PyObject *imported_module; - PyObject *module = __Pyx_Import(name, NULL, 0); - if (!parts_tuple || unlikely(!module)) - return module; - imported_module = __Pyx__ImportDottedModule_Lookup(name); - if (likely(imported_module)) { - Py_DECREF(module); - return imported_module; - } - PyErr_Clear(); - return __Pyx_ImportDottedModule_WalkParts(module, name, parts_tuple); -} -static PyObject *__Pyx_ImportDottedModule(PyObject *name, PyObject *parts_tuple) { -#if CYTHON_COMPILING_IN_CPYTHON - PyObject *module = __Pyx__ImportDottedModule_Lookup(name); - if (likely(module)) { - PyObject *spec = __Pyx_PyObject_GetAttrStrNoError(module, __pyx_mstate_global->__pyx_n_u_spec); - if (likely(spec)) { - PyObject *unsafe = __Pyx_PyObject_GetAttrStrNoError(spec, __pyx_mstate_global->__pyx_n_u_initializing); - if (likely(!unsafe || !__Pyx_PyObject_IsTrue(unsafe))) { - Py_DECREF(spec); - spec = NULL; - } - Py_XDECREF(unsafe); - } - if (likely(!spec)) { - PyErr_Clear(); - return module; - } - Py_DECREF(spec); - Py_DECREF(module); - } else if (PyErr_Occurred()) { - PyErr_Clear(); - } -#endif - return __Pyx__ImportDottedModule(name, parts_tuple); -} - -/* ListPack */ -static PyObject *__Pyx_PyList_Pack(Py_ssize_t n, ...) { - va_list va; - PyObject *l = PyList_New(n); - va_start(va, n); - if (unlikely(!l)) goto end; - for (Py_ssize_t i=0; i__pyx_kp_u__3); - if (unlikely(!module_dot)) { goto modbad; } - full_name = PyUnicode_Concat(module_dot, name); - if (unlikely(!full_name)) { goto modbad; } - #if (CYTHON_COMPILING_IN_PYPY && PYPY_VERSION_NUM < 0x07030400) ||\ - CYTHON_COMPILING_IN_GRAAL - { - PyObject *modules = PyImport_GetModuleDict(); - if (unlikely(!modules)) - goto modbad; - value = PyObject_GetItem(modules, full_name); - } - #else - value = PyImport_GetModule(full_name); - #endif - modbad: - Py_XDECREF(full_name); - Py_XDECREF(module_dot); - Py_XDECREF(module_name); - } - if (unlikely(!value)) { - PyErr_Format(PyExc_ImportError, "cannot import name %S", name); - } - return value; -} - -/* FixUpExtensionType */ -static int __Pyx_fix_up_extension_type_from_spec(PyType_Spec *spec, PyTypeObject *type) { -#if PY_VERSION_HEX > 0x030900B1 || CYTHON_COMPILING_IN_LIMITED_API - CYTHON_UNUSED_VAR(spec); - CYTHON_UNUSED_VAR(type); -#else - const PyType_Slot *slot = spec->slots; - while (slot && slot->slot && slot->slot != Py_tp_members) - slot++; - if (slot && slot->slot == Py_tp_members) { - int changed = 0; -#if !(PY_VERSION_HEX <= 0x030900b1 && CYTHON_COMPILING_IN_CPYTHON) - const -#endif - PyMemberDef *memb = (PyMemberDef*) slot->pfunc; - while (memb && memb->name) { - if (memb->name[0] == '_' && memb->name[1] == '_') { -#if PY_VERSION_HEX < 0x030900b1 - if (strcmp(memb->name, "__weaklistoffset__") == 0) { - assert(memb->type == T_PYSSIZET); - assert(memb->flags == READONLY); - type->tp_weaklistoffset = memb->offset; - changed = 1; - } - else if (strcmp(memb->name, "__dictoffset__") == 0) { - assert(memb->type == T_PYSSIZET); - assert(memb->flags == READONLY); - type->tp_dictoffset = memb->offset; - changed = 1; - } -#if CYTHON_METH_FASTCALL - else if (strcmp(memb->name, "__vectorcalloffset__") == 0) { - assert(memb->type == T_PYSSIZET); - assert(memb->flags == READONLY); -#if PY_VERSION_HEX >= 0x030800b4 - type->tp_vectorcall_offset = memb->offset; -#else - type->tp_print = (printfunc) memb->offset; -#endif - changed = 1; - } -#endif -#else - if ((0)); -#endif -#if PY_VERSION_HEX <= 0x030900b1 && CYTHON_COMPILING_IN_CPYTHON - else if (strcmp(memb->name, "__module__") == 0) { - PyObject *descr; - assert(memb->type == T_OBJECT); - assert(memb->flags == 0 || memb->flags == READONLY); - descr = PyDescr_NewMember(type, memb); - if (unlikely(!descr)) - return -1; - if (unlikely(PyDict_SetItem(type->tp_dict, PyDescr_NAME(descr), descr) < 0)) { - Py_DECREF(descr); - return -1; - } - Py_DECREF(descr); - changed = 1; - } -#endif - } - memb++; - } - if (changed) - PyType_Modified(type); - } -#endif - return 0; -} - -/* FetchSharedCythonModule */ -static PyObject *__Pyx_FetchSharedCythonABIModule(void) { - return __Pyx_PyImport_AddModuleRef(__PYX_ABI_MODULE_NAME); -} - -/* dict_setdefault */ -static CYTHON_INLINE PyObject *__Pyx_PyDict_SetDefault(PyObject *d, PyObject *key, PyObject *default_value, - int is_safe_type) { - PyObject* value; - CYTHON_MAYBE_UNUSED_VAR(is_safe_type); -#if CYTHON_COMPILING_IN_LIMITED_API - value = PyObject_CallMethod(d, "setdefault", "OO", key, default_value); -#elif PY_VERSION_HEX >= 0x030d0000 - PyDict_SetDefaultRef(d, key, default_value, &value); -#else - value = PyDict_SetDefault(d, key, default_value); - if (unlikely(!value)) return NULL; - Py_INCREF(value); -#endif - return value; -} - -/* FetchCommonType */ -static int __Pyx_VerifyCachedType(PyObject *cached_type, - const char *name, - Py_ssize_t expected_basicsize) { - Py_ssize_t basicsize; - if (!PyType_Check(cached_type)) { - PyErr_Format(PyExc_TypeError, - "Shared Cython type %.200s is not a type object", name); - return -1; - } -#if CYTHON_COMPILING_IN_LIMITED_API - PyObject *py_basicsize; - py_basicsize = PyObject_GetAttrString(cached_type, "__basicsize__"); - if (unlikely(!py_basicsize)) return -1; - basicsize = PyLong_AsSsize_t(py_basicsize); - Py_DECREF(py_basicsize); - py_basicsize = NULL; - if (unlikely(basicsize == (Py_ssize_t)-1) && PyErr_Occurred()) return -1; -#else - basicsize = ((PyTypeObject*) cached_type)->tp_basicsize; -#endif - if (basicsize != expected_basicsize) { - PyErr_Format(PyExc_TypeError, - "Shared Cython type %.200s has the wrong size, try recompiling", - name); - return -1; - } - return 0; -} -static PyTypeObject *__Pyx_FetchCommonTypeFromSpec(PyObject *module, PyType_Spec *spec, PyObject *bases) { - PyObject *abi_module = NULL, *cached_type = NULL, *abi_module_dict, *new_cached_type, *py_object_name; - int get_item_ref_result; - const char* object_name = strrchr(spec->name, '.'); - object_name = object_name ? object_name+1 : spec->name; - py_object_name = PyUnicode_FromString(object_name); - if (!py_object_name) return NULL; - abi_module = __Pyx_FetchSharedCythonABIModule(); - if (!abi_module) goto done; - abi_module_dict = PyModule_GetDict(abi_module); - if (!abi_module_dict) goto done; - get_item_ref_result = __Pyx_PyDict_GetItemRef(abi_module_dict, py_object_name, &cached_type); - if (get_item_ref_result == 1) { - if (__Pyx_VerifyCachedType( - cached_type, - object_name, - spec->basicsize) < 0) { - goto bad; - } - goto done; - } else if (unlikely(get_item_ref_result == -1)) { - goto bad; - } - CYTHON_UNUSED_VAR(module); - cached_type = __Pyx_PyType_FromModuleAndSpec(abi_module, spec, bases); - if (unlikely(!cached_type)) goto bad; - if (unlikely(__Pyx_fix_up_extension_type_from_spec(spec, (PyTypeObject *) cached_type) < 0)) goto bad; - new_cached_type = __Pyx_PyDict_SetDefault(abi_module_dict, py_object_name, cached_type, 1); - if (unlikely(new_cached_type != cached_type)) { - if (unlikely(!new_cached_type)) goto bad; - Py_DECREF(cached_type); - cached_type = new_cached_type; - if (__Pyx_VerifyCachedType( - cached_type, - object_name, - spec->basicsize) < 0) { - goto bad; - } - goto done; - } else { - Py_DECREF(new_cached_type); - } -done: - Py_XDECREF(abi_module); - Py_DECREF(py_object_name); - assert(cached_type == NULL || PyType_Check(cached_type)); - return (PyTypeObject *) cached_type; -bad: - Py_XDECREF(cached_type); - cached_type = NULL; - goto done; -} - -/* CallTypeTraverse */ -#if !CYTHON_USE_TYPE_SPECS || (!CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX < 0x03090000) -#else -static int __Pyx_call_type_traverse(PyObject *o, int always_call, visitproc visit, void *arg) { - #if CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX < 0x03090000 - if (__Pyx_get_runtime_version() < 0x03090000) return 0; - #endif - if (!always_call) { - PyTypeObject *base = __Pyx_PyObject_GetSlot(o, tp_base, PyTypeObject*); - unsigned long flags = PyType_GetFlags(base); - if (flags & Py_TPFLAGS_HEAPTYPE) { - return 0; - } - } - Py_VISIT((PyObject*)Py_TYPE(o)); - return 0; -} -#endif - -/* PyMethodNew */ -#if CYTHON_COMPILING_IN_LIMITED_API -static PyObject *__Pyx_PyMethod_New(PyObject *func, PyObject *self, PyObject *typ) { - PyObject *result; - CYTHON_UNUSED_VAR(typ); - if (!self) - return __Pyx_NewRef(func); - #if __PYX_LIMITED_VERSION_HEX >= 0x030C0000 - { - PyObject *args[] = {func, self}; - result = PyObject_Vectorcall(__pyx_mstate_global->__Pyx_CachedMethodType, args, 2, NULL); - } - #else - result = PyObject_CallFunctionObjArgs(__pyx_mstate_global->__Pyx_CachedMethodType, func, self, NULL); - #endif - return result; -} -#else -static PyObject *__Pyx_PyMethod_New(PyObject *func, PyObject *self, PyObject *typ) { - CYTHON_UNUSED_VAR(typ); - if (!self) - return __Pyx_NewRef(func); - return PyMethod_New(func, self); -} -#endif - -/* PyVectorcallFastCallDict */ -#if CYTHON_METH_FASTCALL && (CYTHON_VECTORCALL || CYTHON_BACKPORT_VECTORCALL) -static PyObject *__Pyx_PyVectorcall_FastCallDict_kw(PyObject *func, __pyx_vectorcallfunc vc, PyObject *const *args, size_t nargs, PyObject *kw) -{ - PyObject *res = NULL; - PyObject *kwnames; - PyObject **newargs; - PyObject **kwvalues; - Py_ssize_t i, pos; - size_t j; - PyObject *key, *value; - unsigned long keys_are_strings; - #if !CYTHON_ASSUME_SAFE_SIZE - Py_ssize_t nkw = PyDict_Size(kw); - if (unlikely(nkw == -1)) return NULL; - #else - Py_ssize_t nkw = PyDict_GET_SIZE(kw); - #endif - newargs = (PyObject **)PyMem_Malloc((nargs + (size_t)nkw) * sizeof(args[0])); - if (unlikely(newargs == NULL)) { - PyErr_NoMemory(); - return NULL; - } - for (j = 0; j < nargs; j++) newargs[j] = args[j]; - kwnames = PyTuple_New(nkw); - if (unlikely(kwnames == NULL)) { - PyMem_Free(newargs); - return NULL; - } - kwvalues = newargs + nargs; - pos = i = 0; - keys_are_strings = Py_TPFLAGS_UNICODE_SUBCLASS; - while (PyDict_Next(kw, &pos, &key, &value)) { - keys_are_strings &= - #if CYTHON_COMPILING_IN_LIMITED_API - PyType_GetFlags(Py_TYPE(key)); - #else - Py_TYPE(key)->tp_flags; - #endif - Py_INCREF(key); - Py_INCREF(value); - #if !CYTHON_ASSUME_SAFE_MACROS - if (unlikely(PyTuple_SetItem(kwnames, i, key) < 0)) goto cleanup; - #else - PyTuple_SET_ITEM(kwnames, i, key); - #endif - kwvalues[i] = value; - i++; - } - if (unlikely(!keys_are_strings)) { - PyErr_SetString(PyExc_TypeError, "keywords must be strings"); - goto cleanup; - } - res = vc(func, newargs, nargs, kwnames); -cleanup: - Py_DECREF(kwnames); - for (i = 0; i < nkw; i++) - Py_DECREF(kwvalues[i]); - PyMem_Free(newargs); - return res; -} -static CYTHON_INLINE PyObject *__Pyx_PyVectorcall_FastCallDict(PyObject *func, __pyx_vectorcallfunc vc, PyObject *const *args, size_t nargs, PyObject *kw) -{ - Py_ssize_t kw_size = - likely(kw == NULL) ? - 0 : -#if !CYTHON_ASSUME_SAFE_SIZE - PyDict_Size(kw); -#else - PyDict_GET_SIZE(kw); -#endif - if (kw_size == 0) { - return vc(func, args, nargs, NULL); - } -#if !CYTHON_ASSUME_SAFE_SIZE - else if (unlikely(kw_size == -1)) { - return NULL; - } -#endif - return __Pyx_PyVectorcall_FastCallDict_kw(func, vc, args, nargs, kw); -} -#endif - -/* CythonFunctionShared */ -#if CYTHON_COMPILING_IN_LIMITED_API -static CYTHON_INLINE int __Pyx__IsSameCyOrCFunctionNoMethod(PyObject *func, void (*cfunc)(void)) { - if (__Pyx_CyFunction_Check(func)) { - return PyCFunction_GetFunction(((__pyx_CyFunctionObject*)func)->func) == (PyCFunction) cfunc; - } else if (PyCFunction_Check(func)) { - return PyCFunction_GetFunction(func) == (PyCFunction) cfunc; - } - return 0; -} -static CYTHON_INLINE int __Pyx__IsSameCyOrCFunction(PyObject *func, void (*cfunc)(void)) { - if ((PyObject*)Py_TYPE(func) == __pyx_mstate_global->__Pyx_CachedMethodType) { - int result; - PyObject *newFunc = PyObject_GetAttr(func, __pyx_mstate_global->__pyx_n_u_func); - if (unlikely(!newFunc)) { - PyErr_Clear(); // It's only an optimization, so don't throw an error - return 0; - } - result = __Pyx__IsSameCyOrCFunctionNoMethod(newFunc, cfunc); - Py_DECREF(newFunc); - return result; - } - return __Pyx__IsSameCyOrCFunctionNoMethod(func, cfunc); -} -#else -static CYTHON_INLINE int __Pyx__IsSameCyOrCFunction(PyObject *func, void (*cfunc)(void)) { - if (PyMethod_Check(func)) { - func = PyMethod_GET_FUNCTION(func); - } - return __Pyx_CyOrPyCFunction_Check(func) && __Pyx_CyOrPyCFunction_GET_FUNCTION(func) == (PyCFunction) cfunc; -} -#endif -static CYTHON_INLINE void __Pyx__CyFunction_SetClassObj(__pyx_CyFunctionObject* f, PyObject* classobj) { -#if PY_VERSION_HEX < 0x030900B1 || CYTHON_COMPILING_IN_LIMITED_API - __Pyx_Py_XDECREF_SET( - __Pyx_CyFunction_GetClassObj(f), - ((classobj) ? __Pyx_NewRef(classobj) : NULL)); -#else - __Pyx_Py_XDECREF_SET( - ((PyCMethodObject *) (f))->mm_class, - (PyTypeObject*)((classobj) ? __Pyx_NewRef(classobj) : NULL)); -#endif -} -static PyObject * -__Pyx_CyFunction_get_doc_locked(__pyx_CyFunctionObject *op) -{ - if (unlikely(op->func_doc == NULL)) { -#if CYTHON_COMPILING_IN_LIMITED_API - op->func_doc = PyObject_GetAttrString(op->func, "__doc__"); - if (unlikely(!op->func_doc)) return NULL; -#else - if (((PyCFunctionObject*)op)->m_ml->ml_doc) { - op->func_doc = PyUnicode_FromString(((PyCFunctionObject*)op)->m_ml->ml_doc); - if (unlikely(op->func_doc == NULL)) - return NULL; - } else { - Py_INCREF(Py_None); - return Py_None; - } -#endif - } - Py_INCREF(op->func_doc); - return op->func_doc; -} -static PyObject * -__Pyx_CyFunction_get_doc(__pyx_CyFunctionObject *op, void *closure) { - PyObject *result; - CYTHON_UNUSED_VAR(closure); - __Pyx_BEGIN_CRITICAL_SECTION(op); - result = __Pyx_CyFunction_get_doc_locked(op); - __Pyx_END_CRITICAL_SECTION(); - return result; -} -static int -__Pyx_CyFunction_set_doc(__pyx_CyFunctionObject *op, PyObject *value, void *context) -{ - CYTHON_UNUSED_VAR(context); - if (value == NULL) { - value = Py_None; - } - Py_INCREF(value); - __Pyx_BEGIN_CRITICAL_SECTION(op); - __Pyx_Py_XDECREF_SET(op->func_doc, value); - __Pyx_END_CRITICAL_SECTION(); - return 0; -} -static PyObject * -__Pyx_CyFunction_get_name_locked(__pyx_CyFunctionObject *op) -{ - if (unlikely(op->func_name == NULL)) { -#if CYTHON_COMPILING_IN_LIMITED_API - op->func_name = PyObject_GetAttrString(op->func, "__name__"); -#else - op->func_name = PyUnicode_InternFromString(((PyCFunctionObject*)op)->m_ml->ml_name); -#endif - if (unlikely(op->func_name == NULL)) - return NULL; - } - Py_INCREF(op->func_name); - return op->func_name; -} -static PyObject * -__Pyx_CyFunction_get_name(__pyx_CyFunctionObject *op, void *context) -{ - PyObject *result = NULL; - CYTHON_UNUSED_VAR(context); - __Pyx_BEGIN_CRITICAL_SECTION(op); - result = __Pyx_CyFunction_get_name_locked(op); - __Pyx_END_CRITICAL_SECTION(); - return result; -} -static int -__Pyx_CyFunction_set_name(__pyx_CyFunctionObject *op, PyObject *value, void *context) -{ - CYTHON_UNUSED_VAR(context); - if (unlikely(value == NULL || !PyUnicode_Check(value))) { - PyErr_SetString(PyExc_TypeError, - "__name__ must be set to a string object"); - return -1; - } - Py_INCREF(value); - __Pyx_BEGIN_CRITICAL_SECTION(op); - __Pyx_Py_XDECREF_SET(op->func_name, value); - __Pyx_END_CRITICAL_SECTION(); - return 0; -} -static PyObject * -__Pyx_CyFunction_get_qualname(__pyx_CyFunctionObject *op, void *context) -{ - CYTHON_UNUSED_VAR(context); - PyObject *result; - __Pyx_BEGIN_CRITICAL_SECTION(op); - Py_INCREF(op->func_qualname); - result = op->func_qualname; - __Pyx_END_CRITICAL_SECTION(); - return result; -} -static int -__Pyx_CyFunction_set_qualname(__pyx_CyFunctionObject *op, PyObject *value, void *context) -{ - CYTHON_UNUSED_VAR(context); - if (unlikely(value == NULL || !PyUnicode_Check(value))) { - PyErr_SetString(PyExc_TypeError, - "__qualname__ must be set to a string object"); - return -1; - } - Py_INCREF(value); - __Pyx_BEGIN_CRITICAL_SECTION(op); - __Pyx_Py_XDECREF_SET(op->func_qualname, value); - __Pyx_END_CRITICAL_SECTION(); - return 0; -} -static PyObject * -__Pyx_CyFunction_get_dict_locked(__pyx_CyFunctionObject *op) -{ - if (unlikely(op->func_dict == NULL)) { - op->func_dict = PyDict_New(); - if (unlikely(op->func_dict == NULL)) - return NULL; - } - Py_INCREF(op->func_dict); - return op->func_dict; -} -static PyObject * -__Pyx_CyFunction_get_dict(__pyx_CyFunctionObject *op, void *context) -{ - CYTHON_UNUSED_VAR(context); - PyObject *result; - __Pyx_BEGIN_CRITICAL_SECTION(op); - result = __Pyx_CyFunction_get_dict_locked(op); - __Pyx_END_CRITICAL_SECTION(); - return result; -} -static int -__Pyx_CyFunction_set_dict(__pyx_CyFunctionObject *op, PyObject *value, void *context) -{ - CYTHON_UNUSED_VAR(context); - if (unlikely(value == NULL)) { - PyErr_SetString(PyExc_TypeError, - "function's dictionary may not be deleted"); - return -1; - } - if (unlikely(!PyDict_Check(value))) { - PyErr_SetString(PyExc_TypeError, - "setting function's dictionary to a non-dict"); - return -1; - } - Py_INCREF(value); - __Pyx_BEGIN_CRITICAL_SECTION(op); - __Pyx_Py_XDECREF_SET(op->func_dict, value); - __Pyx_END_CRITICAL_SECTION(); - return 0; -} -static PyObject * -__Pyx_CyFunction_get_globals(__pyx_CyFunctionObject *op, void *context) -{ - CYTHON_UNUSED_VAR(context); - Py_INCREF(op->func_globals); - return op->func_globals; -} -static PyObject * -__Pyx_CyFunction_get_closure(__pyx_CyFunctionObject *op, void *context) -{ - CYTHON_UNUSED_VAR(op); - CYTHON_UNUSED_VAR(context); - Py_INCREF(Py_None); - return Py_None; -} -static PyObject * -__Pyx_CyFunction_get_code(__pyx_CyFunctionObject *op, void *context) -{ - PyObject* result = (op->func_code) ? op->func_code : Py_None; - CYTHON_UNUSED_VAR(context); - Py_INCREF(result); - return result; -} -static int -__Pyx_CyFunction_init_defaults(__pyx_CyFunctionObject *op) { - int result = 0; - PyObject *res = op->defaults_getter((PyObject *) op); - if (unlikely(!res)) - return -1; - #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS - op->defaults_tuple = PyTuple_GET_ITEM(res, 0); - Py_INCREF(op->defaults_tuple); - op->defaults_kwdict = PyTuple_GET_ITEM(res, 1); - Py_INCREF(op->defaults_kwdict); - #else - op->defaults_tuple = __Pyx_PySequence_ITEM(res, 0); - if (unlikely(!op->defaults_tuple)) result = -1; - else { - op->defaults_kwdict = __Pyx_PySequence_ITEM(res, 1); - if (unlikely(!op->defaults_kwdict)) result = -1; - } - #endif - Py_DECREF(res); - return result; -} -static int -__Pyx_CyFunction_set_defaults(__pyx_CyFunctionObject *op, PyObject* value, void *context) { - CYTHON_UNUSED_VAR(context); - if (!value) { - value = Py_None; - } else if (unlikely(value != Py_None && !PyTuple_Check(value))) { - PyErr_SetString(PyExc_TypeError, - "__defaults__ must be set to a tuple object"); - return -1; - } - PyErr_WarnEx(PyExc_RuntimeWarning, "changes to cyfunction.__defaults__ will not " - "currently affect the values used in function calls", 1); - Py_INCREF(value); - __Pyx_BEGIN_CRITICAL_SECTION(op); - __Pyx_Py_XDECREF_SET(op->defaults_tuple, value); - __Pyx_END_CRITICAL_SECTION(); - return 0; -} -static PyObject * -__Pyx_CyFunction_get_defaults_locked(__pyx_CyFunctionObject *op) { - PyObject* result = op->defaults_tuple; - if (unlikely(!result)) { - if (op->defaults_getter) { - if (unlikely(__Pyx_CyFunction_init_defaults(op) < 0)) return NULL; - result = op->defaults_tuple; - } else { - result = Py_None; - } - } - Py_INCREF(result); - return result; -} -static PyObject * -__Pyx_CyFunction_get_defaults(__pyx_CyFunctionObject *op, void *context) { - PyObject* result = NULL; - CYTHON_UNUSED_VAR(context); - __Pyx_BEGIN_CRITICAL_SECTION(op); - result = __Pyx_CyFunction_get_defaults_locked(op); - __Pyx_END_CRITICAL_SECTION(); - return result; -} -static int -__Pyx_CyFunction_set_kwdefaults(__pyx_CyFunctionObject *op, PyObject* value, void *context) { - CYTHON_UNUSED_VAR(context); - if (!value) { - value = Py_None; - } else if (unlikely(value != Py_None && !PyDict_Check(value))) { - PyErr_SetString(PyExc_TypeError, - "__kwdefaults__ must be set to a dict object"); - return -1; - } - PyErr_WarnEx(PyExc_RuntimeWarning, "changes to cyfunction.__kwdefaults__ will not " - "currently affect the values used in function calls", 1); - Py_INCREF(value); - __Pyx_BEGIN_CRITICAL_SECTION(op); - __Pyx_Py_XDECREF_SET(op->defaults_kwdict, value); - __Pyx_END_CRITICAL_SECTION(); - return 0; -} -static PyObject * -__Pyx_CyFunction_get_kwdefaults_locked(__pyx_CyFunctionObject *op) { - PyObject* result = op->defaults_kwdict; - if (unlikely(!result)) { - if (op->defaults_getter) { - if (unlikely(__Pyx_CyFunction_init_defaults(op) < 0)) return NULL; - result = op->defaults_kwdict; - } else { - result = Py_None; - } - } - Py_INCREF(result); - return result; -} -static PyObject * -__Pyx_CyFunction_get_kwdefaults(__pyx_CyFunctionObject *op, void *context) { - PyObject* result; - CYTHON_UNUSED_VAR(context); - __Pyx_BEGIN_CRITICAL_SECTION(op); - result = __Pyx_CyFunction_get_kwdefaults_locked(op); - __Pyx_END_CRITICAL_SECTION(); - return result; -} -static int -__Pyx_CyFunction_set_annotations(__pyx_CyFunctionObject *op, PyObject* value, void *context) { - CYTHON_UNUSED_VAR(context); - if (!value || value == Py_None) { - value = NULL; - } else if (unlikely(!PyDict_Check(value))) { - PyErr_SetString(PyExc_TypeError, - "__annotations__ must be set to a dict object"); - return -1; - } - Py_XINCREF(value); - __Pyx_BEGIN_CRITICAL_SECTION(op); - __Pyx_Py_XDECREF_SET(op->func_annotations, value); - __Pyx_END_CRITICAL_SECTION(); - return 0; -} -static PyObject * -__Pyx_CyFunction_get_annotations_locked(__pyx_CyFunctionObject *op) { - PyObject* result = op->func_annotations; - if (unlikely(!result)) { - result = PyDict_New(); - if (unlikely(!result)) return NULL; - op->func_annotations = result; - } - Py_INCREF(result); - return result; -} -static PyObject * -__Pyx_CyFunction_get_annotations(__pyx_CyFunctionObject *op, void *context) { - PyObject *result; - CYTHON_UNUSED_VAR(context); - __Pyx_BEGIN_CRITICAL_SECTION(op); - result = __Pyx_CyFunction_get_annotations_locked(op); - __Pyx_END_CRITICAL_SECTION(); - return result; -} -static PyObject * -__Pyx_CyFunction_get_is_coroutine_value(__pyx_CyFunctionObject *op) { - int is_coroutine = op->flags & __Pyx_CYFUNCTION_COROUTINE; - if (is_coroutine) { - PyObject *is_coroutine_value, *module, *fromlist, *marker = __pyx_mstate_global->__pyx_n_u_is_coroutine; - fromlist = PyList_New(1); - if (unlikely(!fromlist)) return NULL; - Py_INCREF(marker); -#if CYTHON_ASSUME_SAFE_MACROS - PyList_SET_ITEM(fromlist, 0, marker); -#else - if (unlikely(PyList_SetItem(fromlist, 0, marker) < 0)) { - Py_DECREF(marker); - Py_DECREF(fromlist); - return NULL; - } -#endif - module = PyImport_ImportModuleLevelObject(__pyx_mstate_global->__pyx_n_u_asyncio_coroutines, NULL, NULL, fromlist, 0); - Py_DECREF(fromlist); - if (unlikely(!module)) goto ignore; - is_coroutine_value = __Pyx_PyObject_GetAttrStr(module, marker); - Py_DECREF(module); - if (likely(is_coroutine_value)) { - return is_coroutine_value; - } -ignore: - PyErr_Clear(); - } - return __Pyx_PyBool_FromLong(is_coroutine); -} -static PyObject * -__Pyx_CyFunction_get_is_coroutine(__pyx_CyFunctionObject *op, void *context) { - PyObject *result; - CYTHON_UNUSED_VAR(context); - if (op->func_is_coroutine) { - return __Pyx_NewRef(op->func_is_coroutine); - } - result = __Pyx_CyFunction_get_is_coroutine_value(op); - if (unlikely(!result)) - return NULL; - __Pyx_BEGIN_CRITICAL_SECTION(op); - if (op->func_is_coroutine) { - Py_DECREF(result); - result = __Pyx_NewRef(op->func_is_coroutine); - } else { - op->func_is_coroutine = __Pyx_NewRef(result); - } - __Pyx_END_CRITICAL_SECTION(); - return result; -} -static void __Pyx_CyFunction_raise_argument_count_error(__pyx_CyFunctionObject *func, const char* message, Py_ssize_t size) { -#if CYTHON_COMPILING_IN_LIMITED_API - PyObject *py_name = __Pyx_CyFunction_get_name(func, NULL); - if (!py_name) return; - PyErr_Format(PyExc_TypeError, - "%.200S() %s (%" CYTHON_FORMAT_SSIZE_T "d given)", - py_name, message, size); - Py_DECREF(py_name); -#else - const char* name = ((PyCFunctionObject*)func)->m_ml->ml_name; - PyErr_Format(PyExc_TypeError, - "%.200s() %s (%" CYTHON_FORMAT_SSIZE_T "d given)", - name, message, size); -#endif -} -static void __Pyx_CyFunction_raise_type_error(__pyx_CyFunctionObject *func, const char* message) { -#if CYTHON_COMPILING_IN_LIMITED_API - PyObject *py_name = __Pyx_CyFunction_get_name(func, NULL); - if (!py_name) return; - PyErr_Format(PyExc_TypeError, - "%.200S() %s", - py_name, message); - Py_DECREF(py_name); -#else - const char* name = ((PyCFunctionObject*)func)->m_ml->ml_name; - PyErr_Format(PyExc_TypeError, - "%.200s() %s", - name, message); -#endif -} -#if CYTHON_COMPILING_IN_LIMITED_API -static PyObject * -__Pyx_CyFunction_get_module(__pyx_CyFunctionObject *op, void *context) { - CYTHON_UNUSED_VAR(context); - return PyObject_GetAttrString(op->func, "__module__"); -} -static int -__Pyx_CyFunction_set_module(__pyx_CyFunctionObject *op, PyObject* value, void *context) { - CYTHON_UNUSED_VAR(context); - return PyObject_SetAttrString(op->func, "__module__", value); -} -#endif -static PyGetSetDef __pyx_CyFunction_getsets[] = { - {"func_doc", (getter)__Pyx_CyFunction_get_doc, (setter)__Pyx_CyFunction_set_doc, 0, 0}, - {"__doc__", (getter)__Pyx_CyFunction_get_doc, (setter)__Pyx_CyFunction_set_doc, 0, 0}, - {"func_name", (getter)__Pyx_CyFunction_get_name, (setter)__Pyx_CyFunction_set_name, 0, 0}, - {"__name__", (getter)__Pyx_CyFunction_get_name, (setter)__Pyx_CyFunction_set_name, 0, 0}, - {"__qualname__", (getter)__Pyx_CyFunction_get_qualname, (setter)__Pyx_CyFunction_set_qualname, 0, 0}, - {"func_dict", (getter)__Pyx_CyFunction_get_dict, (setter)__Pyx_CyFunction_set_dict, 0, 0}, - {"__dict__", (getter)__Pyx_CyFunction_get_dict, (setter)__Pyx_CyFunction_set_dict, 0, 0}, - {"func_globals", (getter)__Pyx_CyFunction_get_globals, 0, 0, 0}, - {"__globals__", (getter)__Pyx_CyFunction_get_globals, 0, 0, 0}, - {"func_closure", (getter)__Pyx_CyFunction_get_closure, 0, 0, 0}, - {"__closure__", (getter)__Pyx_CyFunction_get_closure, 0, 0, 0}, - {"func_code", (getter)__Pyx_CyFunction_get_code, 0, 0, 0}, - {"__code__", (getter)__Pyx_CyFunction_get_code, 0, 0, 0}, - {"func_defaults", (getter)__Pyx_CyFunction_get_defaults, (setter)__Pyx_CyFunction_set_defaults, 0, 0}, - {"__defaults__", (getter)__Pyx_CyFunction_get_defaults, (setter)__Pyx_CyFunction_set_defaults, 0, 0}, - {"__kwdefaults__", (getter)__Pyx_CyFunction_get_kwdefaults, (setter)__Pyx_CyFunction_set_kwdefaults, 0, 0}, - {"__annotations__", (getter)__Pyx_CyFunction_get_annotations, (setter)__Pyx_CyFunction_set_annotations, 0, 0}, - {"_is_coroutine", (getter)__Pyx_CyFunction_get_is_coroutine, 0, 0, 0}, -#if CYTHON_COMPILING_IN_LIMITED_API - {"__module__", (getter)__Pyx_CyFunction_get_module, (setter)__Pyx_CyFunction_set_module, 0, 0}, -#endif - {0, 0, 0, 0, 0} -}; -static PyMemberDef __pyx_CyFunction_members[] = { -#if !CYTHON_COMPILING_IN_LIMITED_API - {"__module__", T_OBJECT, offsetof(PyCFunctionObject, m_module), 0, 0}, -#endif - {"__dictoffset__", T_PYSSIZET, offsetof(__pyx_CyFunctionObject, func_dict), READONLY, 0}, -#if CYTHON_METH_FASTCALL -#if CYTHON_BACKPORT_VECTORCALL || CYTHON_COMPILING_IN_LIMITED_API - {"__vectorcalloffset__", T_PYSSIZET, offsetof(__pyx_CyFunctionObject, func_vectorcall), READONLY, 0}, -#else - {"__vectorcalloffset__", T_PYSSIZET, offsetof(PyCFunctionObject, vectorcall), READONLY, 0}, -#endif -#if CYTHON_COMPILING_IN_LIMITED_API - {"__weaklistoffset__", T_PYSSIZET, offsetof(__pyx_CyFunctionObject, func_weakreflist), READONLY, 0}, -#else - {"__weaklistoffset__", T_PYSSIZET, offsetof(PyCFunctionObject, m_weakreflist), READONLY, 0}, -#endif -#endif - {0, 0, 0, 0, 0} -}; -static PyObject * -__Pyx_CyFunction_reduce(__pyx_CyFunctionObject *m, PyObject *args) -{ - PyObject *result = NULL; - CYTHON_UNUSED_VAR(args); - __Pyx_BEGIN_CRITICAL_SECTION(m); - Py_INCREF(m->func_qualname); - result = m->func_qualname; - __Pyx_END_CRITICAL_SECTION(); - return result; -} -static PyMethodDef __pyx_CyFunction_methods[] = { - {"__reduce__", (PyCFunction)__Pyx_CyFunction_reduce, METH_VARARGS, 0}, - {0, 0, 0, 0} -}; -#if CYTHON_COMPILING_IN_LIMITED_API -#define __Pyx_CyFunction_weakreflist(cyfunc) ((cyfunc)->func_weakreflist) -#else -#define __Pyx_CyFunction_weakreflist(cyfunc) (((PyCFunctionObject*)cyfunc)->m_weakreflist) -#endif -static PyObject *__Pyx_CyFunction_Init(__pyx_CyFunctionObject *op, PyMethodDef *ml, int flags, PyObject* qualname, - PyObject *closure, PyObject *module, PyObject* globals, PyObject* code) { -#if !CYTHON_COMPILING_IN_LIMITED_API - PyCFunctionObject *cf = (PyCFunctionObject*) op; -#endif - if (unlikely(op == NULL)) - return NULL; -#if CYTHON_COMPILING_IN_LIMITED_API - op->func = PyCFunction_NewEx(ml, (PyObject*)op, module); - if (unlikely(!op->func)) return NULL; -#endif - op->flags = flags; - __Pyx_CyFunction_weakreflist(op) = NULL; -#if !CYTHON_COMPILING_IN_LIMITED_API - cf->m_ml = ml; - cf->m_self = (PyObject *) op; -#endif - Py_XINCREF(closure); - op->func_closure = closure; -#if !CYTHON_COMPILING_IN_LIMITED_API - Py_XINCREF(module); - cf->m_module = module; -#endif - op->func_dict = NULL; - op->func_name = NULL; - Py_INCREF(qualname); - op->func_qualname = qualname; - op->func_doc = NULL; -#if PY_VERSION_HEX < 0x030900B1 || CYTHON_COMPILING_IN_LIMITED_API - op->func_classobj = NULL; -#else - ((PyCMethodObject*)op)->mm_class = NULL; -#endif - op->func_globals = globals; - Py_INCREF(op->func_globals); - Py_XINCREF(code); - op->func_code = code; - op->defaults = NULL; - op->defaults_tuple = NULL; - op->defaults_kwdict = NULL; - op->defaults_getter = NULL; - op->func_annotations = NULL; - op->func_is_coroutine = NULL; -#if CYTHON_METH_FASTCALL - switch (ml->ml_flags & (METH_VARARGS | METH_FASTCALL | METH_NOARGS | METH_O | METH_KEYWORDS | METH_METHOD)) { - case METH_NOARGS: - __Pyx_CyFunction_func_vectorcall(op) = __Pyx_CyFunction_Vectorcall_NOARGS; - break; - case METH_O: - __Pyx_CyFunction_func_vectorcall(op) = __Pyx_CyFunction_Vectorcall_O; - break; - case METH_METHOD | METH_FASTCALL | METH_KEYWORDS: - __Pyx_CyFunction_func_vectorcall(op) = __Pyx_CyFunction_Vectorcall_FASTCALL_KEYWORDS_METHOD; - break; - case METH_FASTCALL | METH_KEYWORDS: - __Pyx_CyFunction_func_vectorcall(op) = __Pyx_CyFunction_Vectorcall_FASTCALL_KEYWORDS; - break; - case METH_VARARGS | METH_KEYWORDS: - __Pyx_CyFunction_func_vectorcall(op) = NULL; - break; - default: - PyErr_SetString(PyExc_SystemError, "Bad call flags for CyFunction"); - Py_DECREF(op); - return NULL; - } -#endif - return (PyObject *) op; -} -static int -__Pyx_CyFunction_clear(__pyx_CyFunctionObject *m) -{ - Py_CLEAR(m->func_closure); -#if CYTHON_COMPILING_IN_LIMITED_API - Py_CLEAR(m->func); -#else - Py_CLEAR(((PyCFunctionObject*)m)->m_module); -#endif - Py_CLEAR(m->func_dict); - Py_CLEAR(m->func_name); - Py_CLEAR(m->func_qualname); - Py_CLEAR(m->func_doc); - Py_CLEAR(m->func_globals); - Py_CLEAR(m->func_code); -#if !CYTHON_COMPILING_IN_LIMITED_API -#if PY_VERSION_HEX < 0x030900B1 - Py_CLEAR(__Pyx_CyFunction_GetClassObj(m)); -#else - { - PyObject *cls = (PyObject*) ((PyCMethodObject *) (m))->mm_class; - ((PyCMethodObject *) (m))->mm_class = NULL; - Py_XDECREF(cls); - } -#endif -#endif - Py_CLEAR(m->defaults_tuple); - Py_CLEAR(m->defaults_kwdict); - Py_CLEAR(m->func_annotations); - Py_CLEAR(m->func_is_coroutine); - Py_CLEAR(m->defaults); - return 0; -} -static void __Pyx__CyFunction_dealloc(__pyx_CyFunctionObject *m) -{ - if (__Pyx_CyFunction_weakreflist(m) != NULL) - PyObject_ClearWeakRefs((PyObject *) m); - __Pyx_CyFunction_clear(m); - __Pyx_PyHeapTypeObject_GC_Del(m); -} -static void __Pyx_CyFunction_dealloc(__pyx_CyFunctionObject *m) -{ - PyObject_GC_UnTrack(m); - __Pyx__CyFunction_dealloc(m); -} -static int __Pyx_CyFunction_traverse(__pyx_CyFunctionObject *m, visitproc visit, void *arg) -{ - { - int e = __Pyx_call_type_traverse((PyObject*)m, 1, visit, arg); - if (e) return e; - } - Py_VISIT(m->func_closure); -#if CYTHON_COMPILING_IN_LIMITED_API - Py_VISIT(m->func); -#else - Py_VISIT(((PyCFunctionObject*)m)->m_module); -#endif - Py_VISIT(m->func_dict); - __Pyx_VISIT_CONST(m->func_name); - __Pyx_VISIT_CONST(m->func_qualname); - Py_VISIT(m->func_doc); - Py_VISIT(m->func_globals); - __Pyx_VISIT_CONST(m->func_code); -#if !CYTHON_COMPILING_IN_LIMITED_API - Py_VISIT(__Pyx_CyFunction_GetClassObj(m)); -#endif - Py_VISIT(m->defaults_tuple); - Py_VISIT(m->defaults_kwdict); - Py_VISIT(m->func_is_coroutine); - Py_VISIT(m->defaults); - return 0; -} -static PyObject* -__Pyx_CyFunction_repr(__pyx_CyFunctionObject *op) -{ - PyObject *repr; - __Pyx_BEGIN_CRITICAL_SECTION(op); - repr = PyUnicode_FromFormat("", - op->func_qualname, (void *)op); - __Pyx_END_CRITICAL_SECTION(); - return repr; -} -static PyObject * __Pyx_CyFunction_CallMethod(PyObject *func, PyObject *self, PyObject *arg, PyObject *kw) { -#if CYTHON_COMPILING_IN_LIMITED_API - PyObject *f = ((__pyx_CyFunctionObject*)func)->func; - PyCFunction meth; - int flags; - meth = PyCFunction_GetFunction(f); - if (unlikely(!meth)) return NULL; - flags = PyCFunction_GetFlags(f); - if (unlikely(flags < 0)) return NULL; -#else - PyCFunctionObject* f = (PyCFunctionObject*)func; - PyCFunction meth = f->m_ml->ml_meth; - int flags = f->m_ml->ml_flags; -#endif - Py_ssize_t size; - switch (flags & (METH_VARARGS | METH_KEYWORDS | METH_NOARGS | METH_O)) { - case METH_VARARGS: - if (likely(kw == NULL || PyDict_Size(kw) == 0)) - return (*meth)(self, arg); - break; - case METH_VARARGS | METH_KEYWORDS: - return (*(PyCFunctionWithKeywords)(void(*)(void))meth)(self, arg, kw); - case METH_NOARGS: - if (likely(kw == NULL || PyDict_Size(kw) == 0)) { -#if CYTHON_ASSUME_SAFE_SIZE - size = PyTuple_GET_SIZE(arg); -#else - size = PyTuple_Size(arg); - if (unlikely(size < 0)) return NULL; -#endif - if (likely(size == 0)) - return (*meth)(self, NULL); - __Pyx_CyFunction_raise_argument_count_error( - (__pyx_CyFunctionObject*)func, - "takes no arguments", size); - return NULL; - } - break; - case METH_O: - if (likely(kw == NULL || PyDict_Size(kw) == 0)) { -#if CYTHON_ASSUME_SAFE_SIZE - size = PyTuple_GET_SIZE(arg); -#else - size = PyTuple_Size(arg); - if (unlikely(size < 0)) return NULL; -#endif - if (likely(size == 1)) { - PyObject *result, *arg0; - #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS - arg0 = PyTuple_GET_ITEM(arg, 0); - #else - arg0 = __Pyx_PySequence_ITEM(arg, 0); if (unlikely(!arg0)) return NULL; - #endif - result = (*meth)(self, arg0); - #if !(CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS) - Py_DECREF(arg0); - #endif - return result; - } - __Pyx_CyFunction_raise_argument_count_error( - (__pyx_CyFunctionObject*)func, - "takes exactly one argument", size); - return NULL; - } - break; - default: - PyErr_SetString(PyExc_SystemError, "Bad call flags for CyFunction"); - return NULL; - } - __Pyx_CyFunction_raise_type_error( - (__pyx_CyFunctionObject*)func, "takes no keyword arguments"); - return NULL; -} -static CYTHON_INLINE PyObject *__Pyx_CyFunction_Call(PyObject *func, PyObject *arg, PyObject *kw) { - PyObject *self, *result; -#if CYTHON_COMPILING_IN_LIMITED_API - self = PyCFunction_GetSelf(((__pyx_CyFunctionObject*)func)->func); - if (unlikely(!self) && PyErr_Occurred()) return NULL; -#else - self = ((PyCFunctionObject*)func)->m_self; -#endif - result = __Pyx_CyFunction_CallMethod(func, self, arg, kw); - return result; -} -static PyObject *__Pyx_CyFunction_CallAsMethod(PyObject *func, PyObject *args, PyObject *kw) { - PyObject *result; - __pyx_CyFunctionObject *cyfunc = (__pyx_CyFunctionObject *) func; -#if CYTHON_METH_FASTCALL && (CYTHON_VECTORCALL || CYTHON_BACKPORT_VECTORCALL) - __pyx_vectorcallfunc vc = __Pyx_CyFunction_func_vectorcall(cyfunc); - if (vc) { -#if CYTHON_ASSUME_SAFE_MACROS && CYTHON_ASSUME_SAFE_SIZE - return __Pyx_PyVectorcall_FastCallDict(func, vc, &PyTuple_GET_ITEM(args, 0), (size_t)PyTuple_GET_SIZE(args), kw); -#else - (void) &__Pyx_PyVectorcall_FastCallDict; - return PyVectorcall_Call(func, args, kw); -#endif - } -#endif - if ((cyfunc->flags & __Pyx_CYFUNCTION_CCLASS) && !(cyfunc->flags & __Pyx_CYFUNCTION_STATICMETHOD)) { - Py_ssize_t argc; - PyObject *new_args; - PyObject *self; -#if CYTHON_ASSUME_SAFE_SIZE - argc = PyTuple_GET_SIZE(args); -#else - argc = PyTuple_Size(args); - if (unlikely(argc < 0)) return NULL; -#endif - new_args = PyTuple_GetSlice(args, 1, argc); - if (unlikely(!new_args)) - return NULL; - self = PyTuple_GetItem(args, 0); - if (unlikely(!self)) { - Py_DECREF(new_args); - PyErr_Format(PyExc_TypeError, - "unbound method %.200S() needs an argument", - cyfunc->func_qualname); - return NULL; - } - result = __Pyx_CyFunction_CallMethod(func, self, new_args, kw); - Py_DECREF(new_args); - } else { - result = __Pyx_CyFunction_Call(func, args, kw); - } - return result; -} -#if CYTHON_METH_FASTCALL && (CYTHON_VECTORCALL || CYTHON_BACKPORT_VECTORCALL) -static CYTHON_INLINE int __Pyx_CyFunction_Vectorcall_CheckArgs(__pyx_CyFunctionObject *cyfunc, Py_ssize_t nargs, PyObject *kwnames) -{ - int ret = 0; - if ((cyfunc->flags & __Pyx_CYFUNCTION_CCLASS) && !(cyfunc->flags & __Pyx_CYFUNCTION_STATICMETHOD)) { - if (unlikely(nargs < 1)) { - __Pyx_CyFunction_raise_type_error( - cyfunc, "needs an argument"); - return -1; - } - ret = 1; - } - if (unlikely(kwnames) && unlikely(__Pyx_PyTuple_GET_SIZE(kwnames))) { - __Pyx_CyFunction_raise_type_error( - cyfunc, "takes no keyword arguments"); - return -1; - } - return ret; -} -static PyObject * __Pyx_CyFunction_Vectorcall_NOARGS(PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames) -{ - __pyx_CyFunctionObject *cyfunc = (__pyx_CyFunctionObject *)func; -#if CYTHON_BACKPORT_VECTORCALL - Py_ssize_t nargs = (Py_ssize_t)nargsf; -#else - Py_ssize_t nargs = PyVectorcall_NARGS(nargsf); -#endif - PyObject *self; -#if CYTHON_COMPILING_IN_LIMITED_API - PyCFunction meth = PyCFunction_GetFunction(cyfunc->func); - if (unlikely(!meth)) return NULL; -#else - PyCFunction meth = ((PyCFunctionObject*)cyfunc)->m_ml->ml_meth; -#endif - switch (__Pyx_CyFunction_Vectorcall_CheckArgs(cyfunc, nargs, kwnames)) { - case 1: - self = args[0]; - args += 1; - nargs -= 1; - break; - case 0: -#if CYTHON_COMPILING_IN_LIMITED_API - self = PyCFunction_GetSelf(((__pyx_CyFunctionObject*)cyfunc)->func); - if (unlikely(!self) && PyErr_Occurred()) return NULL; -#else - self = ((PyCFunctionObject*)cyfunc)->m_self; -#endif - break; - default: - return NULL; - } - if (unlikely(nargs != 0)) { - __Pyx_CyFunction_raise_argument_count_error( - cyfunc, "takes no arguments", nargs); - return NULL; - } - return meth(self, NULL); -} -static PyObject * __Pyx_CyFunction_Vectorcall_O(PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames) -{ - __pyx_CyFunctionObject *cyfunc = (__pyx_CyFunctionObject *)func; -#if CYTHON_BACKPORT_VECTORCALL - Py_ssize_t nargs = (Py_ssize_t)nargsf; -#else - Py_ssize_t nargs = PyVectorcall_NARGS(nargsf); -#endif - PyObject *self; -#if CYTHON_COMPILING_IN_LIMITED_API - PyCFunction meth = PyCFunction_GetFunction(cyfunc->func); - if (unlikely(!meth)) return NULL; -#else - PyCFunction meth = ((PyCFunctionObject*)cyfunc)->m_ml->ml_meth; -#endif - switch (__Pyx_CyFunction_Vectorcall_CheckArgs(cyfunc, nargs, kwnames)) { - case 1: - self = args[0]; - args += 1; - nargs -= 1; - break; - case 0: -#if CYTHON_COMPILING_IN_LIMITED_API - self = PyCFunction_GetSelf(((__pyx_CyFunctionObject*)cyfunc)->func); - if (unlikely(!self) && PyErr_Occurred()) return NULL; -#else - self = ((PyCFunctionObject*)cyfunc)->m_self; -#endif - break; - default: - return NULL; - } - if (unlikely(nargs != 1)) { - __Pyx_CyFunction_raise_argument_count_error( - cyfunc, "takes exactly one argument", nargs); - return NULL; - } - return meth(self, args[0]); -} -static PyObject * __Pyx_CyFunction_Vectorcall_FASTCALL_KEYWORDS(PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames) -{ - __pyx_CyFunctionObject *cyfunc = (__pyx_CyFunctionObject *)func; -#if CYTHON_BACKPORT_VECTORCALL - Py_ssize_t nargs = (Py_ssize_t)nargsf; -#else - Py_ssize_t nargs = PyVectorcall_NARGS(nargsf); -#endif - PyObject *self; -#if CYTHON_COMPILING_IN_LIMITED_API - PyCFunction meth = PyCFunction_GetFunction(cyfunc->func); - if (unlikely(!meth)) return NULL; -#else - PyCFunction meth = ((PyCFunctionObject*)cyfunc)->m_ml->ml_meth; -#endif - switch (__Pyx_CyFunction_Vectorcall_CheckArgs(cyfunc, nargs, NULL)) { - case 1: - self = args[0]; - args += 1; - nargs -= 1; - break; - case 0: -#if CYTHON_COMPILING_IN_LIMITED_API - self = PyCFunction_GetSelf(((__pyx_CyFunctionObject*)cyfunc)->func); - if (unlikely(!self) && PyErr_Occurred()) return NULL; -#else - self = ((PyCFunctionObject*)cyfunc)->m_self; -#endif - break; - default: - return NULL; - } - return ((__Pyx_PyCFunctionFastWithKeywords)(void(*)(void))meth)(self, args, nargs, kwnames); -} -static PyObject * __Pyx_CyFunction_Vectorcall_FASTCALL_KEYWORDS_METHOD(PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames) -{ - __pyx_CyFunctionObject *cyfunc = (__pyx_CyFunctionObject *)func; - PyTypeObject *cls = (PyTypeObject *) __Pyx_CyFunction_GetClassObj(cyfunc); -#if CYTHON_BACKPORT_VECTORCALL - Py_ssize_t nargs = (Py_ssize_t)nargsf; -#else - Py_ssize_t nargs = PyVectorcall_NARGS(nargsf); -#endif - PyObject *self; -#if CYTHON_COMPILING_IN_LIMITED_API - PyCFunction meth = PyCFunction_GetFunction(cyfunc->func); - if (unlikely(!meth)) return NULL; -#else - PyCFunction meth = ((PyCFunctionObject*)cyfunc)->m_ml->ml_meth; -#endif - switch (__Pyx_CyFunction_Vectorcall_CheckArgs(cyfunc, nargs, NULL)) { - case 1: - self = args[0]; - args += 1; - nargs -= 1; - break; - case 0: -#if CYTHON_COMPILING_IN_LIMITED_API - self = PyCFunction_GetSelf(((__pyx_CyFunctionObject*)cyfunc)->func); - if (unlikely(!self) && PyErr_Occurred()) return NULL; -#else - self = ((PyCFunctionObject*)cyfunc)->m_self; -#endif - break; - default: - return NULL; - } - return ((__Pyx_PyCMethod)(void(*)(void))meth)(self, cls, args, (size_t)nargs, kwnames); -} -#endif -static PyType_Slot __pyx_CyFunctionType_slots[] = { - {Py_tp_dealloc, (void *)__Pyx_CyFunction_dealloc}, - {Py_tp_repr, (void *)__Pyx_CyFunction_repr}, - {Py_tp_call, (void *)__Pyx_CyFunction_CallAsMethod}, - {Py_tp_traverse, (void *)__Pyx_CyFunction_traverse}, - {Py_tp_clear, (void *)__Pyx_CyFunction_clear}, - {Py_tp_methods, (void *)__pyx_CyFunction_methods}, - {Py_tp_members, (void *)__pyx_CyFunction_members}, - {Py_tp_getset, (void *)__pyx_CyFunction_getsets}, - {Py_tp_descr_get, (void *)__Pyx_PyMethod_New}, - {0, 0}, -}; -static PyType_Spec __pyx_CyFunctionType_spec = { - __PYX_TYPE_MODULE_PREFIX "cython_function_or_method", - sizeof(__pyx_CyFunctionObject), - 0, -#ifdef Py_TPFLAGS_METHOD_DESCRIPTOR - Py_TPFLAGS_METHOD_DESCRIPTOR | -#endif -#if CYTHON_METH_FASTCALL -#if defined(Py_TPFLAGS_HAVE_VECTORCALL) - Py_TPFLAGS_HAVE_VECTORCALL | -#elif defined(_Py_TPFLAGS_HAVE_VECTORCALL) - _Py_TPFLAGS_HAVE_VECTORCALL | -#endif -#endif // CYTHON_METH_FASTCALL -#if PY_VERSION_HEX >= 0x030A0000 - Py_TPFLAGS_IMMUTABLETYPE | -#endif - Py_TPFLAGS_DEFAULT | Py_TPFLAGS_HAVE_GC | Py_TPFLAGS_BASETYPE, - __pyx_CyFunctionType_slots -}; -static int __pyx_CyFunction_init(PyObject *module) { - __pyx_mstatetype *mstate = __Pyx_PyModule_GetState(module); - mstate->__pyx_CyFunctionType = __Pyx_FetchCommonTypeFromSpec(module, &__pyx_CyFunctionType_spec, NULL); - if (unlikely(mstate->__pyx_CyFunctionType == NULL)) { - return -1; - } - return 0; -} -static CYTHON_INLINE PyObject *__Pyx_CyFunction_InitDefaults(PyObject *func, PyTypeObject *defaults_type) { - __pyx_CyFunctionObject *m = (__pyx_CyFunctionObject *) func; - m->defaults = PyObject_CallObject((PyObject*)defaults_type, NULL); // _PyObject_New(defaults_type); - if (unlikely(!m->defaults)) - return NULL; - return m->defaults; -} -static CYTHON_INLINE void __Pyx_CyFunction_SetDefaultsTuple(PyObject *func, PyObject *tuple) { - __pyx_CyFunctionObject *m = (__pyx_CyFunctionObject *) func; - m->defaults_tuple = tuple; - Py_INCREF(tuple); -} -static CYTHON_INLINE void __Pyx_CyFunction_SetDefaultsKwDict(PyObject *func, PyObject *dict) { - __pyx_CyFunctionObject *m = (__pyx_CyFunctionObject *) func; - m->defaults_kwdict = dict; - Py_INCREF(dict); -} -static CYTHON_INLINE void __Pyx_CyFunction_SetAnnotationsDict(PyObject *func, PyObject *dict) { - __pyx_CyFunctionObject *m = (__pyx_CyFunctionObject *) func; - m->func_annotations = dict; - Py_INCREF(dict); -} - -/* CythonFunction */ -static PyObject *__Pyx_CyFunction_New(PyMethodDef *ml, int flags, PyObject* qualname, - PyObject *closure, PyObject *module, PyObject* globals, PyObject* code) { - PyObject *op = __Pyx_CyFunction_Init( - PyObject_GC_New(__pyx_CyFunctionObject, __pyx_mstate_global->__pyx_CyFunctionType), - ml, flags, qualname, closure, module, globals, code - ); - if (likely(op)) { - PyObject_GC_Track(op); - } - return op; -} - -/* CalculateMetaclass */ -static PyObject *__Pyx_CalculateMetaclass(PyTypeObject *metaclass, PyObject *bases) { - Py_ssize_t i, nbases; -#if CYTHON_ASSUME_SAFE_SIZE - nbases = PyTuple_GET_SIZE(bases); -#else - nbases = PyTuple_Size(bases); - if (nbases < 0) return NULL; -#endif - for (i=0; i < nbases; i++) { - PyTypeObject *tmptype; -#if CYTHON_ASSUME_SAFE_MACROS - PyObject *tmp = PyTuple_GET_ITEM(bases, i); -#else - PyObject *tmp = PyTuple_GetItem(bases, i); - if (!tmp) return NULL; -#endif - tmptype = Py_TYPE(tmp); - if (!metaclass) { - metaclass = tmptype; - continue; - } - if (PyType_IsSubtype(metaclass, tmptype)) - continue; - if (PyType_IsSubtype(tmptype, metaclass)) { - metaclass = tmptype; - continue; - } - PyErr_SetString(PyExc_TypeError, - "metaclass conflict: " - "the metaclass of a derived class " - "must be a (non-strict) subclass " - "of the metaclasses of all its bases"); - return NULL; - } - if (!metaclass) { - metaclass = &PyType_Type; - } - Py_INCREF((PyObject*) metaclass); - return (PyObject*) metaclass; -} - -/* Py3ClassCreate */ -static PyObject *__Pyx_Py3MetaclassPrepare(PyObject *metaclass, PyObject *bases, PyObject *name, - PyObject *qualname, PyObject *mkw, PyObject *modname, PyObject *doc) { - PyObject *ns; - if (metaclass) { - PyObject *prep = __Pyx_PyObject_GetAttrStrNoError(metaclass, __pyx_mstate_global->__pyx_n_u_prepare); - if (prep) { - PyObject *pargs[3] = {NULL, name, bases}; - ns = __Pyx_PyObject_FastCallDict(prep, pargs+1, 2 | __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET, mkw); - Py_DECREF(prep); - } else { - if (unlikely(PyErr_Occurred())) - return NULL; - ns = PyDict_New(); - } - } else { - ns = PyDict_New(); - } - if (unlikely(!ns)) - return NULL; - if (unlikely(PyObject_SetItem(ns, __pyx_mstate_global->__pyx_n_u_module, modname) < 0)) goto bad; - if (unlikely(PyObject_SetItem(ns, __pyx_mstate_global->__pyx_n_u_qualname, qualname) < 0)) goto bad; - if (unlikely(doc && PyObject_SetItem(ns, __pyx_mstate_global->__pyx_n_u_doc, doc) < 0)) goto bad; - return ns; -bad: - Py_DECREF(ns); - return NULL; -} -static PyObject *__Pyx_Py3ClassCreate(PyObject *metaclass, PyObject *name, PyObject *bases, - PyObject *dict, PyObject *mkw, - int calculate_metaclass, int allow_py2_metaclass) { - PyObject *result; - PyObject *owned_metaclass = NULL; - PyObject *margs[4] = {NULL, name, bases, dict}; - if (allow_py2_metaclass) { - owned_metaclass = PyObject_GetItem(dict, __pyx_mstate_global->__pyx_n_u_metaclass); - if (owned_metaclass) { - metaclass = owned_metaclass; - } else if (likely(PyErr_ExceptionMatches(PyExc_KeyError))) { - PyErr_Clear(); - } else { - return NULL; - } - } - if (calculate_metaclass && (!metaclass || PyType_Check(metaclass))) { - metaclass = __Pyx_CalculateMetaclass((PyTypeObject*) metaclass, bases); - Py_XDECREF(owned_metaclass); - if (unlikely(!metaclass)) - return NULL; - owned_metaclass = metaclass; - } - result = __Pyx_PyObject_FastCallDict(metaclass, margs+1, 3 | __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET, mkw); - Py_XDECREF(owned_metaclass); - return result; -} - -/* CLineInTraceback */ -#if CYTHON_CLINE_IN_TRACEBACK && CYTHON_CLINE_IN_TRACEBACK_RUNTIME -static int __Pyx_CLineForTraceback(PyThreadState *tstate, int c_line) { - PyObject *use_cline; - PyObject *ptype, *pvalue, *ptraceback; -#if CYTHON_COMPILING_IN_CPYTHON - PyObject **cython_runtime_dict; -#endif - CYTHON_MAYBE_UNUSED_VAR(tstate); - if (unlikely(!__pyx_mstate_global->__pyx_cython_runtime)) { - return c_line; - } - __Pyx_ErrFetchInState(tstate, &ptype, &pvalue, &ptraceback); -#if CYTHON_COMPILING_IN_CPYTHON - cython_runtime_dict = _PyObject_GetDictPtr(__pyx_mstate_global->__pyx_cython_runtime); - if (likely(cython_runtime_dict)) { - __Pyx_BEGIN_CRITICAL_SECTION(*cython_runtime_dict); - __PYX_PY_DICT_LOOKUP_IF_MODIFIED( - use_cline, *cython_runtime_dict, - __Pyx_PyDict_GetItemStr(*cython_runtime_dict, __pyx_mstate_global->__pyx_n_u_cline_in_traceback)) - Py_XINCREF(use_cline); - __Pyx_END_CRITICAL_SECTION(); - } else -#endif - { - PyObject *use_cline_obj = __Pyx_PyObject_GetAttrStrNoError(__pyx_mstate_global->__pyx_cython_runtime, __pyx_mstate_global->__pyx_n_u_cline_in_traceback); - if (use_cline_obj) { - use_cline = PyObject_Not(use_cline_obj) ? Py_False : Py_True; - Py_INCREF(use_cline); - Py_DECREF(use_cline_obj); - } else { - PyErr_Clear(); - use_cline = NULL; - } - } - if (!use_cline) { - c_line = 0; - (void) PyObject_SetAttr(__pyx_mstate_global->__pyx_cython_runtime, __pyx_mstate_global->__pyx_n_u_cline_in_traceback, Py_False); - } - else if (use_cline == Py_False || (use_cline != Py_True && PyObject_Not(use_cline) != 0)) { - c_line = 0; - } - Py_XDECREF(use_cline); - __Pyx_ErrRestoreInState(tstate, ptype, pvalue, ptraceback); - return c_line; -} -#endif - -/* CodeObjectCache */ -static int __pyx_bisect_code_objects(__Pyx_CodeObjectCacheEntry* entries, int count, int code_line) { - int start = 0, mid = 0, end = count - 1; - if (end >= 0 && code_line > entries[end].code_line) { - return count; - } - while (start < end) { - mid = start + (end - start) / 2; - if (code_line < entries[mid].code_line) { - end = mid; - } else if (code_line > entries[mid].code_line) { - start = mid + 1; - } else { - return mid; - } - } - if (code_line <= entries[mid].code_line) { - return mid; - } else { - return mid + 1; - } -} -static __Pyx_CachedCodeObjectType *__pyx__find_code_object(struct __Pyx_CodeObjectCache *code_cache, int code_line) { - __Pyx_CachedCodeObjectType* code_object; - int pos; - if (unlikely(!code_line) || unlikely(!code_cache->entries)) { - return NULL; - } - pos = __pyx_bisect_code_objects(code_cache->entries, code_cache->count, code_line); - if (unlikely(pos >= code_cache->count) || unlikely(code_cache->entries[pos].code_line != code_line)) { - return NULL; - } - code_object = code_cache->entries[pos].code_object; - Py_INCREF(code_object); - return code_object; -} -static __Pyx_CachedCodeObjectType *__pyx_find_code_object(int code_line) { -#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING && !CYTHON_ATOMICS - (void)__pyx__find_code_object; - return NULL; // Most implementation should have atomics. But otherwise, don't make it thread-safe, just miss. -#else - struct __Pyx_CodeObjectCache *code_cache = &__pyx_mstate_global->__pyx_code_cache; -#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - __pyx_nonatomic_int_type old_count = __pyx_atomic_incr_acq_rel(&code_cache->accessor_count); - if (old_count < 0) { - __pyx_atomic_decr_acq_rel(&code_cache->accessor_count); - return NULL; - } -#endif - __Pyx_CachedCodeObjectType *result = __pyx__find_code_object(code_cache, code_line); -#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - __pyx_atomic_decr_acq_rel(&code_cache->accessor_count); -#endif - return result; -#endif -} -static void __pyx__insert_code_object(struct __Pyx_CodeObjectCache *code_cache, int code_line, __Pyx_CachedCodeObjectType* code_object) -{ - int pos, i; - __Pyx_CodeObjectCacheEntry* entries = code_cache->entries; - if (unlikely(!code_line)) { - return; - } - if (unlikely(!entries)) { - entries = (__Pyx_CodeObjectCacheEntry*)PyMem_Malloc(64*sizeof(__Pyx_CodeObjectCacheEntry)); - if (likely(entries)) { - code_cache->entries = entries; - code_cache->max_count = 64; - code_cache->count = 1; - entries[0].code_line = code_line; - entries[0].code_object = code_object; - Py_INCREF(code_object); - } - return; - } - pos = __pyx_bisect_code_objects(code_cache->entries, code_cache->count, code_line); - if ((pos < code_cache->count) && unlikely(code_cache->entries[pos].code_line == code_line)) { - __Pyx_CachedCodeObjectType* tmp = entries[pos].code_object; - entries[pos].code_object = code_object; - Py_INCREF(code_object); - Py_DECREF(tmp); - return; - } - if (code_cache->count == code_cache->max_count) { - int new_max = code_cache->max_count + 64; - entries = (__Pyx_CodeObjectCacheEntry*)PyMem_Realloc( - code_cache->entries, ((size_t)new_max) * sizeof(__Pyx_CodeObjectCacheEntry)); - if (unlikely(!entries)) { - return; - } - code_cache->entries = entries; - code_cache->max_count = new_max; - } - for (i=code_cache->count; i>pos; i--) { - entries[i] = entries[i-1]; - } - entries[pos].code_line = code_line; - entries[pos].code_object = code_object; - code_cache->count++; - Py_INCREF(code_object); -} -static void __pyx_insert_code_object(int code_line, __Pyx_CachedCodeObjectType* code_object) { -#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING && !CYTHON_ATOMICS - (void)__pyx__insert_code_object; - return; // Most implementation should have atomics. But otherwise, don't make it thread-safe, just fail. -#else - struct __Pyx_CodeObjectCache *code_cache = &__pyx_mstate_global->__pyx_code_cache; -#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - __pyx_nonatomic_int_type expected = 0; - if (!__pyx_atomic_int_cmp_exchange(&code_cache->accessor_count, &expected, INT_MIN)) { - return; - } -#endif - __pyx__insert_code_object(code_cache, code_line, code_object); -#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - __pyx_atomic_sub(&code_cache->accessor_count, INT_MIN); -#endif -#endif -} - -/* AddTraceback */ -#include "compile.h" -#include "frameobject.h" -#include "traceback.h" -#if PY_VERSION_HEX >= 0x030b00a6 && !CYTHON_COMPILING_IN_LIMITED_API && !defined(PYPY_VERSION) - #ifndef Py_BUILD_CORE - #define Py_BUILD_CORE 1 - #endif - #include "internal/pycore_frame.h" -#endif -#if CYTHON_COMPILING_IN_LIMITED_API -static PyObject *__Pyx_PyCode_Replace_For_AddTraceback(PyObject *code, PyObject *scratch_dict, - PyObject *firstlineno, PyObject *name) { - PyObject *replace = NULL; - if (unlikely(PyDict_SetItemString(scratch_dict, "co_firstlineno", firstlineno))) return NULL; - if (unlikely(PyDict_SetItemString(scratch_dict, "co_name", name))) return NULL; - replace = PyObject_GetAttrString(code, "replace"); - if (likely(replace)) { - PyObject *result = PyObject_Call(replace, __pyx_mstate_global->__pyx_empty_tuple, scratch_dict); - Py_DECREF(replace); - return result; - } - PyErr_Clear(); - return NULL; -} -static void __Pyx_AddTraceback(const char *funcname, int c_line, - int py_line, const char *filename) { - PyObject *code_object = NULL, *py_py_line = NULL, *py_funcname = NULL, *dict = NULL; - PyObject *replace = NULL, *getframe = NULL, *frame = NULL; - PyObject *exc_type, *exc_value, *exc_traceback; - int success = 0; - if (c_line) { - (void) __pyx_cfilenm; - (void) __Pyx_CLineForTraceback(__Pyx_PyThreadState_Current, c_line); - } - PyErr_Fetch(&exc_type, &exc_value, &exc_traceback); - code_object = __pyx_find_code_object(c_line ? -c_line : py_line); - if (!code_object) { - code_object = Py_CompileString("_getframe()", filename, Py_eval_input); - if (unlikely(!code_object)) goto bad; - py_py_line = PyLong_FromLong(py_line); - if (unlikely(!py_py_line)) goto bad; - py_funcname = PyUnicode_FromString(funcname); - if (unlikely(!py_funcname)) goto bad; - dict = PyDict_New(); - if (unlikely(!dict)) goto bad; - { - PyObject *old_code_object = code_object; - code_object = __Pyx_PyCode_Replace_For_AddTraceback(code_object, dict, py_py_line, py_funcname); - Py_DECREF(old_code_object); - } - if (unlikely(!code_object)) goto bad; - __pyx_insert_code_object(c_line ? -c_line : py_line, code_object); - } else { - dict = PyDict_New(); - } - getframe = PySys_GetObject("_getframe"); - if (unlikely(!getframe)) goto bad; - if (unlikely(PyDict_SetItemString(dict, "_getframe", getframe))) goto bad; - frame = PyEval_EvalCode(code_object, dict, dict); - if (unlikely(!frame) || frame == Py_None) goto bad; - success = 1; - bad: - PyErr_Restore(exc_type, exc_value, exc_traceback); - Py_XDECREF(code_object); - Py_XDECREF(py_py_line); - Py_XDECREF(py_funcname); - Py_XDECREF(dict); - Py_XDECREF(replace); - if (success) { - PyTraceBack_Here( - (struct _frame*)frame); - } - Py_XDECREF(frame); -} -#else -static PyCodeObject* __Pyx_CreateCodeObjectForTraceback( - const char *funcname, int c_line, - int py_line, const char *filename) { - PyCodeObject *py_code = NULL; - PyObject *py_funcname = NULL; - if (c_line) { - py_funcname = PyUnicode_FromFormat( "%s (%s:%d)", funcname, __pyx_cfilenm, c_line); - if (!py_funcname) goto bad; - funcname = PyUnicode_AsUTF8(py_funcname); - if (!funcname) goto bad; - } - py_code = PyCode_NewEmpty(filename, funcname, py_line); - Py_XDECREF(py_funcname); - return py_code; -bad: - Py_XDECREF(py_funcname); - return NULL; -} -static void __Pyx_AddTraceback(const char *funcname, int c_line, - int py_line, const char *filename) { - PyCodeObject *py_code = 0; - PyFrameObject *py_frame = 0; - PyThreadState *tstate = __Pyx_PyThreadState_Current; - PyObject *ptype, *pvalue, *ptraceback; - if (c_line) { - c_line = __Pyx_CLineForTraceback(tstate, c_line); - } - py_code = __pyx_find_code_object(c_line ? -c_line : py_line); - if (!py_code) { - __Pyx_ErrFetchInState(tstate, &ptype, &pvalue, &ptraceback); - py_code = __Pyx_CreateCodeObjectForTraceback( - funcname, c_line, py_line, filename); - if (!py_code) { - /* If the code object creation fails, then we should clear the - fetched exception references and propagate the new exception */ - Py_XDECREF(ptype); - Py_XDECREF(pvalue); - Py_XDECREF(ptraceback); - goto bad; - } - __Pyx_ErrRestoreInState(tstate, ptype, pvalue, ptraceback); - __pyx_insert_code_object(c_line ? -c_line : py_line, py_code); - } - py_frame = PyFrame_New( - tstate, /*PyThreadState *tstate,*/ - py_code, /*PyCodeObject *code,*/ - __pyx_mstate_global->__pyx_d, /*PyObject *globals,*/ - 0 /*PyObject *locals*/ - ); - if (!py_frame) goto bad; - __Pyx_PyFrame_SetLineNumber(py_frame, py_line); - PyTraceBack_Here(py_frame); -bad: - Py_XDECREF(py_code); - Py_XDECREF(py_frame); -} -#endif - -/* CIntFromPyVerify */ -#define __PYX_VERIFY_RETURN_INT(target_type, func_type, func_value)\ - __PYX__VERIFY_RETURN_INT(target_type, func_type, func_value, 0) -#define __PYX_VERIFY_RETURN_INT_EXC(target_type, func_type, func_value)\ - __PYX__VERIFY_RETURN_INT(target_type, func_type, func_value, 1) -#define __PYX__VERIFY_RETURN_INT(target_type, func_type, func_value, exc)\ - {\ - func_type value = func_value;\ - if (sizeof(target_type) < sizeof(func_type)) {\ - if (unlikely(value != (func_type) (target_type) value)) {\ - func_type zero = 0;\ - if (exc && unlikely(value == (func_type)-1 && PyErr_Occurred()))\ - return (target_type) -1;\ - if (is_unsigned && unlikely(value < zero))\ - goto raise_neg_overflow;\ - else\ - goto raise_overflow;\ - }\ - }\ - return (target_type) value;\ - } - -/* CIntFromPy */ -static CYTHON_INLINE long __Pyx_PyLong_As_long(PyObject *x) { -#ifdef __Pyx_HAS_GCC_DIAGNOSTIC -#pragma GCC diagnostic push -#pragma GCC diagnostic ignored "-Wconversion" -#endif - const long neg_one = (long) -1, const_zero = (long) 0; -#ifdef __Pyx_HAS_GCC_DIAGNOSTIC -#pragma GCC diagnostic pop -#endif - const int is_unsigned = neg_one > const_zero; - if (unlikely(!PyLong_Check(x))) { - long val; - PyObject *tmp = __Pyx_PyNumber_Long(x); - if (!tmp) return (long) -1; - val = __Pyx_PyLong_As_long(tmp); - Py_DECREF(tmp); - return val; - } - if (is_unsigned) { -#if CYTHON_USE_PYLONG_INTERNALS - if (unlikely(__Pyx_PyLong_IsNeg(x))) { - goto raise_neg_overflow; - } else if (__Pyx_PyLong_IsCompact(x)) { - __PYX_VERIFY_RETURN_INT(long, __Pyx_compact_upylong, __Pyx_PyLong_CompactValueUnsigned(x)) - } else { - const digit* digits = __Pyx_PyLong_Digits(x); - assert(__Pyx_PyLong_DigitCount(x) > 1); - switch (__Pyx_PyLong_DigitCount(x)) { - case 2: - if ((8 * sizeof(long) > 1 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 2 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(long, unsigned long, (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(long) >= 2 * PyLong_SHIFT)) { - return (long) (((((long)digits[1]) << PyLong_SHIFT) | (long)digits[0])); - } - } - break; - case 3: - if ((8 * sizeof(long) > 2 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 3 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(long, unsigned long, (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(long) >= 3 * PyLong_SHIFT)) { - return (long) (((((((long)digits[2]) << PyLong_SHIFT) | (long)digits[1]) << PyLong_SHIFT) | (long)digits[0])); - } - } - break; - case 4: - if ((8 * sizeof(long) > 3 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 4 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(long, unsigned long, (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(long) >= 4 * PyLong_SHIFT)) { - return (long) (((((((((long)digits[3]) << PyLong_SHIFT) | (long)digits[2]) << PyLong_SHIFT) | (long)digits[1]) << PyLong_SHIFT) | (long)digits[0])); - } - } - break; - } - } -#endif -#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX < 0x030C00A7 - if (unlikely(Py_SIZE(x) < 0)) { - goto raise_neg_overflow; - } -#else - { - int result = PyObject_RichCompareBool(x, Py_False, Py_LT); - if (unlikely(result < 0)) - return (long) -1; - if (unlikely(result == 1)) - goto raise_neg_overflow; - } -#endif - if ((sizeof(long) <= sizeof(unsigned long))) { - __PYX_VERIFY_RETURN_INT_EXC(long, unsigned long, PyLong_AsUnsignedLong(x)) -#ifdef HAVE_LONG_LONG - } else if ((sizeof(long) <= sizeof(unsigned PY_LONG_LONG))) { - __PYX_VERIFY_RETURN_INT_EXC(long, unsigned PY_LONG_LONG, PyLong_AsUnsignedLongLong(x)) -#endif - } - } else { -#if CYTHON_USE_PYLONG_INTERNALS - if (__Pyx_PyLong_IsCompact(x)) { - __PYX_VERIFY_RETURN_INT(long, __Pyx_compact_pylong, __Pyx_PyLong_CompactValue(x)) - } else { - const digit* digits = __Pyx_PyLong_Digits(x); - assert(__Pyx_PyLong_DigitCount(x) > 1); - switch (__Pyx_PyLong_SignedDigitCount(x)) { - case -2: - if ((8 * sizeof(long) - 1 > 1 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 2 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(long, long, -(long) (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(long) - 1 > 2 * PyLong_SHIFT)) { - return (long) (((long)-1)*(((((long)digits[1]) << PyLong_SHIFT) | (long)digits[0]))); - } - } - break; - case 2: - if ((8 * sizeof(long) > 1 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 2 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(long, unsigned long, (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(long) - 1 > 2 * PyLong_SHIFT)) { - return (long) ((((((long)digits[1]) << PyLong_SHIFT) | (long)digits[0]))); - } - } - break; - case -3: - if ((8 * sizeof(long) - 1 > 2 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 3 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(long, long, -(long) (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(long) - 1 > 3 * PyLong_SHIFT)) { - return (long) (((long)-1)*(((((((long)digits[2]) << PyLong_SHIFT) | (long)digits[1]) << PyLong_SHIFT) | (long)digits[0]))); - } - } - break; - case 3: - if ((8 * sizeof(long) > 2 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 3 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(long, unsigned long, (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(long) - 1 > 3 * PyLong_SHIFT)) { - return (long) ((((((((long)digits[2]) << PyLong_SHIFT) | (long)digits[1]) << PyLong_SHIFT) | (long)digits[0]))); - } - } - break; - case -4: - if ((8 * sizeof(long) - 1 > 3 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 4 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(long, long, -(long) (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(long) - 1 > 4 * PyLong_SHIFT)) { - return (long) (((long)-1)*(((((((((long)digits[3]) << PyLong_SHIFT) | (long)digits[2]) << PyLong_SHIFT) | (long)digits[1]) << PyLong_SHIFT) | (long)digits[0]))); - } - } - break; - case 4: - if ((8 * sizeof(long) > 3 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 4 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(long, unsigned long, (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(long) - 1 > 4 * PyLong_SHIFT)) { - return (long) ((((((((((long)digits[3]) << PyLong_SHIFT) | (long)digits[2]) << PyLong_SHIFT) | (long)digits[1]) << PyLong_SHIFT) | (long)digits[0]))); - } - } - break; - } - } -#endif - if ((sizeof(long) <= sizeof(long))) { - __PYX_VERIFY_RETURN_INT_EXC(long, long, PyLong_AsLong(x)) -#ifdef HAVE_LONG_LONG - } else if ((sizeof(long) <= sizeof(PY_LONG_LONG))) { - __PYX_VERIFY_RETURN_INT_EXC(long, PY_LONG_LONG, PyLong_AsLongLong(x)) -#endif - } - } - { - long val; - int ret = -1; -#if PY_VERSION_HEX >= 0x030d00A6 && !CYTHON_COMPILING_IN_LIMITED_API - Py_ssize_t bytes_copied = PyLong_AsNativeBytes( - x, &val, sizeof(val), Py_ASNATIVEBYTES_NATIVE_ENDIAN | (is_unsigned ? Py_ASNATIVEBYTES_UNSIGNED_BUFFER | Py_ASNATIVEBYTES_REJECT_NEGATIVE : 0)); - if (unlikely(bytes_copied == -1)) { - } else if (unlikely(bytes_copied > (Py_ssize_t) sizeof(val))) { - goto raise_overflow; - } else { - ret = 0; - } -#elif PY_VERSION_HEX < 0x030d0000 && !(CYTHON_COMPILING_IN_PYPY || CYTHON_COMPILING_IN_LIMITED_API) || defined(_PyLong_AsByteArray) - int one = 1; int is_little = (int)*(unsigned char *)&one; - unsigned char *bytes = (unsigned char *)&val; - ret = _PyLong_AsByteArray((PyLongObject *)x, - bytes, sizeof(val), - is_little, !is_unsigned); -#else - PyObject *v; - PyObject *stepval = NULL, *mask = NULL, *shift = NULL; - int bits, remaining_bits, is_negative = 0; - int chunk_size = (sizeof(long) < 8) ? 30 : 62; - if (likely(PyLong_CheckExact(x))) { - v = __Pyx_NewRef(x); - } else { - v = PyNumber_Long(x); - if (unlikely(!v)) return (long) -1; - assert(PyLong_CheckExact(v)); - } - { - int result = PyObject_RichCompareBool(v, Py_False, Py_LT); - if (unlikely(result < 0)) { - Py_DECREF(v); - return (long) -1; - } - is_negative = result == 1; - } - if (is_unsigned && unlikely(is_negative)) { - Py_DECREF(v); - goto raise_neg_overflow; - } else if (is_negative) { - stepval = PyNumber_Invert(v); - Py_DECREF(v); - if (unlikely(!stepval)) - return (long) -1; - } else { - stepval = v; - } - v = NULL; - val = (long) 0; - mask = PyLong_FromLong((1L << chunk_size) - 1); if (unlikely(!mask)) goto done; - shift = PyLong_FromLong(chunk_size); if (unlikely(!shift)) goto done; - for (bits = 0; bits < (int) sizeof(long) * 8 - chunk_size; bits += chunk_size) { - PyObject *tmp, *digit; - long idigit; - digit = PyNumber_And(stepval, mask); - if (unlikely(!digit)) goto done; - idigit = PyLong_AsLong(digit); - Py_DECREF(digit); - if (unlikely(idigit < 0)) goto done; - val |= ((long) idigit) << bits; - tmp = PyNumber_Rshift(stepval, shift); - if (unlikely(!tmp)) goto done; - Py_DECREF(stepval); stepval = tmp; - } - Py_DECREF(shift); shift = NULL; - Py_DECREF(mask); mask = NULL; - { - long idigit = PyLong_AsLong(stepval); - if (unlikely(idigit < 0)) goto done; - remaining_bits = ((int) sizeof(long) * 8) - bits - (is_unsigned ? 0 : 1); - if (unlikely(idigit >= (1L << remaining_bits))) - goto raise_overflow; - val |= ((long) idigit) << bits; - } - if (!is_unsigned) { - if (unlikely(val & (((long) 1) << (sizeof(long) * 8 - 1)))) - goto raise_overflow; - if (is_negative) - val = ~val; - } - ret = 0; - done: - Py_XDECREF(shift); - Py_XDECREF(mask); - Py_XDECREF(stepval); -#endif - if (unlikely(ret)) - return (long) -1; - return val; - } -raise_overflow: - PyErr_SetString(PyExc_OverflowError, - "value too large to convert to long"); - return (long) -1; -raise_neg_overflow: - PyErr_SetString(PyExc_OverflowError, - "can't convert negative value to long"); - return (long) -1; -} - -/* PyObjectVectorCallKwBuilder */ -#if CYTHON_VECTORCALL -static int __Pyx_VectorcallBuilder_AddArg(PyObject *key, PyObject *value, PyObject *builder, PyObject **args, int n) { - (void)__Pyx_PyObject_FastCallDict; - if (__Pyx_PyTuple_SET_ITEM(builder, n, key) != (0)) return -1; - Py_INCREF(key); - args[n] = value; - return 0; -} -CYTHON_UNUSED static int __Pyx_VectorcallBuilder_AddArg_Check(PyObject *key, PyObject *value, PyObject *builder, PyObject **args, int n) { - (void)__Pyx_VectorcallBuilder_AddArgStr; - if (unlikely(!PyUnicode_Check(key))) { - PyErr_SetString(PyExc_TypeError, "keywords must be strings"); - return -1; - } - return __Pyx_VectorcallBuilder_AddArg(key, value, builder, args, n); -} -static int __Pyx_VectorcallBuilder_AddArgStr(const char *key, PyObject *value, PyObject *builder, PyObject **args, int n) { - PyObject *pyKey = PyUnicode_FromString(key); - if (!pyKey) return -1; - return __Pyx_VectorcallBuilder_AddArg(pyKey, value, builder, args, n); -} -#else // CYTHON_VECTORCALL -CYTHON_UNUSED static int __Pyx_VectorcallBuilder_AddArg_Check(PyObject *key, PyObject *value, PyObject *builder, CYTHON_UNUSED PyObject **args, CYTHON_UNUSED int n) { - if (unlikely(!PyUnicode_Check(key))) { - PyErr_SetString(PyExc_TypeError, "keywords must be strings"); - return -1; - } - return PyDict_SetItem(builder, key, value); -} -#endif - -/* CIntToPy */ -static CYTHON_INLINE PyObject* __Pyx_PyLong_From_long(long value) { -#ifdef __Pyx_HAS_GCC_DIAGNOSTIC -#pragma GCC diagnostic push -#pragma GCC diagnostic ignored "-Wconversion" -#endif - const long neg_one = (long) -1, const_zero = (long) 0; -#ifdef __Pyx_HAS_GCC_DIAGNOSTIC -#pragma GCC diagnostic pop -#endif - const int is_unsigned = neg_one > const_zero; - if (is_unsigned) { - if (sizeof(long) < sizeof(long)) { - return PyLong_FromLong((long) value); - } else if (sizeof(long) <= sizeof(unsigned long)) { - return PyLong_FromUnsignedLong((unsigned long) value); -#ifdef HAVE_LONG_LONG - } else if (sizeof(long) <= sizeof(unsigned PY_LONG_LONG)) { - return PyLong_FromUnsignedLongLong((unsigned PY_LONG_LONG) value); -#endif - } - } else { - if (sizeof(long) <= sizeof(long)) { - return PyLong_FromLong((long) value); -#ifdef HAVE_LONG_LONG - } else if (sizeof(long) <= sizeof(PY_LONG_LONG)) { - return PyLong_FromLongLong((PY_LONG_LONG) value); -#endif - } - } - { - unsigned char *bytes = (unsigned char *)&value; -#if !CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX >= 0x030d00A4 - if (is_unsigned) { - return PyLong_FromUnsignedNativeBytes(bytes, sizeof(value), -1); - } else { - return PyLong_FromNativeBytes(bytes, sizeof(value), -1); - } -#elif !CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX < 0x030d0000 - int one = 1; int little = (int)*(unsigned char *)&one; - return _PyLong_FromByteArray(bytes, sizeof(long), - little, !is_unsigned); -#else - int one = 1; int little = (int)*(unsigned char *)&one; - PyObject *from_bytes, *result = NULL, *kwds = NULL; - PyObject *py_bytes = NULL, *order_str = NULL; - from_bytes = PyObject_GetAttrString((PyObject*)&PyLong_Type, "from_bytes"); - if (!from_bytes) return NULL; - py_bytes = PyBytes_FromStringAndSize((char*)bytes, sizeof(long)); - if (!py_bytes) goto limited_bad; - order_str = PyUnicode_FromString(little ? "little" : "big"); - if (!order_str) goto limited_bad; - { - PyObject *args[3+(CYTHON_VECTORCALL ? 1 : 0)] = { NULL, py_bytes, order_str }; - if (!is_unsigned) { - kwds = __Pyx_MakeVectorcallBuilderKwds(1); - if (!kwds) goto limited_bad; - if (__Pyx_VectorcallBuilder_AddArgStr("signed", __Pyx_NewRef(Py_True), kwds, args+3, 0) < 0) goto limited_bad; - } - result = __Pyx_Object_Vectorcall_CallFromBuilder(from_bytes, args+1, 2 | __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET, kwds); - } - limited_bad: - Py_XDECREF(kwds); - Py_XDECREF(order_str); - Py_XDECREF(py_bytes); - Py_XDECREF(from_bytes); - return result; -#endif - } -} - -/* FormatTypeName */ -#if CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX < 0x030d0000 -static __Pyx_TypeName -__Pyx_PyType_GetFullyQualifiedName(PyTypeObject* tp) -{ - PyObject *module = NULL, *name = NULL, *result = NULL; - #if __PYX_LIMITED_VERSION_HEX < 0x030b0000 - name = __Pyx_PyObject_GetAttrStr((PyObject *)tp, - __pyx_mstate_global->__pyx_n_u_qualname); - #else - name = PyType_GetQualName(tp); - #endif - if (unlikely(name == NULL) || unlikely(!PyUnicode_Check(name))) goto bad; - module = __Pyx_PyObject_GetAttrStr((PyObject *)tp, - __pyx_mstate_global->__pyx_n_u_module); - if (unlikely(module == NULL) || unlikely(!PyUnicode_Check(module))) goto bad; - if (PyUnicode_CompareWithASCIIString(module, "builtins") == 0) { - result = name; - name = NULL; - goto done; - } - result = PyUnicode_FromFormat("%U.%U", module, name); - if (unlikely(result == NULL)) goto bad; - done: - Py_XDECREF(name); - Py_XDECREF(module); - return result; - bad: - PyErr_Clear(); - if (name) { - result = name; - name = NULL; - } else { - result = __Pyx_NewRef(__pyx_mstate_global->__pyx_kp_u__5); - } - goto done; -} -#endif - -/* CIntFromPy */ -static CYTHON_INLINE int __Pyx_PyLong_As_int(PyObject *x) { -#ifdef __Pyx_HAS_GCC_DIAGNOSTIC -#pragma GCC diagnostic push -#pragma GCC diagnostic ignored "-Wconversion" -#endif - const int neg_one = (int) -1, const_zero = (int) 0; -#ifdef __Pyx_HAS_GCC_DIAGNOSTIC -#pragma GCC diagnostic pop -#endif - const int is_unsigned = neg_one > const_zero; - if (unlikely(!PyLong_Check(x))) { - int val; - PyObject *tmp = __Pyx_PyNumber_Long(x); - if (!tmp) return (int) -1; - val = __Pyx_PyLong_As_int(tmp); - Py_DECREF(tmp); - return val; - } - if (is_unsigned) { -#if CYTHON_USE_PYLONG_INTERNALS - if (unlikely(__Pyx_PyLong_IsNeg(x))) { - goto raise_neg_overflow; - } else if (__Pyx_PyLong_IsCompact(x)) { - __PYX_VERIFY_RETURN_INT(int, __Pyx_compact_upylong, __Pyx_PyLong_CompactValueUnsigned(x)) - } else { - const digit* digits = __Pyx_PyLong_Digits(x); - assert(__Pyx_PyLong_DigitCount(x) > 1); - switch (__Pyx_PyLong_DigitCount(x)) { - case 2: - if ((8 * sizeof(int) > 1 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 2 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(int, unsigned long, (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(int) >= 2 * PyLong_SHIFT)) { - return (int) (((((int)digits[1]) << PyLong_SHIFT) | (int)digits[0])); - } - } - break; - case 3: - if ((8 * sizeof(int) > 2 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 3 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(int, unsigned long, (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(int) >= 3 * PyLong_SHIFT)) { - return (int) (((((((int)digits[2]) << PyLong_SHIFT) | (int)digits[1]) << PyLong_SHIFT) | (int)digits[0])); - } - } - break; - case 4: - if ((8 * sizeof(int) > 3 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 4 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(int, unsigned long, (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(int) >= 4 * PyLong_SHIFT)) { - return (int) (((((((((int)digits[3]) << PyLong_SHIFT) | (int)digits[2]) << PyLong_SHIFT) | (int)digits[1]) << PyLong_SHIFT) | (int)digits[0])); - } - } - break; - } - } -#endif -#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX < 0x030C00A7 - if (unlikely(Py_SIZE(x) < 0)) { - goto raise_neg_overflow; - } -#else - { - int result = PyObject_RichCompareBool(x, Py_False, Py_LT); - if (unlikely(result < 0)) - return (int) -1; - if (unlikely(result == 1)) - goto raise_neg_overflow; - } -#endif - if ((sizeof(int) <= sizeof(unsigned long))) { - __PYX_VERIFY_RETURN_INT_EXC(int, unsigned long, PyLong_AsUnsignedLong(x)) -#ifdef HAVE_LONG_LONG - } else if ((sizeof(int) <= sizeof(unsigned PY_LONG_LONG))) { - __PYX_VERIFY_RETURN_INT_EXC(int, unsigned PY_LONG_LONG, PyLong_AsUnsignedLongLong(x)) -#endif - } - } else { -#if CYTHON_USE_PYLONG_INTERNALS - if (__Pyx_PyLong_IsCompact(x)) { - __PYX_VERIFY_RETURN_INT(int, __Pyx_compact_pylong, __Pyx_PyLong_CompactValue(x)) - } else { - const digit* digits = __Pyx_PyLong_Digits(x); - assert(__Pyx_PyLong_DigitCount(x) > 1); - switch (__Pyx_PyLong_SignedDigitCount(x)) { - case -2: - if ((8 * sizeof(int) - 1 > 1 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 2 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(int, long, -(long) (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(int) - 1 > 2 * PyLong_SHIFT)) { - return (int) (((int)-1)*(((((int)digits[1]) << PyLong_SHIFT) | (int)digits[0]))); - } - } - break; - case 2: - if ((8 * sizeof(int) > 1 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 2 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(int, unsigned long, (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(int) - 1 > 2 * PyLong_SHIFT)) { - return (int) ((((((int)digits[1]) << PyLong_SHIFT) | (int)digits[0]))); - } - } - break; - case -3: - if ((8 * sizeof(int) - 1 > 2 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 3 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(int, long, -(long) (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(int) - 1 > 3 * PyLong_SHIFT)) { - return (int) (((int)-1)*(((((((int)digits[2]) << PyLong_SHIFT) | (int)digits[1]) << PyLong_SHIFT) | (int)digits[0]))); - } - } - break; - case 3: - if ((8 * sizeof(int) > 2 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 3 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(int, unsigned long, (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(int) - 1 > 3 * PyLong_SHIFT)) { - return (int) ((((((((int)digits[2]) << PyLong_SHIFT) | (int)digits[1]) << PyLong_SHIFT) | (int)digits[0]))); - } - } - break; - case -4: - if ((8 * sizeof(int) - 1 > 3 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 4 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(int, long, -(long) (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(int) - 1 > 4 * PyLong_SHIFT)) { - return (int) (((int)-1)*(((((((((int)digits[3]) << PyLong_SHIFT) | (int)digits[2]) << PyLong_SHIFT) | (int)digits[1]) << PyLong_SHIFT) | (int)digits[0]))); - } - } - break; - case 4: - if ((8 * sizeof(int) > 3 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 4 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(int, unsigned long, (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(int) - 1 > 4 * PyLong_SHIFT)) { - return (int) ((((((((((int)digits[3]) << PyLong_SHIFT) | (int)digits[2]) << PyLong_SHIFT) | (int)digits[1]) << PyLong_SHIFT) | (int)digits[0]))); - } - } - break; - } - } -#endif - if ((sizeof(int) <= sizeof(long))) { - __PYX_VERIFY_RETURN_INT_EXC(int, long, PyLong_AsLong(x)) -#ifdef HAVE_LONG_LONG - } else if ((sizeof(int) <= sizeof(PY_LONG_LONG))) { - __PYX_VERIFY_RETURN_INT_EXC(int, PY_LONG_LONG, PyLong_AsLongLong(x)) -#endif - } - } - { - int val; - int ret = -1; -#if PY_VERSION_HEX >= 0x030d00A6 && !CYTHON_COMPILING_IN_LIMITED_API - Py_ssize_t bytes_copied = PyLong_AsNativeBytes( - x, &val, sizeof(val), Py_ASNATIVEBYTES_NATIVE_ENDIAN | (is_unsigned ? Py_ASNATIVEBYTES_UNSIGNED_BUFFER | Py_ASNATIVEBYTES_REJECT_NEGATIVE : 0)); - if (unlikely(bytes_copied == -1)) { - } else if (unlikely(bytes_copied > (Py_ssize_t) sizeof(val))) { - goto raise_overflow; - } else { - ret = 0; - } -#elif PY_VERSION_HEX < 0x030d0000 && !(CYTHON_COMPILING_IN_PYPY || CYTHON_COMPILING_IN_LIMITED_API) || defined(_PyLong_AsByteArray) - int one = 1; int is_little = (int)*(unsigned char *)&one; - unsigned char *bytes = (unsigned char *)&val; - ret = _PyLong_AsByteArray((PyLongObject *)x, - bytes, sizeof(val), - is_little, !is_unsigned); -#else - PyObject *v; - PyObject *stepval = NULL, *mask = NULL, *shift = NULL; - int bits, remaining_bits, is_negative = 0; - int chunk_size = (sizeof(long) < 8) ? 30 : 62; - if (likely(PyLong_CheckExact(x))) { - v = __Pyx_NewRef(x); - } else { - v = PyNumber_Long(x); - if (unlikely(!v)) return (int) -1; - assert(PyLong_CheckExact(v)); - } - { - int result = PyObject_RichCompareBool(v, Py_False, Py_LT); - if (unlikely(result < 0)) { - Py_DECREF(v); - return (int) -1; - } - is_negative = result == 1; - } - if (is_unsigned && unlikely(is_negative)) { - Py_DECREF(v); - goto raise_neg_overflow; - } else if (is_negative) { - stepval = PyNumber_Invert(v); - Py_DECREF(v); - if (unlikely(!stepval)) - return (int) -1; - } else { - stepval = v; - } - v = NULL; - val = (int) 0; - mask = PyLong_FromLong((1L << chunk_size) - 1); if (unlikely(!mask)) goto done; - shift = PyLong_FromLong(chunk_size); if (unlikely(!shift)) goto done; - for (bits = 0; bits < (int) sizeof(int) * 8 - chunk_size; bits += chunk_size) { - PyObject *tmp, *digit; - long idigit; - digit = PyNumber_And(stepval, mask); - if (unlikely(!digit)) goto done; - idigit = PyLong_AsLong(digit); - Py_DECREF(digit); - if (unlikely(idigit < 0)) goto done; - val |= ((int) idigit) << bits; - tmp = PyNumber_Rshift(stepval, shift); - if (unlikely(!tmp)) goto done; - Py_DECREF(stepval); stepval = tmp; - } - Py_DECREF(shift); shift = NULL; - Py_DECREF(mask); mask = NULL; - { - long idigit = PyLong_AsLong(stepval); - if (unlikely(idigit < 0)) goto done; - remaining_bits = ((int) sizeof(int) * 8) - bits - (is_unsigned ? 0 : 1); - if (unlikely(idigit >= (1L << remaining_bits))) - goto raise_overflow; - val |= ((int) idigit) << bits; - } - if (!is_unsigned) { - if (unlikely(val & (((int) 1) << (sizeof(int) * 8 - 1)))) - goto raise_overflow; - if (is_negative) - val = ~val; - } - ret = 0; - done: - Py_XDECREF(shift); - Py_XDECREF(mask); - Py_XDECREF(stepval); -#endif - if (unlikely(ret)) - return (int) -1; - return val; - } -raise_overflow: - PyErr_SetString(PyExc_OverflowError, - "value too large to convert to int"); - return (int) -1; -raise_neg_overflow: - PyErr_SetString(PyExc_OverflowError, - "can't convert negative value to int"); - return (int) -1; -} - -/* FastTypeChecks */ -#if CYTHON_COMPILING_IN_CPYTHON -static int __Pyx_InBases(PyTypeObject *a, PyTypeObject *b) { - while (a) { - a = __Pyx_PyType_GetSlot(a, tp_base, PyTypeObject*); - if (a == b) - return 1; - } - return b == &PyBaseObject_Type; -} -static CYTHON_INLINE int __Pyx_IsSubtype(PyTypeObject *a, PyTypeObject *b) { - PyObject *mro; - if (a == b) return 1; - mro = a->tp_mro; - if (likely(mro)) { - Py_ssize_t i, n; - n = PyTuple_GET_SIZE(mro); - for (i = 0; i < n; i++) { - if (PyTuple_GET_ITEM(mro, i) == (PyObject *)b) - return 1; - } - return 0; - } - return __Pyx_InBases(a, b); -} -static CYTHON_INLINE int __Pyx_IsAnySubtype2(PyTypeObject *cls, PyTypeObject *a, PyTypeObject *b) { - PyObject *mro; - if (cls == a || cls == b) return 1; - mro = cls->tp_mro; - if (likely(mro)) { - Py_ssize_t i, n; - n = PyTuple_GET_SIZE(mro); - for (i = 0; i < n; i++) { - PyObject *base = PyTuple_GET_ITEM(mro, i); - if (base == (PyObject *)a || base == (PyObject *)b) - return 1; - } - return 0; - } - return __Pyx_InBases(cls, a) || __Pyx_InBases(cls, b); -} -static CYTHON_INLINE int __Pyx_inner_PyErr_GivenExceptionMatches2(PyObject *err, PyObject* exc_type1, PyObject *exc_type2) { - if (exc_type1) { - return __Pyx_IsAnySubtype2((PyTypeObject*)err, (PyTypeObject*)exc_type1, (PyTypeObject*)exc_type2); - } else { - return __Pyx_IsSubtype((PyTypeObject*)err, (PyTypeObject*)exc_type2); - } -} -static int __Pyx_PyErr_GivenExceptionMatchesTuple(PyObject *exc_type, PyObject *tuple) { - Py_ssize_t i, n; - assert(PyExceptionClass_Check(exc_type)); - n = PyTuple_GET_SIZE(tuple); - for (i=0; i= 0x030b0000 - return Py_Version & ~0xFFUL; -#else - static unsigned long __Pyx_cached_runtime_version = 0; - if (__Pyx_cached_runtime_version == 0) { - const char* rt_version = Py_GetVersion(); - unsigned long version = 0; - unsigned long factor = 0x01000000UL; - unsigned int digit = 0; - int i = 0; - while (factor) { - while ('0' <= rt_version[i] && rt_version[i] <= '9') { - digit = digit * 10 + (unsigned int) (rt_version[i] - '0'); - ++i; - } - version += factor * digit; - if (rt_version[i] != '.') - break; - digit = 0; - factor >>= 8; - ++i; - } - __Pyx_cached_runtime_version = version; - } - return __Pyx_cached_runtime_version; -#endif -} - -/* CheckBinaryVersion */ -static int __Pyx_check_binary_version(unsigned long ct_version, unsigned long rt_version, int allow_newer) { - const unsigned long MAJOR_MINOR = 0xFFFF0000UL; - if ((rt_version & MAJOR_MINOR) == (ct_version & MAJOR_MINOR)) - return 0; - if (likely(allow_newer && (rt_version & MAJOR_MINOR) > (ct_version & MAJOR_MINOR))) - return 1; - { - char message[200]; - PyOS_snprintf(message, sizeof(message), - "compile time Python version %d.%d " - "of module '%.100s' " - "%s " - "runtime version %d.%d", - (int) (ct_version >> 24), (int) ((ct_version >> 16) & 0xFF), - __Pyx_MODULE_NAME, - (allow_newer) ? "was newer than" : "does not match", - (int) (rt_version >> 24), (int) ((rt_version >> 16) & 0xFF) - ); - return PyErr_WarnEx(NULL, message, 1); - } -} - -/* NewCodeObj */ -#if CYTHON_COMPILING_IN_LIMITED_API - static PyObject* __Pyx__PyCode_New(int a, int p, int k, int l, int s, int f, - PyObject *code, PyObject *c, PyObject* n, PyObject *v, - PyObject *fv, PyObject *cell, PyObject* fn, - PyObject *name, int fline, PyObject *lnos) { - PyObject *exception_table = NULL; - PyObject *types_module=NULL, *code_type=NULL, *result=NULL; - #if __PYX_LIMITED_VERSION_HEX < 0x030b0000 - PyObject *version_info; - PyObject *py_minor_version = NULL; - #endif - long minor_version = 0; - PyObject *type, *value, *traceback; - PyErr_Fetch(&type, &value, &traceback); - #if __PYX_LIMITED_VERSION_HEX >= 0x030b0000 - minor_version = 11; - #else - if (!(version_info = PySys_GetObject("version_info"))) goto end; - if (!(py_minor_version = PySequence_GetItem(version_info, 1))) goto end; - minor_version = PyLong_AsLong(py_minor_version); - Py_DECREF(py_minor_version); - if (minor_version == -1 && PyErr_Occurred()) goto end; - #endif - if (!(types_module = PyImport_ImportModule("types"))) goto end; - if (!(code_type = PyObject_GetAttrString(types_module, "CodeType"))) goto end; - if (minor_version <= 7) { - (void)p; - result = PyObject_CallFunction(code_type, "iiiiiOOOOOOiOOO", a, k, l, s, f, code, - c, n, v, fn, name, fline, lnos, fv, cell); - } else if (minor_version <= 10) { - result = PyObject_CallFunction(code_type, "iiiiiiOOOOOOiOOO", a,p, k, l, s, f, code, - c, n, v, fn, name, fline, lnos, fv, cell); - } else { - if (!(exception_table = PyBytes_FromStringAndSize(NULL, 0))) goto end; - result = PyObject_CallFunction(code_type, "iiiiiiOOOOOOOiOOOO", a,p, k, l, s, f, code, - c, n, v, fn, name, name, fline, lnos, exception_table, fv, cell); - } - end: - Py_XDECREF(code_type); - Py_XDECREF(exception_table); - Py_XDECREF(types_module); - if (type) { - PyErr_Restore(type, value, traceback); - } - return result; - } -#elif PY_VERSION_HEX >= 0x030B0000 - static PyCodeObject* __Pyx__PyCode_New(int a, int p, int k, int l, int s, int f, - PyObject *code, PyObject *c, PyObject* n, PyObject *v, - PyObject *fv, PyObject *cell, PyObject* fn, - PyObject *name, int fline, PyObject *lnos) { - PyCodeObject *result; - result = - #if PY_VERSION_HEX >= 0x030C0000 - PyUnstable_Code_NewWithPosOnlyArgs - #else - PyCode_NewWithPosOnlyArgs - #endif - (a, p, k, l, s, f, code, c, n, v, fv, cell, fn, name, name, fline, lnos, __pyx_mstate_global->__pyx_empty_bytes); - return result; - } -#elif PY_VERSION_HEX >= 0x030800B2 && !CYTHON_COMPILING_IN_PYPY - #define __Pyx__PyCode_New(a, p, k, l, s, f, code, c, n, v, fv, cell, fn, name, fline, lnos)\ - PyCode_NewWithPosOnlyArgs(a, p, k, l, s, f, code, c, n, v, fv, cell, fn, name, fline, lnos) -#else - #define __Pyx__PyCode_New(a, p, k, l, s, f, code, c, n, v, fv, cell, fn, name, fline, lnos)\ - PyCode_New(a, k, l, s, f, code, c, n, v, fv, cell, fn, name, fline, lnos) -#endif -static PyObject* __Pyx_PyCode_New( - __Pyx_PyCode_New_function_description descr, - PyObject **varnames, - PyObject* filename, - PyObject *funcname, - const char *line_table, - PyObject *tuple_dedup_map -) { - PyObject *code_obj = NULL, *varnames_tuple_dedup = NULL, *code_bytes = NULL, *line_table_bytes = NULL; - Py_ssize_t var_count = (Py_ssize_t) descr.nlocals; - PyObject *varnames_tuple = PyTuple_New(var_count); - if (unlikely(!varnames_tuple)) return NULL; - for (Py_ssize_t i=0; i < var_count; i++) { - Py_INCREF(varnames[i]); - if (__Pyx_PyTuple_SET_ITEM(varnames_tuple, i, varnames[i]) != (0)) goto done; - } - #if CYTHON_COMPILING_IN_LIMITED_API - varnames_tuple_dedup = PyDict_GetItem(tuple_dedup_map, varnames_tuple); - if (!varnames_tuple_dedup) { - if (unlikely(PyDict_SetItem(tuple_dedup_map, varnames_tuple, varnames_tuple) < 0)) goto done; - varnames_tuple_dedup = varnames_tuple; - } - #else - varnames_tuple_dedup = PyDict_SetDefault(tuple_dedup_map, varnames_tuple, varnames_tuple); - if (unlikely(!varnames_tuple_dedup)) goto done; - #endif - #if CYTHON_AVOID_BORROWED_REFS - Py_INCREF(varnames_tuple_dedup); - #endif - if (__PYX_LIMITED_VERSION_HEX >= (0x030b0000) && line_table != NULL - && !CYTHON_COMPILING_IN_GRAAL) { - line_table_bytes = PyBytes_FromStringAndSize(line_table, descr.line_table_length); - if (unlikely(!line_table_bytes)) goto done; - Py_ssize_t code_len = (descr.line_table_length * 2 + 4) & ~3; - code_bytes = PyBytes_FromStringAndSize(NULL, code_len); - if (unlikely(!code_bytes)) goto done; - char* c_code_bytes = PyBytes_AsString(code_bytes); - if (unlikely(!c_code_bytes)) goto done; - memset(c_code_bytes, 0, (size_t) code_len); - } - code_obj = (PyObject*) __Pyx__PyCode_New( - (int) descr.argcount, - (int) descr.num_posonly_args, - (int) descr.num_kwonly_args, - (int) descr.nlocals, - 0, - (int) descr.flags, - code_bytes ? code_bytes : __pyx_mstate_global->__pyx_empty_bytes, - __pyx_mstate_global->__pyx_empty_tuple, - __pyx_mstate_global->__pyx_empty_tuple, - varnames_tuple_dedup, - __pyx_mstate_global->__pyx_empty_tuple, - __pyx_mstate_global->__pyx_empty_tuple, - filename, - funcname, - (int) descr.first_line, - (__PYX_LIMITED_VERSION_HEX >= (0x030b0000) && line_table_bytes) ? line_table_bytes : __pyx_mstate_global->__pyx_empty_bytes - ); -done: - Py_XDECREF(code_bytes); - Py_XDECREF(line_table_bytes); - #if CYTHON_AVOID_BORROWED_REFS - Py_XDECREF(varnames_tuple_dedup); - #endif - Py_DECREF(varnames_tuple); - return code_obj; -} - -/* InitStrings */ -static int __Pyx_InitStrings(__Pyx_StringTabEntry const *t, PyObject **target, const char* const* encoding_names) { - while (t->s) { - PyObject *str; - if (t->is_unicode) { - if (t->intern) { - str = PyUnicode_InternFromString(t->s); - } else if (t->encoding) { - str = PyUnicode_Decode(t->s, t->n - 1, encoding_names[t->encoding], NULL); - } else { - str = PyUnicode_FromStringAndSize(t->s, t->n - 1); - } - } else { - str = PyBytes_FromStringAndSize(t->s, t->n - 1); - } - if (!str) - return -1; - *target = str; - if (PyObject_Hash(str) == -1) - return -1; - ++t; - ++target; - } - return 0; -} - -#include -static CYTHON_INLINE Py_ssize_t __Pyx_ssize_strlen(const char *s) { - size_t len = strlen(s); - if (unlikely(len > (size_t) PY_SSIZE_T_MAX)) { - PyErr_SetString(PyExc_OverflowError, "byte string is too long"); - return -1; - } - return (Py_ssize_t) len; -} -static CYTHON_INLINE PyObject* __Pyx_PyUnicode_FromString(const char* c_str) { - Py_ssize_t len = __Pyx_ssize_strlen(c_str); - if (unlikely(len < 0)) return NULL; - return __Pyx_PyUnicode_FromStringAndSize(c_str, len); -} -static CYTHON_INLINE PyObject* __Pyx_PyByteArray_FromString(const char* c_str) { - Py_ssize_t len = __Pyx_ssize_strlen(c_str); - if (unlikely(len < 0)) return NULL; - return PyByteArray_FromStringAndSize(c_str, len); -} -static CYTHON_INLINE const char* __Pyx_PyObject_AsString(PyObject* o) { - Py_ssize_t ignore; - return __Pyx_PyObject_AsStringAndSize(o, &ignore); -} -#if __PYX_DEFAULT_STRING_ENCODING_IS_ASCII || __PYX_DEFAULT_STRING_ENCODING_IS_UTF8 -static CYTHON_INLINE const char* __Pyx_PyUnicode_AsStringAndSize(PyObject* o, Py_ssize_t *length) { - if (unlikely(__Pyx_PyUnicode_READY(o) == -1)) return NULL; -#if CYTHON_COMPILING_IN_LIMITED_API - { - const char* result; - Py_ssize_t unicode_length; - CYTHON_MAYBE_UNUSED_VAR(unicode_length); // only for __PYX_DEFAULT_STRING_ENCODING_IS_ASCII - #if __PYX_LIMITED_VERSION_HEX < 0x030A0000 - if (unlikely(PyArg_Parse(o, "s#", &result, length) < 0)) return NULL; - #else - result = PyUnicode_AsUTF8AndSize(o, length); - #endif - #if __PYX_DEFAULT_STRING_ENCODING_IS_ASCII - unicode_length = PyUnicode_GetLength(o); - if (unlikely(unicode_length < 0)) return NULL; - if (unlikely(unicode_length != *length)) { - PyUnicode_AsASCIIString(o); - return NULL; - } - #endif - return result; - } -#else -#if __PYX_DEFAULT_STRING_ENCODING_IS_ASCII - if (likely(PyUnicode_IS_ASCII(o))) { - *length = PyUnicode_GET_LENGTH(o); - return PyUnicode_AsUTF8(o); - } else { - PyUnicode_AsASCIIString(o); - return NULL; - } -#else - return PyUnicode_AsUTF8AndSize(o, length); -#endif -#endif -} -#endif -static CYTHON_INLINE const char* __Pyx_PyObject_AsStringAndSize(PyObject* o, Py_ssize_t *length) { -#if __PYX_DEFAULT_STRING_ENCODING_IS_ASCII || __PYX_DEFAULT_STRING_ENCODING_IS_UTF8 - if (PyUnicode_Check(o)) { - return __Pyx_PyUnicode_AsStringAndSize(o, length); - } else -#endif - if (PyByteArray_Check(o)) { -#if (CYTHON_ASSUME_SAFE_SIZE && CYTHON_ASSUME_SAFE_MACROS) || (CYTHON_COMPILING_IN_PYPY && (defined(PyByteArray_AS_STRING) && defined(PyByteArray_GET_SIZE))) - *length = PyByteArray_GET_SIZE(o); - return PyByteArray_AS_STRING(o); -#else - *length = PyByteArray_Size(o); - if (*length == -1) return NULL; - return PyByteArray_AsString(o); -#endif - } else - { - char* result; - int r = PyBytes_AsStringAndSize(o, &result, length); - if (unlikely(r < 0)) { - return NULL; - } else { - return result; - } - } -} -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 int __Pyx_PyObject_IsTrueAndDecref(PyObject* x) { - int retval; - if (unlikely(!x)) return -1; - retval = __Pyx_PyObject_IsTrue(x); - Py_DECREF(x); - return retval; -} -static PyObject* __Pyx_PyNumber_LongWrongResultType(PyObject* result) { - __Pyx_TypeName result_type_name = __Pyx_PyType_GetFullyQualifiedName(Py_TYPE(result)); - if (PyLong_Check(result)) { - if (PyErr_WarnFormat(PyExc_DeprecationWarning, 1, - "__int__ returned non-int (type " __Pyx_FMT_TYPENAME "). " - "The ability to return an instance of a strict subclass of int is deprecated, " - "and may be removed in a future version of Python.", - result_type_name)) { - __Pyx_DECREF_TypeName(result_type_name); - Py_DECREF(result); - return NULL; - } - __Pyx_DECREF_TypeName(result_type_name); - return result; - } - PyErr_Format(PyExc_TypeError, - "__int__ returned non-int (type " __Pyx_FMT_TYPENAME ")", - result_type_name); - __Pyx_DECREF_TypeName(result_type_name); - Py_DECREF(result); - return NULL; -} -static CYTHON_INLINE PyObject* __Pyx_PyNumber_Long(PyObject* x) { -#if CYTHON_USE_TYPE_SLOTS - PyNumberMethods *m; -#endif - PyObject *res = NULL; - if (likely(PyLong_Check(x))) - return __Pyx_NewRef(x); -#if CYTHON_USE_TYPE_SLOTS - m = Py_TYPE(x)->tp_as_number; - if (likely(m && m->nb_int)) { - res = m->nb_int(x); - } -#else - if (!PyBytes_CheckExact(x) && !PyUnicode_CheckExact(x)) { - res = PyNumber_Long(x); - } -#endif - if (likely(res)) { - if (unlikely(!PyLong_CheckExact(res))) { - return __Pyx_PyNumber_LongWrongResultType(res); - } - } - 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; - if (likely(PyLong_CheckExact(b))) { - #if CYTHON_USE_PYLONG_INTERNALS - if (likely(__Pyx_PyLong_IsCompact(b))) { - return __Pyx_PyLong_CompactValue(b); - } else { - const digit* digits = __Pyx_PyLong_Digits(b); - const Py_ssize_t size = __Pyx_PyLong_SignedDigitCount(b); - switch (size) { - case 2: - if (8 * sizeof(Py_ssize_t) > 2 * PyLong_SHIFT) { - return (Py_ssize_t) (((((size_t)digits[1]) << PyLong_SHIFT) | (size_t)digits[0])); - } - break; - case -2: - if (8 * sizeof(Py_ssize_t) > 2 * PyLong_SHIFT) { - return -(Py_ssize_t) (((((size_t)digits[1]) << PyLong_SHIFT) | (size_t)digits[0])); - } - break; - case 3: - if (8 * sizeof(Py_ssize_t) > 3 * PyLong_SHIFT) { - return (Py_ssize_t) (((((((size_t)digits[2]) << PyLong_SHIFT) | (size_t)digits[1]) << PyLong_SHIFT) | (size_t)digits[0])); - } - break; - case -3: - if (8 * sizeof(Py_ssize_t) > 3 * PyLong_SHIFT) { - return -(Py_ssize_t) (((((((size_t)digits[2]) << PyLong_SHIFT) | (size_t)digits[1]) << PyLong_SHIFT) | (size_t)digits[0])); - } - break; - case 4: - if (8 * sizeof(Py_ssize_t) > 4 * PyLong_SHIFT) { - return (Py_ssize_t) (((((((((size_t)digits[3]) << PyLong_SHIFT) | (size_t)digits[2]) << PyLong_SHIFT) | (size_t)digits[1]) << PyLong_SHIFT) | (size_t)digits[0])); - } - break; - case -4: - if (8 * sizeof(Py_ssize_t) > 4 * PyLong_SHIFT) { - return -(Py_ssize_t) (((((((((size_t)digits[3]) << PyLong_SHIFT) | (size_t)digits[2]) << PyLong_SHIFT) | (size_t)digits[1]) << PyLong_SHIFT) | (size_t)digits[0])); - } - break; - } - } - #endif - return PyLong_AsSsize_t(b); - } - x = PyNumber_Index(b); - if (!x) return -1; - ival = PyLong_AsSsize_t(x); - Py_DECREF(x); - return ival; -} -static CYTHON_INLINE Py_hash_t __Pyx_PyIndex_AsHash_t(PyObject* o) { - if (sizeof(Py_hash_t) == sizeof(Py_ssize_t)) { - return (Py_hash_t) __Pyx_PyIndex_AsSsize_t(o); - } else { - Py_ssize_t ival; - PyObject *x; - x = PyNumber_Index(o); - if (!x) return -1; - ival = PyLong_AsLong(x); - Py_DECREF(x); - return ival; - } -} -static CYTHON_INLINE PyObject *__Pyx_Owned_Py_None(int b) { - CYTHON_UNUSED_VAR(b); - return __Pyx_NewRef(Py_None); -} -static CYTHON_INLINE PyObject * __Pyx_PyBool_FromLong(long b) { - return b ? __Pyx_NewRef(Py_True) : __Pyx_NewRef(Py_False); -} -static CYTHON_INLINE PyObject * __Pyx_PyLong_FromSize_t(size_t ival) { - return PyLong_FromSize_t(ival); -} - - -/* MultiPhaseInitModuleState */ -#if CYTHON_PEP489_MULTI_PHASE_INIT && CYTHON_USE_MODULE_STATE -#ifndef CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE -#if (CYTHON_COMPILING_IN_LIMITED_API || PY_VERSION_HEX >= 0x030C0000) - #define CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE 1 -#else - #define CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE 0 -#endif -#endif -#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE && !CYTHON_ATOMICS -#error "Module state with PEP489 requires atomics. Currently that's one of\ - C11, C++11, gcc atomic intrinsics or MSVC atomic intrinsics" -#endif -#if !CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE -#define __Pyx_ModuleStateLookup_Lock() -#define __Pyx_ModuleStateLookup_Unlock() -#elif !CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX >= 0x030d0000 -static PyMutex __Pyx_ModuleStateLookup_mutex = {0}; -#define __Pyx_ModuleStateLookup_Lock() PyMutex_Lock(&__Pyx_ModuleStateLookup_mutex) -#define __Pyx_ModuleStateLookup_Unlock() PyMutex_Unlock(&__Pyx_ModuleStateLookup_mutex) -#elif defined(__cplusplus) && __cplusplus >= 201103L -#include -static std::mutex __Pyx_ModuleStateLookup_mutex; -#define __Pyx_ModuleStateLookup_Lock() __Pyx_ModuleStateLookup_mutex.lock() -#define __Pyx_ModuleStateLookup_Unlock() __Pyx_ModuleStateLookup_mutex.unlock() -#elif defined(__STDC_VERSION__) && (__STDC_VERSION__ > 201112L) && !defined(__STDC_NO_THREADS__) -#include -static mtx_t __Pyx_ModuleStateLookup_mutex; -static once_flag __Pyx_ModuleStateLookup_mutex_once_flag = ONCE_FLAG_INIT; -static void __Pyx_ModuleStateLookup_initialize_mutex(void) { - mtx_init(&__Pyx_ModuleStateLookup_mutex, mtx_plain); -} -#define __Pyx_ModuleStateLookup_Lock()\ - call_once(&__Pyx_ModuleStateLookup_mutex_once_flag, __Pyx_ModuleStateLookup_initialize_mutex);\ - mtx_lock(&__Pyx_ModuleStateLookup_mutex) -#define __Pyx_ModuleStateLookup_Unlock() mtx_unlock(&__Pyx_ModuleStateLookup_mutex) -#elif defined(HAVE_PTHREAD_H) -#include -static pthread_mutex_t __Pyx_ModuleStateLookup_mutex = PTHREAD_MUTEX_INITIALIZER; -#define __Pyx_ModuleStateLookup_Lock() pthread_mutex_lock(&__Pyx_ModuleStateLookup_mutex) -#define __Pyx_ModuleStateLookup_Unlock() pthread_mutex_unlock(&__Pyx_ModuleStateLookup_mutex) -#elif defined(_WIN32) -#include // synchapi.h on its own doesn't work -static SRWLOCK __Pyx_ModuleStateLookup_mutex = SRWLOCK_INIT; -#define __Pyx_ModuleStateLookup_Lock() AcquireSRWLockExclusive(&__Pyx_ModuleStateLookup_mutex) -#define __Pyx_ModuleStateLookup_Unlock() ReleaseSRWLockExclusive(&__Pyx_ModuleStateLookup_mutex) -#else -#error "No suitable lock available for CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE.\ - Requires C standard >= C11, or C++ standard >= C++11,\ - or pthreads, or the Windows 32 API, or Python >= 3.13." -#endif -typedef struct { - int64_t id; - PyObject *module; -} __Pyx_InterpreterIdAndModule; -typedef struct { - char interpreter_id_as_index; - Py_ssize_t count; - Py_ssize_t allocated; - __Pyx_InterpreterIdAndModule table[1]; -} __Pyx_ModuleStateLookupData; -#define __PYX_MODULE_STATE_LOOKUP_SMALL_SIZE 32 -#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE -static __pyx_atomic_int_type __Pyx_ModuleStateLookup_read_counter = 0; -#endif -#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE -static __pyx_atomic_ptr_type __Pyx_ModuleStateLookup_data = 0; -#else -static __Pyx_ModuleStateLookupData* __Pyx_ModuleStateLookup_data = NULL; -#endif -static __Pyx_InterpreterIdAndModule* __Pyx_State_FindModuleStateLookupTableLowerBound( - __Pyx_InterpreterIdAndModule* table, - Py_ssize_t count, - int64_t interpreterId) { - __Pyx_InterpreterIdAndModule* begin = table; - __Pyx_InterpreterIdAndModule* end = begin + count; - if (begin->id == interpreterId) { - return begin; - } - while ((end - begin) > __PYX_MODULE_STATE_LOOKUP_SMALL_SIZE) { - __Pyx_InterpreterIdAndModule* halfway = begin + (end - begin)/2; - if (halfway->id == interpreterId) { - return halfway; - } - if (halfway->id < interpreterId) { - begin = halfway; - } else { - end = halfway; - } - } - for (; begin < end; ++begin) { - if (begin->id >= interpreterId) return begin; - } - return begin; -} -static PyObject *__Pyx_State_FindModule(CYTHON_UNUSED void* dummy) { - int64_t interpreter_id = PyInterpreterState_GetID(__Pyx_PyInterpreterState_Get()); - if (interpreter_id == -1) return NULL; -#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE - __Pyx_ModuleStateLookupData* data = (__Pyx_ModuleStateLookupData*)__pyx_atomic_pointer_load_relaxed(&__Pyx_ModuleStateLookup_data); - { - __pyx_atomic_incr_acq_rel(&__Pyx_ModuleStateLookup_read_counter); - if (likely(data)) { - __Pyx_ModuleStateLookupData* new_data = (__Pyx_ModuleStateLookupData*)__pyx_atomic_pointer_load_acquire(&__Pyx_ModuleStateLookup_data); - if (likely(data == new_data)) { - goto read_finished; - } - } - __pyx_atomic_decr_acq_rel(&__Pyx_ModuleStateLookup_read_counter); - __Pyx_ModuleStateLookup_Lock(); - __pyx_atomic_incr_relaxed(&__Pyx_ModuleStateLookup_read_counter); - data = (__Pyx_ModuleStateLookupData*)__pyx_atomic_pointer_load_relaxed(&__Pyx_ModuleStateLookup_data); - __Pyx_ModuleStateLookup_Unlock(); - } - read_finished:; -#else - __Pyx_ModuleStateLookupData* data = __Pyx_ModuleStateLookup_data; -#endif - __Pyx_InterpreterIdAndModule* found = NULL; - if (unlikely(!data)) goto end; - if (data->interpreter_id_as_index) { - if (interpreter_id < data->count) { - found = data->table+interpreter_id; - } - } else { - found = __Pyx_State_FindModuleStateLookupTableLowerBound( - data->table, data->count, interpreter_id); - } - end: - { - PyObject *result=NULL; - if (found && found->id == interpreter_id) { - result = found->module; - } -#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE - __pyx_atomic_decr_acq_rel(&__Pyx_ModuleStateLookup_read_counter); -#endif - return result; - } -} -#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE -static void __Pyx_ModuleStateLookup_wait_until_no_readers(void) { - while (__pyx_atomic_load(&__Pyx_ModuleStateLookup_read_counter) != 0); -} -#else -#define __Pyx_ModuleStateLookup_wait_until_no_readers() -#endif -static int __Pyx_State_AddModuleInterpIdAsIndex(__Pyx_ModuleStateLookupData **old_data, PyObject* module, int64_t interpreter_id) { - Py_ssize_t to_allocate = (*old_data)->allocated; - while (to_allocate <= interpreter_id) { - if (to_allocate == 0) to_allocate = 1; - else to_allocate *= 2; - } - __Pyx_ModuleStateLookupData *new_data = *old_data; - if (to_allocate != (*old_data)->allocated) { - new_data = (__Pyx_ModuleStateLookupData *)realloc( - *old_data, - sizeof(__Pyx_ModuleStateLookupData)+(to_allocate-1)*sizeof(__Pyx_InterpreterIdAndModule)); - if (!new_data) { - PyErr_NoMemory(); - return -1; - } - for (Py_ssize_t i = new_data->allocated; i < to_allocate; ++i) { - new_data->table[i].id = i; - new_data->table[i].module = NULL; - } - new_data->allocated = to_allocate; - } - new_data->table[interpreter_id].module = module; - if (new_data->count < interpreter_id+1) { - new_data->count = interpreter_id+1; - } - *old_data = new_data; - return 0; -} -static void __Pyx_State_ConvertFromInterpIdAsIndex(__Pyx_ModuleStateLookupData *data) { - __Pyx_InterpreterIdAndModule *read = data->table; - __Pyx_InterpreterIdAndModule *write = data->table; - __Pyx_InterpreterIdAndModule *end = read + data->count; - for (; readmodule) { - write->id = read->id; - write->module = read->module; - ++write; - } - } - data->count = write - data->table; - for (; writeid = 0; - write->module = NULL; - } - data->interpreter_id_as_index = 0; -} -static int __Pyx_State_AddModule(PyObject* module, CYTHON_UNUSED void* dummy) { - int64_t interpreter_id = PyInterpreterState_GetID(__Pyx_PyInterpreterState_Get()); - if (interpreter_id == -1) return -1; - int result = 0; - __Pyx_ModuleStateLookup_Lock(); -#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE - __Pyx_ModuleStateLookupData *old_data = (__Pyx_ModuleStateLookupData *) - __pyx_atomic_pointer_exchange(&__Pyx_ModuleStateLookup_data, 0); -#else - __Pyx_ModuleStateLookupData *old_data = __Pyx_ModuleStateLookup_data; -#endif - __Pyx_ModuleStateLookupData *new_data = old_data; - if (!new_data) { - new_data = (__Pyx_ModuleStateLookupData *)calloc(1, sizeof(__Pyx_ModuleStateLookupData)); - if (!new_data) { - result = -1; - PyErr_NoMemory(); - goto end; - } - new_data->allocated = 1; - new_data->interpreter_id_as_index = 1; - } - __Pyx_ModuleStateLookup_wait_until_no_readers(); - if (new_data->interpreter_id_as_index) { - if (interpreter_id < __PYX_MODULE_STATE_LOOKUP_SMALL_SIZE) { - result = __Pyx_State_AddModuleInterpIdAsIndex(&new_data, module, interpreter_id); - goto end; - } - __Pyx_State_ConvertFromInterpIdAsIndex(new_data); - } - { - Py_ssize_t insert_at = 0; - { - __Pyx_InterpreterIdAndModule* lower_bound = __Pyx_State_FindModuleStateLookupTableLowerBound( - new_data->table, new_data->count, interpreter_id); - assert(lower_bound); - insert_at = lower_bound - new_data->table; - if (unlikely(insert_at < new_data->count && lower_bound->id == interpreter_id)) { - lower_bound->module = module; - goto end; // already in table, nothing more to do - } - } - if (new_data->count+1 >= new_data->allocated) { - Py_ssize_t to_allocate = (new_data->count+1)*2; - new_data = - (__Pyx_ModuleStateLookupData*)realloc( - new_data, - sizeof(__Pyx_ModuleStateLookupData) + - (to_allocate-1)*sizeof(__Pyx_InterpreterIdAndModule)); - if (!new_data) { - result = -1; - new_data = old_data; - PyErr_NoMemory(); - goto end; - } - new_data->allocated = to_allocate; - } - ++new_data->count; - int64_t last_id = interpreter_id; - PyObject *last_module = module; - for (Py_ssize_t i=insert_at; icount; ++i) { - int64_t current_id = new_data->table[i].id; - new_data->table[i].id = last_id; - last_id = current_id; - PyObject *current_module = new_data->table[i].module; - new_data->table[i].module = last_module; - last_module = current_module; - } - } - end: -#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE - __pyx_atomic_pointer_exchange(&__Pyx_ModuleStateLookup_data, new_data); -#else - __Pyx_ModuleStateLookup_data = new_data; -#endif - __Pyx_ModuleStateLookup_Unlock(); - return result; -} -static int __Pyx_State_RemoveModule(CYTHON_UNUSED void* dummy) { - int64_t interpreter_id = PyInterpreterState_GetID(__Pyx_PyInterpreterState_Get()); - if (interpreter_id == -1) return -1; - __Pyx_ModuleStateLookup_Lock(); -#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE - __Pyx_ModuleStateLookupData *data = (__Pyx_ModuleStateLookupData *) - __pyx_atomic_pointer_exchange(&__Pyx_ModuleStateLookup_data, 0); -#else - __Pyx_ModuleStateLookupData *data = __Pyx_ModuleStateLookup_data; -#endif - if (data->interpreter_id_as_index) { - if (interpreter_id < data->count) { - data->table[interpreter_id].module = NULL; - } - goto done; - } - { - __Pyx_ModuleStateLookup_wait_until_no_readers(); - __Pyx_InterpreterIdAndModule* lower_bound = __Pyx_State_FindModuleStateLookupTableLowerBound( - data->table, data->count, interpreter_id); - if (!lower_bound) goto done; - if (lower_bound->id != interpreter_id) goto done; - __Pyx_InterpreterIdAndModule *end = data->table+data->count; - for (;lower_boundid = (lower_bound+1)->id; - lower_bound->module = (lower_bound+1)->module; - } - } - --data->count; - if (data->count == 0) { - free(data); - data = NULL; - } - done: -#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE - __pyx_atomic_pointer_exchange(&__Pyx_ModuleStateLookup_data, data); -#else - __Pyx_ModuleStateLookup_data = data; -#endif - __Pyx_ModuleStateLookup_Unlock(); - return 0; -} -#endif - -/* #### Code section: utility_code_pragmas_end ### */ -#ifdef _MSC_VER -#pragma warning( pop ) -#endif - - - -/* #### Code section: end ### */ -#endif /* Py_PYTHON_H */ diff --git a/epanet/epanet2-0.dll b/epanet/epanet2-0.dll deleted file mode 100644 index 129d2eb926ce2cb5d0d338d948c9d291fbb8afc4..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 649728 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 z%0A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

xcS5GOMI5T`e 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�cqkNdN|V(+i(YpT%Gp2Z|+Tn|2anO7PU*( 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 diff --git a/epanet/epanet2-2.2.0.dll b/epanet/epanet2-2.2.0.dll deleted file mode 100644 index a3bea5e853355f2da857fb190d70963e93ac4dc5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 460288 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%0D}dzBeBClJg-xCkMHumNE?!disX_W8Rg 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

4h)@kG$H7yjnVO8C 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

kCLE^FmxdGjuAtV$7ul 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

EM? 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 Kev^)~^)Qt*JCAUxiLq9|U*c&OCI43Q-$=83 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%0Avc>PTX`s-CCjtcoE5#PAR-{@` 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
MUZ^>nFsD>GWBxn&TxF)R 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 Zr&>@4_dXPlVKmE#%KY!Y{~t@>{{SZNW(NQO diff --git a/epanet/epanet2-cannot run.dll b/epanet/epanet2-cannot run.dll deleted file mode 100644 index cdebe8f8683feeb154c4e3e8d337cc8b926c71e2..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 217088 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

XDmd8tm|w-Rs;CFF9h( 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

66qwCG3coOQW$ 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 O!3-44!2eA%@P7bz9*C&` diff --git a/epanet/epanet2_ec.c b/epanet/epanet2_ec.c deleted file mode 100644 index cf6fd8f..0000000 --- a/epanet/epanet2_ec.c +++ /dev/null @@ -1,6027 +0,0 @@ -/* Generated by Cython 3.1.0 */ - -/* BEGIN: Cython Metadata -{ - "distutils": { - "name": "epanet.epanet2_ec", - "sources": [ - "epanet\\epanet2_ec.py" - ] - }, - "module_name": "epanet.epanet2_ec" -} -END: Cython Metadata */ - -#ifndef PY_SSIZE_T_CLEAN -#define PY_SSIZE_T_CLEAN -#endif /* PY_SSIZE_T_CLEAN */ -/* InitLimitedAPI */ -#if defined(Py_LIMITED_API) && !defined(CYTHON_LIMITED_API) - #define CYTHON_LIMITED_API 1 -#endif - -#include "Python.h" -#ifndef Py_PYTHON_H - #error Python headers needed to compile C extensions, please install development version of Python. -#elif PY_VERSION_HEX < 0x03080000 - #error Cython requires Python 3.8+. -#else -#define __PYX_ABI_VERSION "3_1_0" -#define CYTHON_HEX_VERSION 0x030100F0 -#define CYTHON_FUTURE_DIVISION 1 -/* CModulePreamble */ -#include -#ifndef offsetof - #define offsetof(type, member) ( (size_t) & ((type*)0) -> member ) -#endif -#if !defined(_WIN32) && !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 -#define __PYX_COMMA , -#ifndef HAVE_LONG_LONG - #define HAVE_LONG_LONG -#endif -#ifndef PY_LONG_LONG - #define PY_LONG_LONG LONG_LONG -#endif -#ifndef Py_HUGE_VAL - #define Py_HUGE_VAL HUGE_VAL -#endif -#define __PYX_LIMITED_VERSION_HEX PY_VERSION_HEX -#if defined(GRAALVM_PYTHON) - /* For very preliminary testing purposes. Most variables are set the same as PyPy. - The existence of this section does not imply that anything works or is even tested */ - #define CYTHON_COMPILING_IN_PYPY 0 - #define CYTHON_COMPILING_IN_CPYTHON 0 - #define CYTHON_COMPILING_IN_LIMITED_API 0 - #define CYTHON_COMPILING_IN_GRAAL 1 - #define CYTHON_COMPILING_IN_CPYTHON_FREETHREADING 0 - #undef CYTHON_USE_TYPE_SLOTS - #define CYTHON_USE_TYPE_SLOTS 0 - #undef CYTHON_USE_TYPE_SPECS - #define CYTHON_USE_TYPE_SPECS 0 - #undef CYTHON_USE_PYTYPE_LOOKUP - #define CYTHON_USE_PYTYPE_LOOKUP 0 - #undef CYTHON_USE_PYLIST_INTERNALS - #define CYTHON_USE_PYLIST_INTERNALS 0 - #undef CYTHON_USE_UNICODE_INTERNALS - #define CYTHON_USE_UNICODE_INTERNALS 0 - #undef CYTHON_USE_UNICODE_WRITER - #define CYTHON_USE_UNICODE_WRITER 0 - #undef CYTHON_USE_PYLONG_INTERNALS - #define CYTHON_USE_PYLONG_INTERNALS 0 - #undef CYTHON_AVOID_BORROWED_REFS - #define CYTHON_AVOID_BORROWED_REFS 1 - #undef CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS - #define CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS 1 - #undef CYTHON_ASSUME_SAFE_MACROS - #define CYTHON_ASSUME_SAFE_MACROS 0 - #undef CYTHON_ASSUME_SAFE_SIZE - #define CYTHON_ASSUME_SAFE_SIZE 0 - #undef CYTHON_UNPACK_METHODS - #define CYTHON_UNPACK_METHODS 0 - #undef CYTHON_FAST_THREAD_STATE - #define CYTHON_FAST_THREAD_STATE 0 - #undef CYTHON_FAST_GIL - #define CYTHON_FAST_GIL 0 - #undef CYTHON_METH_FASTCALL - #define CYTHON_METH_FASTCALL 0 - #undef CYTHON_FAST_PYCALL - #define CYTHON_FAST_PYCALL 0 - #ifndef CYTHON_PEP487_INIT_SUBCLASS - #define CYTHON_PEP487_INIT_SUBCLASS 1 - #endif - #undef CYTHON_PEP489_MULTI_PHASE_INIT - #define CYTHON_PEP489_MULTI_PHASE_INIT 1 - #undef CYTHON_USE_MODULE_STATE - #define CYTHON_USE_MODULE_STATE 0 - #undef CYTHON_USE_SYS_MONITORING - #define CYTHON_USE_SYS_MONITORING 0 - #undef CYTHON_USE_TP_FINALIZE - #define CYTHON_USE_TP_FINALIZE 0 - #undef CYTHON_USE_AM_SEND - #define CYTHON_USE_AM_SEND 0 - #undef CYTHON_USE_DICT_VERSIONS - #define CYTHON_USE_DICT_VERSIONS 0 - #undef CYTHON_USE_EXC_INFO_STACK - #define CYTHON_USE_EXC_INFO_STACK 1 - #ifndef CYTHON_UPDATE_DESCRIPTOR_DOC - #define CYTHON_UPDATE_DESCRIPTOR_DOC 0 - #endif - #undef CYTHON_USE_FREELISTS - #define CYTHON_USE_FREELISTS 0 -#elif defined(PYPY_VERSION) - #define CYTHON_COMPILING_IN_PYPY 1 - #define CYTHON_COMPILING_IN_CPYTHON 0 - #define CYTHON_COMPILING_IN_LIMITED_API 0 - #define CYTHON_COMPILING_IN_GRAAL 0 - #define CYTHON_COMPILING_IN_CPYTHON_FREETHREADING 0 - #undef CYTHON_USE_TYPE_SLOTS - #define CYTHON_USE_TYPE_SLOTS 1 - #ifndef CYTHON_USE_TYPE_SPECS - #define CYTHON_USE_TYPE_SPECS 0 - #endif - #undef CYTHON_USE_PYTYPE_LOOKUP - #define CYTHON_USE_PYTYPE_LOOKUP 0 - #undef CYTHON_USE_PYLIST_INTERNALS - #define CYTHON_USE_PYLIST_INTERNALS 0 - #undef CYTHON_USE_UNICODE_INTERNALS - #define CYTHON_USE_UNICODE_INTERNALS 0 - #undef CYTHON_USE_UNICODE_WRITER - #define CYTHON_USE_UNICODE_WRITER 0 - #undef CYTHON_USE_PYLONG_INTERNALS - #define CYTHON_USE_PYLONG_INTERNALS 0 - #undef CYTHON_AVOID_BORROWED_REFS - #define CYTHON_AVOID_BORROWED_REFS 1 - #undef CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS - #define CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS 1 - #undef CYTHON_ASSUME_SAFE_MACROS - #define CYTHON_ASSUME_SAFE_MACROS 0 - #ifndef CYTHON_ASSUME_SAFE_SIZE - #define CYTHON_ASSUME_SAFE_SIZE 1 - #endif - #undef CYTHON_UNPACK_METHODS - #define CYTHON_UNPACK_METHODS 0 - #undef CYTHON_FAST_THREAD_STATE - #define CYTHON_FAST_THREAD_STATE 0 - #undef CYTHON_FAST_GIL - #define CYTHON_FAST_GIL 0 - #undef CYTHON_METH_FASTCALL - #define CYTHON_METH_FASTCALL 0 - #undef CYTHON_FAST_PYCALL - #define CYTHON_FAST_PYCALL 0 - #ifndef CYTHON_PEP487_INIT_SUBCLASS - #define CYTHON_PEP487_INIT_SUBCLASS 1 - #endif - #if PY_VERSION_HEX < 0x03090000 - #undef CYTHON_PEP489_MULTI_PHASE_INIT - #define CYTHON_PEP489_MULTI_PHASE_INIT 0 - #elif !defined(CYTHON_PEP489_MULTI_PHASE_INIT) - #define CYTHON_PEP489_MULTI_PHASE_INIT 1 - #endif - #undef CYTHON_USE_MODULE_STATE - #define CYTHON_USE_MODULE_STATE 0 - #undef CYTHON_USE_SYS_MONITORING - #define CYTHON_USE_SYS_MONITORING 0 - #ifndef CYTHON_USE_TP_FINALIZE - #define CYTHON_USE_TP_FINALIZE (PYPY_VERSION_NUM >= 0x07030C00) - #endif - #undef CYTHON_USE_AM_SEND - #define CYTHON_USE_AM_SEND 0 - #undef CYTHON_USE_DICT_VERSIONS - #define CYTHON_USE_DICT_VERSIONS 0 - #undef CYTHON_USE_EXC_INFO_STACK - #define CYTHON_USE_EXC_INFO_STACK 0 - #ifndef CYTHON_UPDATE_DESCRIPTOR_DOC - #define CYTHON_UPDATE_DESCRIPTOR_DOC (PYPY_VERSION_NUM >= 0x07031100) - #endif - #undef CYTHON_USE_FREELISTS - #define CYTHON_USE_FREELISTS 0 -#elif defined(CYTHON_LIMITED_API) - #ifdef Py_LIMITED_API - #undef __PYX_LIMITED_VERSION_HEX - #define __PYX_LIMITED_VERSION_HEX Py_LIMITED_API - #endif - #define CYTHON_COMPILING_IN_PYPY 0 - #define CYTHON_COMPILING_IN_CPYTHON 0 - #define CYTHON_COMPILING_IN_LIMITED_API 1 - #define CYTHON_COMPILING_IN_GRAAL 0 - #define CYTHON_COMPILING_IN_CPYTHON_FREETHREADING 0 - #undef CYTHON_CLINE_IN_TRACEBACK - #define CYTHON_CLINE_IN_TRACEBACK 0 - #undef CYTHON_USE_TYPE_SLOTS - #define CYTHON_USE_TYPE_SLOTS 0 - #undef CYTHON_USE_TYPE_SPECS - #define CYTHON_USE_TYPE_SPECS 1 - #undef CYTHON_USE_PYTYPE_LOOKUP - #define CYTHON_USE_PYTYPE_LOOKUP 0 - #undef CYTHON_USE_PYLIST_INTERNALS - #define CYTHON_USE_PYLIST_INTERNALS 0 - #undef CYTHON_USE_UNICODE_INTERNALS - #define CYTHON_USE_UNICODE_INTERNALS 0 - #ifndef CYTHON_USE_UNICODE_WRITER - #define CYTHON_USE_UNICODE_WRITER 0 - #endif - #undef CYTHON_USE_PYLONG_INTERNALS - #define CYTHON_USE_PYLONG_INTERNALS 0 - #ifndef CYTHON_AVOID_BORROWED_REFS - #define CYTHON_AVOID_BORROWED_REFS 0 - #endif - #ifndef CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS - #define CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS 0 - #endif - #undef CYTHON_ASSUME_SAFE_MACROS - #define CYTHON_ASSUME_SAFE_MACROS 0 - #undef CYTHON_ASSUME_SAFE_SIZE - #define CYTHON_ASSUME_SAFE_SIZE 0 - #undef CYTHON_UNPACK_METHODS - #define CYTHON_UNPACK_METHODS 0 - #undef CYTHON_FAST_THREAD_STATE - #define CYTHON_FAST_THREAD_STATE 0 - #undef CYTHON_FAST_GIL - #define CYTHON_FAST_GIL 0 - #undef CYTHON_METH_FASTCALL - #define CYTHON_METH_FASTCALL (__PYX_LIMITED_VERSION_HEX >= 0x030C0000) - #undef CYTHON_FAST_PYCALL - #define CYTHON_FAST_PYCALL 0 - #ifndef CYTHON_PEP487_INIT_SUBCLASS - #define CYTHON_PEP487_INIT_SUBCLASS 1 - #endif - #ifndef CYTHON_PEP489_MULTI_PHASE_INIT - #define CYTHON_PEP489_MULTI_PHASE_INIT 1 - #endif - #ifndef CYTHON_USE_MODULE_STATE - #define CYTHON_USE_MODULE_STATE 0 - #endif - #undef CYTHON_USE_SYS_MONITORING - #define CYTHON_USE_SYS_MONITORING 0 - #ifndef CYTHON_USE_TP_FINALIZE - #define CYTHON_USE_TP_FINALIZE 0 - #endif - #ifndef CYTHON_USE_AM_SEND - #define CYTHON_USE_AM_SEND (__PYX_LIMITED_VERSION_HEX >= 0x030A0000) - #endif - #undef CYTHON_USE_DICT_VERSIONS - #define CYTHON_USE_DICT_VERSIONS 0 - #undef CYTHON_USE_EXC_INFO_STACK - #define CYTHON_USE_EXC_INFO_STACK 0 - #ifndef CYTHON_UPDATE_DESCRIPTOR_DOC - #define CYTHON_UPDATE_DESCRIPTOR_DOC 0 - #endif - #undef CYTHON_USE_FREELISTS - #define CYTHON_USE_FREELISTS 0 -#else - #define CYTHON_COMPILING_IN_PYPY 0 - #define CYTHON_COMPILING_IN_CPYTHON 1 - #define CYTHON_COMPILING_IN_LIMITED_API 0 - #define CYTHON_COMPILING_IN_GRAAL 0 - #ifdef Py_GIL_DISABLED - #define CYTHON_COMPILING_IN_CPYTHON_FREETHREADING 1 - #else - #define CYTHON_COMPILING_IN_CPYTHON_FREETHREADING 0 - #endif - #if PY_VERSION_HEX < 0x030A0000 - #undef CYTHON_USE_TYPE_SLOTS - #define CYTHON_USE_TYPE_SLOTS 1 - #elif !defined(CYTHON_USE_TYPE_SLOTS) - #define CYTHON_USE_TYPE_SLOTS 1 - #endif - #ifndef CYTHON_USE_TYPE_SPECS - #define CYTHON_USE_TYPE_SPECS 0 - #endif - #ifndef CYTHON_USE_PYTYPE_LOOKUP - #define CYTHON_USE_PYTYPE_LOOKUP 1 - #endif - #ifndef CYTHON_USE_PYLONG_INTERNALS - #define CYTHON_USE_PYLONG_INTERNALS 1 - #endif - #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - #undef CYTHON_USE_PYLIST_INTERNALS - #define CYTHON_USE_PYLIST_INTERNALS 0 - #elif !defined(CYTHON_USE_PYLIST_INTERNALS) - #define CYTHON_USE_PYLIST_INTERNALS 1 - #endif - #ifndef CYTHON_USE_UNICODE_INTERNALS - #define CYTHON_USE_UNICODE_INTERNALS 1 - #endif - #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING || PY_VERSION_HEX >= 0x030B00A2 - #undef CYTHON_USE_UNICODE_WRITER - #define CYTHON_USE_UNICODE_WRITER 0 - #elif !defined(CYTHON_USE_UNICODE_WRITER) - #define CYTHON_USE_UNICODE_WRITER 1 - #endif - #ifndef CYTHON_AVOID_BORROWED_REFS - #define CYTHON_AVOID_BORROWED_REFS 0 - #endif - #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - #undef CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS - #define CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS 1 - #elif !defined(CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS) - #define CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS 0 - #endif - #ifndef CYTHON_ASSUME_SAFE_MACROS - #define CYTHON_ASSUME_SAFE_MACROS 1 - #endif - #ifndef CYTHON_ASSUME_SAFE_SIZE - #define CYTHON_ASSUME_SAFE_SIZE 1 - #endif - #ifndef CYTHON_UNPACK_METHODS - #define CYTHON_UNPACK_METHODS 1 - #endif - #ifndef CYTHON_FAST_THREAD_STATE - #define CYTHON_FAST_THREAD_STATE 1 - #endif - #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - #undef CYTHON_FAST_GIL - #define CYTHON_FAST_GIL 0 - #elif !defined(CYTHON_FAST_GIL) - #define CYTHON_FAST_GIL (PY_VERSION_HEX < 0x030C00A6) - #endif - #ifndef CYTHON_METH_FASTCALL - #define CYTHON_METH_FASTCALL 1 - #endif - #ifndef CYTHON_FAST_PYCALL - #define CYTHON_FAST_PYCALL 1 - #endif - #ifndef CYTHON_PEP487_INIT_SUBCLASS - #define CYTHON_PEP487_INIT_SUBCLASS 1 - #endif - #ifndef CYTHON_PEP489_MULTI_PHASE_INIT - #define CYTHON_PEP489_MULTI_PHASE_INIT 1 - #endif - #ifndef CYTHON_USE_MODULE_STATE - #define CYTHON_USE_MODULE_STATE 0 - #endif - #ifndef CYTHON_USE_SYS_MONITORING - #define CYTHON_USE_SYS_MONITORING (PY_VERSION_HEX >= 0x030d00B1) - #endif - #ifndef CYTHON_USE_TP_FINALIZE - #define CYTHON_USE_TP_FINALIZE 1 - #endif - #ifndef CYTHON_USE_AM_SEND - #define CYTHON_USE_AM_SEND 1 - #endif - #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - #undef CYTHON_USE_DICT_VERSIONS - #define CYTHON_USE_DICT_VERSIONS 0 - #elif !defined(CYTHON_USE_DICT_VERSIONS) - #define CYTHON_USE_DICT_VERSIONS (PY_VERSION_HEX < 0x030C00A5 && !CYTHON_USE_MODULE_STATE) - #endif - #ifndef CYTHON_USE_EXC_INFO_STACK - #define CYTHON_USE_EXC_INFO_STACK 1 - #endif - #ifndef CYTHON_UPDATE_DESCRIPTOR_DOC - #define CYTHON_UPDATE_DESCRIPTOR_DOC 1 - #endif - #ifndef CYTHON_USE_FREELISTS - #define CYTHON_USE_FREELISTS (!CYTHON_COMPILING_IN_CPYTHON_FREETHREADING) - #endif -#endif -#ifndef CYTHON_FAST_PYCCALL -#define CYTHON_FAST_PYCCALL CYTHON_FAST_PYCALL -#endif -#ifndef CYTHON_VECTORCALL -#if CYTHON_COMPILING_IN_LIMITED_API -#define CYTHON_VECTORCALL (__PYX_LIMITED_VERSION_HEX >= 0x030C0000) -#else -#define CYTHON_VECTORCALL (CYTHON_FAST_PYCCALL && PY_VERSION_HEX >= 0x030800B1) -#endif -#endif -#define CYTHON_BACKPORT_VECTORCALL (CYTHON_METH_FASTCALL && PY_VERSION_HEX < 0x030800B1) -#if CYTHON_USE_PYLONG_INTERNALS - #undef SHIFT - #undef BASE - #undef MASK - #ifdef SIZEOF_VOID_P - enum { __pyx_check_sizeof_voidp = 1 / (int)(SIZEOF_VOID_P == sizeof(void*)) }; - #endif -#endif -#ifndef __has_attribute - #define __has_attribute(x) 0 -#endif -#ifndef __has_cpp_attribute - #define __has_cpp_attribute(x) 0 -#endif -#ifndef CYTHON_RESTRICT - #if defined(__GNUC__) - #define CYTHON_RESTRICT __restrict__ - #elif defined(_MSC_VER) && _MSC_VER >= 1400 - #define CYTHON_RESTRICT __restrict - #elif defined (__STDC_VERSION__) && __STDC_VERSION__ >= 199901L - #define CYTHON_RESTRICT restrict - #else - #define CYTHON_RESTRICT - #endif -#endif -#ifndef CYTHON_UNUSED - #if defined(__cplusplus) - /* for clang __has_cpp_attribute(maybe_unused) is true even before C++17 - * but leads to warnings with -pedantic, since it is a C++17 feature */ - #if ((defined(_MSVC_LANG) && _MSVC_LANG >= 201703L) || __cplusplus >= 201703L) - #if __has_cpp_attribute(maybe_unused) - #define CYTHON_UNUSED [[maybe_unused]] - #endif - #endif - #endif -#endif -#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) && !defined(_MSC_VER)) -# define CYTHON_UNUSED __attribute__ ((__unused__)) -# else -# define CYTHON_UNUSED -# endif -#endif -#ifndef CYTHON_UNUSED_VAR -# if defined(__cplusplus) - template void CYTHON_UNUSED_VAR( const T& ) { } -# else -# define CYTHON_UNUSED_VAR(x) (void)(x) -# endif -#endif -#ifndef CYTHON_MAYBE_UNUSED_VAR - #define CYTHON_MAYBE_UNUSED_VAR(x) CYTHON_UNUSED_VAR(x) -#endif -#ifndef CYTHON_NCP_UNUSED -# if CYTHON_COMPILING_IN_CPYTHON -# define CYTHON_NCP_UNUSED -# else -# define CYTHON_NCP_UNUSED CYTHON_UNUSED -# endif -#endif -#ifndef CYTHON_USE_CPP_STD_MOVE - #if defined(__cplusplus) && (\ - __cplusplus >= 201103L || (defined(_MSC_VER) && _MSC_VER >= 1600)) - #define CYTHON_USE_CPP_STD_MOVE 1 - #else - #define CYTHON_USE_CPP_STD_MOVE 0 - #endif -#endif -#define __Pyx_void_to_None(void_result) ((void)(void_result), Py_INCREF(Py_None), Py_None) -#ifdef _MSC_VER - #ifndef _MSC_STDINT_H_ - #if _MSC_VER < 1300 - typedef unsigned char uint8_t; - typedef unsigned short uint16_t; - typedef unsigned int uint32_t; - #else - typedef unsigned __int8 uint8_t; - typedef unsigned __int16 uint16_t; - typedef unsigned __int32 uint32_t; - #endif - #endif - #if _MSC_VER < 1300 - #ifdef _WIN64 - typedef unsigned long long __pyx_uintptr_t; - #else - typedef unsigned int __pyx_uintptr_t; - #endif - #else - #ifdef _WIN64 - typedef unsigned __int64 __pyx_uintptr_t; - #else - typedef unsigned __int32 __pyx_uintptr_t; - #endif - #endif -#else - #include - typedef uintptr_t __pyx_uintptr_t; -#endif -#ifndef CYTHON_FALLTHROUGH - #if defined(__cplusplus) - /* for clang __has_cpp_attribute(fallthrough) is true even before C++17 - * but leads to warnings with -pedantic, since it is a C++17 feature */ - #if ((defined(_MSVC_LANG) && _MSVC_LANG >= 201703L) || __cplusplus >= 201703L) - #if __has_cpp_attribute(fallthrough) - #define CYTHON_FALLTHROUGH [[fallthrough]] - #endif - #endif - #ifndef CYTHON_FALLTHROUGH - #if __has_cpp_attribute(clang::fallthrough) - #define CYTHON_FALLTHROUGH [[clang::fallthrough]] - #elif __has_cpp_attribute(gnu::fallthrough) - #define CYTHON_FALLTHROUGH [[gnu::fallthrough]] - #endif - #endif - #endif - #ifndef CYTHON_FALLTHROUGH - #if __has_attribute(fallthrough) - #define CYTHON_FALLTHROUGH __attribute__((fallthrough)) - #else - #define CYTHON_FALLTHROUGH - #endif - #endif - #if defined(__clang__) && defined(__apple_build_version__) - #if __apple_build_version__ < 7000000 - #undef CYTHON_FALLTHROUGH - #define CYTHON_FALLTHROUGH - #endif - #endif -#endif -#ifndef Py_UNREACHABLE - #define Py_UNREACHABLE() assert(0); abort() -#endif -#ifdef __cplusplus - template - struct __PYX_IS_UNSIGNED_IMPL {static const bool value = T(0) < T(-1);}; - #define __PYX_IS_UNSIGNED(type) (__PYX_IS_UNSIGNED_IMPL::value) -#else - #define __PYX_IS_UNSIGNED(type) (((type)-1) > 0) -#endif -#if CYTHON_COMPILING_IN_PYPY == 1 - #define __PYX_NEED_TP_PRINT_SLOT (PY_VERSION_HEX >= 0x030800b4 && PY_VERSION_HEX < 0x030A0000) -#else - #define __PYX_NEED_TP_PRINT_SLOT (PY_VERSION_HEX >= 0x030800b4 && PY_VERSION_HEX < 0x03090000) -#endif -#define __PYX_REINTERPRET_FUNCION(func_pointer, other_pointer) ((func_pointer)(void(*)(void))(other_pointer)) - -/* CInitCode */ -#ifndef CYTHON_INLINE - #if defined(__clang__) - #define CYTHON_INLINE __inline__ __attribute__ ((__unused__)) - #elif 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 - -/* PythonCompatibility */ -#define __PYX_BUILD_PY_SSIZE_T "n" -#define CYTHON_FORMAT_SSIZE_T "z" -#define __Pyx_BUILTIN_MODULE_NAME "builtins" -#define __Pyx_DefaultClassType PyType_Type -#if CYTHON_COMPILING_IN_LIMITED_API - #ifndef CO_OPTIMIZED - static int CO_OPTIMIZED; - #endif - #ifndef CO_NEWLOCALS - static int CO_NEWLOCALS; - #endif - #ifndef CO_VARARGS - static int CO_VARARGS; - #endif - #ifndef CO_VARKEYWORDS - static int CO_VARKEYWORDS; - #endif - #ifndef CO_ASYNC_GENERATOR - static int CO_ASYNC_GENERATOR; - #endif - #ifndef CO_GENERATOR - static int CO_GENERATOR; - #endif - #ifndef CO_COROUTINE - static int CO_COROUTINE; - #endif -#else - #ifndef CO_COROUTINE - #define CO_COROUTINE 0x80 - #endif - #ifndef CO_ASYNC_GENERATOR - #define CO_ASYNC_GENERATOR 0x200 - #endif -#endif -static int __Pyx_init_co_variables(void); -#if PY_VERSION_HEX >= 0x030900A4 || defined(Py_IS_TYPE) - #define __Pyx_IS_TYPE(ob, type) Py_IS_TYPE(ob, type) -#else - #define __Pyx_IS_TYPE(ob, type) (((const PyObject*)ob)->ob_type == (type)) -#endif -#if PY_VERSION_HEX >= 0x030A00B1 || defined(Py_Is) - #define __Pyx_Py_Is(x, y) Py_Is(x, y) -#else - #define __Pyx_Py_Is(x, y) ((x) == (y)) -#endif -#if PY_VERSION_HEX >= 0x030A00B1 || defined(Py_IsNone) - #define __Pyx_Py_IsNone(ob) Py_IsNone(ob) -#else - #define __Pyx_Py_IsNone(ob) __Pyx_Py_Is((ob), Py_None) -#endif -#if PY_VERSION_HEX >= 0x030A00B1 || defined(Py_IsTrue) - #define __Pyx_Py_IsTrue(ob) Py_IsTrue(ob) -#else - #define __Pyx_Py_IsTrue(ob) __Pyx_Py_Is((ob), Py_True) -#endif -#if PY_VERSION_HEX >= 0x030A00B1 || defined(Py_IsFalse) - #define __Pyx_Py_IsFalse(ob) Py_IsFalse(ob) -#else - #define __Pyx_Py_IsFalse(ob) __Pyx_Py_Is((ob), Py_False) -#endif -#define __Pyx_NoneAsNull(obj) (__Pyx_Py_IsNone(obj) ? NULL : (obj)) -#if PY_VERSION_HEX >= 0x030900F0 && !CYTHON_COMPILING_IN_PYPY - #define __Pyx_PyObject_GC_IsFinalized(o) PyObject_GC_IsFinalized(o) -#else - #define __Pyx_PyObject_GC_IsFinalized(o) _PyGC_FINALIZED(o) -#endif -#ifndef Py_TPFLAGS_CHECKTYPES - #define Py_TPFLAGS_CHECKTYPES 0 -#endif -#ifndef Py_TPFLAGS_HAVE_INDEX - #define Py_TPFLAGS_HAVE_INDEX 0 -#endif -#ifndef Py_TPFLAGS_HAVE_NEWBUFFER - #define Py_TPFLAGS_HAVE_NEWBUFFER 0 -#endif -#ifndef Py_TPFLAGS_HAVE_FINALIZE - #define Py_TPFLAGS_HAVE_FINALIZE 0 -#endif -#ifndef Py_TPFLAGS_SEQUENCE - #define Py_TPFLAGS_SEQUENCE 0 -#endif -#ifndef Py_TPFLAGS_MAPPING - #define Py_TPFLAGS_MAPPING 0 -#endif -#ifndef METH_STACKLESS - #define METH_STACKLESS 0 -#endif -#ifndef METH_FASTCALL - #ifndef METH_FASTCALL - #define METH_FASTCALL 0x80 - #endif - typedef PyObject *(*__Pyx_PyCFunctionFast) (PyObject *self, PyObject *const *args, Py_ssize_t nargs); - typedef PyObject *(*__Pyx_PyCFunctionFastWithKeywords) (PyObject *self, PyObject *const *args, - Py_ssize_t nargs, PyObject *kwnames); -#else - #if PY_VERSION_HEX >= 0x030d00A4 - # define __Pyx_PyCFunctionFast PyCFunctionFast - # define __Pyx_PyCFunctionFastWithKeywords PyCFunctionFastWithKeywords - #else - # define __Pyx_PyCFunctionFast _PyCFunctionFast - # define __Pyx_PyCFunctionFastWithKeywords _PyCFunctionFastWithKeywords - #endif -#endif -#if CYTHON_METH_FASTCALL - #define __Pyx_METH_FASTCALL METH_FASTCALL - #define __Pyx_PyCFunction_FastCall __Pyx_PyCFunctionFast - #define __Pyx_PyCFunction_FastCallWithKeywords __Pyx_PyCFunctionFastWithKeywords -#else - #define __Pyx_METH_FASTCALL METH_VARARGS - #define __Pyx_PyCFunction_FastCall PyCFunction - #define __Pyx_PyCFunction_FastCallWithKeywords PyCFunctionWithKeywords -#endif -#if CYTHON_VECTORCALL - #define __pyx_vectorcallfunc vectorcallfunc - #define __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET PY_VECTORCALL_ARGUMENTS_OFFSET - #define __Pyx_PyVectorcall_NARGS(n) PyVectorcall_NARGS((size_t)(n)) -#elif CYTHON_BACKPORT_VECTORCALL - typedef PyObject *(*__pyx_vectorcallfunc)(PyObject *callable, PyObject *const *args, - size_t nargsf, PyObject *kwnames); - #define __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET ((size_t)1 << (8 * sizeof(size_t) - 1)) - #define __Pyx_PyVectorcall_NARGS(n) ((Py_ssize_t)(((size_t)(n)) & ~__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)) -#else - #define __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET 0 - #define __Pyx_PyVectorcall_NARGS(n) ((Py_ssize_t)(n)) -#endif -#if PY_VERSION_HEX >= 0x030900B1 -#define __Pyx_PyCFunction_CheckExact(func) PyCFunction_CheckExact(func) -#else -#define __Pyx_PyCFunction_CheckExact(func) PyCFunction_Check(func) -#endif -#define __Pyx_CyOrPyCFunction_Check(func) PyCFunction_Check(func) -#if CYTHON_COMPILING_IN_CPYTHON -#define __Pyx_CyOrPyCFunction_GET_FUNCTION(func) (((PyCFunctionObject*)(func))->m_ml->ml_meth) -#elif !CYTHON_COMPILING_IN_LIMITED_API -#define __Pyx_CyOrPyCFunction_GET_FUNCTION(func) PyCFunction_GET_FUNCTION(func) -#endif -#if CYTHON_COMPILING_IN_CPYTHON -#define __Pyx_CyOrPyCFunction_GET_FLAGS(func) (((PyCFunctionObject*)(func))->m_ml->ml_flags) -static CYTHON_INLINE PyObject* __Pyx_CyOrPyCFunction_GET_SELF(PyObject *func) { - return (__Pyx_CyOrPyCFunction_GET_FLAGS(func) & METH_STATIC) ? NULL : ((PyCFunctionObject*)func)->m_self; -} -#endif -static CYTHON_INLINE int __Pyx__IsSameCFunction(PyObject *func, void (*cfunc)(void)) { -#if CYTHON_COMPILING_IN_LIMITED_API - return PyCFunction_Check(func) && PyCFunction_GetFunction(func) == (PyCFunction) cfunc; -#else - return PyCFunction_Check(func) && PyCFunction_GET_FUNCTION(func) == (PyCFunction) cfunc; -#endif -} -#define __Pyx_IsSameCFunction(func, cfunc) __Pyx__IsSameCFunction(func, cfunc) -#if __PYX_LIMITED_VERSION_HEX < 0x03090000 - #define __Pyx_PyType_FromModuleAndSpec(m, s, b) ((void)m, PyType_FromSpecWithBases(s, b)) - typedef PyObject *(*__Pyx_PyCMethod)(PyObject *, PyTypeObject *, PyObject *const *, size_t, PyObject *); -#else - #define __Pyx_PyType_FromModuleAndSpec(m, s, b) PyType_FromModuleAndSpec(m, s, b) - #define __Pyx_PyCMethod PyCMethod -#endif -#ifndef METH_METHOD - #define METH_METHOD 0x200 -#endif -#if CYTHON_COMPILING_IN_PYPY && !defined(PyObject_Malloc) - #define PyObject_Malloc(s) PyMem_Malloc(s) - #define PyObject_Free(p) PyMem_Free(p) - #define PyObject_Realloc(p) PyMem_Realloc(p) -#endif -#if CYTHON_COMPILING_IN_LIMITED_API - #define __Pyx_PyFrame_SetLineNumber(frame, lineno) -#elif CYTHON_COMPILING_IN_GRAAL - #define __Pyx_PyCode_HasFreeVars(co) (PyCode_GetNumFree(co) > 0) - #define __Pyx_PyFrame_SetLineNumber(frame, lineno) _PyFrame_SetLineNumber((frame), (lineno)) -#else - #define __Pyx_PyCode_HasFreeVars(co) (PyCode_GetNumFree(co) > 0) - #define __Pyx_PyFrame_SetLineNumber(frame, lineno) (frame)->f_lineno = (lineno) -#endif -#if CYTHON_COMPILING_IN_LIMITED_API - #define __Pyx_PyThreadState_Current PyThreadState_Get() -#elif !CYTHON_FAST_THREAD_STATE - #define __Pyx_PyThreadState_Current PyThreadState_GET() -#elif PY_VERSION_HEX >= 0x030d00A1 - #define __Pyx_PyThreadState_Current PyThreadState_GetUnchecked() -#else - #define __Pyx_PyThreadState_Current _PyThreadState_UncheckedGet() -#endif -#if CYTHON_USE_MODULE_STATE -static CYTHON_INLINE void *__Pyx__PyModule_GetState(PyObject *op) -{ - void *result; - result = PyModule_GetState(op); - if (!result) - Py_FatalError("Couldn't find the module state"); - return result; -} -#define __Pyx_PyModule_GetState(o) (__pyx_mstatetype *)__Pyx__PyModule_GetState(o) -#else -#define __Pyx_PyModule_GetState(op) ((void)op,__pyx_mstate_global) -#endif -#define __Pyx_PyObject_GetSlot(obj, name, func_ctype) __Pyx_PyType_GetSlot(Py_TYPE((PyObject *) obj), name, func_ctype) -#define __Pyx_PyObject_TryGetSlot(obj, name, func_ctype) __Pyx_PyType_TryGetSlot(Py_TYPE(obj), name, func_ctype) -#define __Pyx_PyObject_GetSubSlot(obj, sub, name, func_ctype) __Pyx_PyType_GetSubSlot(Py_TYPE(obj), sub, name, func_ctype) -#define __Pyx_PyObject_TryGetSubSlot(obj, sub, name, func_ctype) __Pyx_PyType_TryGetSubSlot(Py_TYPE(obj), sub, name, func_ctype) -#if CYTHON_USE_TYPE_SLOTS - #define __Pyx_PyType_GetSlot(type, name, func_ctype) ((type)->name) - #define __Pyx_PyType_TryGetSlot(type, name, func_ctype) __Pyx_PyType_GetSlot(type, name, func_ctype) - #define __Pyx_PyType_GetSubSlot(type, sub, name, func_ctype) (((type)->sub) ? ((type)->sub->name) : NULL) - #define __Pyx_PyType_TryGetSubSlot(type, sub, name, func_ctype) __Pyx_PyType_GetSubSlot(type, sub, name, func_ctype) -#else - #define __Pyx_PyType_GetSlot(type, name, func_ctype) ((func_ctype) PyType_GetSlot((type), Py_##name)) - #define __Pyx_PyType_TryGetSlot(type, name, func_ctype)\ - ((__PYX_LIMITED_VERSION_HEX >= 0x030A0000 ||\ - (PyType_GetFlags(type) & Py_TPFLAGS_HEAPTYPE) || __Pyx_get_runtime_version() >= 0x030A0000) ?\ - __Pyx_PyType_GetSlot(type, name, func_ctype) : NULL) - #define __Pyx_PyType_GetSubSlot(obj, sub, name, func_ctype) __Pyx_PyType_GetSlot(obj, name, func_ctype) - #define __Pyx_PyType_TryGetSubSlot(obj, sub, name, func_ctype) __Pyx_PyType_TryGetSlot(obj, name, func_ctype) -#endif -#if CYTHON_COMPILING_IN_CPYTHON || defined(_PyDict_NewPresized) -#define __Pyx_PyDict_NewPresized(n) ((n <= 8) ? PyDict_New() : _PyDict_NewPresized(n)) -#else -#define __Pyx_PyDict_NewPresized(n) PyDict_New() -#endif -#define __Pyx_PyNumber_Divide(x,y) PyNumber_TrueDivide(x,y) -#define __Pyx_PyNumber_InPlaceDivide(x,y) PyNumber_InPlaceTrueDivide(x,y) -#if CYTHON_COMPILING_IN_CPYTHON && CYTHON_USE_UNICODE_INTERNALS -#define __Pyx_PyDict_GetItemStrWithError(dict, name) _PyDict_GetItem_KnownHash(dict, name, ((PyASCIIObject *) name)->hash) -static CYTHON_INLINE PyObject * __Pyx_PyDict_GetItemStr(PyObject *dict, PyObject *name) { - PyObject *res = __Pyx_PyDict_GetItemStrWithError(dict, name); - if (res == NULL) PyErr_Clear(); - return res; -} -#elif !CYTHON_COMPILING_IN_PYPY || PYPY_VERSION_NUM >= 0x07020000 -#define __Pyx_PyDict_GetItemStrWithError PyDict_GetItemWithError -#define __Pyx_PyDict_GetItemStr PyDict_GetItem -#else -static CYTHON_INLINE PyObject * __Pyx_PyDict_GetItemStrWithError(PyObject *dict, PyObject *name) { -#if CYTHON_COMPILING_IN_PYPY - return PyDict_GetItem(dict, name); -#else - PyDictEntry *ep; - PyDictObject *mp = (PyDictObject*) dict; - long hash = ((PyStringObject *) name)->ob_shash; - assert(hash != -1); - ep = (mp->ma_lookup)(mp, name, hash); - if (ep == NULL) { - return NULL; - } - return ep->me_value; -#endif -} -#define __Pyx_PyDict_GetItemStr PyDict_GetItem -#endif -#if CYTHON_USE_TYPE_SLOTS - #define __Pyx_PyType_GetFlags(tp) (((PyTypeObject *)tp)->tp_flags) - #define __Pyx_PyType_HasFeature(type, feature) ((__Pyx_PyType_GetFlags(type) & (feature)) != 0) -#else - #define __Pyx_PyType_GetFlags(tp) (PyType_GetFlags((PyTypeObject *)tp)) - #define __Pyx_PyType_HasFeature(type, feature) PyType_HasFeature(type, feature) -#endif -#define __Pyx_PyObject_GetIterNextFunc(iterator) __Pyx_PyObject_GetSlot(iterator, tp_iternext, iternextfunc) -#if CYTHON_USE_TYPE_SPECS && PY_VERSION_HEX >= 0x03080000 -#define __Pyx_PyHeapTypeObject_GC_Del(obj) {\ - PyTypeObject *type = Py_TYPE((PyObject*)obj);\ - assert(__Pyx_PyType_HasFeature(type, Py_TPFLAGS_HEAPTYPE));\ - PyObject_GC_Del(obj);\ - Py_DECREF(type);\ -} -#else -#define __Pyx_PyHeapTypeObject_GC_Del(obj) PyObject_GC_Del(obj) -#endif -#if CYTHON_COMPILING_IN_LIMITED_API - #define __Pyx_PyUnicode_READY(op) (0) - #define __Pyx_PyUnicode_READ_CHAR(u, i) PyUnicode_ReadChar(u, i) - #define __Pyx_PyUnicode_MAX_CHAR_VALUE(u) ((void)u, 1114111U) - #define __Pyx_PyUnicode_KIND(u) ((void)u, (0)) - #define __Pyx_PyUnicode_DATA(u) ((void*)u) - #define __Pyx_PyUnicode_READ(k, d, i) ((void)k, PyUnicode_ReadChar((PyObject*)(d), i)) - #define __Pyx_PyUnicode_IS_TRUE(u) (0 != PyUnicode_GetLength(u)) -#else - #if PY_VERSION_HEX >= 0x030C0000 - #define __Pyx_PyUnicode_READY(op) (0) - #else - #define __Pyx_PyUnicode_READY(op) (likely(PyUnicode_IS_READY(op)) ?\ - 0 : _PyUnicode_Ready((PyObject *)(op))) - #endif - #define __Pyx_PyUnicode_READ_CHAR(u, i) PyUnicode_READ_CHAR(u, i) - #define __Pyx_PyUnicode_MAX_CHAR_VALUE(u) PyUnicode_MAX_CHAR_VALUE(u) - #define __Pyx_PyUnicode_KIND(u) ((int)PyUnicode_KIND(u)) - #define __Pyx_PyUnicode_DATA(u) PyUnicode_DATA(u) - #define __Pyx_PyUnicode_READ(k, d, i) PyUnicode_READ(k, d, i) - #define __Pyx_PyUnicode_WRITE(k, d, i, ch) PyUnicode_WRITE(k, d, i, (Py_UCS4) ch) - #if PY_VERSION_HEX >= 0x030C0000 - #define __Pyx_PyUnicode_IS_TRUE(u) (0 != PyUnicode_GET_LENGTH(u)) - #else - #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x03090000 - #define __Pyx_PyUnicode_IS_TRUE(u) (0 != (likely(PyUnicode_IS_READY(u)) ? PyUnicode_GET_LENGTH(u) : ((PyCompactUnicodeObject *)(u))->wstr_length)) - #else - #define __Pyx_PyUnicode_IS_TRUE(u) (0 != (likely(PyUnicode_IS_READY(u)) ? PyUnicode_GET_LENGTH(u) : PyUnicode_GET_SIZE(u))) - #endif - #endif -#endif -#if CYTHON_COMPILING_IN_PYPY - #define __Pyx_PyUnicode_Concat(a, b) PyNumber_Add(a, b) - #define __Pyx_PyUnicode_ConcatSafe(a, b) PyNumber_Add(a, b) -#else - #define __Pyx_PyUnicode_Concat(a, b) PyUnicode_Concat(a, b) - #define __Pyx_PyUnicode_ConcatSafe(a, b) ((unlikely((a) == Py_None) || unlikely((b) == Py_None)) ?\ - PyNumber_Add(a, b) : __Pyx_PyUnicode_Concat(a, b)) -#endif -#if CYTHON_COMPILING_IN_PYPY - #if !defined(PyUnicode_DecodeUnicodeEscape) - #define PyUnicode_DecodeUnicodeEscape(s, size, errors) PyUnicode_Decode(s, size, "unicode_escape", errors) - #endif - #if !defined(PyUnicode_Contains) - #define PyUnicode_Contains(u, s) PySequence_Contains(u, s) - #endif - #if !defined(PyByteArray_Check) - #define PyByteArray_Check(obj) PyObject_TypeCheck(obj, &PyByteArray_Type) - #endif - #if !defined(PyObject_Format) - #define PyObject_Format(obj, fmt) PyObject_CallMethod(obj, "__format__", "O", fmt) - #endif -#endif -#define __Pyx_PyUnicode_FormatSafe(a, b) ((unlikely((a) == Py_None || (PyUnicode_Check(b) && !PyUnicode_CheckExact(b)))) ? PyNumber_Remainder(a, b) : PyUnicode_Format(a, b)) -#if CYTHON_COMPILING_IN_CPYTHON - #define __Pyx_PySequence_ListKeepNew(obj)\ - (likely(PyList_CheckExact(obj) && Py_REFCNT(obj) == 1) ? __Pyx_NewRef(obj) : PySequence_List(obj)) -#else - #define __Pyx_PySequence_ListKeepNew(obj) PySequence_List(obj) -#endif -#ifndef PySet_CheckExact - #define PySet_CheckExact(obj) __Pyx_IS_TYPE(obj, &PySet_Type) -#endif -#if PY_VERSION_HEX >= 0x030900A4 - #define __Pyx_SET_REFCNT(obj, refcnt) Py_SET_REFCNT(obj, refcnt) - #define __Pyx_SET_SIZE(obj, size) Py_SET_SIZE(obj, size) -#else - #define __Pyx_SET_REFCNT(obj, refcnt) Py_REFCNT(obj) = (refcnt) - #define __Pyx_SET_SIZE(obj, size) Py_SIZE(obj) = (size) -#endif -#if CYTHON_COMPILING_IN_LIMITED_API || CYTHON_AVOID_BORROWED_REFS || CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS || !CYTHON_ASSUME_SAFE_MACROS - #if __PYX_LIMITED_VERSION_HEX >= 0x030d0000 - #define __Pyx_PyList_GetItemRef(o, i) PyList_GetItemRef(o, i) - #else - #define __Pyx_PyList_GetItemRef(o, i) PySequence_GetItem(o, i) - #endif -#else - #define __Pyx_PyList_GetItemRef(o, i) __Pyx_NewRef(PyList_GET_ITEM(o, i)) -#endif -#if __PYX_LIMITED_VERSION_HEX >= 0x030d0000 -#define __Pyx_PyDict_GetItemRef(dict, key, result) PyDict_GetItemRef(dict, key, result) -#elif CYTHON_AVOID_BORROWED_REFS || CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS -static CYTHON_INLINE int __Pyx_PyDict_GetItemRef(PyObject *dict, PyObject *key, PyObject **result) { - *result = PyObject_GetItem(dict, key); - if (*result == NULL) { - if (PyErr_ExceptionMatches(PyExc_KeyError)) { - PyErr_Clear(); - return 0; - } - return -1; - } - return 1; -} -#else -static CYTHON_INLINE int __Pyx_PyDict_GetItemRef(PyObject *dict, PyObject *key, PyObject **result) { - *result = PyDict_GetItemWithError(dict, key); - if (*result == NULL) { - return PyErr_Occurred() ? -1 : 0; - } - Py_INCREF(*result); - return 1; -} -#endif -#if defined(CYTHON_DEBUG_VISIT_CONST) && CYTHON_DEBUG_VISIT_CONST - #define __Pyx_VISIT_CONST(obj) Py_VISIT(obj) -#else - #define __Pyx_VISIT_CONST(obj) -#endif -#if CYTHON_ASSUME_SAFE_MACROS - #define __Pyx_PySequence_ITEM(o, i) PySequence_ITEM(o, i) - #define __Pyx_PySequence_SIZE(seq) Py_SIZE(seq) - #define __Pyx_PyTuple_SET_ITEM(o, i, v) (PyTuple_SET_ITEM(o, i, v), (0)) - #define __Pyx_PyTuple_GET_ITEM(o, i) PyTuple_GET_ITEM(o, i) - #define __Pyx_PyList_SET_ITEM(o, i, v) (PyList_SET_ITEM(o, i, v), (0)) - #define __Pyx_PyList_GET_ITEM(o, i) PyList_GET_ITEM(o, i) -#else - #define __Pyx_PySequence_ITEM(o, i) PySequence_GetItem(o, i) - #define __Pyx_PySequence_SIZE(seq) PySequence_Size(seq) - #define __Pyx_PyTuple_SET_ITEM(o, i, v) PyTuple_SetItem(o, i, v) - #define __Pyx_PyTuple_GET_ITEM(o, i) PyTuple_GetItem(o, i) - #define __Pyx_PyList_SET_ITEM(o, i, v) PyList_SetItem(o, i, v) - #define __Pyx_PyList_GET_ITEM(o, i) PyList_GetItem(o, i) -#endif -#if CYTHON_ASSUME_SAFE_SIZE - #define __Pyx_PyTuple_GET_SIZE(o) PyTuple_GET_SIZE(o) - #define __Pyx_PyList_GET_SIZE(o) PyList_GET_SIZE(o) - #define __Pyx_PySet_GET_SIZE(o) PySet_GET_SIZE(o) - #define __Pyx_PyBytes_GET_SIZE(o) PyBytes_GET_SIZE(o) - #define __Pyx_PyByteArray_GET_SIZE(o) PyByteArray_GET_SIZE(o) - #define __Pyx_PyUnicode_GET_LENGTH(o) PyUnicode_GET_LENGTH(o) -#else - #define __Pyx_PyTuple_GET_SIZE(o) PyTuple_Size(o) - #define __Pyx_PyList_GET_SIZE(o) PyList_Size(o) - #define __Pyx_PySet_GET_SIZE(o) PySet_Size(o) - #define __Pyx_PyBytes_GET_SIZE(o) PyBytes_Size(o) - #define __Pyx_PyByteArray_GET_SIZE(o) PyByteArray_Size(o) - #define __Pyx_PyUnicode_GET_LENGTH(o) PyUnicode_GetLength(o) -#endif -#if __PYX_LIMITED_VERSION_HEX >= 0x030d0000 - #define __Pyx_PyImport_AddModuleRef(name) PyImport_AddModuleRef(name) -#else - static CYTHON_INLINE PyObject *__Pyx_PyImport_AddModuleRef(const char *name) { - PyObject *module = PyImport_AddModule(name); - Py_XINCREF(module); - return module; - } -#endif -#if CYTHON_COMPILING_IN_PYPY && !defined(PyUnicode_InternFromString) - #define PyUnicode_InternFromString(s) PyUnicode_FromString(s) -#endif -#define __Pyx_PyLong_FromHash_t PyLong_FromSsize_t -#define __Pyx_PyLong_AsHash_t __Pyx_PyIndex_AsSsize_t -#if __PYX_LIMITED_VERSION_HEX >= 0x030A0000 - #define __Pyx_PySendResult PySendResult -#else - typedef enum { - PYGEN_RETURN = 0, - PYGEN_ERROR = -1, - PYGEN_NEXT = 1, - } __Pyx_PySendResult; -#endif -#if CYTHON_COMPILING_IN_LIMITED_API || PY_VERSION_HEX < 0x030A00A3 - typedef __Pyx_PySendResult (*__Pyx_pyiter_sendfunc)(PyObject *iter, PyObject *value, PyObject **result); -#else - #define __Pyx_pyiter_sendfunc sendfunc -#endif -#if !CYTHON_USE_AM_SEND -#define __PYX_HAS_PY_AM_SEND 0 -#elif __PYX_LIMITED_VERSION_HEX >= 0x030A0000 -#define __PYX_HAS_PY_AM_SEND 1 -#else -#define __PYX_HAS_PY_AM_SEND 2 // our own backported implementation -#endif -#if __PYX_HAS_PY_AM_SEND < 2 - #define __Pyx_PyAsyncMethodsStruct PyAsyncMethods -#else - typedef struct { - unaryfunc am_await; - unaryfunc am_aiter; - unaryfunc am_anext; - __Pyx_pyiter_sendfunc am_send; - } __Pyx_PyAsyncMethodsStruct; - #define __Pyx_SlotTpAsAsync(s) ((PyAsyncMethods*)(s)) -#endif -#if CYTHON_USE_AM_SEND && PY_VERSION_HEX < 0x030A00F0 - #define __Pyx_TPFLAGS_HAVE_AM_SEND (1UL << 21) -#else - #define __Pyx_TPFLAGS_HAVE_AM_SEND (0) -#endif -#if PY_VERSION_HEX >= 0x03090000 -#define __Pyx_PyInterpreterState_Get() PyInterpreterState_Get() -#else -#define __Pyx_PyInterpreterState_Get() PyThreadState_Get()->interp -#endif -#if CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX < 0x030A0000 -#ifdef __cplusplus -extern "C" -#endif -PyAPI_FUNC(void *) PyMem_Calloc(size_t nelem, size_t elsize); -#endif -#if CYTHON_COMPILING_IN_LIMITED_API -static int __Pyx_init_co_variable(PyObject *inspect, const char* name, int *write_to) { - int value; - PyObject *py_value = PyObject_GetAttrString(inspect, name); - if (!py_value) return 0; - value = (int) PyLong_AsLong(py_value); - Py_DECREF(py_value); - *write_to = value; - return value != -1 || !PyErr_Occurred(); -} -static int __Pyx_init_co_variables(void) { - PyObject *inspect; - int result; - inspect = PyImport_ImportModule("inspect"); - result = -#if !defined(CO_OPTIMIZED) - __Pyx_init_co_variable(inspect, "CO_OPTIMIZED", &CO_OPTIMIZED) && -#endif -#if !defined(CO_NEWLOCALS) - __Pyx_init_co_variable(inspect, "CO_NEWLOCALS", &CO_NEWLOCALS) && -#endif -#if !defined(CO_VARARGS) - __Pyx_init_co_variable(inspect, "CO_VARARGS", &CO_VARARGS) && -#endif -#if !defined(CO_VARKEYWORDS) - __Pyx_init_co_variable(inspect, "CO_VARKEYWORDS", &CO_VARKEYWORDS) && -#endif -#if !defined(CO_ASYNC_GENERATOR) - __Pyx_init_co_variable(inspect, "CO_ASYNC_GENERATOR", &CO_ASYNC_GENERATOR) && -#endif -#if !defined(CO_GENERATOR) - __Pyx_init_co_variable(inspect, "CO_GENERATOR", &CO_GENERATOR) && -#endif -#if !defined(CO_COROUTINE) - __Pyx_init_co_variable(inspect, "CO_COROUTINE", &CO_COROUTINE) && -#endif - 1; - Py_DECREF(inspect); - return result ? 0 : -1; -} -#else -static int __Pyx_init_co_variables(void) { - return 0; // It's a limited API-only feature -} -#endif - -/* MathInitCode */ -#if defined(_WIN32) || defined(WIN32) || defined(MS_WINDOWS) - #ifndef _USE_MATH_DEFINES - #define _USE_MATH_DEFINES - #endif -#endif -#include -#ifdef NAN -#define __PYX_NAN() ((float) NAN) -#else -static CYTHON_INLINE float __PYX_NAN() { - float value; - memset(&value, 0xFF, sizeof(value)); - return value; -} -#endif -#if defined(__CYGWIN__) && defined(_LDBL_EQ_DBL) -#define __Pyx_truncl trunc -#else -#define __Pyx_truncl truncl -#endif - -#ifndef CYTHON_CLINE_IN_TRACEBACK_RUNTIME -#define CYTHON_CLINE_IN_TRACEBACK_RUNTIME 0 -#endif -#ifndef CYTHON_CLINE_IN_TRACEBACK -#define CYTHON_CLINE_IN_TRACEBACK CYTHON_CLINE_IN_TRACEBACK_RUNTIME -#endif -#if CYTHON_CLINE_IN_TRACEBACK -#define __PYX_MARK_ERR_POS(f_index, lineno) { __pyx_filename = __pyx_f[f_index]; (void) __pyx_filename; __pyx_lineno = lineno; (void) __pyx_lineno; __pyx_clineno = __LINE__; (void) __pyx_clineno; } -#else -#define __PYX_MARK_ERR_POS(f_index, lineno) { __pyx_filename = __pyx_f[f_index]; (void) __pyx_filename; __pyx_lineno = lineno; (void) __pyx_lineno; (void) __pyx_clineno; } -#endif -#define __PYX_ERR(f_index, lineno, Ln_error) \ - { __PYX_MARK_ERR_POS(f_index, lineno) goto Ln_error; } - -#ifdef CYTHON_EXTERN_C - #undef __PYX_EXTERN_C - #define __PYX_EXTERN_C CYTHON_EXTERN_C -#elif defined(__PYX_EXTERN_C) - #ifdef _MSC_VER - #pragma message ("Please do not define the '__PYX_EXTERN_C' macro externally. Use 'CYTHON_EXTERN_C' instead.") - #else - #warning Please do not define the '__PYX_EXTERN_C' macro externally. Use 'CYTHON_EXTERN_C' instead. - #endif -#else - #ifdef __cplusplus - #define __PYX_EXTERN_C extern "C" - #else - #define __PYX_EXTERN_C extern - #endif -#endif - -#define __PYX_HAVE__epanet__epanet2_ec -#define __PYX_HAVE_API__epanet__epanet2_ec -/* Early includes */ -#ifdef _OPENMP -#include -#endif /* _OPENMP */ - -#if defined(PYREX_WITHOUT_ASSERTIONS) && !defined(CYTHON_WITHOUT_ASSERTIONS) -#define CYTHON_WITHOUT_ASSERTIONS -#endif - -#define __PYX_DEFAULT_STRING_ENCODING_IS_ASCII 0 -#define __PYX_DEFAULT_STRING_ENCODING_IS_UTF8 0 -#define __PYX_DEFAULT_STRING_ENCODING "" -#define __Pyx_PyObject_FromString __Pyx_PyBytes_FromString -#define __Pyx_PyObject_FromStringAndSize __Pyx_PyBytes_FromStringAndSize -#define __Pyx_uchar_cast(c) ((unsigned char)c) -#define __Pyx_long_cast(x) ((long)x) -#define __Pyx_fits_Py_ssize_t(v, type, is_signed) (\ - (sizeof(type) < sizeof(Py_ssize_t)) ||\ - (sizeof(type) > sizeof(Py_ssize_t) &&\ - likely(v < (type)PY_SSIZE_T_MAX ||\ - v == (type)PY_SSIZE_T_MAX) &&\ - (!is_signed || likely(v > (type)PY_SSIZE_T_MIN ||\ - v == (type)PY_SSIZE_T_MIN))) ||\ - (sizeof(type) == sizeof(Py_ssize_t) &&\ - (is_signed || likely(v < (type)PY_SSIZE_T_MAX ||\ - v == (type)PY_SSIZE_T_MAX))) ) -static CYTHON_INLINE int __Pyx_is_valid_index(Py_ssize_t i, Py_ssize_t limit) { - return (size_t) i < (size_t) limit; -} -#if defined (__cplusplus) && __cplusplus >= 201103L - #include - #define __Pyx_sst_abs(value) std::abs(value) -#elif SIZEOF_INT >= SIZEOF_SIZE_T - #define __Pyx_sst_abs(value) abs(value) -#elif SIZEOF_LONG >= SIZEOF_SIZE_T - #define __Pyx_sst_abs(value) labs(value) -#elif defined (_MSC_VER) - #define __Pyx_sst_abs(value) ((Py_ssize_t)_abs64(value)) -#elif defined (__STDC_VERSION__) && __STDC_VERSION__ >= 199901L - #define __Pyx_sst_abs(value) llabs(value) -#elif defined (__GNUC__) - #define __Pyx_sst_abs(value) __builtin_llabs(value) -#else - #define __Pyx_sst_abs(value) ((value<0) ? -value : value) -#endif -static CYTHON_INLINE Py_ssize_t __Pyx_ssize_strlen(const char *s); -static CYTHON_INLINE const char* __Pyx_PyObject_AsString(PyObject*); -static CYTHON_INLINE const char* __Pyx_PyObject_AsStringAndSize(PyObject*, Py_ssize_t* length); -static CYTHON_INLINE PyObject* __Pyx_PyByteArray_FromString(const char*); -#define __Pyx_PyByteArray_FromStringAndSize(s, l) PyByteArray_FromStringAndSize((const char*)s, l) -#define __Pyx_PyBytes_FromString PyBytes_FromString -#define __Pyx_PyBytes_FromStringAndSize PyBytes_FromStringAndSize -static CYTHON_INLINE PyObject* __Pyx_PyUnicode_FromString(const char*); -#if CYTHON_ASSUME_SAFE_MACROS - #define __Pyx_PyBytes_AsWritableString(s) ((char*) PyBytes_AS_STRING(s)) - #define __Pyx_PyBytes_AsWritableSString(s) ((signed char*) PyBytes_AS_STRING(s)) - #define __Pyx_PyBytes_AsWritableUString(s) ((unsigned char*) PyBytes_AS_STRING(s)) - #define __Pyx_PyBytes_AsString(s) ((const char*) PyBytes_AS_STRING(s)) - #define __Pyx_PyBytes_AsSString(s) ((const signed char*) PyBytes_AS_STRING(s)) - #define __Pyx_PyBytes_AsUString(s) ((const unsigned char*) PyBytes_AS_STRING(s)) - #define __Pyx_PyByteArray_AsString(s) PyByteArray_AS_STRING(s) -#else - #define __Pyx_PyBytes_AsWritableString(s) ((char*) PyBytes_AsString(s)) - #define __Pyx_PyBytes_AsWritableSString(s) ((signed char*) PyBytes_AsString(s)) - #define __Pyx_PyBytes_AsWritableUString(s) ((unsigned char*) PyBytes_AsString(s)) - #define __Pyx_PyBytes_AsString(s) ((const char*) PyBytes_AsString(s)) - #define __Pyx_PyBytes_AsSString(s) ((const signed char*) PyBytes_AsString(s)) - #define __Pyx_PyBytes_AsUString(s) ((const unsigned char*) PyBytes_AsString(s)) - #define __Pyx_PyByteArray_AsString(s) PyByteArray_AsString(s) -#endif -#define __Pyx_PyObject_AsWritableString(s) ((char*)(__pyx_uintptr_t) __Pyx_PyObject_AsString(s)) -#define __Pyx_PyObject_AsWritableSString(s) ((signed char*)(__pyx_uintptr_t) __Pyx_PyObject_AsString(s)) -#define __Pyx_PyObject_AsWritableUString(s) ((unsigned char*)(__pyx_uintptr_t) __Pyx_PyObject_AsString(s)) -#define __Pyx_PyObject_AsSString(s) ((const signed char*) __Pyx_PyObject_AsString(s)) -#define __Pyx_PyObject_AsUString(s) ((const unsigned char*) __Pyx_PyObject_AsString(s)) -#define __Pyx_PyObject_FromCString(s) __Pyx_PyObject_FromString((const char*)s) -#define __Pyx_PyBytes_FromCString(s) __Pyx_PyBytes_FromString((const char*)s) -#define __Pyx_PyByteArray_FromCString(s) __Pyx_PyByteArray_FromString((const char*)s) -#define __Pyx_PyUnicode_FromCString(s) __Pyx_PyUnicode_FromString((const char*)s) -#define __Pyx_PyUnicode_FromOrdinal(o) PyUnicode_FromOrdinal((int)o) -#define __Pyx_PyUnicode_AsUnicode PyUnicode_AsUnicode -static CYTHON_INLINE PyObject *__Pyx_NewRef(PyObject *obj) { -#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030a0000 || defined(Py_NewRef) - return Py_NewRef(obj); -#else - Py_INCREF(obj); - return obj; -#endif -} -static CYTHON_INLINE PyObject *__Pyx_XNewRef(PyObject *obj) { -#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030a0000 || defined(Py_XNewRef) - return Py_XNewRef(obj); -#else - Py_XINCREF(obj); - return obj; -#endif -} -static CYTHON_INLINE PyObject *__Pyx_Owned_Py_None(int b); -static CYTHON_INLINE PyObject * __Pyx_PyBool_FromLong(long b); -static CYTHON_INLINE int __Pyx_PyObject_IsTrue(PyObject*); -static CYTHON_INLINE int __Pyx_PyObject_IsTrueAndDecref(PyObject*); -static CYTHON_INLINE PyObject* __Pyx_PyNumber_Long(PyObject* x); -#define __Pyx_PySequence_Tuple(obj)\ - (likely(PyTuple_CheckExact(obj)) ? __Pyx_NewRef(obj) : PySequence_Tuple(obj)) -static CYTHON_INLINE Py_ssize_t __Pyx_PyIndex_AsSsize_t(PyObject*); -static CYTHON_INLINE PyObject * __Pyx_PyLong_FromSize_t(size_t); -static CYTHON_INLINE Py_hash_t __Pyx_PyIndex_AsHash_t(PyObject*); -#if CYTHON_ASSUME_SAFE_MACROS -#define __Pyx_PyFloat_AsDouble(x) (PyFloat_CheckExact(x) ? PyFloat_AS_DOUBLE(x) : PyFloat_AsDouble(x)) -#define __Pyx_PyFloat_AS_DOUBLE(x) PyFloat_AS_DOUBLE(x) -#else -#define __Pyx_PyFloat_AsDouble(x) PyFloat_AsDouble(x) -#define __Pyx_PyFloat_AS_DOUBLE(x) PyFloat_AsDouble(x) -#endif -#define __Pyx_PyFloat_AsFloat(x) ((float) __Pyx_PyFloat_AsDouble(x)) -#define __Pyx_PyNumber_Int(x) (PyLong_CheckExact(x) ? __Pyx_NewRef(x) : PyNumber_Long(x)) -#if CYTHON_USE_PYLONG_INTERNALS - #if PY_VERSION_HEX >= 0x030C00A7 - #ifndef _PyLong_SIGN_MASK - #define _PyLong_SIGN_MASK 3 - #endif - #ifndef _PyLong_NON_SIZE_BITS - #define _PyLong_NON_SIZE_BITS 3 - #endif - #define __Pyx_PyLong_Sign(x) (((PyLongObject*)x)->long_value.lv_tag & _PyLong_SIGN_MASK) - #define __Pyx_PyLong_IsNeg(x) ((__Pyx_PyLong_Sign(x) & 2) != 0) - #define __Pyx_PyLong_IsNonNeg(x) (!__Pyx_PyLong_IsNeg(x)) - #define __Pyx_PyLong_IsZero(x) (__Pyx_PyLong_Sign(x) & 1) - #define __Pyx_PyLong_IsPos(x) (__Pyx_PyLong_Sign(x) == 0) - #define __Pyx_PyLong_CompactValueUnsigned(x) (__Pyx_PyLong_Digits(x)[0]) - #define __Pyx_PyLong_DigitCount(x) ((Py_ssize_t) (((PyLongObject*)x)->long_value.lv_tag >> _PyLong_NON_SIZE_BITS)) - #define __Pyx_PyLong_SignedDigitCount(x)\ - ((1 - (Py_ssize_t) __Pyx_PyLong_Sign(x)) * __Pyx_PyLong_DigitCount(x)) - #if defined(PyUnstable_Long_IsCompact) && defined(PyUnstable_Long_CompactValue) - #define __Pyx_PyLong_IsCompact(x) PyUnstable_Long_IsCompact((PyLongObject*) x) - #define __Pyx_PyLong_CompactValue(x) PyUnstable_Long_CompactValue((PyLongObject*) x) - #else - #define __Pyx_PyLong_IsCompact(x) (((PyLongObject*)x)->long_value.lv_tag < (2 << _PyLong_NON_SIZE_BITS)) - #define __Pyx_PyLong_CompactValue(x) ((1 - (Py_ssize_t) __Pyx_PyLong_Sign(x)) * (Py_ssize_t) __Pyx_PyLong_Digits(x)[0]) - #endif - typedef Py_ssize_t __Pyx_compact_pylong; - typedef size_t __Pyx_compact_upylong; - #else - #define __Pyx_PyLong_IsNeg(x) (Py_SIZE(x) < 0) - #define __Pyx_PyLong_IsNonNeg(x) (Py_SIZE(x) >= 0) - #define __Pyx_PyLong_IsZero(x) (Py_SIZE(x) == 0) - #define __Pyx_PyLong_IsPos(x) (Py_SIZE(x) > 0) - #define __Pyx_PyLong_CompactValueUnsigned(x) ((Py_SIZE(x) == 0) ? 0 : __Pyx_PyLong_Digits(x)[0]) - #define __Pyx_PyLong_DigitCount(x) __Pyx_sst_abs(Py_SIZE(x)) - #define __Pyx_PyLong_SignedDigitCount(x) Py_SIZE(x) - #define __Pyx_PyLong_IsCompact(x) (Py_SIZE(x) == 0 || Py_SIZE(x) == 1 || Py_SIZE(x) == -1) - #define __Pyx_PyLong_CompactValue(x)\ - ((Py_SIZE(x) == 0) ? (sdigit) 0 : ((Py_SIZE(x) < 0) ? -(sdigit)__Pyx_PyLong_Digits(x)[0] : (sdigit)__Pyx_PyLong_Digits(x)[0])) - typedef sdigit __Pyx_compact_pylong; - typedef digit __Pyx_compact_upylong; - #endif - #if PY_VERSION_HEX >= 0x030C00A5 - #define __Pyx_PyLong_Digits(x) (((PyLongObject*)x)->long_value.ob_digit) - #else - #define __Pyx_PyLong_Digits(x) (((PyLongObject*)x)->ob_digit) - #endif -#endif -#if __PYX_DEFAULT_STRING_ENCODING_IS_UTF8 - #define __Pyx_PyUnicode_FromStringAndSize(c_str, size) PyUnicode_DecodeUTF8(c_str, size, NULL) -#elif __PYX_DEFAULT_STRING_ENCODING_IS_ASCII - #define __Pyx_PyUnicode_FromStringAndSize(c_str, size) PyUnicode_DecodeASCII(c_str, size, NULL) -#else - #define __Pyx_PyUnicode_FromStringAndSize(c_str, size) PyUnicode_Decode(c_str, size, __PYX_DEFAULT_STRING_ENCODING, NULL) -#endif - - -/* Test for GCC > 2.95 */ -#if defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95))) - #define likely(x) __builtin_expect(!!(x), 1) - #define unlikely(x) __builtin_expect(!!(x), 0) -#else /* !__GNUC__ or GCC < 2.95 */ - #define likely(x) (x) - #define unlikely(x) (x) -#endif /* __GNUC__ */ -/* PretendToInitialize */ -#ifdef __cplusplus -#include -template -static void __Pyx_pretend_to_initialize(T* ptr) { -#if __cplusplus > 201103L - if ((std::is_trivially_default_constructible::value)) -#endif - *ptr = T(); - (void)ptr; -} -#else -static CYTHON_INLINE void __Pyx_pretend_to_initialize(void* ptr) { (void)ptr; } -#endif - - -#if !CYTHON_USE_MODULE_STATE -static PyObject *__pyx_m = NULL; -#endif -static int __pyx_lineno; -static int __pyx_clineno = 0; -static const char * const __pyx_cfilenm = __FILE__; -static const char *__pyx_filename; - -/* #### Code section: filename_table ### */ - -static const char* const __pyx_f[] = { - "epanet/epanet2_ec.py", -}; -/* #### Code section: utility_code_proto_before_types ### */ -/* CriticalSections.proto */ -#if !CYTHON_COMPILING_IN_CPYTHON_FREETHREADING -#define __Pyx_PyCriticalSection void* -#define __Pyx_PyCriticalSection2 void* -#define __Pyx_PyCriticalSection_Begin1(cs, arg) (void)cs -#define __Pyx_PyCriticalSection_Begin2(cs, arg1, arg2) (void)cs -#define __Pyx_PyCriticalSection_End1(cs) -#define __Pyx_PyCriticalSection_End2(cs) -#else -#define __Pyx_PyCriticalSection PyCriticalSection -#define __Pyx_PyCriticalSection2 PyCriticalSection2 -#define __Pyx_PyCriticalSection_Begin1 PyCriticalSection_Begin -#define __Pyx_PyCriticalSection_Begin2 PyCriticalSection2_Begin -#define __Pyx_PyCriticalSection_End1 PyCriticalSection_End -#define __Pyx_PyCriticalSection_End2 PyCriticalSection2_End -#endif -#if PY_VERSION_HEX < 0x030d0000 || CYTHON_COMPILING_IN_LIMITED_API -#define __Pyx_BEGIN_CRITICAL_SECTION(o) { -#define __Pyx_END_CRITICAL_SECTION() } -#else -#define __Pyx_BEGIN_CRITICAL_SECTION Py_BEGIN_CRITICAL_SECTION -#define __Pyx_END_CRITICAL_SECTION Py_END_CRITICAL_SECTION -#endif - -/* Atomics.proto */ -#include -#ifndef CYTHON_ATOMICS - #define CYTHON_ATOMICS 1 -#endif -#define __PYX_CYTHON_ATOMICS_ENABLED() CYTHON_ATOMICS -#define __PYX_GET_CYTHON_COMPILING_IN_CPYTHON_FREETHREADING() CYTHON_COMPILING_IN_CPYTHON_FREETHREADING -#define __pyx_atomic_int_type int -#define __pyx_nonatomic_int_type int -#if CYTHON_ATOMICS && (defined(__STDC_VERSION__) &&\ - (__STDC_VERSION__ >= 201112L) &&\ - !defined(__STDC_NO_ATOMICS__)) - #include -#elif CYTHON_ATOMICS && (defined(__cplusplus) && (\ - (__cplusplus >= 201103L) ||\ - (defined(_MSC_VER) && _MSC_VER >= 1700))) - #include -#endif -#if CYTHON_ATOMICS && (defined(__STDC_VERSION__) &&\ - (__STDC_VERSION__ >= 201112L) &&\ - !defined(__STDC_NO_ATOMICS__) &&\ - ATOMIC_INT_LOCK_FREE == 2) - #undef __pyx_atomic_int_type - #define __pyx_atomic_int_type atomic_int - #define __pyx_atomic_ptr_type atomic_uintptr_t - #define __pyx_nonatomic_ptr_type uintptr_t - #define __pyx_atomic_incr_relaxed(value) atomic_fetch_add_explicit(value, 1, memory_order_relaxed) - #define __pyx_atomic_incr_acq_rel(value) atomic_fetch_add_explicit(value, 1, memory_order_acq_rel) - #define __pyx_atomic_decr_acq_rel(value) atomic_fetch_sub_explicit(value, 1, memory_order_acq_rel) - #define __pyx_atomic_sub(value, arg) atomic_fetch_sub(value, arg) - #define __pyx_atomic_int_cmp_exchange(value, expected, desired) atomic_compare_exchange_strong(value, expected, desired) - #define __pyx_atomic_load(value) atomic_load(value) - #define __pyx_atomic_store(value, new_value) atomic_store(value, new_value) - #define __pyx_atomic_pointer_load_relaxed(value) atomic_load_explicit(value, memory_order_relaxed) - #define __pyx_atomic_pointer_load_acquire(value) atomic_load_explicit(value, memory_order_acquire) - #define __pyx_atomic_pointer_exchange(value, new_value) atomic_exchange(value, (__pyx_nonatomic_ptr_type)new_value) - #if defined(__PYX_DEBUG_ATOMICS) && defined(_MSC_VER) - #pragma message ("Using standard C atomics") - #elif defined(__PYX_DEBUG_ATOMICS) - #warning "Using standard C atomics" - #endif -#elif CYTHON_ATOMICS && (defined(__cplusplus) && (\ - (__cplusplus >= 201103L) ||\ -\ - (defined(_MSC_VER) && _MSC_VER >= 1700)) &&\ - ATOMIC_INT_LOCK_FREE == 2) - #undef __pyx_atomic_int_type - #define __pyx_atomic_int_type std::atomic_int - #define __pyx_atomic_ptr_type std::atomic_uintptr_t - #define __pyx_nonatomic_ptr_type uintptr_t - #define __pyx_atomic_incr_relaxed(value) std::atomic_fetch_add_explicit(value, 1, std::memory_order_relaxed) - #define __pyx_atomic_incr_acq_rel(value) std::atomic_fetch_add_explicit(value, 1, std::memory_order_acq_rel) - #define __pyx_atomic_decr_acq_rel(value) std::atomic_fetch_sub_explicit(value, 1, std::memory_order_acq_rel) - #define __pyx_atomic_sub(value, arg) std::atomic_fetch_sub(value, arg) - #define __pyx_atomic_int_cmp_exchange(value, expected, desired) std::atomic_compare_exchange_strong(value, expected, desired) - #define __pyx_atomic_load(value) std::atomic_load(value) - #define __pyx_atomic_store(value, new_value) std::atomic_store(value, new_value) - #define __pyx_atomic_pointer_load_relaxed(value) std::atomic_load_explicit(value, std::memory_order_relaxed) - #define __pyx_atomic_pointer_load_acquire(value) std::atomic_load_explicit(value, std::memory_order_acquire) - #define __pyx_atomic_pointer_exchange(value, new_value) std::atomic_exchange(value, (__pyx_nonatomic_ptr_type)new_value) - #if defined(__PYX_DEBUG_ATOMICS) && defined(_MSC_VER) - #pragma message ("Using standard C++ atomics") - #elif defined(__PYX_DEBUG_ATOMICS) - #warning "Using standard C++ atomics" - #endif -#elif CYTHON_ATOMICS && (__GNUC__ >= 5 || (__GNUC__ == 4 &&\ - (__GNUC_MINOR__ > 1 ||\ - (__GNUC_MINOR__ == 1 && __GNUC_PATCHLEVEL__ >= 2)))) - #define __pyx_atomic_ptr_type void* - #define __pyx_atomic_incr_relaxed(value) __sync_fetch_and_add(value, 1) - #define __pyx_atomic_incr_acq_rel(value) __sync_fetch_and_add(value, 1) - #define __pyx_atomic_decr_acq_rel(value) __sync_fetch_and_sub(value, 1) - #define __pyx_atomic_sub(value, arg) __sync_fetch_and_sub(value, arg) - static CYTHON_INLINE int __pyx_atomic_int_cmp_exchange(__pyx_atomic_int_type* value, __pyx_nonatomic_int_type* expected, __pyx_nonatomic_int_type desired) { - __pyx_nonatomic_int_type old = __sync_val_compare_and_swap(value, *expected, desired); - int result = old == *expected; - *expected = old; - return result; - } - #define __pyx_atomic_load(value) __sync_fetch_and_add(value, 0) - #define __pyx_atomic_store(value, new_value) __sync_lock_test_and_set(value, new_value) - #define __pyx_atomic_pointer_load_relaxed(value) __sync_fetch_and_add(value, 0) - #define __pyx_atomic_pointer_load_acquire(value) __sync_fetch_and_add(value, 0) - #define __pyx_atomic_pointer_exchange(value, new_value) __sync_lock_test_and_set(value, (__pyx_atomic_ptr_type)new_value) - #ifdef __PYX_DEBUG_ATOMICS - #warning "Using GNU atomics" - #endif -#elif CYTHON_ATOMICS && defined(_MSC_VER) - #include - #undef __pyx_atomic_int_type - #define __pyx_atomic_int_type long - #define __pyx_atomic_ptr_type void* - #undef __pyx_nonatomic_int_type - #define __pyx_nonatomic_int_type long - #pragma intrinsic (_InterlockedExchangeAdd, _InterlockedExchange, _InterlockedCompareExchange, _InterlockedCompareExchangePointer, _InterlockedExchangePointer) - #define __pyx_atomic_incr_relaxed(value) _InterlockedExchangeAdd(value, 1) - #define __pyx_atomic_incr_acq_rel(value) _InterlockedExchangeAdd(value, 1) - #define __pyx_atomic_decr_acq_rel(value) _InterlockedExchangeAdd(value, -1) - #define __pyx_atomic_sub(value, arg) _InterlockedExchangeAdd(value, -arg) - static CYTHON_INLINE int __pyx_atomic_int_cmp_exchange(__pyx_atomic_int_type* value, __pyx_nonatomic_int_type* expected, __pyx_nonatomic_int_type desired) { - __pyx_nonatomic_int_type old = _InterlockedCompareExchange(value, desired, *expected); - int result = old == *expected; - *expected = old; - return result; - } - #define __pyx_atomic_load(value) _InterlockedExchangeAdd(value, 0) - #define __pyx_atomic_store(value, new_value) _InterlockedExchange(value, new_value) - #define __pyx_atomic_pointer_load_relaxed(value) *(void * volatile *)value - #define __pyx_atomic_pointer_load_acquire(value) _InterlockedCompareExchangePointer(value, 0, 0) - #define __pyx_atomic_pointer_exchange(value, new_value) _InterlockedExchangePointer(value, (__pyx_atomic_ptr_type)new_value) - #ifdef __PYX_DEBUG_ATOMICS - #pragma message ("Using MSVC atomics") - #endif -#else - #undef CYTHON_ATOMICS - #define CYTHON_ATOMICS 0 - #ifdef __PYX_DEBUG_ATOMICS - #warning "Not using atomics" - #endif -#endif -#if CYTHON_ATOMICS - #define __pyx_add_acquisition_count(memview)\ - __pyx_atomic_incr_relaxed(__pyx_get_slice_count_pointer(memview)) - #define __pyx_sub_acquisition_count(memview)\ - __pyx_atomic_decr_acq_rel(__pyx_get_slice_count_pointer(memview)) -#else - #define __pyx_add_acquisition_count(memview)\ - __pyx_add_acquisition_count_locked(__pyx_get_slice_count_pointer(memview), memview->lock) - #define __pyx_sub_acquisition_count(memview)\ - __pyx_sub_acquisition_count_locked(__pyx_get_slice_count_pointer(memview), memview->lock) -#endif - -/* #### Code section: numeric_typedefs ### */ -/* #### Code section: complex_type_declarations ### */ -/* #### Code section: type_declarations ### */ - -/*--- Type declarations ---*/ -/* #### Code section: utility_code_proto ### */ - -/* --- Runtime support code (head) --- */ -/* Refnanny.proto */ -#ifndef CYTHON_REFNANNY - #define CYTHON_REFNANNY 0 -#endif -#if CYTHON_REFNANNY - typedef struct { - void (*INCREF)(void*, PyObject*, Py_ssize_t); - void (*DECREF)(void*, PyObject*, Py_ssize_t); - void (*GOTREF)(void*, PyObject*, Py_ssize_t); - void (*GIVEREF)(void*, PyObject*, Py_ssize_t); - void* (*SetupContext)(const char*, Py_ssize_t, const char*); - void (*FinishContext)(void**); - } __Pyx_RefNannyAPIStruct; - static __Pyx_RefNannyAPIStruct *__Pyx_RefNanny = NULL; - static __Pyx_RefNannyAPIStruct *__Pyx_RefNannyImportAPI(const char *modname); - #define __Pyx_RefNannyDeclarations void *__pyx_refnanny = NULL; - #define __Pyx_RefNannySetupContext(name, acquire_gil)\ - if (acquire_gil) {\ - PyGILState_STATE __pyx_gilstate_save = PyGILState_Ensure();\ - __pyx_refnanny = __Pyx_RefNanny->SetupContext((name), (__LINE__), (__FILE__));\ - PyGILState_Release(__pyx_gilstate_save);\ - } else {\ - __pyx_refnanny = __Pyx_RefNanny->SetupContext((name), (__LINE__), (__FILE__));\ - } - #define __Pyx_RefNannyFinishContextNogil() {\ - PyGILState_STATE __pyx_gilstate_save = PyGILState_Ensure();\ - __Pyx_RefNannyFinishContext();\ - PyGILState_Release(__pyx_gilstate_save);\ - } - #define __Pyx_RefNannyFinishContextNogil() {\ - PyGILState_STATE __pyx_gilstate_save = PyGILState_Ensure();\ - __Pyx_RefNannyFinishContext();\ - PyGILState_Release(__pyx_gilstate_save);\ - } - #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); else {__Pyx_INCREF(r); }} while(0) - #define __Pyx_XDECREF(r) do { if((r) == NULL); else {__Pyx_DECREF(r); }} while(0) - #define __Pyx_XGOTREF(r) do { if((r) == NULL); else {__Pyx_GOTREF(r); }} while(0) - #define __Pyx_XGIVEREF(r) do { if((r) == NULL); else {__Pyx_GIVEREF(r);}} while(0) -#else - #define __Pyx_RefNannyDeclarations - #define __Pyx_RefNannySetupContext(name, acquire_gil) - #define __Pyx_RefNannyFinishContextNogil() - #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 -#define __Pyx_Py_XDECREF_SET(r, v) do {\ - PyObject *tmp = (PyObject *) r;\ - r = v; Py_XDECREF(tmp);\ - } while (0) -#define __Pyx_XDECREF_SET(r, v) do {\ - PyObject *tmp = (PyObject *) r;\ - r = v; __Pyx_XDECREF(tmp);\ - } while (0) -#define __Pyx_DECREF_SET(r, v) do {\ - PyObject *tmp = (PyObject *) r;\ - r = v; __Pyx_DECREF(tmp);\ - } while (0) -#define __Pyx_CLEAR(r) do { PyObject* tmp = ((PyObject*)(r)); r = NULL; __Pyx_DECREF(tmp);} while(0) -#define __Pyx_XCLEAR(r) do { if((r) != NULL) {PyObject* tmp = ((PyObject*)(r)); r = NULL; __Pyx_DECREF(tmp);}} while(0) - -/* PyErrExceptionMatches.proto */ -#if CYTHON_FAST_THREAD_STATE -#define __Pyx_PyErr_ExceptionMatches(err) __Pyx_PyErr_ExceptionMatchesInState(__pyx_tstate, err) -static CYTHON_INLINE int __Pyx_PyErr_ExceptionMatchesInState(PyThreadState* tstate, PyObject* err); -#else -#define __Pyx_PyErr_ExceptionMatches(err) PyErr_ExceptionMatches(err) -#endif - -/* PyThreadStateGet.proto */ -#if CYTHON_FAST_THREAD_STATE -#define __Pyx_PyThreadState_declare PyThreadState *__pyx_tstate; -#define __Pyx_PyThreadState_assign __pyx_tstate = __Pyx_PyThreadState_Current; -#if PY_VERSION_HEX >= 0x030C00A6 -#define __Pyx_PyErr_Occurred() (__pyx_tstate->current_exception != NULL) -#define __Pyx_PyErr_CurrentExceptionType() (__pyx_tstate->current_exception ? (PyObject*) Py_TYPE(__pyx_tstate->current_exception) : (PyObject*) NULL) -#else -#define __Pyx_PyErr_Occurred() (__pyx_tstate->curexc_type != NULL) -#define __Pyx_PyErr_CurrentExceptionType() (__pyx_tstate->curexc_type) -#endif -#else -#define __Pyx_PyThreadState_declare -#define __Pyx_PyThreadState_assign -#define __Pyx_PyErr_Occurred() (PyErr_Occurred() != NULL) -#define __Pyx_PyErr_CurrentExceptionType() PyErr_Occurred() -#endif - -/* PyErrFetchRestore.proto */ -#if CYTHON_FAST_THREAD_STATE -#define __Pyx_PyErr_Clear() __Pyx_ErrRestore(NULL, NULL, NULL) -#define __Pyx_ErrRestoreWithState(type, value, tb) __Pyx_ErrRestoreInState(PyThreadState_GET(), type, value, tb) -#define __Pyx_ErrFetchWithState(type, value, tb) __Pyx_ErrFetchInState(PyThreadState_GET(), type, value, tb) -#define __Pyx_ErrRestore(type, value, tb) __Pyx_ErrRestoreInState(__pyx_tstate, type, value, tb) -#define __Pyx_ErrFetch(type, value, tb) __Pyx_ErrFetchInState(__pyx_tstate, type, value, tb) -static CYTHON_INLINE void __Pyx_ErrRestoreInState(PyThreadState *tstate, PyObject *type, PyObject *value, PyObject *tb); -static CYTHON_INLINE void __Pyx_ErrFetchInState(PyThreadState *tstate, PyObject **type, PyObject **value, PyObject **tb); -#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX < 0x030C00A6 -#define __Pyx_PyErr_SetNone(exc) (Py_INCREF(exc), __Pyx_ErrRestore((exc), NULL, NULL)) -#else -#define __Pyx_PyErr_SetNone(exc) PyErr_SetNone(exc) -#endif -#else -#define __Pyx_PyErr_Clear() PyErr_Clear() -#define __Pyx_PyErr_SetNone(exc) PyErr_SetNone(exc) -#define __Pyx_ErrRestoreWithState(type, value, tb) PyErr_Restore(type, value, tb) -#define __Pyx_ErrFetchWithState(type, value, tb) PyErr_Fetch(type, value, tb) -#define __Pyx_ErrRestoreInState(tstate, type, value, tb) PyErr_Restore(type, value, tb) -#define __Pyx_ErrFetchInState(tstate, type, value, tb) PyErr_Fetch(type, value, tb) -#define __Pyx_ErrRestore(type, value, tb) PyErr_Restore(type, value, tb) -#define __Pyx_ErrFetch(type, value, tb) PyErr_Fetch(type, value, tb) -#endif - -/* PyObjectGetAttrStr.proto */ -#if CYTHON_USE_TYPE_SLOTS -static CYTHON_INLINE PyObject* __Pyx_PyObject_GetAttrStr(PyObject* obj, PyObject* attr_name); -#else -#define __Pyx_PyObject_GetAttrStr(o,n) PyObject_GetAttr(o,n) -#endif - -/* PyObjectGetAttrStrNoError.proto */ -static CYTHON_INLINE PyObject* __Pyx_PyObject_GetAttrStrNoError(PyObject* obj, PyObject* attr_name); - -/* GetBuiltinName.proto */ -static PyObject *__Pyx_GetBuiltinName(PyObject *name); - -/* PyDictVersioning.proto */ -#if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_TYPE_SLOTS -#define __PYX_DICT_VERSION_INIT ((PY_UINT64_T) -1) -#define __PYX_GET_DICT_VERSION(dict) (((PyDictObject*)(dict))->ma_version_tag) -#define __PYX_UPDATE_DICT_CACHE(dict, value, cache_var, version_var)\ - (version_var) = __PYX_GET_DICT_VERSION(dict);\ - (cache_var) = (value); -#define __PYX_PY_DICT_LOOKUP_IF_MODIFIED(VAR, DICT, LOOKUP) {\ - static PY_UINT64_T __pyx_dict_version = 0;\ - static PyObject *__pyx_dict_cached_value = NULL;\ - if (likely(__PYX_GET_DICT_VERSION(DICT) == __pyx_dict_version)) {\ - (VAR) = __pyx_dict_cached_value;\ - } else {\ - (VAR) = __pyx_dict_cached_value = (LOOKUP);\ - __pyx_dict_version = __PYX_GET_DICT_VERSION(DICT);\ - }\ -} -static CYTHON_INLINE PY_UINT64_T __Pyx_get_tp_dict_version(PyObject *obj); -static CYTHON_INLINE PY_UINT64_T __Pyx_get_object_dict_version(PyObject *obj); -static CYTHON_INLINE int __Pyx_object_dict_version_matches(PyObject* obj, PY_UINT64_T tp_dict_version, PY_UINT64_T obj_dict_version); -#else -#define __PYX_GET_DICT_VERSION(dict) (0) -#define __PYX_UPDATE_DICT_CACHE(dict, value, cache_var, version_var) -#define __PYX_PY_DICT_LOOKUP_IF_MODIFIED(VAR, DICT, LOOKUP) (VAR) = (LOOKUP); -#endif - -/* GetModuleGlobalName.proto */ -#if CYTHON_USE_DICT_VERSIONS -#define __Pyx_GetModuleGlobalName(var, name) do {\ - static PY_UINT64_T __pyx_dict_version = 0;\ - static PyObject *__pyx_dict_cached_value = NULL;\ - (var) = (likely(__pyx_dict_version == __PYX_GET_DICT_VERSION(__pyx_mstate_global->__pyx_d))) ?\ - (likely(__pyx_dict_cached_value) ? __Pyx_NewRef(__pyx_dict_cached_value) : __Pyx_GetBuiltinName(name)) :\ - __Pyx__GetModuleGlobalName(name, &__pyx_dict_version, &__pyx_dict_cached_value);\ -} while(0) -#define __Pyx_GetModuleGlobalNameUncached(var, name) do {\ - PY_UINT64_T __pyx_dict_version;\ - PyObject *__pyx_dict_cached_value;\ - (var) = __Pyx__GetModuleGlobalName(name, &__pyx_dict_version, &__pyx_dict_cached_value);\ -} while(0) -static PyObject *__Pyx__GetModuleGlobalName(PyObject *name, PY_UINT64_T *dict_version, PyObject **dict_cached_value); -#else -#define __Pyx_GetModuleGlobalName(var, name) (var) = __Pyx__GetModuleGlobalName(name) -#define __Pyx_GetModuleGlobalNameUncached(var, name) (var) = __Pyx__GetModuleGlobalName(name) -static CYTHON_INLINE PyObject *__Pyx__GetModuleGlobalName(PyObject *name); -#endif - -/* CLineInTraceback.proto */ -#if CYTHON_CLINE_IN_TRACEBACK && CYTHON_CLINE_IN_TRACEBACK_RUNTIME -static int __Pyx_CLineForTraceback(PyThreadState *tstate, int c_line); -#else -#define __Pyx_CLineForTraceback(tstate, c_line) (((CYTHON_CLINE_IN_TRACEBACK)) ? c_line : 0) -#endif - -/* CodeObjectCache.proto */ -#if CYTHON_COMPILING_IN_LIMITED_API -typedef PyObject __Pyx_CachedCodeObjectType; -#else -typedef PyCodeObject __Pyx_CachedCodeObjectType; -#endif -typedef struct { - __Pyx_CachedCodeObjectType* code_object; - int code_line; -} __Pyx_CodeObjectCacheEntry; -struct __Pyx_CodeObjectCache { - int count; - int max_count; - __Pyx_CodeObjectCacheEntry* entries; - #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - __pyx_atomic_int_type accessor_count; - #endif -}; -static int __pyx_bisect_code_objects(__Pyx_CodeObjectCacheEntry* entries, int count, int code_line); -static __Pyx_CachedCodeObjectType *__pyx_find_code_object(int code_line); -static void __pyx_insert_code_object(int code_line, __Pyx_CachedCodeObjectType* code_object); - -/* AddTraceback.proto */ -static void __Pyx_AddTraceback(const char *funcname, int c_line, - int py_line, const char *filename); - -/* FormatTypeName.proto */ -#if CYTHON_COMPILING_IN_LIMITED_API -typedef PyObject *__Pyx_TypeName; -#define __Pyx_FMT_TYPENAME "%U" -#define __Pyx_DECREF_TypeName(obj) Py_XDECREF(obj) -#if __PYX_LIMITED_VERSION_HEX >= 0x030d0000 -#define __Pyx_PyType_GetFullyQualifiedName PyType_GetFullyQualifiedName -#else -static __Pyx_TypeName __Pyx_PyType_GetFullyQualifiedName(PyTypeObject* tp); -#endif -#else // !LIMITED_API -typedef const char *__Pyx_TypeName; -#define __Pyx_FMT_TYPENAME "%.200s" -#define __Pyx_PyType_GetFullyQualifiedName(tp) ((tp)->tp_name) -#define __Pyx_DECREF_TypeName(obj) -#endif - -/* GCCDiagnostics.proto */ -#if !defined(__INTEL_COMPILER) && defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 6)) -#define __Pyx_HAS_GCC_DIAGNOSTIC -#endif - -/* PyFunctionFastCall.proto */ -#if CYTHON_FAST_PYCALL -#if !CYTHON_VECTORCALL -#define __Pyx_PyFunction_FastCall(func, args, nargs)\ - __Pyx_PyFunction_FastCallDict((func), (args), (nargs), NULL) -static PyObject *__Pyx_PyFunction_FastCallDict(PyObject *func, PyObject *const *args, Py_ssize_t nargs, PyObject *kwargs); -#endif -#define __Pyx_BUILD_ASSERT_EXPR(cond)\ - (sizeof(char [1 - 2*!(cond)]) - 1) -#ifndef Py_MEMBER_SIZE -#define Py_MEMBER_SIZE(type, member) sizeof(((type *)0)->member) -#endif -#if !CYTHON_VECTORCALL -#if PY_VERSION_HEX >= 0x03080000 - #include "frameobject.h" - #define __Pxy_PyFrame_Initialize_Offsets() - #define __Pyx_PyFrame_GetLocalsplus(frame) ((frame)->f_localsplus) -#else - static size_t __pyx_pyframe_localsplus_offset = 0; - #include "frameobject.h" - #define __Pxy_PyFrame_Initialize_Offsets()\ - ((void)__Pyx_BUILD_ASSERT_EXPR(sizeof(PyFrameObject) == offsetof(PyFrameObject, f_localsplus) + Py_MEMBER_SIZE(PyFrameObject, f_localsplus)),\ - (void)(__pyx_pyframe_localsplus_offset = ((size_t)PyFrame_Type.tp_basicsize) - Py_MEMBER_SIZE(PyFrameObject, f_localsplus))) - #define __Pyx_PyFrame_GetLocalsplus(frame)\ - (assert(__pyx_pyframe_localsplus_offset), (PyObject **)(((char *)(frame)) + __pyx_pyframe_localsplus_offset)) -#endif -#endif -#endif - -/* PyObjectCall.proto */ -#if CYTHON_COMPILING_IN_CPYTHON -static CYTHON_INLINE PyObject* __Pyx_PyObject_Call(PyObject *func, PyObject *arg, PyObject *kw); -#else -#define __Pyx_PyObject_Call(func, arg, kw) PyObject_Call(func, arg, kw) -#endif - -/* PyObjectCallMethO.proto */ -#if CYTHON_COMPILING_IN_CPYTHON -static CYTHON_INLINE PyObject* __Pyx_PyObject_CallMethO(PyObject *func, PyObject *arg); -#endif - -/* PyObjectFastCall.proto */ -#define __Pyx_PyObject_FastCall(func, args, nargs) __Pyx_PyObject_FastCallDict(func, args, (size_t)(nargs), NULL) -static CYTHON_INLINE PyObject* __Pyx_PyObject_FastCallDict(PyObject *func, PyObject * const*args, size_t nargs, PyObject *kwargs); - -/* PyObjectVectorCallKwBuilder.proto */ -CYTHON_UNUSED static int __Pyx_VectorcallBuilder_AddArg_Check(PyObject *key, PyObject *value, PyObject *builder, PyObject **args, int n); -#if CYTHON_VECTORCALL -#if PY_VERSION_HEX >= 0x03090000 -#define __Pyx_Object_Vectorcall_CallFromBuilder PyObject_Vectorcall -#else -#define __Pyx_Object_Vectorcall_CallFromBuilder _PyObject_Vectorcall -#endif -#define __Pyx_MakeVectorcallBuilderKwds(n) PyTuple_New(n) -static int __Pyx_VectorcallBuilder_AddArg(PyObject *key, PyObject *value, PyObject *builder, PyObject **args, int n); -static int __Pyx_VectorcallBuilder_AddArgStr(const char *key, PyObject *value, PyObject *builder, PyObject **args, int n); -#else -#define __Pyx_Object_Vectorcall_CallFromBuilder __Pyx_PyObject_FastCallDict -#define __Pyx_MakeVectorcallBuilderKwds(n) __Pyx_PyDict_NewPresized(n) -#define __Pyx_VectorcallBuilder_AddArg(key, value, builder, args, n) PyDict_SetItem(builder, key, value) -#define __Pyx_VectorcallBuilder_AddArgStr(key, value, builder, args, n) PyDict_SetItemString(builder, key, value) -#endif - -/* CIntToPy.proto */ -static CYTHON_INLINE PyObject* __Pyx_PyLong_From_long(long value); - -/* CIntFromPy.proto */ -static CYTHON_INLINE long __Pyx_PyLong_As_long(PyObject *); - -/* CIntFromPy.proto */ -static CYTHON_INLINE int __Pyx_PyLong_As_int(PyObject *); - -/* FastTypeChecks.proto */ -#if CYTHON_COMPILING_IN_CPYTHON -#define __Pyx_TypeCheck(obj, type) __Pyx_IsSubtype(Py_TYPE(obj), (PyTypeObject *)type) -#define __Pyx_TypeCheck2(obj, type1, type2) __Pyx_IsAnySubtype2(Py_TYPE(obj), (PyTypeObject *)type1, (PyTypeObject *)type2) -static CYTHON_INLINE int __Pyx_IsSubtype(PyTypeObject *a, PyTypeObject *b); -static CYTHON_INLINE int __Pyx_IsAnySubtype2(PyTypeObject *cls, PyTypeObject *a, PyTypeObject *b); -static CYTHON_INLINE int __Pyx_PyErr_GivenExceptionMatches(PyObject *err, PyObject *type); -static CYTHON_INLINE int __Pyx_PyErr_GivenExceptionMatches2(PyObject *err, PyObject *type1, PyObject *type2); -#else -#define __Pyx_TypeCheck(obj, type) PyObject_TypeCheck(obj, (PyTypeObject *)type) -#define __Pyx_TypeCheck2(obj, type1, type2) (PyObject_TypeCheck(obj, (PyTypeObject *)type1) || PyObject_TypeCheck(obj, (PyTypeObject *)type2)) -#define __Pyx_PyErr_GivenExceptionMatches(err, type) PyErr_GivenExceptionMatches(err, type) -static CYTHON_INLINE int __Pyx_PyErr_GivenExceptionMatches2(PyObject *err, PyObject *type1, PyObject *type2) { - return PyErr_GivenExceptionMatches(err, type1) || PyErr_GivenExceptionMatches(err, type2); -} -#endif -#define __Pyx_PyErr_ExceptionMatches2(err1, err2) __Pyx_PyErr_GivenExceptionMatches2(__Pyx_PyErr_CurrentExceptionType(), err1, err2) -#define __Pyx_PyException_Check(obj) __Pyx_TypeCheck(obj, PyExc_Exception) -#ifdef PyExceptionInstance_Check - #define __Pyx_PyBaseException_Check(obj) PyExceptionInstance_Check(obj) -#else - #define __Pyx_PyBaseException_Check(obj) __Pyx_TypeCheck(obj, PyExc_BaseException) -#endif - -/* GetRuntimeVersion.proto */ -static unsigned long __Pyx_get_runtime_version(void); - -/* CheckBinaryVersion.proto */ -static int __Pyx_check_binary_version(unsigned long ct_version, unsigned long rt_version, int allow_newer); - -/* MultiPhaseInitModuleState.proto */ -#if CYTHON_PEP489_MULTI_PHASE_INIT && CYTHON_USE_MODULE_STATE -static PyObject *__Pyx_State_FindModule(void*); -static int __Pyx_State_AddModule(PyObject* module, void*); -static int __Pyx_State_RemoveModule(void*); -#elif CYTHON_USE_MODULE_STATE -#define __Pyx_State_FindModule PyState_FindModule -#define __Pyx_State_AddModule PyState_AddModule -#define __Pyx_State_RemoveModule PyState_RemoveModule -#endif - -/* #### Code section: module_declarations ### */ -/* CythonABIVersion.proto */ -#if CYTHON_COMPILING_IN_LIMITED_API - #if CYTHON_METH_FASTCALL - #define __PYX_FASTCALL_ABI_SUFFIX "_fastcall" - #else - #define __PYX_FASTCALL_ABI_SUFFIX - #endif - #define __PYX_LIMITED_ABI_SUFFIX "limited" __PYX_FASTCALL_ABI_SUFFIX __PYX_AM_SEND_ABI_SUFFIX -#else - #define __PYX_LIMITED_ABI_SUFFIX -#endif -#if __PYX_HAS_PY_AM_SEND == 1 - #define __PYX_AM_SEND_ABI_SUFFIX -#elif __PYX_HAS_PY_AM_SEND == 2 - #define __PYX_AM_SEND_ABI_SUFFIX "amsendbackport" -#else - #define __PYX_AM_SEND_ABI_SUFFIX "noamsend" -#endif -#ifndef __PYX_MONITORING_ABI_SUFFIX - #define __PYX_MONITORING_ABI_SUFFIX -#endif -#if CYTHON_USE_TP_FINALIZE - #define __PYX_TP_FINALIZE_ABI_SUFFIX -#else - #define __PYX_TP_FINALIZE_ABI_SUFFIX "nofinalize" -#endif -#if CYTHON_USE_FREELISTS || !defined(__Pyx_AsyncGen_USED) - #define __PYX_FREELISTS_ABI_SUFFIX -#else - #define __PYX_FREELISTS_ABI_SUFFIX "nofreelists" -#endif -#define CYTHON_ABI __PYX_ABI_VERSION __PYX_LIMITED_ABI_SUFFIX __PYX_MONITORING_ABI_SUFFIX __PYX_TP_FINALIZE_ABI_SUFFIX __PYX_FREELISTS_ABI_SUFFIX __PYX_AM_SEND_ABI_SUFFIX -#define __PYX_ABI_MODULE_NAME "_cython_" CYTHON_ABI -#define __PYX_TYPE_MODULE_PREFIX __PYX_ABI_MODULE_NAME "." - - -/* Module declarations from "epanet.epanet2_ec" */ -/* #### Code section: typeinfo ### */ -/* #### Code section: before_global_var ### */ -#define __Pyx_MODULE_NAME "epanet.epanet2_ec" -extern int __pyx_module_is_main_epanet__epanet2_ec; -int __pyx_module_is_main_epanet__epanet2_ec = 0; - -/* Implementation of "epanet.epanet2_ec" */ -/* #### Code section: global_var ### */ -/* #### Code section: string_decls ### */ -static const char __pyx_k_[] = "?"; -static const char __pyx_k_0[] = "0"; -static const char __pyx_k_10[] = "10"; -static const char __pyx_k_ok[] = "ok"; -static const char __pyx_k_101[] = "101"; -static const char __pyx_k_102[] = "102"; -static const char __pyx_k_103[] = "103"; -static const char __pyx_k_104[] = "104"; -static const char __pyx_k_105[] = "105"; -static const char __pyx_k_106[] = "106"; -static const char __pyx_k_107[] = "107"; -static const char __pyx_k_108[] = "108"; -static const char __pyx_k_110[] = "110"; -static const char __pyx_k_120[] = "120"; -static const char __pyx_k_200[] = "200"; -static const char __pyx_k_201[] = "201"; -static const char __pyx_k_202[] = "202"; -static const char __pyx_k_203[] = "203"; -static const char __pyx_k_204[] = "204"; -static const char __pyx_k_205[] = "205"; -static const char __pyx_k_206[] = "206"; -static const char __pyx_k_207[] = "207"; -static const char __pyx_k_208[] = "208"; -static const char __pyx_k_209[] = "209"; -static const char __pyx_k_211[] = "211"; -static const char __pyx_k_212[] = "212"; -static const char __pyx_k_213[] = "213"; -static const char __pyx_k_214[] = "214"; -static const char __pyx_k_215[] = "215"; -static const char __pyx_k_216[] = "216"; -static const char __pyx_k_217[] = "217"; -static const char __pyx_k_219[] = "219"; -static const char __pyx_k_220[] = "220"; -static const char __pyx_k_221[] = "221"; -static const char __pyx_k_222[] = "222"; -static const char __pyx_k_223[] = "223"; -static const char __pyx_k_224[] = "224"; -static const char __pyx_k_225[] = "225"; -static const char __pyx_k_226[] = "226"; -static const char __pyx_k_227[] = "227"; -static const char __pyx_k_230[] = "230"; -static const char __pyx_k_233[] = "233"; -static const char __pyx_k_234[] = "234"; -static const char __pyx_k_240[] = "240"; -static const char __pyx_k_241[] = "241"; -static const char __pyx_k_250[] = "250"; -static const char __pyx_k_251[] = "251"; -static const char __pyx_k_252[] = "252"; -static const char __pyx_k_253[] = "253"; -static const char __pyx_k_254[] = "254"; -static const char __pyx_k_255[] = "255"; -static const char __pyx_k_257[] = "257"; -static const char __pyx_k_258[] = "258"; -static const char __pyx_k_259[] = "259"; -static const char __pyx_k_260[] = "260"; -static const char __pyx_k_261[] = "261"; -static const char __pyx_k_262[] = "262"; -static const char __pyx_k_263[] = "263"; -static const char __pyx_k_301[] = "301"; -static const char __pyx_k_302[] = "302"; -static const char __pyx_k_303[] = "303"; -static const char __pyx_k_304[] = "304"; -static const char __pyx_k_305[] = "305"; -static const char __pyx_k_306[] = "306"; -static const char __pyx_k_307[] = "307"; -static const char __pyx_k_308[] = "308"; -static const char __pyx_k_309[] = "309"; -static const char __pyx_k_411[] = "411"; -static const char __pyx_k_412[] = "412"; -static const char __pyx_k_421[] = "421"; -static const char __pyx_k_422[] = "422"; -static const char __pyx_k_423[] = "423"; -static const char __pyx_k_434[] = "434"; -static const char __pyx_k_435[] = "435"; -static const char __pyx_k_436[] = "436"; -static const char __pyx_k_ERR[] = "ERR"; -static const char __pyx_k_main[] = "__main__"; -static const char __pyx_k_name[] = "__name__"; -static const char __pyx_k_test[] = "__test__"; -static const char __pyx_k_module[] = "__module__"; -static const char __pyx_k_qualname[] = "__qualname__"; -static const char __pyx_k_ERROR_CODE[] = "ERROR_CODE"; -static const char __pyx_k_syntax_error[] = "syntax error"; -static const char __pyx_k_invalid_format[] = "invalid format"; -static const char __pyx_k_undefined_link[] = "undefined link"; -static const char __pyx_k_undefined_node[] = "undefined node"; -static const char __pyx_k_invalid_ID_name[] = "invalid ID name"; -static const char __pyx_k_undefined_curve[] = "undefined curve"; -static const char __pyx_k_nonexistent_rule[] = "nonexistent rule"; -static const char __pyx_k_cline_in_traceback[] = "cline_in_traceback"; -static const char __pyx_k_duplicate_ID_label[] = "duplicate ID label"; -static const char __pyx_k_node_is_not_a_tank[] = "node is not a tank"; -static const char __pyx_k_nonexistent_source[] = "nonexistent source"; -static const char __pyx_k_invalid_link_vertex[] = "invalid link vertex"; -static const char __pyx_k_nonexistent_control[] = "nonexistent control"; -static const char __pyx_k_identical_file_names[] = "identical file names"; -static const char __pyx_k_invalid_option_value[] = "invalid option value"; -static const char __pyx_k_undefined_trace_node[] = "undefined trace node"; -static const char __pyx_k_illegal_numeric_value[] = "illegal numeric value"; -static const char __pyx_k_cannot_open_input_file[] = "cannot open input file"; -static const char __pyx_k_invalid_parameter_code[] = "invalid parameter code"; -static const char __pyx_k_undefined_time_pattern[] = "undefined time pattern"; -static const char __pyx_k_cannot_open_report_file[] = "cannot open report file"; -static const char __pyx_k_nonexistent_rule_clause[] = "nonexistent rule clause"; -static const char __pyx_k_invalid_pump_energy_data[] = "invalid pump energy data"; -static const char __pyx_k_node_with_no_coordinates[] = "node with no coordinates"; -static const char __pyx_k_no_network_data_available[] = "no network data available"; -static const char __pyx_k_cannot_open_hydraulics_file[] = "cannot open hydraulics file"; -static const char __pyx_k_cannot_read_hydraulics_file[] = "cannot read hydraulics file"; -static const char __pyx_k_cannot_save_results_to_file[] = "cannot save results to file"; -static const char __pyx_k_hydraulic_solver_not_opened[] = "hydraulic solver not opened"; -static const char __pyx_k_illegal_PDA_pressure_limits[] = "illegal PDA pressure limits"; -static const char __pyx_k_illegal_link_property_value[] = "illegal link property value"; -static const char __pyx_k_illegal_node_property_value[] = "illegal node property value"; -static const char __pyx_k_invalid_head_curve_for_pump[] = "invalid head curve for pump"; -static const char __pyx_k_nonexistent_demand_category[] = "nonexistent demand category"; -static const char __pyx_k_not_enough_nodes_in_network[] = "not enough nodes in network"; -static const char __pyx_k_reference_to_undefined_pump[] = "reference to undefined pump"; -static const char __pyx_k_insufficient_memory_available[] = "insufficient memory available"; -static const char __pyx_k_network_has_unconnected_nodes[] = "network has unconnected nodes"; -static const char __pyx_k_no_results_saved_to_report_on[] = "no results saved to report on"; -static const char __pyx_k_attempt_to_control_CV_GPV_link[] = "attempt to control CV/GPV link"; -static const char __pyx_k_cannot_open_binary_output_file[] = "cannot open binary output file"; -static const char __pyx_k_attempt_to_delete_node_assigned[] = "attempt to delete node assigned as a Trace Node"; -static const char __pyx_k_network_has_an_unconnected_node[] = "network has an unconnected node with ID: "; -static const char __pyx_k_no_hydraulics_for_water_quality[] = "no hydraulics for water quality analysis"; -static const char __pyx_k_water_quality_solver_not_opened[] = "water quality solver not opened"; -static const char __pyx_k_Error_An_unknown_error_has_occur[] = "Error: An unknown error has occurred"; -static const char __pyx_k_File_Error_434_unable_to_open_bi[] = "File Error 434: unable to open binary file"; -static const char __pyx_k_File_Error_435_invalid_binary_fi[] = "File Error 435: invalid binary file type"; -static const char __pyx_k_File_Error_436_no_results_in_bin[] = "File Error 436: no results in binary file"; -static const char __pyx_k_Input_Error_411_no_memory_alloca[] = "Input Error 411: no memory allocated for results"; -static const char __pyx_k_Input_Error_412_binary_file_hasn[] = "Input Error 412: binary file hasn't been opened"; -static const char __pyx_k_Input_Error_421_invalid_paramete[] = "Input Error 421: invalid parameter code"; -static const char __pyx_k_Input_Error_422_reporting_period[] = "Input Error 422: reporting period index out of range"; -static const char __pyx_k_Input_Error_423_element_index_ou[] = "Input Error 423: element index out of range"; -static const char __pyx_k_Warning_model_run_issued_warning[] = "Warning: model run issued warnings"; -static const char __pyx_k_attempt_to_delete_a_node_or_link[] = "attempt to delete a node or link contained in a control"; -static const char __pyx_k_attempt_to_delete_a_node_that_st[] = "attempt to delete a node that still has links connected to it"; -static const char __pyx_k_attempt_to_modify_network_struct[] = "attempt to modify network structure while solver is active"; -static const char __pyx_k_cannot_save_results_to_report_fi[] = "cannot save results to report file"; -static const char __pyx_k_cannot_solve_network_hydraulic_e[] = "cannot solve network hydraulic equations"; -static const char __pyx_k_cannot_solve_water_quality_trans[] = "cannot solve water quality transport equations"; -static const char __pyx_k_cannot_use_external_file_while_h[] = "cannot use external file while hydraulics solver is active"; -static const char __pyx_k_hydraulics_file_does_not_match_n[] = "hydraulics file does not match network data"; -static const char __pyx_k_hydraulics_supplied_from_externa[] = "hydraulics supplied from external file"; -static const char __pyx_k_illegal_valve_connection_to_anot[] = "illegal valve connection to another valve"; -static const char __pyx_k_illegal_valve_connection_to_tank[] = "illegal valve connection to tank node"; -static const char __pyx_k_invalid_lower_upper_levels_for_t[] = "invalid lower/upper levels for tank"; -static const char __pyx_k_mis_placed_rule_clause_in_rule_b[] = "mis-placed rule clause in rule-based control"; -static const char __pyx_k_no_head_curve_or_power_rating_fo[] = "no head curve or power rating for pump"; -static const char __pyx_k_no_tanks_or_reservoirs_in_networ[] = "no tanks or reservoirs in network"; -static const char __pyx_k_nonincreasing_x_values_for_curve[] = "nonincreasing x-values for curve"; -static const char __pyx_k_one_or_more_errors_in_input_file[] = "one or more errors in input file"; -static const char __pyx_k_same_start_and_end_nodes_for_lin[] = "same start and end nodes for link"; -static const char __pyx_k_too_many_characters_in_input_lin[] = "too many characters in input line"; -/* #### Code section: decls ### */ -/* #### Code section: late_includes ### */ -/* #### Code section: module_state ### */ -/* SmallCodeConfig */ -#ifndef CYTHON_SMALL_CODE -#if defined(__clang__) - #define CYTHON_SMALL_CODE -#elif defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 3)) - #define CYTHON_SMALL_CODE __attribute__((cold)) -#else - #define CYTHON_SMALL_CODE -#endif -#endif - -typedef struct { - PyObject *__pyx_d; - PyObject *__pyx_b; - PyObject *__pyx_cython_runtime; - PyObject *__pyx_empty_tuple; - PyObject *__pyx_empty_bytes; - PyObject *__pyx_empty_unicode; - #ifdef __Pyx_CyFunction_USED - PyTypeObject *__pyx_CyFunctionType; - #endif - #ifdef __Pyx_FusedFunction_USED - PyTypeObject *__pyx_FusedFunctionType; - #endif - #ifdef __Pyx_Generator_USED - PyTypeObject *__pyx_GeneratorType; - #endif - #ifdef __Pyx_IterableCoroutine_USED - PyTypeObject *__pyx_IterableCoroutineType; - #endif - #ifdef __Pyx_Coroutine_USED - PyTypeObject *__pyx_CoroutineAwaitType; - #endif - #ifdef __Pyx_Coroutine_USED - PyTypeObject *__pyx_CoroutineType; - #endif - PyObject *__pyx_string_tab[156]; -/* #### Code section: module_state_contents ### */ -/* CodeObjectCache.module_state_decls */ -struct __Pyx_CodeObjectCache __pyx_code_cache; - -/* #### Code section: module_state_end ### */ -} __pyx_mstatetype; - -#if CYTHON_USE_MODULE_STATE -#ifdef __cplusplus -namespace { -extern struct PyModuleDef __pyx_moduledef; -} /* anonymous namespace */ -#else -static struct PyModuleDef __pyx_moduledef; -#endif - -#define __pyx_mstate_global (__Pyx_PyModule_GetState(__Pyx_State_FindModule(&__pyx_moduledef))) - -#define __pyx_m (__Pyx_State_FindModule(&__pyx_moduledef)) -#else -static __pyx_mstatetype __pyx_mstate_global_static = -#ifdef __cplusplus - {}; -#else - {0}; -#endif -static __pyx_mstatetype * const __pyx_mstate_global = &__pyx_mstate_global_static; -#endif -/* #### Code section: constant_name_defines ### */ -#define __pyx_kp_u_ __pyx_string_tab[0] -#define __pyx_kp_u_0 __pyx_string_tab[1] -#define __pyx_kp_u_10 __pyx_string_tab[2] -#define __pyx_kp_u_101 __pyx_string_tab[3] -#define __pyx_kp_u_102 __pyx_string_tab[4] -#define __pyx_kp_u_103 __pyx_string_tab[5] -#define __pyx_kp_u_104 __pyx_string_tab[6] -#define __pyx_kp_u_105 __pyx_string_tab[7] -#define __pyx_kp_u_106 __pyx_string_tab[8] -#define __pyx_kp_u_107 __pyx_string_tab[9] -#define __pyx_kp_u_108 __pyx_string_tab[10] -#define __pyx_kp_u_110 __pyx_string_tab[11] -#define __pyx_kp_u_120 __pyx_string_tab[12] -#define __pyx_kp_u_200 __pyx_string_tab[13] -#define __pyx_kp_u_201 __pyx_string_tab[14] -#define __pyx_kp_u_202 __pyx_string_tab[15] -#define __pyx_kp_u_203 __pyx_string_tab[16] -#define __pyx_kp_u_204 __pyx_string_tab[17] -#define __pyx_kp_u_205 __pyx_string_tab[18] -#define __pyx_kp_u_206 __pyx_string_tab[19] -#define __pyx_kp_u_207 __pyx_string_tab[20] -#define __pyx_kp_u_208 __pyx_string_tab[21] -#define __pyx_kp_u_209 __pyx_string_tab[22] -#define __pyx_kp_u_211 __pyx_string_tab[23] -#define __pyx_kp_u_212 __pyx_string_tab[24] -#define __pyx_kp_u_213 __pyx_string_tab[25] -#define __pyx_kp_u_214 __pyx_string_tab[26] -#define __pyx_kp_u_215 __pyx_string_tab[27] -#define __pyx_kp_u_216 __pyx_string_tab[28] -#define __pyx_kp_u_217 __pyx_string_tab[29] -#define __pyx_kp_u_219 __pyx_string_tab[30] -#define __pyx_kp_u_220 __pyx_string_tab[31] -#define __pyx_kp_u_221 __pyx_string_tab[32] -#define __pyx_kp_u_222 __pyx_string_tab[33] -#define __pyx_kp_u_223 __pyx_string_tab[34] -#define __pyx_kp_u_224 __pyx_string_tab[35] -#define __pyx_kp_u_225 __pyx_string_tab[36] -#define __pyx_kp_u_226 __pyx_string_tab[37] -#define __pyx_kp_u_227 __pyx_string_tab[38] -#define __pyx_kp_u_230 __pyx_string_tab[39] -#define __pyx_kp_u_233 __pyx_string_tab[40] -#define __pyx_kp_u_234 __pyx_string_tab[41] -#define __pyx_kp_u_240 __pyx_string_tab[42] -#define __pyx_kp_u_241 __pyx_string_tab[43] -#define __pyx_kp_u_250 __pyx_string_tab[44] -#define __pyx_kp_u_251 __pyx_string_tab[45] -#define __pyx_kp_u_252 __pyx_string_tab[46] -#define __pyx_kp_u_253 __pyx_string_tab[47] -#define __pyx_kp_u_254 __pyx_string_tab[48] -#define __pyx_kp_u_255 __pyx_string_tab[49] -#define __pyx_kp_u_257 __pyx_string_tab[50] -#define __pyx_kp_u_258 __pyx_string_tab[51] -#define __pyx_kp_u_259 __pyx_string_tab[52] -#define __pyx_kp_u_260 __pyx_string_tab[53] -#define __pyx_kp_u_261 __pyx_string_tab[54] -#define __pyx_kp_u_262 __pyx_string_tab[55] -#define __pyx_kp_u_263 __pyx_string_tab[56] -#define __pyx_kp_u_301 __pyx_string_tab[57] -#define __pyx_kp_u_302 __pyx_string_tab[58] -#define __pyx_kp_u_303 __pyx_string_tab[59] -#define __pyx_kp_u_304 __pyx_string_tab[60] -#define __pyx_kp_u_305 __pyx_string_tab[61] -#define __pyx_kp_u_306 __pyx_string_tab[62] -#define __pyx_kp_u_307 __pyx_string_tab[63] -#define __pyx_kp_u_308 __pyx_string_tab[64] -#define __pyx_kp_u_309 __pyx_string_tab[65] -#define __pyx_kp_u_411 __pyx_string_tab[66] -#define __pyx_kp_u_412 __pyx_string_tab[67] -#define __pyx_kp_u_421 __pyx_string_tab[68] -#define __pyx_kp_u_422 __pyx_string_tab[69] -#define __pyx_kp_u_423 __pyx_string_tab[70] -#define __pyx_kp_u_434 __pyx_string_tab[71] -#define __pyx_kp_u_435 __pyx_string_tab[72] -#define __pyx_kp_u_436 __pyx_string_tab[73] -#define __pyx_n_u_ERR __pyx_string_tab[74] -#define __pyx_n_u_ERROR_CODE __pyx_string_tab[75] -#define __pyx_kp_u_Error_An_unknown_error_has_occur __pyx_string_tab[76] -#define __pyx_kp_u_File_Error_434_unable_to_open_bi __pyx_string_tab[77] -#define __pyx_kp_u_File_Error_435_invalid_binary_fi __pyx_string_tab[78] -#define __pyx_kp_u_File_Error_436_no_results_in_bin __pyx_string_tab[79] -#define __pyx_kp_u_Input_Error_411_no_memory_alloca __pyx_string_tab[80] -#define __pyx_kp_u_Input_Error_412_binary_file_hasn __pyx_string_tab[81] -#define __pyx_kp_u_Input_Error_421_invalid_paramete __pyx_string_tab[82] -#define __pyx_kp_u_Input_Error_422_reporting_period __pyx_string_tab[83] -#define __pyx_kp_u_Input_Error_423_element_index_ou __pyx_string_tab[84] -#define __pyx_kp_u_Warning_model_run_issued_warning __pyx_string_tab[85] -#define __pyx_kp_u_attempt_to_control_CV_GPV_link __pyx_string_tab[86] -#define __pyx_kp_u_attempt_to_delete_a_node_or_link __pyx_string_tab[87] -#define __pyx_kp_u_attempt_to_delete_a_node_that_st __pyx_string_tab[88] -#define __pyx_kp_u_attempt_to_delete_node_assigned __pyx_string_tab[89] -#define __pyx_kp_u_attempt_to_modify_network_struct __pyx_string_tab[90] -#define __pyx_kp_u_cannot_open_binary_output_file __pyx_string_tab[91] -#define __pyx_kp_u_cannot_open_hydraulics_file __pyx_string_tab[92] -#define __pyx_kp_u_cannot_open_input_file __pyx_string_tab[93] -#define __pyx_kp_u_cannot_open_report_file __pyx_string_tab[94] -#define __pyx_kp_u_cannot_read_hydraulics_file __pyx_string_tab[95] -#define __pyx_kp_u_cannot_save_results_to_file __pyx_string_tab[96] -#define __pyx_kp_u_cannot_save_results_to_report_fi __pyx_string_tab[97] -#define __pyx_kp_u_cannot_solve_network_hydraulic_e __pyx_string_tab[98] -#define __pyx_kp_u_cannot_solve_water_quality_trans __pyx_string_tab[99] -#define __pyx_kp_u_cannot_use_external_file_while_h __pyx_string_tab[100] -#define __pyx_n_u_cline_in_traceback __pyx_string_tab[101] -#define __pyx_kp_u_duplicate_ID_label __pyx_string_tab[102] -#define __pyx_kp_u_hydraulic_solver_not_opened __pyx_string_tab[103] -#define __pyx_kp_u_hydraulics_file_does_not_match_n __pyx_string_tab[104] -#define __pyx_kp_u_hydraulics_supplied_from_externa __pyx_string_tab[105] -#define __pyx_kp_u_identical_file_names __pyx_string_tab[106] -#define __pyx_kp_u_illegal_PDA_pressure_limits __pyx_string_tab[107] -#define __pyx_kp_u_illegal_link_property_value __pyx_string_tab[108] -#define __pyx_kp_u_illegal_node_property_value __pyx_string_tab[109] -#define __pyx_kp_u_illegal_numeric_value __pyx_string_tab[110] -#define __pyx_kp_u_illegal_valve_connection_to_anot __pyx_string_tab[111] -#define __pyx_kp_u_illegal_valve_connection_to_tank __pyx_string_tab[112] -#define __pyx_kp_u_insufficient_memory_available __pyx_string_tab[113] -#define __pyx_kp_u_invalid_ID_name __pyx_string_tab[114] -#define __pyx_kp_u_invalid_format __pyx_string_tab[115] -#define __pyx_kp_u_invalid_head_curve_for_pump __pyx_string_tab[116] -#define __pyx_kp_u_invalid_link_vertex __pyx_string_tab[117] -#define __pyx_kp_u_invalid_lower_upper_levels_for_t __pyx_string_tab[118] -#define __pyx_kp_u_invalid_option_value __pyx_string_tab[119] -#define __pyx_kp_u_invalid_parameter_code __pyx_string_tab[120] -#define __pyx_kp_u_invalid_pump_energy_data __pyx_string_tab[121] -#define __pyx_n_u_main __pyx_string_tab[122] -#define __pyx_kp_u_mis_placed_rule_clause_in_rule_b __pyx_string_tab[123] -#define __pyx_n_u_module __pyx_string_tab[124] -#define __pyx_n_u_name __pyx_string_tab[125] -#define __pyx_kp_u_network_has_an_unconnected_node __pyx_string_tab[126] -#define __pyx_kp_u_network_has_unconnected_nodes __pyx_string_tab[127] -#define __pyx_kp_u_no_head_curve_or_power_rating_fo __pyx_string_tab[128] -#define __pyx_kp_u_no_hydraulics_for_water_quality __pyx_string_tab[129] -#define __pyx_kp_u_no_network_data_available __pyx_string_tab[130] -#define __pyx_kp_u_no_results_saved_to_report_on __pyx_string_tab[131] -#define __pyx_kp_u_no_tanks_or_reservoirs_in_networ __pyx_string_tab[132] -#define __pyx_kp_u_node_is_not_a_tank __pyx_string_tab[133] -#define __pyx_kp_u_node_with_no_coordinates __pyx_string_tab[134] -#define __pyx_kp_u_nonexistent_control __pyx_string_tab[135] -#define __pyx_kp_u_nonexistent_demand_category __pyx_string_tab[136] -#define __pyx_kp_u_nonexistent_rule __pyx_string_tab[137] -#define __pyx_kp_u_nonexistent_rule_clause __pyx_string_tab[138] -#define __pyx_kp_u_nonexistent_source __pyx_string_tab[139] -#define __pyx_kp_u_nonincreasing_x_values_for_curve __pyx_string_tab[140] -#define __pyx_kp_u_not_enough_nodes_in_network __pyx_string_tab[141] -#define __pyx_n_u_ok __pyx_string_tab[142] -#define __pyx_kp_u_one_or_more_errors_in_input_file __pyx_string_tab[143] -#define __pyx_n_u_qualname __pyx_string_tab[144] -#define __pyx_kp_u_reference_to_undefined_pump __pyx_string_tab[145] -#define __pyx_kp_u_same_start_and_end_nodes_for_lin __pyx_string_tab[146] -#define __pyx_kp_u_syntax_error __pyx_string_tab[147] -#define __pyx_n_u_test __pyx_string_tab[148] -#define __pyx_kp_u_too_many_characters_in_input_lin __pyx_string_tab[149] -#define __pyx_kp_u_undefined_curve __pyx_string_tab[150] -#define __pyx_kp_u_undefined_link __pyx_string_tab[151] -#define __pyx_kp_u_undefined_node __pyx_string_tab[152] -#define __pyx_kp_u_undefined_time_pattern __pyx_string_tab[153] -#define __pyx_kp_u_undefined_trace_node __pyx_string_tab[154] -#define __pyx_kp_u_water_quality_solver_not_opened __pyx_string_tab[155] -/* #### Code section: module_state_clear ### */ -#if CYTHON_USE_MODULE_STATE -static CYTHON_SMALL_CODE int __pyx_m_clear(PyObject *m) { - __pyx_mstatetype *clear_module_state = __Pyx_PyModule_GetState(m); - if (!clear_module_state) return 0; - Py_CLEAR(clear_module_state->__pyx_d); - Py_CLEAR(clear_module_state->__pyx_b); - Py_CLEAR(clear_module_state->__pyx_cython_runtime); - Py_CLEAR(clear_module_state->__pyx_empty_tuple); - Py_CLEAR(clear_module_state->__pyx_empty_bytes); - Py_CLEAR(clear_module_state->__pyx_empty_unicode); - #ifdef __Pyx_CyFunction_USED - Py_CLEAR(clear_module_state->__pyx_CyFunctionType); - #endif - #ifdef __Pyx_FusedFunction_USED - Py_CLEAR(clear_module_state->__pyx_FusedFunctionType); - #endif - #if CYTHON_PEP489_MULTI_PHASE_INIT - __Pyx_State_RemoveModule(NULL); - #endif - for (int i=0; i<156; ++i) { Py_CLEAR(clear_module_state->__pyx_string_tab[i]); } - return 0; -} -#endif -/* #### Code section: module_state_traverse ### */ -#if CYTHON_USE_MODULE_STATE -static CYTHON_SMALL_CODE int __pyx_m_traverse(PyObject *m, visitproc visit, void *arg) { - __pyx_mstatetype *traverse_module_state = __Pyx_PyModule_GetState(m); - if (!traverse_module_state) return 0; - Py_VISIT(traverse_module_state->__pyx_d); - Py_VISIT(traverse_module_state->__pyx_b); - Py_VISIT(traverse_module_state->__pyx_cython_runtime); - __Pyx_VISIT_CONST(traverse_module_state->__pyx_empty_tuple); - __Pyx_VISIT_CONST(traverse_module_state->__pyx_empty_bytes); - __Pyx_VISIT_CONST(traverse_module_state->__pyx_empty_unicode); - #ifdef __Pyx_CyFunction_USED - Py_VISIT(traverse_module_state->__pyx_CyFunctionType); - #endif - #ifdef __Pyx_FusedFunction_USED - Py_VISIT(traverse_module_state->__pyx_FusedFunctionType); - #endif - for (int i=0; i<156; ++i) { __Pyx_VISIT_CONST(traverse_module_state->__pyx_string_tab[i]); } - return 0; -} -#endif -/* #### Code section: module_code ### */ -/* #### Code section: module_exttypes ### */ - -static PyMethodDef __pyx_methods[] = { - {0, 0, 0, 0} -}; -/* #### Code section: initfunc_declarations ### */ -static CYTHON_SMALL_CODE int __Pyx_InitCachedBuiltins(__pyx_mstatetype *__pyx_mstate); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_InitCachedConstants(__pyx_mstatetype *__pyx_mstate); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_InitGlobals(void); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_InitConstants(__pyx_mstatetype *__pyx_mstate); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_modinit_global_init_code(__pyx_mstatetype *__pyx_mstate); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_modinit_variable_export_code(__pyx_mstatetype *__pyx_mstate); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_modinit_function_export_code(__pyx_mstatetype *__pyx_mstate); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_modinit_type_init_code(__pyx_mstatetype *__pyx_mstate); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_modinit_type_import_code(__pyx_mstatetype *__pyx_mstate); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_modinit_variable_import_code(__pyx_mstatetype *__pyx_mstate); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_modinit_function_import_code(__pyx_mstatetype *__pyx_mstate); /*proto*/ -static CYTHON_SMALL_CODE int __Pyx_CreateCodeObjects(__pyx_mstatetype *__pyx_mstate); /*proto*/ -/* #### Code section: init_module ### */ - -static int __Pyx_modinit_global_init_code(__pyx_mstatetype *__pyx_mstate) { - __Pyx_RefNannyDeclarations - CYTHON_UNUSED_VAR(__pyx_mstate); - __Pyx_RefNannySetupContext("__Pyx_modinit_global_init_code", 0); - /*--- Global init code ---*/ - __Pyx_RefNannyFinishContext(); - return 0; -} - -static int __Pyx_modinit_variable_export_code(__pyx_mstatetype *__pyx_mstate) { - __Pyx_RefNannyDeclarations - CYTHON_UNUSED_VAR(__pyx_mstate); - __Pyx_RefNannySetupContext("__Pyx_modinit_variable_export_code", 0); - /*--- Variable export code ---*/ - __Pyx_RefNannyFinishContext(); - return 0; -} - -static int __Pyx_modinit_function_export_code(__pyx_mstatetype *__pyx_mstate) { - __Pyx_RefNannyDeclarations - CYTHON_UNUSED_VAR(__pyx_mstate); - __Pyx_RefNannySetupContext("__Pyx_modinit_function_export_code", 0); - /*--- Function export code ---*/ - __Pyx_RefNannyFinishContext(); - return 0; -} - -static int __Pyx_modinit_type_init_code(__pyx_mstatetype *__pyx_mstate) { - __Pyx_RefNannyDeclarations - CYTHON_UNUSED_VAR(__pyx_mstate); - __Pyx_RefNannySetupContext("__Pyx_modinit_type_init_code", 0); - /*--- Type init code ---*/ - __Pyx_RefNannyFinishContext(); - return 0; -} - -static int __Pyx_modinit_type_import_code(__pyx_mstatetype *__pyx_mstate) { - __Pyx_RefNannyDeclarations - CYTHON_UNUSED_VAR(__pyx_mstate); - __Pyx_RefNannySetupContext("__Pyx_modinit_type_import_code", 0); - /*--- Type import code ---*/ - __Pyx_RefNannyFinishContext(); - return 0; -} - -static int __Pyx_modinit_variable_import_code(__pyx_mstatetype *__pyx_mstate) { - __Pyx_RefNannyDeclarations - CYTHON_UNUSED_VAR(__pyx_mstate); - __Pyx_RefNannySetupContext("__Pyx_modinit_variable_import_code", 0); - /*--- Variable import code ---*/ - __Pyx_RefNannyFinishContext(); - return 0; -} - -static int __Pyx_modinit_function_import_code(__pyx_mstatetype *__pyx_mstate) { - __Pyx_RefNannyDeclarations - CYTHON_UNUSED_VAR(__pyx_mstate); - __Pyx_RefNannySetupContext("__Pyx_modinit_function_import_code", 0); - /*--- Function import code ---*/ - __Pyx_RefNannyFinishContext(); - return 0; -} - -#if CYTHON_PEP489_MULTI_PHASE_INIT -static PyObject* __pyx_pymod_create(PyObject *spec, PyModuleDef *def); /*proto*/ -static int __pyx_pymod_exec_epanet2_ec(PyObject* module); /*proto*/ -static PyModuleDef_Slot __pyx_moduledef_slots[] = { - {Py_mod_create, (void*)__pyx_pymod_create}, - {Py_mod_exec, (void*)__pyx_pymod_exec_epanet2_ec}, - #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - {Py_mod_gil, Py_MOD_GIL_USED}, - #endif - #if PY_VERSION_HEX >= 0x030C0000 && CYTHON_USE_MODULE_STATE - {Py_mod_multiple_interpreters, Py_MOD_MULTIPLE_INTERPRETERS_NOT_SUPPORTED}, - #endif - {0, NULL} -}; -#endif - -#ifdef __cplusplus -namespace { - struct PyModuleDef __pyx_moduledef = - #else - static struct PyModuleDef __pyx_moduledef = - #endif - { - PyModuleDef_HEAD_INIT, - "epanet2_ec", - 0, /* m_doc */ - #if CYTHON_USE_MODULE_STATE - sizeof(__pyx_mstatetype), /* m_size */ - #else - (CYTHON_PEP489_MULTI_PHASE_INIT) ? 0 : -1, /* m_size */ - #endif - __pyx_methods /* m_methods */, - #if CYTHON_PEP489_MULTI_PHASE_INIT - __pyx_moduledef_slots, /* m_slots */ - #else - NULL, /* m_reload */ - #endif - #if CYTHON_USE_MODULE_STATE - __pyx_m_traverse, /* m_traverse */ - __pyx_m_clear, /* m_clear */ - NULL /* m_free */ - #else - NULL, /* m_traverse */ - NULL, /* m_clear */ - NULL /* m_free */ - #endif - }; - #ifdef __cplusplus -} /* anonymous namespace */ -#endif - -/* PyModInitFuncType */ -#ifndef CYTHON_NO_PYINIT_EXPORT - #define __Pyx_PyMODINIT_FUNC PyMODINIT_FUNC -#else - #ifdef __cplusplus - #define __Pyx_PyMODINIT_FUNC extern "C" PyObject * - #else - #define __Pyx_PyMODINIT_FUNC PyObject * - #endif -#endif - -__Pyx_PyMODINIT_FUNC PyInit_epanet2_ec(void) CYTHON_SMALL_CODE; /*proto*/ -__Pyx_PyMODINIT_FUNC PyInit_epanet2_ec(void) -#if CYTHON_PEP489_MULTI_PHASE_INIT -{ - return PyModuleDef_Init(&__pyx_moduledef); -} -/* ModuleCreationPEP489 */ -#if CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX < 0x03090000 -static PY_INT64_T __Pyx_GetCurrentInterpreterId(void) { - { - PyObject *module = PyImport_ImportModule("_interpreters"); // 3.13+ I think - if (!module) { - PyErr_Clear(); // just try the 3.8-3.12 version - module = PyImport_ImportModule("_xxsubinterpreters"); - if (!module) goto bad; - } - PyObject *current = PyObject_CallMethod(module, "get_current", NULL); - Py_DECREF(module); - if (!current) goto bad; - if (PyTuple_Check(current)) { - PyObject *new_current = PySequence_GetItem(current, 0); - Py_DECREF(current); - current = new_current; - if (!new_current) goto bad; - } - long long as_c_int = PyLong_AsLongLong(current); - Py_DECREF(current); - return as_c_int; - } - bad: - PySys_WriteStderr("__Pyx_GetCurrentInterpreterId failed. Try setting the C define CYTHON_PEP489_MULTI_PHASE_INIT=0\n"); - return -1; -} -#endif -#if !CYTHON_USE_MODULE_STATE -static CYTHON_SMALL_CODE int __Pyx_check_single_interpreter(void) { - static PY_INT64_T main_interpreter_id = -1; -#if CYTHON_COMPILING_IN_GRAAL - PY_INT64_T current_id = PyInterpreterState_GetIDFromThreadState(PyThreadState_Get()); -#elif CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX >= 0x03090000 - PY_INT64_T current_id = PyInterpreterState_GetID(PyInterpreterState_Get()); -#elif CYTHON_COMPILING_IN_LIMITED_API - PY_INT64_T current_id = __Pyx_GetCurrentInterpreterId(); -#else - PY_INT64_T current_id = PyInterpreterState_GetID(PyThreadState_Get()->interp); -#endif - if (unlikely(current_id == -1)) { - return -1; - } - if (main_interpreter_id == -1) { - main_interpreter_id = current_id; - return 0; - } else if (unlikely(main_interpreter_id != current_id)) { - PyErr_SetString( - PyExc_ImportError, - "Interpreter change detected - this module can only be loaded into one interpreter per process."); - return -1; - } - return 0; -} -#endif -static CYTHON_SMALL_CODE int __Pyx_copy_spec_to_module(PyObject *spec, PyObject *moddict, const char* from_name, const char* to_name, int allow_none) -{ - PyObject *value = PyObject_GetAttrString(spec, from_name); - int result = 0; - if (likely(value)) { - if (allow_none || value != Py_None) { - result = PyDict_SetItemString(moddict, to_name, value); - } - Py_DECREF(value); - } else if (PyErr_ExceptionMatches(PyExc_AttributeError)) { - PyErr_Clear(); - } else { - result = -1; - } - return result; -} -static CYTHON_SMALL_CODE PyObject* __pyx_pymod_create(PyObject *spec, PyModuleDef *def) { - PyObject *module = NULL, *moddict, *modname; - CYTHON_UNUSED_VAR(def); - #if !CYTHON_USE_MODULE_STATE - if (__Pyx_check_single_interpreter()) - return NULL; - #endif - if (__pyx_m) - return __Pyx_NewRef(__pyx_m); - modname = PyObject_GetAttrString(spec, "name"); - if (unlikely(!modname)) goto bad; - module = PyModule_NewObject(modname); - Py_DECREF(modname); - if (unlikely(!module)) goto bad; - moddict = PyModule_GetDict(module); - if (unlikely(!moddict)) goto bad; - if (unlikely(__Pyx_copy_spec_to_module(spec, moddict, "loader", "__loader__", 1) < 0)) goto bad; - if (unlikely(__Pyx_copy_spec_to_module(spec, moddict, "origin", "__file__", 1) < 0)) goto bad; - if (unlikely(__Pyx_copy_spec_to_module(spec, moddict, "parent", "__package__", 1) < 0)) goto bad; - if (unlikely(__Pyx_copy_spec_to_module(spec, moddict, "submodule_search_locations", "__path__", 0) < 0)) goto bad; - return module; -bad: - Py_XDECREF(module); - return NULL; -} - - -static CYTHON_SMALL_CODE int __pyx_pymod_exec_epanet2_ec(PyObject *__pyx_pyinit_module) -#endif -{ - int stringtab_initialized = 0; - #if CYTHON_USE_MODULE_STATE - int pystate_addmodule_run = 0; - #endif - __pyx_mstatetype *__pyx_mstate = NULL; - PyObject *__pyx_t_1 = NULL; - PyObject *__pyx_t_2 = NULL; - int __pyx_lineno = 0; - const char *__pyx_filename = NULL; - int __pyx_clineno = 0; - __Pyx_RefNannyDeclarations - #if CYTHON_PEP489_MULTI_PHASE_INIT - if (__pyx_m) { - if (__pyx_m == __pyx_pyinit_module) return 0; - PyErr_SetString(PyExc_RuntimeError, "Module 'epanet2_ec' has already been imported. Re-initialisation is not supported."); - return -1; - } - #else - if (__pyx_m) return __Pyx_NewRef(__pyx_m); - #endif - /*--- Module creation code ---*/ - #if CYTHON_PEP489_MULTI_PHASE_INIT - __pyx_t_1 = __pyx_pyinit_module; - Py_INCREF(__pyx_t_1); - #else - __pyx_t_1 = PyModule_Create(&__pyx_moduledef); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1, __pyx_L1_error) - #endif - #if CYTHON_USE_MODULE_STATE - { - int add_module_result = __Pyx_State_AddModule(__pyx_t_1, &__pyx_moduledef); - __pyx_t_1 = 0; /* transfer ownership from __pyx_t_1 to "epanet2_ec" pseudovariable */ - if (unlikely((add_module_result < 0))) __PYX_ERR(0, 1, __pyx_L1_error) - pystate_addmodule_run = 1; - } - #else - __pyx_m = __pyx_t_1; - #endif - #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - PyUnstable_Module_SetGIL(__pyx_m, Py_MOD_GIL_USED); - #endif - __pyx_mstate = __pyx_mstate_global; - CYTHON_UNUSED_VAR(__pyx_t_1); - __pyx_mstate->__pyx_d = PyModule_GetDict(__pyx_m); if (unlikely(!__pyx_mstate->__pyx_d)) __PYX_ERR(0, 1, __pyx_L1_error) - Py_INCREF(__pyx_mstate->__pyx_d); - __pyx_mstate->__pyx_b = __Pyx_PyImport_AddModuleRef(__Pyx_BUILTIN_MODULE_NAME); if (unlikely(!__pyx_mstate->__pyx_b)) __PYX_ERR(0, 1, __pyx_L1_error) - __pyx_mstate->__pyx_cython_runtime = __Pyx_PyImport_AddModuleRef("cython_runtime"); if (unlikely(!__pyx_mstate->__pyx_cython_runtime)) __PYX_ERR(0, 1, __pyx_L1_error) - if (PyObject_SetAttrString(__pyx_m, "__builtins__", __pyx_mstate->__pyx_b) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - /* ImportRefnannyAPI */ - #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("PyInit_epanet2_ec", 0); - if (__Pyx_check_binary_version(__PYX_LIMITED_VERSION_HEX, __Pyx_get_runtime_version(), CYTHON_COMPILING_IN_LIMITED_API) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - #ifdef __Pxy_PyFrame_Initialize_Offsets - __Pxy_PyFrame_Initialize_Offsets(); - #endif - __pyx_mstate->__pyx_empty_tuple = PyTuple_New(0); if (unlikely(!__pyx_mstate->__pyx_empty_tuple)) __PYX_ERR(0, 1, __pyx_L1_error) - __pyx_mstate->__pyx_empty_bytes = PyBytes_FromStringAndSize("", 0); if (unlikely(!__pyx_mstate->__pyx_empty_bytes)) __PYX_ERR(0, 1, __pyx_L1_error) - __pyx_mstate->__pyx_empty_unicode = PyUnicode_FromStringAndSize("", 0); if (unlikely(!__pyx_mstate->__pyx_empty_unicode)) __PYX_ERR(0, 1, __pyx_L1_error) - #ifdef __Pyx_CyFunction_USED - if (__pyx_CyFunction_init(__pyx_m) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - #endif - #ifdef __Pyx_FusedFunction_USED - if (__pyx_FusedFunction_init(__pyx_m) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - #endif - #ifdef __Pyx_Coroutine_USED - if (__pyx_Coroutine_init(__pyx_m) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - #endif - #ifdef __Pyx_Generator_USED - if (__pyx_Generator_init(__pyx_m) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - #endif - #ifdef __Pyx_AsyncGen_USED - if (__pyx_AsyncGen_init(__pyx_m) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - #endif - /*--- Library function declarations ---*/ - /*--- Initialize various global constants etc. ---*/ - if (__Pyx_InitConstants(__pyx_mstate) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - stringtab_initialized = 1; - if (__Pyx_InitGlobals() < 0) __PYX_ERR(0, 1, __pyx_L1_error) - if (__pyx_module_is_main_epanet__epanet2_ec) { - if (PyObject_SetAttr(__pyx_m, __pyx_mstate_global->__pyx_n_u_name, __pyx_mstate_global->__pyx_n_u_main) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - } - { - PyObject *modules = PyImport_GetModuleDict(); if (unlikely(!modules)) __PYX_ERR(0, 1, __pyx_L1_error) - if (!PyDict_GetItemString(modules, "epanet.epanet2_ec")) { - if (unlikely((PyDict_SetItemString(modules, "epanet.epanet2_ec", __pyx_m) < 0))) __PYX_ERR(0, 1, __pyx_L1_error) - } - } - /*--- Builtin init code ---*/ - if (__Pyx_InitCachedBuiltins(__pyx_mstate) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - /*--- Constants init code ---*/ - if (__Pyx_InitCachedConstants(__pyx_mstate) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - if (__Pyx_CreateCodeObjects(__pyx_mstate) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - /*--- Global type/function init code ---*/ - (void)__Pyx_modinit_global_init_code(__pyx_mstate); - (void)__Pyx_modinit_variable_export_code(__pyx_mstate); - (void)__Pyx_modinit_function_export_code(__pyx_mstate); - (void)__Pyx_modinit_type_init_code(__pyx_mstate); - (void)__Pyx_modinit_type_import_code(__pyx_mstate); - (void)__Pyx_modinit_variable_import_code(__pyx_mstate); - (void)__Pyx_modinit_function_import_code(__pyx_mstate); - /*--- Execution code ---*/ - - /* "epanet/epanet2_ec.py":1 - * ERROR_CODE = {} # <<<<<<<<<<<<<< - * - * # EPANET 2 Error Messages -*/ - __pyx_t_2 = __Pyx_PyDict_NewPresized(0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_ERROR_CODE, __pyx_t_2) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":4 - * - * # EPANET 2 Error Messages - * ERROR_CODE['0'] = "ok" # <<<<<<<<<<<<<< - * - * ERROR_CODE['10'] = "Warning: model run issued warnings" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 4, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_0, __pyx_mstate_global->__pyx_n_u_ok) < 0))) __PYX_ERR(0, 4, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":6 - * ERROR_CODE['0'] = "ok" - * - * ERROR_CODE['10'] = "Warning: model run issued warnings" # <<<<<<<<<<<<<< - * - * ERROR_CODE['101'] = "insufficient memory available" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_10, __pyx_mstate_global->__pyx_kp_u_Warning_model_run_issued_warning) < 0))) __PYX_ERR(0, 6, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":8 - * ERROR_CODE['10'] = "Warning: model run issued warnings" - * - * ERROR_CODE['101'] = "insufficient memory available" # <<<<<<<<<<<<<< - * ERROR_CODE['102'] = "no network data available" - * ERROR_CODE['103'] = "hydraulic solver not opened" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_101, __pyx_mstate_global->__pyx_kp_u_insufficient_memory_available) < 0))) __PYX_ERR(0, 8, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":9 - * - * ERROR_CODE['101'] = "insufficient memory available" - * ERROR_CODE['102'] = "no network data available" # <<<<<<<<<<<<<< - * ERROR_CODE['103'] = "hydraulic solver not opened" - * ERROR_CODE['104'] = "no hydraulics for water quality analysis" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 9, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_102, __pyx_mstate_global->__pyx_kp_u_no_network_data_available) < 0))) __PYX_ERR(0, 9, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":10 - * ERROR_CODE['101'] = "insufficient memory available" - * ERROR_CODE['102'] = "no network data available" - * ERROR_CODE['103'] = "hydraulic solver not opened" # <<<<<<<<<<<<<< - * ERROR_CODE['104'] = "no hydraulics for water quality analysis" - * ERROR_CODE['105'] = "water quality solver not opened" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 10, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_103, __pyx_mstate_global->__pyx_kp_u_hydraulic_solver_not_opened) < 0))) __PYX_ERR(0, 10, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":11 - * ERROR_CODE['102'] = "no network data available" - * ERROR_CODE['103'] = "hydraulic solver not opened" - * ERROR_CODE['104'] = "no hydraulics for water quality analysis" # <<<<<<<<<<<<<< - * ERROR_CODE['105'] = "water quality solver not opened" - * ERROR_CODE['106'] = "no results saved to report on" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 11, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_104, __pyx_mstate_global->__pyx_kp_u_no_hydraulics_for_water_quality) < 0))) __PYX_ERR(0, 11, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":12 - * ERROR_CODE['103'] = "hydraulic solver not opened" - * ERROR_CODE['104'] = "no hydraulics for water quality analysis" - * ERROR_CODE['105'] = "water quality solver not opened" # <<<<<<<<<<<<<< - * ERROR_CODE['106'] = "no results saved to report on" - * ERROR_CODE['107'] = "hydraulics supplied from external file" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 12, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_105, __pyx_mstate_global->__pyx_kp_u_water_quality_solver_not_opened) < 0))) __PYX_ERR(0, 12, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":13 - * ERROR_CODE['104'] = "no hydraulics for water quality analysis" - * ERROR_CODE['105'] = "water quality solver not opened" - * ERROR_CODE['106'] = "no results saved to report on" # <<<<<<<<<<<<<< - * ERROR_CODE['107'] = "hydraulics supplied from external file" - * ERROR_CODE['108'] = "cannot use external file while hydraulics solver is active" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 13, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_106, __pyx_mstate_global->__pyx_kp_u_no_results_saved_to_report_on) < 0))) __PYX_ERR(0, 13, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":14 - * ERROR_CODE['105'] = "water quality solver not opened" - * ERROR_CODE['106'] = "no results saved to report on" - * ERROR_CODE['107'] = "hydraulics supplied from external file" # <<<<<<<<<<<<<< - * ERROR_CODE['108'] = "cannot use external file while hydraulics solver is active" - * ERROR_CODE['110'] = "cannot solve network hydraulic equations" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 14, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_107, __pyx_mstate_global->__pyx_kp_u_hydraulics_supplied_from_externa) < 0))) __PYX_ERR(0, 14, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":15 - * ERROR_CODE['106'] = "no results saved to report on" - * ERROR_CODE['107'] = "hydraulics supplied from external file" - * ERROR_CODE['108'] = "cannot use external file while hydraulics solver is active" # <<<<<<<<<<<<<< - * ERROR_CODE['110'] = "cannot solve network hydraulic equations" - * ERROR_CODE['120'] = "cannot solve water quality transport equations" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 15, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_108, __pyx_mstate_global->__pyx_kp_u_cannot_use_external_file_while_h) < 0))) __PYX_ERR(0, 15, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":16 - * ERROR_CODE['107'] = "hydraulics supplied from external file" - * ERROR_CODE['108'] = "cannot use external file while hydraulics solver is active" - * ERROR_CODE['110'] = "cannot solve network hydraulic equations" # <<<<<<<<<<<<<< - * ERROR_CODE['120'] = "cannot solve water quality transport equations" - * -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 16, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_110, __pyx_mstate_global->__pyx_kp_u_cannot_solve_network_hydraulic_e) < 0))) __PYX_ERR(0, 16, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":17 - * ERROR_CODE['108'] = "cannot use external file while hydraulics solver is active" - * ERROR_CODE['110'] = "cannot solve network hydraulic equations" - * ERROR_CODE['120'] = "cannot solve water quality transport equations" # <<<<<<<<<<<<<< - * - * # These errors apply only to an input file -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 17, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_120, __pyx_mstate_global->__pyx_kp_u_cannot_solve_water_quality_trans) < 0))) __PYX_ERR(0, 17, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":20 - * - * # These errors apply only to an input file - * ERROR_CODE['200'] = "one or more errors in input file" # <<<<<<<<<<<<<< - * ERROR_CODE['201'] = "syntax error" - * -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 20, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_200, __pyx_mstate_global->__pyx_kp_u_one_or_more_errors_in_input_file) < 0))) __PYX_ERR(0, 20, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":21 - * # These errors apply only to an input file - * ERROR_CODE['200'] = "one or more errors in input file" - * ERROR_CODE['201'] = "syntax error" # <<<<<<<<<<<<<< - * - * # These errors apply to both an input file and to API functions -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 21, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_201, __pyx_mstate_global->__pyx_kp_u_syntax_error) < 0))) __PYX_ERR(0, 21, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":24 - * - * # These errors apply to both an input file and to API functions - * ERROR_CODE['202'] = "illegal numeric value" # <<<<<<<<<<<<<< - * ERROR_CODE['203'] = "undefined node" - * ERROR_CODE['204'] = "undefined link" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 24, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_202, __pyx_mstate_global->__pyx_kp_u_illegal_numeric_value) < 0))) __PYX_ERR(0, 24, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":25 - * # These errors apply to both an input file and to API functions - * ERROR_CODE['202'] = "illegal numeric value" - * ERROR_CODE['203'] = "undefined node" # <<<<<<<<<<<<<< - * ERROR_CODE['204'] = "undefined link" - * ERROR_CODE['205'] = "undefined time pattern" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 25, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_203, __pyx_mstate_global->__pyx_kp_u_undefined_node) < 0))) __PYX_ERR(0, 25, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":26 - * ERROR_CODE['202'] = "illegal numeric value" - * ERROR_CODE['203'] = "undefined node" - * ERROR_CODE['204'] = "undefined link" # <<<<<<<<<<<<<< - * ERROR_CODE['205'] = "undefined time pattern" - * ERROR_CODE['206'] = "undefined curve" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 26, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_204, __pyx_mstate_global->__pyx_kp_u_undefined_link) < 0))) __PYX_ERR(0, 26, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":27 - * ERROR_CODE['203'] = "undefined node" - * ERROR_CODE['204'] = "undefined link" - * ERROR_CODE['205'] = "undefined time pattern" # <<<<<<<<<<<<<< - * ERROR_CODE['206'] = "undefined curve" - * ERROR_CODE['207'] = "attempt to control CV/GPV link" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 27, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_205, __pyx_mstate_global->__pyx_kp_u_undefined_time_pattern) < 0))) __PYX_ERR(0, 27, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":28 - * ERROR_CODE['204'] = "undefined link" - * ERROR_CODE['205'] = "undefined time pattern" - * ERROR_CODE['206'] = "undefined curve" # <<<<<<<<<<<<<< - * ERROR_CODE['207'] = "attempt to control CV/GPV link" - * ERROR_CODE['208'] = "illegal PDA pressure limits" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 28, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_206, __pyx_mstate_global->__pyx_kp_u_undefined_curve) < 0))) __PYX_ERR(0, 28, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":29 - * ERROR_CODE['205'] = "undefined time pattern" - * ERROR_CODE['206'] = "undefined curve" - * ERROR_CODE['207'] = "attempt to control CV/GPV link" # <<<<<<<<<<<<<< - * ERROR_CODE['208'] = "illegal PDA pressure limits" - * ERROR_CODE['209'] = "illegal node property value" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 29, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_207, __pyx_mstate_global->__pyx_kp_u_attempt_to_control_CV_GPV_link) < 0))) __PYX_ERR(0, 29, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":30 - * ERROR_CODE['206'] = "undefined curve" - * ERROR_CODE['207'] = "attempt to control CV/GPV link" - * ERROR_CODE['208'] = "illegal PDA pressure limits" # <<<<<<<<<<<<<< - * ERROR_CODE['209'] = "illegal node property value" - * ERROR_CODE['211'] = "illegal link property value" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 30, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_208, __pyx_mstate_global->__pyx_kp_u_illegal_PDA_pressure_limits) < 0))) __PYX_ERR(0, 30, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":31 - * ERROR_CODE['207'] = "attempt to control CV/GPV link" - * ERROR_CODE['208'] = "illegal PDA pressure limits" - * ERROR_CODE['209'] = "illegal node property value" # <<<<<<<<<<<<<< - * ERROR_CODE['211'] = "illegal link property value" - * ERROR_CODE['212'] = "undefined trace node" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 31, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_209, __pyx_mstate_global->__pyx_kp_u_illegal_node_property_value) < 0))) __PYX_ERR(0, 31, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":32 - * ERROR_CODE['208'] = "illegal PDA pressure limits" - * ERROR_CODE['209'] = "illegal node property value" - * ERROR_CODE['211'] = "illegal link property value" # <<<<<<<<<<<<<< - * ERROR_CODE['212'] = "undefined trace node" - * ERROR_CODE['213'] = "invalid option value" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 32, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_211, __pyx_mstate_global->__pyx_kp_u_illegal_link_property_value) < 0))) __PYX_ERR(0, 32, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":33 - * ERROR_CODE['209'] = "illegal node property value" - * ERROR_CODE['211'] = "illegal link property value" - * ERROR_CODE['212'] = "undefined trace node" # <<<<<<<<<<<<<< - * ERROR_CODE['213'] = "invalid option value" - * ERROR_CODE['214'] = "too many characters in input line" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 33, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_212, __pyx_mstate_global->__pyx_kp_u_undefined_trace_node) < 0))) __PYX_ERR(0, 33, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":34 - * ERROR_CODE['211'] = "illegal link property value" - * ERROR_CODE['212'] = "undefined trace node" - * ERROR_CODE['213'] = "invalid option value" # <<<<<<<<<<<<<< - * ERROR_CODE['214'] = "too many characters in input line" - * ERROR_CODE['215'] = "duplicate ID label" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 34, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_213, __pyx_mstate_global->__pyx_kp_u_invalid_option_value) < 0))) __PYX_ERR(0, 34, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":35 - * ERROR_CODE['212'] = "undefined trace node" - * ERROR_CODE['213'] = "invalid option value" - * ERROR_CODE['214'] = "too many characters in input line" # <<<<<<<<<<<<<< - * ERROR_CODE['215'] = "duplicate ID label" - * ERROR_CODE['216'] = "reference to undefined pump" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 35, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_214, __pyx_mstate_global->__pyx_kp_u_too_many_characters_in_input_lin) < 0))) __PYX_ERR(0, 35, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":36 - * ERROR_CODE['213'] = "invalid option value" - * ERROR_CODE['214'] = "too many characters in input line" - * ERROR_CODE['215'] = "duplicate ID label" # <<<<<<<<<<<<<< - * ERROR_CODE['216'] = "reference to undefined pump" - * ERROR_CODE['217'] = "invalid pump energy data" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 36, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_215, __pyx_mstate_global->__pyx_kp_u_duplicate_ID_label) < 0))) __PYX_ERR(0, 36, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":37 - * ERROR_CODE['214'] = "too many characters in input line" - * ERROR_CODE['215'] = "duplicate ID label" - * ERROR_CODE['216'] = "reference to undefined pump" # <<<<<<<<<<<<<< - * ERROR_CODE['217'] = "invalid pump energy data" - * ERROR_CODE['219'] = "illegal valve connection to tank node" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 37, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_216, __pyx_mstate_global->__pyx_kp_u_reference_to_undefined_pump) < 0))) __PYX_ERR(0, 37, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":38 - * ERROR_CODE['215'] = "duplicate ID label" - * ERROR_CODE['216'] = "reference to undefined pump" - * ERROR_CODE['217'] = "invalid pump energy data" # <<<<<<<<<<<<<< - * ERROR_CODE['219'] = "illegal valve connection to tank node" - * ERROR_CODE['220'] = "illegal valve connection to another valve" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 38, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_217, __pyx_mstate_global->__pyx_kp_u_invalid_pump_energy_data) < 0))) __PYX_ERR(0, 38, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":39 - * ERROR_CODE['216'] = "reference to undefined pump" - * ERROR_CODE['217'] = "invalid pump energy data" - * ERROR_CODE['219'] = "illegal valve connection to tank node" # <<<<<<<<<<<<<< - * ERROR_CODE['220'] = "illegal valve connection to another valve" - * ERROR_CODE['221'] = "mis-placed rule clause in rule-based control" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 39, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_219, __pyx_mstate_global->__pyx_kp_u_illegal_valve_connection_to_tank) < 0))) __PYX_ERR(0, 39, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":40 - * ERROR_CODE['217'] = "invalid pump energy data" - * ERROR_CODE['219'] = "illegal valve connection to tank node" - * ERROR_CODE['220'] = "illegal valve connection to another valve" # <<<<<<<<<<<<<< - * ERROR_CODE['221'] = "mis-placed rule clause in rule-based control" - * ERROR_CODE['222'] = "same start and end nodes for link" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 40, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_220, __pyx_mstate_global->__pyx_kp_u_illegal_valve_connection_to_anot) < 0))) __PYX_ERR(0, 40, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":41 - * ERROR_CODE['219'] = "illegal valve connection to tank node" - * ERROR_CODE['220'] = "illegal valve connection to another valve" - * ERROR_CODE['221'] = "mis-placed rule clause in rule-based control" # <<<<<<<<<<<<<< - * ERROR_CODE['222'] = "same start and end nodes for link" - * -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 41, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_221, __pyx_mstate_global->__pyx_kp_u_mis_placed_rule_clause_in_rule_b) < 0))) __PYX_ERR(0, 41, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":42 - * ERROR_CODE['220'] = "illegal valve connection to another valve" - * ERROR_CODE['221'] = "mis-placed rule clause in rule-based control" - * ERROR_CODE['222'] = "same start and end nodes for link" # <<<<<<<<<<<<<< - * - * # These errors apply to network consistency check -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 42, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_222, __pyx_mstate_global->__pyx_kp_u_same_start_and_end_nodes_for_lin) < 0))) __PYX_ERR(0, 42, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":45 - * - * # These errors apply to network consistency check - * ERROR_CODE['223'] = "not enough nodes in network" # <<<<<<<<<<<<<< - * ERROR_CODE['224'] = "no tanks or reservoirs in network" - * ERROR_CODE['225'] = "invalid lower/upper levels for tank" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 45, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_223, __pyx_mstate_global->__pyx_kp_u_not_enough_nodes_in_network) < 0))) __PYX_ERR(0, 45, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":46 - * # These errors apply to network consistency check - * ERROR_CODE['223'] = "not enough nodes in network" - * ERROR_CODE['224'] = "no tanks or reservoirs in network" # <<<<<<<<<<<<<< - * ERROR_CODE['225'] = "invalid lower/upper levels for tank" - * ERROR_CODE['226'] = "no head curve or power rating for pump" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 46, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_224, __pyx_mstate_global->__pyx_kp_u_no_tanks_or_reservoirs_in_networ) < 0))) __PYX_ERR(0, 46, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":47 - * ERROR_CODE['223'] = "not enough nodes in network" - * ERROR_CODE['224'] = "no tanks or reservoirs in network" - * ERROR_CODE['225'] = "invalid lower/upper levels for tank" # <<<<<<<<<<<<<< - * ERROR_CODE['226'] = "no head curve or power rating for pump" - * ERROR_CODE['227'] = "invalid head curve for pump" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 47, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_225, __pyx_mstate_global->__pyx_kp_u_invalid_lower_upper_levels_for_t) < 0))) __PYX_ERR(0, 47, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":48 - * ERROR_CODE['224'] = "no tanks or reservoirs in network" - * ERROR_CODE['225'] = "invalid lower/upper levels for tank" - * ERROR_CODE['226'] = "no head curve or power rating for pump" # <<<<<<<<<<<<<< - * ERROR_CODE['227'] = "invalid head curve for pump" - * ERROR_CODE['230'] = "nonincreasing x-values for curve" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 48, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_226, __pyx_mstate_global->__pyx_kp_u_no_head_curve_or_power_rating_fo) < 0))) __PYX_ERR(0, 48, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":49 - * ERROR_CODE['225'] = "invalid lower/upper levels for tank" - * ERROR_CODE['226'] = "no head curve or power rating for pump" - * ERROR_CODE['227'] = "invalid head curve for pump" # <<<<<<<<<<<<<< - * ERROR_CODE['230'] = "nonincreasing x-values for curve" - * ERROR_CODE['233'] = "network has unconnected nodes" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 49, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_227, __pyx_mstate_global->__pyx_kp_u_invalid_head_curve_for_pump) < 0))) __PYX_ERR(0, 49, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":50 - * ERROR_CODE['226'] = "no head curve or power rating for pump" - * ERROR_CODE['227'] = "invalid head curve for pump" - * ERROR_CODE['230'] = "nonincreasing x-values for curve" # <<<<<<<<<<<<<< - * ERROR_CODE['233'] = "network has unconnected nodes" - * ERROR_CODE['234'] = "network has an unconnected node with ID: " -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 50, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_230, __pyx_mstate_global->__pyx_kp_u_nonincreasing_x_values_for_curve) < 0))) __PYX_ERR(0, 50, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":51 - * ERROR_CODE['227'] = "invalid head curve for pump" - * ERROR_CODE['230'] = "nonincreasing x-values for curve" - * ERROR_CODE['233'] = "network has unconnected nodes" # <<<<<<<<<<<<<< - * ERROR_CODE['234'] = "network has an unconnected node with ID: " - * -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 51, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_233, __pyx_mstate_global->__pyx_kp_u_network_has_unconnected_nodes) < 0))) __PYX_ERR(0, 51, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":52 - * ERROR_CODE['230'] = "nonincreasing x-values for curve" - * ERROR_CODE['233'] = "network has unconnected nodes" - * ERROR_CODE['234'] = "network has an unconnected node with ID: " # <<<<<<<<<<<<<< - * - * # These errors apply only to API functions -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 52, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_234, __pyx_mstate_global->__pyx_kp_u_network_has_an_unconnected_node) < 0))) __PYX_ERR(0, 52, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":55 - * - * # These errors apply only to API functions - * ERROR_CODE['240'] = "nonexistent source" # <<<<<<<<<<<<<< - * ERROR_CODE['241'] = "nonexistent control" - * ERROR_CODE['250'] = "invalid format" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 55, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_240, __pyx_mstate_global->__pyx_kp_u_nonexistent_source) < 0))) __PYX_ERR(0, 55, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":56 - * # These errors apply only to API functions - * ERROR_CODE['240'] = "nonexistent source" - * ERROR_CODE['241'] = "nonexistent control" # <<<<<<<<<<<<<< - * ERROR_CODE['250'] = "invalid format" - * ERROR_CODE['251'] = "invalid parameter code" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 56, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_241, __pyx_mstate_global->__pyx_kp_u_nonexistent_control) < 0))) __PYX_ERR(0, 56, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":57 - * ERROR_CODE['240'] = "nonexistent source" - * ERROR_CODE['241'] = "nonexistent control" - * ERROR_CODE['250'] = "invalid format" # <<<<<<<<<<<<<< - * ERROR_CODE['251'] = "invalid parameter code" - * ERROR_CODE['252'] = "invalid ID name" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 57, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_250, __pyx_mstate_global->__pyx_kp_u_invalid_format) < 0))) __PYX_ERR(0, 57, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":58 - * ERROR_CODE['241'] = "nonexistent control" - * ERROR_CODE['250'] = "invalid format" - * ERROR_CODE['251'] = "invalid parameter code" # <<<<<<<<<<<<<< - * ERROR_CODE['252'] = "invalid ID name" - * ERROR_CODE['253'] = "nonexistent demand category" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 58, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_251, __pyx_mstate_global->__pyx_kp_u_invalid_parameter_code) < 0))) __PYX_ERR(0, 58, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":59 - * ERROR_CODE['250'] = "invalid format" - * ERROR_CODE['251'] = "invalid parameter code" - * ERROR_CODE['252'] = "invalid ID name" # <<<<<<<<<<<<<< - * ERROR_CODE['253'] = "nonexistent demand category" - * ERROR_CODE['254'] = "node with no coordinates" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 59, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_252, __pyx_mstate_global->__pyx_kp_u_invalid_ID_name) < 0))) __PYX_ERR(0, 59, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":60 - * ERROR_CODE['251'] = "invalid parameter code" - * ERROR_CODE['252'] = "invalid ID name" - * ERROR_CODE['253'] = "nonexistent demand category" # <<<<<<<<<<<<<< - * ERROR_CODE['254'] = "node with no coordinates" - * ERROR_CODE['255'] = "invalid link vertex" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 60, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_253, __pyx_mstate_global->__pyx_kp_u_nonexistent_demand_category) < 0))) __PYX_ERR(0, 60, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":61 - * ERROR_CODE['252'] = "invalid ID name" - * ERROR_CODE['253'] = "nonexistent demand category" - * ERROR_CODE['254'] = "node with no coordinates" # <<<<<<<<<<<<<< - * ERROR_CODE['255'] = "invalid link vertex" - * ERROR_CODE['257'] = "nonexistent rule" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 61, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_254, __pyx_mstate_global->__pyx_kp_u_node_with_no_coordinates) < 0))) __PYX_ERR(0, 61, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":62 - * ERROR_CODE['253'] = "nonexistent demand category" - * ERROR_CODE['254'] = "node with no coordinates" - * ERROR_CODE['255'] = "invalid link vertex" # <<<<<<<<<<<<<< - * ERROR_CODE['257'] = "nonexistent rule" - * ERROR_CODE['258'] = "nonexistent rule clause" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 62, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_255, __pyx_mstate_global->__pyx_kp_u_invalid_link_vertex) < 0))) __PYX_ERR(0, 62, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":63 - * ERROR_CODE['254'] = "node with no coordinates" - * ERROR_CODE['255'] = "invalid link vertex" - * ERROR_CODE['257'] = "nonexistent rule" # <<<<<<<<<<<<<< - * ERROR_CODE['258'] = "nonexistent rule clause" - * ERROR_CODE['259'] = "attempt to delete a node that still has links connected to it" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 63, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_257, __pyx_mstate_global->__pyx_kp_u_nonexistent_rule) < 0))) __PYX_ERR(0, 63, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":64 - * ERROR_CODE['255'] = "invalid link vertex" - * ERROR_CODE['257'] = "nonexistent rule" - * ERROR_CODE['258'] = "nonexistent rule clause" # <<<<<<<<<<<<<< - * ERROR_CODE['259'] = "attempt to delete a node that still has links connected to it" - * ERROR_CODE['260'] = "attempt to delete node assigned as a Trace Node" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 64, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_258, __pyx_mstate_global->__pyx_kp_u_nonexistent_rule_clause) < 0))) __PYX_ERR(0, 64, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":65 - * ERROR_CODE['257'] = "nonexistent rule" - * ERROR_CODE['258'] = "nonexistent rule clause" - * ERROR_CODE['259'] = "attempt to delete a node that still has links connected to it" # <<<<<<<<<<<<<< - * ERROR_CODE['260'] = "attempt to delete node assigned as a Trace Node" - * ERROR_CODE['261'] = "attempt to delete a node or link contained in a control" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 65, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_259, __pyx_mstate_global->__pyx_kp_u_attempt_to_delete_a_node_that_st) < 0))) __PYX_ERR(0, 65, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":66 - * ERROR_CODE['258'] = "nonexistent rule clause" - * ERROR_CODE['259'] = "attempt to delete a node that still has links connected to it" - * ERROR_CODE['260'] = "attempt to delete node assigned as a Trace Node" # <<<<<<<<<<<<<< - * ERROR_CODE['261'] = "attempt to delete a node or link contained in a control" - * ERROR_CODE['262'] = "attempt to modify network structure while solver is active" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 66, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_260, __pyx_mstate_global->__pyx_kp_u_attempt_to_delete_node_assigned) < 0))) __PYX_ERR(0, 66, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":67 - * ERROR_CODE['259'] = "attempt to delete a node that still has links connected to it" - * ERROR_CODE['260'] = "attempt to delete node assigned as a Trace Node" - * ERROR_CODE['261'] = "attempt to delete a node or link contained in a control" # <<<<<<<<<<<<<< - * ERROR_CODE['262'] = "attempt to modify network structure while solver is active" - * ERROR_CODE['263'] = "node is not a tank" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 67, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_261, __pyx_mstate_global->__pyx_kp_u_attempt_to_delete_a_node_or_link) < 0))) __PYX_ERR(0, 67, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":68 - * ERROR_CODE['260'] = "attempt to delete node assigned as a Trace Node" - * ERROR_CODE['261'] = "attempt to delete a node or link contained in a control" - * ERROR_CODE['262'] = "attempt to modify network structure while solver is active" # <<<<<<<<<<<<<< - * ERROR_CODE['263'] = "node is not a tank" - * -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 68, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_262, __pyx_mstate_global->__pyx_kp_u_attempt_to_modify_network_struct) < 0))) __PYX_ERR(0, 68, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":69 - * ERROR_CODE['261'] = "attempt to delete a node or link contained in a control" - * ERROR_CODE['262'] = "attempt to modify network structure while solver is active" - * ERROR_CODE['263'] = "node is not a tank" # <<<<<<<<<<<<<< - * - * # File errors -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 69, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_263, __pyx_mstate_global->__pyx_kp_u_node_is_not_a_tank) < 0))) __PYX_ERR(0, 69, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":72 - * - * # File errors - * ERROR_CODE['301'] = "identical file names" # <<<<<<<<<<<<<< - * ERROR_CODE['302'] = "cannot open input file" - * ERROR_CODE['303'] = "cannot open report file" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 72, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_301, __pyx_mstate_global->__pyx_kp_u_identical_file_names) < 0))) __PYX_ERR(0, 72, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":73 - * # File errors - * ERROR_CODE['301'] = "identical file names" - * ERROR_CODE['302'] = "cannot open input file" # <<<<<<<<<<<<<< - * ERROR_CODE['303'] = "cannot open report file" - * ERROR_CODE['304'] = "cannot open binary output file" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 73, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_302, __pyx_mstate_global->__pyx_kp_u_cannot_open_input_file) < 0))) __PYX_ERR(0, 73, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":74 - * ERROR_CODE['301'] = "identical file names" - * ERROR_CODE['302'] = "cannot open input file" - * ERROR_CODE['303'] = "cannot open report file" # <<<<<<<<<<<<<< - * ERROR_CODE['304'] = "cannot open binary output file" - * ERROR_CODE['305'] = "cannot open hydraulics file" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 74, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_303, __pyx_mstate_global->__pyx_kp_u_cannot_open_report_file) < 0))) __PYX_ERR(0, 74, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":75 - * ERROR_CODE['302'] = "cannot open input file" - * ERROR_CODE['303'] = "cannot open report file" - * ERROR_CODE['304'] = "cannot open binary output file" # <<<<<<<<<<<<<< - * ERROR_CODE['305'] = "cannot open hydraulics file" - * ERROR_CODE['306'] = "hydraulics file does not match network data" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 75, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_304, __pyx_mstate_global->__pyx_kp_u_cannot_open_binary_output_file) < 0))) __PYX_ERR(0, 75, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":76 - * ERROR_CODE['303'] = "cannot open report file" - * ERROR_CODE['304'] = "cannot open binary output file" - * ERROR_CODE['305'] = "cannot open hydraulics file" # <<<<<<<<<<<<<< - * ERROR_CODE['306'] = "hydraulics file does not match network data" - * ERROR_CODE['307'] = "cannot read hydraulics file" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 76, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_305, __pyx_mstate_global->__pyx_kp_u_cannot_open_hydraulics_file) < 0))) __PYX_ERR(0, 76, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":77 - * ERROR_CODE['304'] = "cannot open binary output file" - * ERROR_CODE['305'] = "cannot open hydraulics file" - * ERROR_CODE['306'] = "hydraulics file does not match network data" # <<<<<<<<<<<<<< - * ERROR_CODE['307'] = "cannot read hydraulics file" - * ERROR_CODE['308'] = "cannot save results to file" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 77, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_306, __pyx_mstate_global->__pyx_kp_u_hydraulics_file_does_not_match_n) < 0))) __PYX_ERR(0, 77, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":78 - * ERROR_CODE['305'] = "cannot open hydraulics file" - * ERROR_CODE['306'] = "hydraulics file does not match network data" - * ERROR_CODE['307'] = "cannot read hydraulics file" # <<<<<<<<<<<<<< - * ERROR_CODE['308'] = "cannot save results to file" - * ERROR_CODE['309'] = "cannot save results to report file" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 78, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_307, __pyx_mstate_global->__pyx_kp_u_cannot_read_hydraulics_file) < 0))) __PYX_ERR(0, 78, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":79 - * ERROR_CODE['306'] = "hydraulics file does not match network data" - * ERROR_CODE['307'] = "cannot read hydraulics file" - * ERROR_CODE['308'] = "cannot save results to file" # <<<<<<<<<<<<<< - * ERROR_CODE['309'] = "cannot save results to report file" - * -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 79, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_308, __pyx_mstate_global->__pyx_kp_u_cannot_save_results_to_file) < 0))) __PYX_ERR(0, 79, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":80 - * ERROR_CODE['307'] = "cannot read hydraulics file" - * ERROR_CODE['308'] = "cannot save results to file" - * ERROR_CODE['309'] = "cannot save results to report file" # <<<<<<<<<<<<<< - * - * ERROR_CODE['411'] = "Input Error 411: no memory allocated for results" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 80, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_309, __pyx_mstate_global->__pyx_kp_u_cannot_save_results_to_report_fi) < 0))) __PYX_ERR(0, 80, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":82 - * ERROR_CODE['309'] = "cannot save results to report file" - * - * ERROR_CODE['411'] = "Input Error 411: no memory allocated for results" # <<<<<<<<<<<<<< - * ERROR_CODE['412'] = "Input Error 412: binary file hasn't been opened" - * ERROR_CODE['421'] = "Input Error 421: invalid parameter code" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 82, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_411, __pyx_mstate_global->__pyx_kp_u_Input_Error_411_no_memory_alloca) < 0))) __PYX_ERR(0, 82, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":83 - * - * ERROR_CODE['411'] = "Input Error 411: no memory allocated for results" - * ERROR_CODE['412'] = "Input Error 412: binary file hasn't been opened" # <<<<<<<<<<<<<< - * ERROR_CODE['421'] = "Input Error 421: invalid parameter code" - * ERROR_CODE['422'] = "Input Error 422: reporting period index out of range" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 83, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_412, __pyx_mstate_global->__pyx_kp_u_Input_Error_412_binary_file_hasn) < 0))) __PYX_ERR(0, 83, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":84 - * ERROR_CODE['411'] = "Input Error 411: no memory allocated for results" - * ERROR_CODE['412'] = "Input Error 412: binary file hasn't been opened" - * ERROR_CODE['421'] = "Input Error 421: invalid parameter code" # <<<<<<<<<<<<<< - * ERROR_CODE['422'] = "Input Error 422: reporting period index out of range" - * ERROR_CODE['423'] = "Input Error 423: element index out of range" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 84, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_421, __pyx_mstate_global->__pyx_kp_u_Input_Error_421_invalid_paramete) < 0))) __PYX_ERR(0, 84, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":85 - * ERROR_CODE['412'] = "Input Error 412: binary file hasn't been opened" - * ERROR_CODE['421'] = "Input Error 421: invalid parameter code" - * ERROR_CODE['422'] = "Input Error 422: reporting period index out of range" # <<<<<<<<<<<<<< - * ERROR_CODE['423'] = "Input Error 423: element index out of range" - * -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 85, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_422, __pyx_mstate_global->__pyx_kp_u_Input_Error_422_reporting_period) < 0))) __PYX_ERR(0, 85, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":86 - * ERROR_CODE['421'] = "Input Error 421: invalid parameter code" - * ERROR_CODE['422'] = "Input Error 422: reporting period index out of range" - * ERROR_CODE['423'] = "Input Error 423: element index out of range" # <<<<<<<<<<<<<< - * - * ERROR_CODE['434'] = "File Error 434: unable to open binary file" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 86, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_423, __pyx_mstate_global->__pyx_kp_u_Input_Error_423_element_index_ou) < 0))) __PYX_ERR(0, 86, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":88 - * ERROR_CODE['423'] = "Input Error 423: element index out of range" - * - * ERROR_CODE['434'] = "File Error 434: unable to open binary file" # <<<<<<<<<<<<<< - * ERROR_CODE['435'] = "File Error 435: invalid binary file type" - * ERROR_CODE['436'] = "File Error 436: no results in binary file" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 88, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_434, __pyx_mstate_global->__pyx_kp_u_File_Error_434_unable_to_open_bi) < 0))) __PYX_ERR(0, 88, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":89 - * - * ERROR_CODE['434'] = "File Error 434: unable to open binary file" - * ERROR_CODE['435'] = "File Error 435: invalid binary file type" # <<<<<<<<<<<<<< - * ERROR_CODE['436'] = "File Error 436: no results in binary file" - * -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 89, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_435, __pyx_mstate_global->__pyx_kp_u_File_Error_435_invalid_binary_fi) < 0))) __PYX_ERR(0, 89, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":90 - * ERROR_CODE['434'] = "File Error 434: unable to open binary file" - * ERROR_CODE['435'] = "File Error 435: invalid binary file type" - * ERROR_CODE['436'] = "File Error 436: no results in binary file" # <<<<<<<<<<<<<< - * - * ERROR_CODE['ERR'] = "Error: An unknown error has occurred" -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 90, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_436, __pyx_mstate_global->__pyx_kp_u_File_Error_436_no_results_in_bin) < 0))) __PYX_ERR(0, 90, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":92 - * ERROR_CODE['436'] = "File Error 436: no results in binary file" - * - * ERROR_CODE['ERR'] = "Error: An unknown error has occurred" # <<<<<<<<<<<<<< -*/ - __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERROR_CODE); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 92, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (unlikely((PyObject_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ERR, __pyx_mstate_global->__pyx_kp_u_Error_An_unknown_error_has_occur) < 0))) __PYX_ERR(0, 92, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /* "epanet/epanet2_ec.py":1 - * ERROR_CODE = {} # <<<<<<<<<<<<<< - * - * # EPANET 2 Error Messages -*/ - __pyx_t_2 = __Pyx_PyDict_NewPresized(0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1, __pyx_L1_error) - __Pyx_GOTREF(__pyx_t_2); - if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_test, __pyx_t_2) < 0) __PYX_ERR(0, 1, __pyx_L1_error) - __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; - - /*--- Wrapped vars code ---*/ - - goto __pyx_L0; - __pyx_L1_error:; - __Pyx_XDECREF(__pyx_t_2); - if (__pyx_m) { - if (__pyx_mstate->__pyx_d && stringtab_initialized) { - __Pyx_AddTraceback("init epanet.epanet2_ec", __pyx_clineno, __pyx_lineno, __pyx_filename); - } - #if !CYTHON_USE_MODULE_STATE - Py_CLEAR(__pyx_m); - #else - Py_DECREF(__pyx_m); - if (pystate_addmodule_run) { - PyObject *tp, *value, *tb; - PyErr_Fetch(&tp, &value, &tb); - PyState_RemoveModule(&__pyx_moduledef); - PyErr_Restore(tp, value, tb); - } - #endif - } else if (!PyErr_Occurred()) { - PyErr_SetString(PyExc_ImportError, "init epanet.epanet2_ec"); - } - __pyx_L0:; - __Pyx_RefNannyFinishContext(); - #if CYTHON_PEP489_MULTI_PHASE_INIT - return (__pyx_m != NULL) ? 0 : -1; - #else - return __pyx_m; - #endif -} -/* #### Code section: pystring_table ### */ - -typedef struct { - const char *s; -#if 61 <= 65535 - const unsigned short n; -#elif 61 / 2 < INT_MAX - const unsigned int n; -#elif 61 / 2 < LONG_MAX - const unsigned long n; -#else - const Py_ssize_t n; -#endif -#if 1 <= 31 - const unsigned int encoding : 5; -#elif 1 <= 255 - const unsigned char encoding; -#elif 1 <= 65535 - const unsigned short encoding; -#else - const Py_ssize_t encoding; -#endif - const unsigned int is_unicode : 1; - const unsigned int intern : 1; -} __Pyx_StringTabEntry; -static const char * const __pyx_string_tab_encodings[] = { 0 }; -static const __Pyx_StringTabEntry __pyx_string_tab[] = { - {__pyx_k_, sizeof(__pyx_k_), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_ */ - {__pyx_k_0, sizeof(__pyx_k_0), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_0 */ - {__pyx_k_10, sizeof(__pyx_k_10), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_10 */ - {__pyx_k_101, sizeof(__pyx_k_101), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_101 */ - {__pyx_k_102, sizeof(__pyx_k_102), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_102 */ - {__pyx_k_103, sizeof(__pyx_k_103), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_103 */ - {__pyx_k_104, sizeof(__pyx_k_104), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_104 */ - {__pyx_k_105, sizeof(__pyx_k_105), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_105 */ - {__pyx_k_106, sizeof(__pyx_k_106), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_106 */ - {__pyx_k_107, sizeof(__pyx_k_107), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_107 */ - {__pyx_k_108, sizeof(__pyx_k_108), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_108 */ - {__pyx_k_110, sizeof(__pyx_k_110), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_110 */ - {__pyx_k_120, sizeof(__pyx_k_120), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_120 */ - {__pyx_k_200, sizeof(__pyx_k_200), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_200 */ - {__pyx_k_201, sizeof(__pyx_k_201), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_201 */ - {__pyx_k_202, sizeof(__pyx_k_202), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_202 */ - {__pyx_k_203, sizeof(__pyx_k_203), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_203 */ - {__pyx_k_204, sizeof(__pyx_k_204), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_204 */ - {__pyx_k_205, sizeof(__pyx_k_205), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_205 */ - {__pyx_k_206, sizeof(__pyx_k_206), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_206 */ - {__pyx_k_207, sizeof(__pyx_k_207), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_207 */ - {__pyx_k_208, sizeof(__pyx_k_208), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_208 */ - {__pyx_k_209, sizeof(__pyx_k_209), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_209 */ - {__pyx_k_211, sizeof(__pyx_k_211), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_211 */ - {__pyx_k_212, sizeof(__pyx_k_212), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_212 */ - {__pyx_k_213, sizeof(__pyx_k_213), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_213 */ - {__pyx_k_214, sizeof(__pyx_k_214), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_214 */ - {__pyx_k_215, sizeof(__pyx_k_215), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_215 */ - {__pyx_k_216, sizeof(__pyx_k_216), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_216 */ - {__pyx_k_217, sizeof(__pyx_k_217), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_217 */ - {__pyx_k_219, sizeof(__pyx_k_219), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_219 */ - {__pyx_k_220, sizeof(__pyx_k_220), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_220 */ - {__pyx_k_221, sizeof(__pyx_k_221), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_221 */ - {__pyx_k_222, sizeof(__pyx_k_222), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_222 */ - {__pyx_k_223, sizeof(__pyx_k_223), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_223 */ - {__pyx_k_224, sizeof(__pyx_k_224), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_224 */ - {__pyx_k_225, sizeof(__pyx_k_225), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_225 */ - {__pyx_k_226, sizeof(__pyx_k_226), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_226 */ - {__pyx_k_227, sizeof(__pyx_k_227), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_227 */ - {__pyx_k_230, sizeof(__pyx_k_230), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_230 */ - {__pyx_k_233, sizeof(__pyx_k_233), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_233 */ - {__pyx_k_234, sizeof(__pyx_k_234), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_234 */ - {__pyx_k_240, sizeof(__pyx_k_240), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_240 */ - {__pyx_k_241, sizeof(__pyx_k_241), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_241 */ - {__pyx_k_250, sizeof(__pyx_k_250), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_250 */ - {__pyx_k_251, sizeof(__pyx_k_251), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_251 */ - {__pyx_k_252, sizeof(__pyx_k_252), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_252 */ - {__pyx_k_253, sizeof(__pyx_k_253), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_253 */ - {__pyx_k_254, sizeof(__pyx_k_254), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_254 */ - {__pyx_k_255, sizeof(__pyx_k_255), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_255 */ - {__pyx_k_257, sizeof(__pyx_k_257), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_257 */ - {__pyx_k_258, sizeof(__pyx_k_258), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_258 */ - {__pyx_k_259, sizeof(__pyx_k_259), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_259 */ - {__pyx_k_260, sizeof(__pyx_k_260), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_260 */ - {__pyx_k_261, sizeof(__pyx_k_261), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_261 */ - {__pyx_k_262, sizeof(__pyx_k_262), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_262 */ - {__pyx_k_263, sizeof(__pyx_k_263), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_263 */ - {__pyx_k_301, sizeof(__pyx_k_301), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_301 */ - {__pyx_k_302, sizeof(__pyx_k_302), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_302 */ - {__pyx_k_303, sizeof(__pyx_k_303), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_303 */ - {__pyx_k_304, sizeof(__pyx_k_304), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_304 */ - {__pyx_k_305, sizeof(__pyx_k_305), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_305 */ - {__pyx_k_306, sizeof(__pyx_k_306), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_306 */ - {__pyx_k_307, sizeof(__pyx_k_307), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_307 */ - {__pyx_k_308, sizeof(__pyx_k_308), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_308 */ - {__pyx_k_309, sizeof(__pyx_k_309), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_309 */ - {__pyx_k_411, sizeof(__pyx_k_411), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_411 */ - {__pyx_k_412, sizeof(__pyx_k_412), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_412 */ - {__pyx_k_421, sizeof(__pyx_k_421), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_421 */ - {__pyx_k_422, sizeof(__pyx_k_422), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_422 */ - {__pyx_k_423, sizeof(__pyx_k_423), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_423 */ - {__pyx_k_434, sizeof(__pyx_k_434), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_434 */ - {__pyx_k_435, sizeof(__pyx_k_435), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_435 */ - {__pyx_k_436, sizeof(__pyx_k_436), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_436 */ - {__pyx_k_ERR, sizeof(__pyx_k_ERR), 0, 1, 1}, /* PyObject cname: __pyx_n_u_ERR */ - {__pyx_k_ERROR_CODE, sizeof(__pyx_k_ERROR_CODE), 0, 1, 1}, /* PyObject cname: __pyx_n_u_ERROR_CODE */ - {__pyx_k_Error_An_unknown_error_has_occur, sizeof(__pyx_k_Error_An_unknown_error_has_occur), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_Error_An_unknown_error_has_occur */ - {__pyx_k_File_Error_434_unable_to_open_bi, sizeof(__pyx_k_File_Error_434_unable_to_open_bi), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_File_Error_434_unable_to_open_bi */ - {__pyx_k_File_Error_435_invalid_binary_fi, sizeof(__pyx_k_File_Error_435_invalid_binary_fi), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_File_Error_435_invalid_binary_fi */ - {__pyx_k_File_Error_436_no_results_in_bin, sizeof(__pyx_k_File_Error_436_no_results_in_bin), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_File_Error_436_no_results_in_bin */ - {__pyx_k_Input_Error_411_no_memory_alloca, sizeof(__pyx_k_Input_Error_411_no_memory_alloca), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_Input_Error_411_no_memory_alloca */ - {__pyx_k_Input_Error_412_binary_file_hasn, sizeof(__pyx_k_Input_Error_412_binary_file_hasn), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_Input_Error_412_binary_file_hasn */ - {__pyx_k_Input_Error_421_invalid_paramete, sizeof(__pyx_k_Input_Error_421_invalid_paramete), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_Input_Error_421_invalid_paramete */ - {__pyx_k_Input_Error_422_reporting_period, sizeof(__pyx_k_Input_Error_422_reporting_period), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_Input_Error_422_reporting_period */ - {__pyx_k_Input_Error_423_element_index_ou, sizeof(__pyx_k_Input_Error_423_element_index_ou), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_Input_Error_423_element_index_ou */ - {__pyx_k_Warning_model_run_issued_warning, sizeof(__pyx_k_Warning_model_run_issued_warning), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_Warning_model_run_issued_warning */ - {__pyx_k_attempt_to_control_CV_GPV_link, sizeof(__pyx_k_attempt_to_control_CV_GPV_link), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_attempt_to_control_CV_GPV_link */ - {__pyx_k_attempt_to_delete_a_node_or_link, sizeof(__pyx_k_attempt_to_delete_a_node_or_link), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_attempt_to_delete_a_node_or_link */ - {__pyx_k_attempt_to_delete_a_node_that_st, sizeof(__pyx_k_attempt_to_delete_a_node_that_st), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_attempt_to_delete_a_node_that_st */ - {__pyx_k_attempt_to_delete_node_assigned, sizeof(__pyx_k_attempt_to_delete_node_assigned), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_attempt_to_delete_node_assigned */ - {__pyx_k_attempt_to_modify_network_struct, sizeof(__pyx_k_attempt_to_modify_network_struct), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_attempt_to_modify_network_struct */ - {__pyx_k_cannot_open_binary_output_file, sizeof(__pyx_k_cannot_open_binary_output_file), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_cannot_open_binary_output_file */ - {__pyx_k_cannot_open_hydraulics_file, sizeof(__pyx_k_cannot_open_hydraulics_file), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_cannot_open_hydraulics_file */ - {__pyx_k_cannot_open_input_file, sizeof(__pyx_k_cannot_open_input_file), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_cannot_open_input_file */ - {__pyx_k_cannot_open_report_file, sizeof(__pyx_k_cannot_open_report_file), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_cannot_open_report_file */ - {__pyx_k_cannot_read_hydraulics_file, sizeof(__pyx_k_cannot_read_hydraulics_file), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_cannot_read_hydraulics_file */ - {__pyx_k_cannot_save_results_to_file, sizeof(__pyx_k_cannot_save_results_to_file), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_cannot_save_results_to_file */ - {__pyx_k_cannot_save_results_to_report_fi, sizeof(__pyx_k_cannot_save_results_to_report_fi), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_cannot_save_results_to_report_fi */ - {__pyx_k_cannot_solve_network_hydraulic_e, sizeof(__pyx_k_cannot_solve_network_hydraulic_e), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_cannot_solve_network_hydraulic_e */ - {__pyx_k_cannot_solve_water_quality_trans, sizeof(__pyx_k_cannot_solve_water_quality_trans), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_cannot_solve_water_quality_trans */ - {__pyx_k_cannot_use_external_file_while_h, sizeof(__pyx_k_cannot_use_external_file_while_h), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_cannot_use_external_file_while_h */ - {__pyx_k_cline_in_traceback, sizeof(__pyx_k_cline_in_traceback), 0, 1, 1}, /* PyObject cname: __pyx_n_u_cline_in_traceback */ - {__pyx_k_duplicate_ID_label, sizeof(__pyx_k_duplicate_ID_label), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_duplicate_ID_label */ - {__pyx_k_hydraulic_solver_not_opened, sizeof(__pyx_k_hydraulic_solver_not_opened), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_hydraulic_solver_not_opened */ - {__pyx_k_hydraulics_file_does_not_match_n, sizeof(__pyx_k_hydraulics_file_does_not_match_n), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_hydraulics_file_does_not_match_n */ - {__pyx_k_hydraulics_supplied_from_externa, sizeof(__pyx_k_hydraulics_supplied_from_externa), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_hydraulics_supplied_from_externa */ - {__pyx_k_identical_file_names, sizeof(__pyx_k_identical_file_names), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_identical_file_names */ - {__pyx_k_illegal_PDA_pressure_limits, sizeof(__pyx_k_illegal_PDA_pressure_limits), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_illegal_PDA_pressure_limits */ - {__pyx_k_illegal_link_property_value, sizeof(__pyx_k_illegal_link_property_value), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_illegal_link_property_value */ - {__pyx_k_illegal_node_property_value, sizeof(__pyx_k_illegal_node_property_value), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_illegal_node_property_value */ - {__pyx_k_illegal_numeric_value, sizeof(__pyx_k_illegal_numeric_value), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_illegal_numeric_value */ - {__pyx_k_illegal_valve_connection_to_anot, sizeof(__pyx_k_illegal_valve_connection_to_anot), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_illegal_valve_connection_to_anot */ - {__pyx_k_illegal_valve_connection_to_tank, sizeof(__pyx_k_illegal_valve_connection_to_tank), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_illegal_valve_connection_to_tank */ - {__pyx_k_insufficient_memory_available, sizeof(__pyx_k_insufficient_memory_available), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_insufficient_memory_available */ - {__pyx_k_invalid_ID_name, sizeof(__pyx_k_invalid_ID_name), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_invalid_ID_name */ - {__pyx_k_invalid_format, sizeof(__pyx_k_invalid_format), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_invalid_format */ - {__pyx_k_invalid_head_curve_for_pump, sizeof(__pyx_k_invalid_head_curve_for_pump), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_invalid_head_curve_for_pump */ - {__pyx_k_invalid_link_vertex, sizeof(__pyx_k_invalid_link_vertex), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_invalid_link_vertex */ - {__pyx_k_invalid_lower_upper_levels_for_t, sizeof(__pyx_k_invalid_lower_upper_levels_for_t), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_invalid_lower_upper_levels_for_t */ - {__pyx_k_invalid_option_value, sizeof(__pyx_k_invalid_option_value), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_invalid_option_value */ - {__pyx_k_invalid_parameter_code, sizeof(__pyx_k_invalid_parameter_code), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_invalid_parameter_code */ - {__pyx_k_invalid_pump_energy_data, sizeof(__pyx_k_invalid_pump_energy_data), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_invalid_pump_energy_data */ - {__pyx_k_main, sizeof(__pyx_k_main), 0, 1, 1}, /* PyObject cname: __pyx_n_u_main */ - {__pyx_k_mis_placed_rule_clause_in_rule_b, sizeof(__pyx_k_mis_placed_rule_clause_in_rule_b), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_mis_placed_rule_clause_in_rule_b */ - {__pyx_k_module, sizeof(__pyx_k_module), 0, 1, 1}, /* PyObject cname: __pyx_n_u_module */ - {__pyx_k_name, sizeof(__pyx_k_name), 0, 1, 1}, /* PyObject cname: __pyx_n_u_name */ - {__pyx_k_network_has_an_unconnected_node, sizeof(__pyx_k_network_has_an_unconnected_node), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_network_has_an_unconnected_node */ - {__pyx_k_network_has_unconnected_nodes, sizeof(__pyx_k_network_has_unconnected_nodes), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_network_has_unconnected_nodes */ - {__pyx_k_no_head_curve_or_power_rating_fo, sizeof(__pyx_k_no_head_curve_or_power_rating_fo), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_no_head_curve_or_power_rating_fo */ - {__pyx_k_no_hydraulics_for_water_quality, sizeof(__pyx_k_no_hydraulics_for_water_quality), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_no_hydraulics_for_water_quality */ - {__pyx_k_no_network_data_available, sizeof(__pyx_k_no_network_data_available), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_no_network_data_available */ - {__pyx_k_no_results_saved_to_report_on, sizeof(__pyx_k_no_results_saved_to_report_on), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_no_results_saved_to_report_on */ - {__pyx_k_no_tanks_or_reservoirs_in_networ, sizeof(__pyx_k_no_tanks_or_reservoirs_in_networ), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_no_tanks_or_reservoirs_in_networ */ - {__pyx_k_node_is_not_a_tank, sizeof(__pyx_k_node_is_not_a_tank), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_node_is_not_a_tank */ - {__pyx_k_node_with_no_coordinates, sizeof(__pyx_k_node_with_no_coordinates), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_node_with_no_coordinates */ - {__pyx_k_nonexistent_control, sizeof(__pyx_k_nonexistent_control), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_nonexistent_control */ - {__pyx_k_nonexistent_demand_category, sizeof(__pyx_k_nonexistent_demand_category), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_nonexistent_demand_category */ - {__pyx_k_nonexistent_rule, sizeof(__pyx_k_nonexistent_rule), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_nonexistent_rule */ - {__pyx_k_nonexistent_rule_clause, sizeof(__pyx_k_nonexistent_rule_clause), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_nonexistent_rule_clause */ - {__pyx_k_nonexistent_source, sizeof(__pyx_k_nonexistent_source), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_nonexistent_source */ - {__pyx_k_nonincreasing_x_values_for_curve, sizeof(__pyx_k_nonincreasing_x_values_for_curve), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_nonincreasing_x_values_for_curve */ - {__pyx_k_not_enough_nodes_in_network, sizeof(__pyx_k_not_enough_nodes_in_network), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_not_enough_nodes_in_network */ - {__pyx_k_ok, sizeof(__pyx_k_ok), 0, 1, 1}, /* PyObject cname: __pyx_n_u_ok */ - {__pyx_k_one_or_more_errors_in_input_file, sizeof(__pyx_k_one_or_more_errors_in_input_file), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_one_or_more_errors_in_input_file */ - {__pyx_k_qualname, sizeof(__pyx_k_qualname), 0, 1, 1}, /* PyObject cname: __pyx_n_u_qualname */ - {__pyx_k_reference_to_undefined_pump, sizeof(__pyx_k_reference_to_undefined_pump), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_reference_to_undefined_pump */ - {__pyx_k_same_start_and_end_nodes_for_lin, sizeof(__pyx_k_same_start_and_end_nodes_for_lin), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_same_start_and_end_nodes_for_lin */ - {__pyx_k_syntax_error, sizeof(__pyx_k_syntax_error), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_syntax_error */ - {__pyx_k_test, sizeof(__pyx_k_test), 0, 1, 1}, /* PyObject cname: __pyx_n_u_test */ - {__pyx_k_too_many_characters_in_input_lin, sizeof(__pyx_k_too_many_characters_in_input_lin), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_too_many_characters_in_input_lin */ - {__pyx_k_undefined_curve, sizeof(__pyx_k_undefined_curve), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_undefined_curve */ - {__pyx_k_undefined_link, sizeof(__pyx_k_undefined_link), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_undefined_link */ - {__pyx_k_undefined_node, sizeof(__pyx_k_undefined_node), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_undefined_node */ - {__pyx_k_undefined_time_pattern, sizeof(__pyx_k_undefined_time_pattern), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_undefined_time_pattern */ - {__pyx_k_undefined_trace_node, sizeof(__pyx_k_undefined_trace_node), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_undefined_trace_node */ - {__pyx_k_water_quality_solver_not_opened, sizeof(__pyx_k_water_quality_solver_not_opened), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_water_quality_solver_not_opened */ - {0, 0, 0, 0, 0} -}; -/* InitStrings.proto */ -static int __Pyx_InitStrings(__Pyx_StringTabEntry const *t, PyObject **target, const char* const* encoding_names); - -/* #### Code section: cached_builtins ### */ - -static int __Pyx_InitCachedBuiltins(__pyx_mstatetype *__pyx_mstate) { - CYTHON_UNUSED_VAR(__pyx_mstate); - return 0; -} -/* #### Code section: cached_constants ### */ - -static int __Pyx_InitCachedConstants(__pyx_mstatetype *__pyx_mstate) { - __Pyx_RefNannyDeclarations - CYTHON_UNUSED_VAR(__pyx_mstate); - __Pyx_RefNannySetupContext("__Pyx_InitCachedConstants", 0); - __Pyx_RefNannyFinishContext(); - return 0; -} -/* #### Code section: init_constants ### */ - -static int __Pyx_InitConstants(__pyx_mstatetype *__pyx_mstate) { - CYTHON_UNUSED_VAR(__pyx_mstate); - if (__Pyx_InitStrings(__pyx_string_tab, __pyx_mstate->__pyx_string_tab, __pyx_string_tab_encodings) < 0) __PYX_ERR(0, 1, __pyx_L1_error); - return 0; - __pyx_L1_error:; - return -1; -} -/* #### Code section: init_codeobjects ### */ - -static int __Pyx_CreateCodeObjects(__pyx_mstatetype *__pyx_mstate) { - CYTHON_UNUSED_VAR(__pyx_mstate); - return 0; -} -/* #### Code section: init_globals ### */ - -static int __Pyx_InitGlobals(void) { - /* PythonCompatibility.init */ - if (likely(__Pyx_init_co_variables() == 0)); else - -if (unlikely(PyErr_Occurred())) __PYX_ERR(0, 1, __pyx_L1_error) - - return 0; - __pyx_L1_error:; - return -1; -} -/* #### Code section: cleanup_globals ### */ -/* #### Code section: cleanup_module ### */ -/* #### Code section: main_method ### */ -/* #### Code section: utility_code_pragmas ### */ -#ifdef _MSC_VER -#pragma warning( push ) -/* Warning 4127: conditional expression is constant - * Cython uses constant conditional expressions to allow in inline functions to be optimized at - * compile-time, so this warning is not useful - */ -#pragma warning( disable : 4127 ) -#endif - - - -/* #### Code section: utility_code_def ### */ - -/* --- Runtime support code --- */ -/* Refnanny */ -#if CYTHON_REFNANNY -static __Pyx_RefNannyAPIStruct *__Pyx_RefNannyImportAPI(const char *modname) { - PyObject *m = NULL, *p = NULL; - void *r = NULL; - m = PyImport_ImportModule(modname); - if (!m) goto end; - p = PyObject_GetAttrString(m, "RefNannyAPI"); - if (!p) goto end; - r = PyLong_AsVoidPtr(p); -end: - Py_XDECREF(p); - Py_XDECREF(m); - return (__Pyx_RefNannyAPIStruct *)r; -} -#endif - -/* PyErrExceptionMatches */ -#if CYTHON_FAST_THREAD_STATE -static int __Pyx_PyErr_ExceptionMatchesTuple(PyObject *exc_type, PyObject *tuple) { - Py_ssize_t i, n; - n = PyTuple_GET_SIZE(tuple); - for (i=0; i= 0x030C00A6 - PyObject *current_exception = tstate->current_exception; - if (unlikely(!current_exception)) return 0; - exc_type = (PyObject*) Py_TYPE(current_exception); - if (exc_type == err) return 1; -#else - exc_type = tstate->curexc_type; - if (exc_type == err) return 1; - if (unlikely(!exc_type)) return 0; -#endif - #if CYTHON_AVOID_BORROWED_REFS - Py_INCREF(exc_type); - #endif - if (unlikely(PyTuple_Check(err))) { - result = __Pyx_PyErr_ExceptionMatchesTuple(exc_type, err); - } else { - result = __Pyx_PyErr_GivenExceptionMatches(exc_type, err); - } - #if CYTHON_AVOID_BORROWED_REFS - Py_DECREF(exc_type); - #endif - return result; -} -#endif - -/* PyErrFetchRestore */ -#if CYTHON_FAST_THREAD_STATE -static CYTHON_INLINE void __Pyx_ErrRestoreInState(PyThreadState *tstate, PyObject *type, PyObject *value, PyObject *tb) { -#if PY_VERSION_HEX >= 0x030C00A6 - PyObject *tmp_value; - assert(type == NULL || (value != NULL && type == (PyObject*) Py_TYPE(value))); - if (value) { - #if CYTHON_COMPILING_IN_CPYTHON - if (unlikely(((PyBaseExceptionObject*) value)->traceback != tb)) - #endif - PyException_SetTraceback(value, tb); - } - tmp_value = tstate->current_exception; - tstate->current_exception = value; - Py_XDECREF(tmp_value); - Py_XDECREF(type); - Py_XDECREF(tb); -#else - PyObject *tmp_type, *tmp_value, *tmp_tb; - tmp_type = tstate->curexc_type; - tmp_value = tstate->curexc_value; - tmp_tb = tstate->curexc_traceback; - tstate->curexc_type = type; - tstate->curexc_value = value; - tstate->curexc_traceback = tb; - Py_XDECREF(tmp_type); - Py_XDECREF(tmp_value); - Py_XDECREF(tmp_tb); -#endif -} -static CYTHON_INLINE void __Pyx_ErrFetchInState(PyThreadState *tstate, PyObject **type, PyObject **value, PyObject **tb) { -#if PY_VERSION_HEX >= 0x030C00A6 - PyObject* exc_value; - exc_value = tstate->current_exception; - tstate->current_exception = 0; - *value = exc_value; - *type = NULL; - *tb = NULL; - if (exc_value) { - *type = (PyObject*) Py_TYPE(exc_value); - Py_INCREF(*type); - #if CYTHON_COMPILING_IN_CPYTHON - *tb = ((PyBaseExceptionObject*) exc_value)->traceback; - Py_XINCREF(*tb); - #else - *tb = PyException_GetTraceback(exc_value); - #endif - } -#else - *type = tstate->curexc_type; - *value = tstate->curexc_value; - *tb = tstate->curexc_traceback; - tstate->curexc_type = 0; - tstate->curexc_value = 0; - tstate->curexc_traceback = 0; -#endif -} -#endif - -/* PyObjectGetAttrStr */ -#if CYTHON_USE_TYPE_SLOTS -static CYTHON_INLINE PyObject* __Pyx_PyObject_GetAttrStr(PyObject* obj, PyObject* attr_name) { - PyTypeObject* tp = Py_TYPE(obj); - if (likely(tp->tp_getattro)) - return tp->tp_getattro(obj, attr_name); - return PyObject_GetAttr(obj, attr_name); -} -#endif - -/* PyObjectGetAttrStrNoError */ -#if __PYX_LIMITED_VERSION_HEX < 0x030d0000 -static void __Pyx_PyObject_GetAttrStr_ClearAttributeError(void) { - __Pyx_PyThreadState_declare - __Pyx_PyThreadState_assign - if (likely(__Pyx_PyErr_ExceptionMatches(PyExc_AttributeError))) - __Pyx_PyErr_Clear(); -} -#endif -static CYTHON_INLINE PyObject* __Pyx_PyObject_GetAttrStrNoError(PyObject* obj, PyObject* attr_name) { - PyObject *result; -#if __PYX_LIMITED_VERSION_HEX >= 0x030d0000 - (void) PyObject_GetOptionalAttr(obj, attr_name, &result); - return result; -#else -#if CYTHON_COMPILING_IN_CPYTHON && CYTHON_USE_TYPE_SLOTS - PyTypeObject* tp = Py_TYPE(obj); - if (likely(tp->tp_getattro == PyObject_GenericGetAttr)) { - return _PyObject_GenericGetAttrWithDict(obj, attr_name, NULL, 1); - } -#endif - result = __Pyx_PyObject_GetAttrStr(obj, attr_name); - if (unlikely(!result)) { - __Pyx_PyObject_GetAttrStr_ClearAttributeError(); - } - return result; -#endif -} - -/* GetBuiltinName */ -static PyObject *__Pyx_GetBuiltinName(PyObject *name) { - PyObject* result = __Pyx_PyObject_GetAttrStrNoError(__pyx_mstate_global->__pyx_b, name); - if (unlikely(!result) && !PyErr_Occurred()) { - PyErr_Format(PyExc_NameError, - "name '%U' is not defined", name); - } - return result; -} - -/* PyDictVersioning */ -#if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_TYPE_SLOTS -static CYTHON_INLINE PY_UINT64_T __Pyx_get_tp_dict_version(PyObject *obj) { - PyObject *dict = Py_TYPE(obj)->tp_dict; - return likely(dict) ? __PYX_GET_DICT_VERSION(dict) : 0; -} -static CYTHON_INLINE PY_UINT64_T __Pyx_get_object_dict_version(PyObject *obj) { - PyObject **dictptr = NULL; - Py_ssize_t offset = Py_TYPE(obj)->tp_dictoffset; - if (offset) { -#if CYTHON_COMPILING_IN_CPYTHON - dictptr = (likely(offset > 0)) ? (PyObject **) ((char *)obj + offset) : _PyObject_GetDictPtr(obj); -#else - dictptr = _PyObject_GetDictPtr(obj); -#endif - } - return (dictptr && *dictptr) ? __PYX_GET_DICT_VERSION(*dictptr) : 0; -} -static CYTHON_INLINE int __Pyx_object_dict_version_matches(PyObject* obj, PY_UINT64_T tp_dict_version, PY_UINT64_T obj_dict_version) { - PyObject *dict = Py_TYPE(obj)->tp_dict; - if (unlikely(!dict) || unlikely(tp_dict_version != __PYX_GET_DICT_VERSION(dict))) - return 0; - return obj_dict_version == __Pyx_get_object_dict_version(obj); -} -#endif - -/* GetModuleGlobalName */ -#if CYTHON_USE_DICT_VERSIONS -static PyObject *__Pyx__GetModuleGlobalName(PyObject *name, PY_UINT64_T *dict_version, PyObject **dict_cached_value) -#else -static CYTHON_INLINE PyObject *__Pyx__GetModuleGlobalName(PyObject *name) -#endif -{ - PyObject *result; -#if CYTHON_COMPILING_IN_LIMITED_API - if (unlikely(!__pyx_m)) { - if (!PyErr_Occurred()) - PyErr_SetNone(PyExc_NameError); - return NULL; - } - result = PyObject_GetAttr(__pyx_m, name); - if (likely(result)) { - return result; - } - PyErr_Clear(); -#elif CYTHON_AVOID_BORROWED_REFS || CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS - if (unlikely(__Pyx_PyDict_GetItemRef(__pyx_mstate_global->__pyx_d, name, &result) == -1)) PyErr_Clear(); - __PYX_UPDATE_DICT_CACHE(__pyx_mstate_global->__pyx_d, result, *dict_cached_value, *dict_version) - if (likely(result)) { - return result; - } -#else - result = _PyDict_GetItem_KnownHash(__pyx_mstate_global->__pyx_d, name, ((PyASCIIObject *) name)->hash); - __PYX_UPDATE_DICT_CACHE(__pyx_mstate_global->__pyx_d, result, *dict_cached_value, *dict_version) - if (likely(result)) { - return __Pyx_NewRef(result); - } - PyErr_Clear(); -#endif - return __Pyx_GetBuiltinName(name); -} - -/* CLineInTraceback */ -#if CYTHON_CLINE_IN_TRACEBACK && CYTHON_CLINE_IN_TRACEBACK_RUNTIME -static int __Pyx_CLineForTraceback(PyThreadState *tstate, int c_line) { - PyObject *use_cline; - PyObject *ptype, *pvalue, *ptraceback; -#if CYTHON_COMPILING_IN_CPYTHON - PyObject **cython_runtime_dict; -#endif - CYTHON_MAYBE_UNUSED_VAR(tstate); - if (unlikely(!__pyx_mstate_global->__pyx_cython_runtime)) { - return c_line; - } - __Pyx_ErrFetchInState(tstate, &ptype, &pvalue, &ptraceback); -#if CYTHON_COMPILING_IN_CPYTHON - cython_runtime_dict = _PyObject_GetDictPtr(__pyx_mstate_global->__pyx_cython_runtime); - if (likely(cython_runtime_dict)) { - __Pyx_BEGIN_CRITICAL_SECTION(*cython_runtime_dict); - __PYX_PY_DICT_LOOKUP_IF_MODIFIED( - use_cline, *cython_runtime_dict, - __Pyx_PyDict_GetItemStr(*cython_runtime_dict, __pyx_mstate_global->__pyx_n_u_cline_in_traceback)) - Py_XINCREF(use_cline); - __Pyx_END_CRITICAL_SECTION(); - } else -#endif - { - PyObject *use_cline_obj = __Pyx_PyObject_GetAttrStrNoError(__pyx_mstate_global->__pyx_cython_runtime, __pyx_mstate_global->__pyx_n_u_cline_in_traceback); - if (use_cline_obj) { - use_cline = PyObject_Not(use_cline_obj) ? Py_False : Py_True; - Py_INCREF(use_cline); - Py_DECREF(use_cline_obj); - } else { - PyErr_Clear(); - use_cline = NULL; - } - } - if (!use_cline) { - c_line = 0; - (void) PyObject_SetAttr(__pyx_mstate_global->__pyx_cython_runtime, __pyx_mstate_global->__pyx_n_u_cline_in_traceback, Py_False); - } - else if (use_cline == Py_False || (use_cline != Py_True && PyObject_Not(use_cline) != 0)) { - c_line = 0; - } - Py_XDECREF(use_cline); - __Pyx_ErrRestoreInState(tstate, ptype, pvalue, ptraceback); - return c_line; -} -#endif - -/* CodeObjectCache */ -static int __pyx_bisect_code_objects(__Pyx_CodeObjectCacheEntry* entries, int count, int code_line) { - int start = 0, mid = 0, end = count - 1; - if (end >= 0 && code_line > entries[end].code_line) { - return count; - } - while (start < end) { - mid = start + (end - start) / 2; - if (code_line < entries[mid].code_line) { - end = mid; - } else if (code_line > entries[mid].code_line) { - start = mid + 1; - } else { - return mid; - } - } - if (code_line <= entries[mid].code_line) { - return mid; - } else { - return mid + 1; - } -} -static __Pyx_CachedCodeObjectType *__pyx__find_code_object(struct __Pyx_CodeObjectCache *code_cache, int code_line) { - __Pyx_CachedCodeObjectType* code_object; - int pos; - if (unlikely(!code_line) || unlikely(!code_cache->entries)) { - return NULL; - } - pos = __pyx_bisect_code_objects(code_cache->entries, code_cache->count, code_line); - if (unlikely(pos >= code_cache->count) || unlikely(code_cache->entries[pos].code_line != code_line)) { - return NULL; - } - code_object = code_cache->entries[pos].code_object; - Py_INCREF(code_object); - return code_object; -} -static __Pyx_CachedCodeObjectType *__pyx_find_code_object(int code_line) { -#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING && !CYTHON_ATOMICS - (void)__pyx__find_code_object; - return NULL; // Most implementation should have atomics. But otherwise, don't make it thread-safe, just miss. -#else - struct __Pyx_CodeObjectCache *code_cache = &__pyx_mstate_global->__pyx_code_cache; -#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - __pyx_nonatomic_int_type old_count = __pyx_atomic_incr_acq_rel(&code_cache->accessor_count); - if (old_count < 0) { - __pyx_atomic_decr_acq_rel(&code_cache->accessor_count); - return NULL; - } -#endif - __Pyx_CachedCodeObjectType *result = __pyx__find_code_object(code_cache, code_line); -#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - __pyx_atomic_decr_acq_rel(&code_cache->accessor_count); -#endif - return result; -#endif -} -static void __pyx__insert_code_object(struct __Pyx_CodeObjectCache *code_cache, int code_line, __Pyx_CachedCodeObjectType* code_object) -{ - int pos, i; - __Pyx_CodeObjectCacheEntry* entries = code_cache->entries; - if (unlikely(!code_line)) { - return; - } - if (unlikely(!entries)) { - entries = (__Pyx_CodeObjectCacheEntry*)PyMem_Malloc(64*sizeof(__Pyx_CodeObjectCacheEntry)); - if (likely(entries)) { - code_cache->entries = entries; - code_cache->max_count = 64; - code_cache->count = 1; - entries[0].code_line = code_line; - entries[0].code_object = code_object; - Py_INCREF(code_object); - } - return; - } - pos = __pyx_bisect_code_objects(code_cache->entries, code_cache->count, code_line); - if ((pos < code_cache->count) && unlikely(code_cache->entries[pos].code_line == code_line)) { - __Pyx_CachedCodeObjectType* tmp = entries[pos].code_object; - entries[pos].code_object = code_object; - Py_INCREF(code_object); - Py_DECREF(tmp); - return; - } - if (code_cache->count == code_cache->max_count) { - int new_max = code_cache->max_count + 64; - entries = (__Pyx_CodeObjectCacheEntry*)PyMem_Realloc( - code_cache->entries, ((size_t)new_max) * sizeof(__Pyx_CodeObjectCacheEntry)); - if (unlikely(!entries)) { - return; - } - code_cache->entries = entries; - code_cache->max_count = new_max; - } - for (i=code_cache->count; i>pos; i--) { - entries[i] = entries[i-1]; - } - entries[pos].code_line = code_line; - entries[pos].code_object = code_object; - code_cache->count++; - Py_INCREF(code_object); -} -static void __pyx_insert_code_object(int code_line, __Pyx_CachedCodeObjectType* code_object) { -#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING && !CYTHON_ATOMICS - (void)__pyx__insert_code_object; - return; // Most implementation should have atomics. But otherwise, don't make it thread-safe, just fail. -#else - struct __Pyx_CodeObjectCache *code_cache = &__pyx_mstate_global->__pyx_code_cache; -#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - __pyx_nonatomic_int_type expected = 0; - if (!__pyx_atomic_int_cmp_exchange(&code_cache->accessor_count, &expected, INT_MIN)) { - return; - } -#endif - __pyx__insert_code_object(code_cache, code_line, code_object); -#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING - __pyx_atomic_sub(&code_cache->accessor_count, INT_MIN); -#endif -#endif -} - -/* AddTraceback */ -#include "compile.h" -#include "frameobject.h" -#include "traceback.h" -#if PY_VERSION_HEX >= 0x030b00a6 && !CYTHON_COMPILING_IN_LIMITED_API && !defined(PYPY_VERSION) - #ifndef Py_BUILD_CORE - #define Py_BUILD_CORE 1 - #endif - #include "internal/pycore_frame.h" -#endif -#if CYTHON_COMPILING_IN_LIMITED_API -static PyObject *__Pyx_PyCode_Replace_For_AddTraceback(PyObject *code, PyObject *scratch_dict, - PyObject *firstlineno, PyObject *name) { - PyObject *replace = NULL; - if (unlikely(PyDict_SetItemString(scratch_dict, "co_firstlineno", firstlineno))) return NULL; - if (unlikely(PyDict_SetItemString(scratch_dict, "co_name", name))) return NULL; - replace = PyObject_GetAttrString(code, "replace"); - if (likely(replace)) { - PyObject *result = PyObject_Call(replace, __pyx_mstate_global->__pyx_empty_tuple, scratch_dict); - Py_DECREF(replace); - return result; - } - PyErr_Clear(); - return NULL; -} -static void __Pyx_AddTraceback(const char *funcname, int c_line, - int py_line, const char *filename) { - PyObject *code_object = NULL, *py_py_line = NULL, *py_funcname = NULL, *dict = NULL; - PyObject *replace = NULL, *getframe = NULL, *frame = NULL; - PyObject *exc_type, *exc_value, *exc_traceback; - int success = 0; - if (c_line) { - (void) __pyx_cfilenm; - (void) __Pyx_CLineForTraceback(__Pyx_PyThreadState_Current, c_line); - } - PyErr_Fetch(&exc_type, &exc_value, &exc_traceback); - code_object = __pyx_find_code_object(c_line ? -c_line : py_line); - if (!code_object) { - code_object = Py_CompileString("_getframe()", filename, Py_eval_input); - if (unlikely(!code_object)) goto bad; - py_py_line = PyLong_FromLong(py_line); - if (unlikely(!py_py_line)) goto bad; - py_funcname = PyUnicode_FromString(funcname); - if (unlikely(!py_funcname)) goto bad; - dict = PyDict_New(); - if (unlikely(!dict)) goto bad; - { - PyObject *old_code_object = code_object; - code_object = __Pyx_PyCode_Replace_For_AddTraceback(code_object, dict, py_py_line, py_funcname); - Py_DECREF(old_code_object); - } - if (unlikely(!code_object)) goto bad; - __pyx_insert_code_object(c_line ? -c_line : py_line, code_object); - } else { - dict = PyDict_New(); - } - getframe = PySys_GetObject("_getframe"); - if (unlikely(!getframe)) goto bad; - if (unlikely(PyDict_SetItemString(dict, "_getframe", getframe))) goto bad; - frame = PyEval_EvalCode(code_object, dict, dict); - if (unlikely(!frame) || frame == Py_None) goto bad; - success = 1; - bad: - PyErr_Restore(exc_type, exc_value, exc_traceback); - Py_XDECREF(code_object); - Py_XDECREF(py_py_line); - Py_XDECREF(py_funcname); - Py_XDECREF(dict); - Py_XDECREF(replace); - if (success) { - PyTraceBack_Here( - (struct _frame*)frame); - } - Py_XDECREF(frame); -} -#else -static PyCodeObject* __Pyx_CreateCodeObjectForTraceback( - const char *funcname, int c_line, - int py_line, const char *filename) { - PyCodeObject *py_code = NULL; - PyObject *py_funcname = NULL; - if (c_line) { - py_funcname = PyUnicode_FromFormat( "%s (%s:%d)", funcname, __pyx_cfilenm, c_line); - if (!py_funcname) goto bad; - funcname = PyUnicode_AsUTF8(py_funcname); - if (!funcname) goto bad; - } - py_code = PyCode_NewEmpty(filename, funcname, py_line); - Py_XDECREF(py_funcname); - return py_code; -bad: - Py_XDECREF(py_funcname); - return NULL; -} -static void __Pyx_AddTraceback(const char *funcname, int c_line, - int py_line, const char *filename) { - PyCodeObject *py_code = 0; - PyFrameObject *py_frame = 0; - PyThreadState *tstate = __Pyx_PyThreadState_Current; - PyObject *ptype, *pvalue, *ptraceback; - if (c_line) { - c_line = __Pyx_CLineForTraceback(tstate, c_line); - } - py_code = __pyx_find_code_object(c_line ? -c_line : py_line); - if (!py_code) { - __Pyx_ErrFetchInState(tstate, &ptype, &pvalue, &ptraceback); - py_code = __Pyx_CreateCodeObjectForTraceback( - funcname, c_line, py_line, filename); - if (!py_code) { - /* If the code object creation fails, then we should clear the - fetched exception references and propagate the new exception */ - Py_XDECREF(ptype); - Py_XDECREF(pvalue); - Py_XDECREF(ptraceback); - goto bad; - } - __Pyx_ErrRestoreInState(tstate, ptype, pvalue, ptraceback); - __pyx_insert_code_object(c_line ? -c_line : py_line, py_code); - } - py_frame = PyFrame_New( - tstate, /*PyThreadState *tstate,*/ - py_code, /*PyCodeObject *code,*/ - __pyx_mstate_global->__pyx_d, /*PyObject *globals,*/ - 0 /*PyObject *locals*/ - ); - if (!py_frame) goto bad; - __Pyx_PyFrame_SetLineNumber(py_frame, py_line); - PyTraceBack_Here(py_frame); -bad: - Py_XDECREF(py_code); - Py_XDECREF(py_frame); -} -#endif - -/* FormatTypeName */ -#if CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX < 0x030d0000 -static __Pyx_TypeName -__Pyx_PyType_GetFullyQualifiedName(PyTypeObject* tp) -{ - PyObject *module = NULL, *name = NULL, *result = NULL; - #if __PYX_LIMITED_VERSION_HEX < 0x030b0000 - name = __Pyx_PyObject_GetAttrStr((PyObject *)tp, - __pyx_mstate_global->__pyx_n_u_qualname); - #else - name = PyType_GetQualName(tp); - #endif - if (unlikely(name == NULL) || unlikely(!PyUnicode_Check(name))) goto bad; - module = __Pyx_PyObject_GetAttrStr((PyObject *)tp, - __pyx_mstate_global->__pyx_n_u_module); - if (unlikely(module == NULL) || unlikely(!PyUnicode_Check(module))) goto bad; - if (PyUnicode_CompareWithASCIIString(module, "builtins") == 0) { - result = name; - name = NULL; - goto done; - } - result = PyUnicode_FromFormat("%U.%U", module, name); - if (unlikely(result == NULL)) goto bad; - done: - Py_XDECREF(name); - Py_XDECREF(module); - return result; - bad: - PyErr_Clear(); - if (name) { - result = name; - name = NULL; - } else { - result = __Pyx_NewRef(__pyx_mstate_global->__pyx_kp_u_); - } - goto done; -} -#endif - -/* PyFunctionFastCall */ -#if CYTHON_FAST_PYCALL && !CYTHON_VECTORCALL -static PyObject* __Pyx_PyFunction_FastCallNoKw(PyCodeObject *co, PyObject *const *args, Py_ssize_t na, - PyObject *globals) { - PyFrameObject *f; - PyThreadState *tstate = __Pyx_PyThreadState_Current; - PyObject **fastlocals; - Py_ssize_t i; - PyObject *result; - assert(globals != NULL); - /* XXX Perhaps we should create a specialized - PyFrame_New() that doesn't take locals, but does - take builtins without sanity checking them. - */ - assert(tstate != NULL); - f = PyFrame_New(tstate, co, globals, NULL); - if (f == NULL) { - return NULL; - } - fastlocals = __Pyx_PyFrame_GetLocalsplus(f); - for (i = 0; i < na; i++) { - Py_INCREF(*args); - fastlocals[i] = *args++; - } - result = PyEval_EvalFrameEx(f,0); - ++tstate->recursion_depth; - Py_DECREF(f); - --tstate->recursion_depth; - return result; -} -static PyObject *__Pyx_PyFunction_FastCallDict(PyObject *func, PyObject *const *args, Py_ssize_t nargs, PyObject *kwargs) { - PyCodeObject *co = (PyCodeObject *)PyFunction_GET_CODE(func); - PyObject *globals = PyFunction_GET_GLOBALS(func); - PyObject *argdefs = PyFunction_GET_DEFAULTS(func); - PyObject *closure; - PyObject *kwdefs; - PyObject *kwtuple, **k; - PyObject **d; - Py_ssize_t nd; - Py_ssize_t nk; - PyObject *result; - assert(kwargs == NULL || PyDict_Check(kwargs)); - nk = kwargs ? PyDict_Size(kwargs) : 0; - if (unlikely(Py_EnterRecursiveCall(" while calling a Python object"))) { - return NULL; - } - if ( - co->co_kwonlyargcount == 0 && - likely(kwargs == NULL || nk == 0) && - co->co_flags == (CO_OPTIMIZED | CO_NEWLOCALS | CO_NOFREE)) { - if (argdefs == NULL && co->co_argcount == nargs) { - result = __Pyx_PyFunction_FastCallNoKw(co, args, nargs, globals); - goto done; - } - else if (nargs == 0 && argdefs != NULL - && co->co_argcount == Py_SIZE(argdefs)) { - /* function called with no arguments, but all parameters have - a default value: use default values as arguments .*/ - args = &PyTuple_GET_ITEM(argdefs, 0); - result =__Pyx_PyFunction_FastCallNoKw(co, args, Py_SIZE(argdefs), globals); - goto done; - } - } - if (kwargs != NULL) { - Py_ssize_t pos, i; - kwtuple = PyTuple_New(2 * nk); - if (kwtuple == NULL) { - result = NULL; - goto done; - } - k = &PyTuple_GET_ITEM(kwtuple, 0); - pos = i = 0; - while (PyDict_Next(kwargs, &pos, &k[i], &k[i+1])) { - Py_INCREF(k[i]); - Py_INCREF(k[i+1]); - i += 2; - } - nk = i / 2; - } - else { - kwtuple = NULL; - k = NULL; - } - closure = PyFunction_GET_CLOSURE(func); - kwdefs = PyFunction_GET_KW_DEFAULTS(func); - if (argdefs != NULL) { - d = &PyTuple_GET_ITEM(argdefs, 0); - nd = Py_SIZE(argdefs); - } - else { - d = NULL; - nd = 0; - } - result = PyEval_EvalCodeEx((PyObject*)co, globals, (PyObject *)NULL, - args, (int)nargs, - k, (int)nk, - d, (int)nd, kwdefs, closure); - Py_XDECREF(kwtuple); -done: - Py_LeaveRecursiveCall(); - return result; -} -#endif - -/* PyObjectCall */ -#if CYTHON_COMPILING_IN_CPYTHON -static CYTHON_INLINE PyObject* __Pyx_PyObject_Call(PyObject *func, PyObject *arg, PyObject *kw) { - PyObject *result; - ternaryfunc call = Py_TYPE(func)->tp_call; - if (unlikely(!call)) - return PyObject_Call(func, arg, kw); - if (unlikely(Py_EnterRecursiveCall(" while calling a Python object"))) - return NULL; - result = (*call)(func, arg, kw); - Py_LeaveRecursiveCall(); - if (unlikely(!result) && unlikely(!PyErr_Occurred())) { - PyErr_SetString( - PyExc_SystemError, - "NULL result without error in PyObject_Call"); - } - return result; -} -#endif - -/* PyObjectCallMethO */ -#if CYTHON_COMPILING_IN_CPYTHON -static CYTHON_INLINE PyObject* __Pyx_PyObject_CallMethO(PyObject *func, PyObject *arg) { - PyObject *self, *result; - PyCFunction cfunc; - cfunc = __Pyx_CyOrPyCFunction_GET_FUNCTION(func); - self = __Pyx_CyOrPyCFunction_GET_SELF(func); - if (unlikely(Py_EnterRecursiveCall(" while calling a Python object"))) - return NULL; - result = cfunc(self, arg); - Py_LeaveRecursiveCall(); - if (unlikely(!result) && unlikely(!PyErr_Occurred())) { - PyErr_SetString( - PyExc_SystemError, - "NULL result without error in PyObject_Call"); - } - return result; -} -#endif - -/* PyObjectFastCall */ -#if PY_VERSION_HEX < 0x03090000 || CYTHON_COMPILING_IN_LIMITED_API -static PyObject* __Pyx_PyObject_FastCall_fallback(PyObject *func, PyObject * const*args, size_t nargs, PyObject *kwargs) { - PyObject *argstuple; - PyObject *result = 0; - size_t i; - argstuple = PyTuple_New((Py_ssize_t)nargs); - if (unlikely(!argstuple)) return NULL; - for (i = 0; i < nargs; i++) { - Py_INCREF(args[i]); - if (__Pyx_PyTuple_SET_ITEM(argstuple, (Py_ssize_t)i, args[i]) != (0)) goto bad; - } - result = __Pyx_PyObject_Call(func, argstuple, kwargs); - bad: - Py_DECREF(argstuple); - return result; -} -#endif -#if CYTHON_VECTORCALL && !CYTHON_COMPILING_IN_LIMITED_API - #if PY_VERSION_HEX < 0x03090000 - #define __Pyx_PyVectorcall_Function(callable) _PyVectorcall_Function(callable) - #elif CYTHON_COMPILING_IN_CPYTHON -static CYTHON_INLINE vectorcallfunc __Pyx_PyVectorcall_Function(PyObject *callable) { - PyTypeObject *tp = Py_TYPE(callable); - #if defined(__Pyx_CyFunction_USED) - if (__Pyx_CyFunction_CheckExact(callable)) { - return __Pyx_CyFunction_func_vectorcall(callable); - } - #endif - if (!PyType_HasFeature(tp, Py_TPFLAGS_HAVE_VECTORCALL)) { - return NULL; - } - assert(PyCallable_Check(callable)); - Py_ssize_t offset = tp->tp_vectorcall_offset; - assert(offset > 0); - vectorcallfunc ptr; - memcpy(&ptr, (char *) callable + offset, sizeof(ptr)); - return ptr; -} - #else - #define __Pyx_PyVectorcall_Function(callable) PyVectorcall_Function(callable) - #endif -#endif -static CYTHON_INLINE PyObject* __Pyx_PyObject_FastCallDict(PyObject *func, PyObject *const *args, size_t _nargs, PyObject *kwargs) { - Py_ssize_t nargs = __Pyx_PyVectorcall_NARGS(_nargs); -#if CYTHON_COMPILING_IN_CPYTHON - if (nargs == 0 && kwargs == NULL) { - if (__Pyx_CyOrPyCFunction_Check(func) && likely( __Pyx_CyOrPyCFunction_GET_FLAGS(func) & METH_NOARGS)) - return __Pyx_PyObject_CallMethO(func, NULL); - } - else if (nargs == 1 && kwargs == NULL) { - if (__Pyx_CyOrPyCFunction_Check(func) && likely( __Pyx_CyOrPyCFunction_GET_FLAGS(func) & METH_O)) - return __Pyx_PyObject_CallMethO(func, args[0]); - } -#endif - #if PY_VERSION_HEX < 0x030800B1 - #if CYTHON_FAST_PYCCALL - if (PyCFunction_Check(func)) { - if (kwargs) { - return _PyCFunction_FastCallDict(func, args, nargs, kwargs); - } else { - return _PyCFunction_FastCallKeywords(func, args, nargs, NULL); - } - } - if (!kwargs && __Pyx_IS_TYPE(func, &PyMethodDescr_Type)) { - return _PyMethodDescr_FastCallKeywords(func, args, nargs, NULL); - } - #endif - #if CYTHON_FAST_PYCALL - if (PyFunction_Check(func)) { - return __Pyx_PyFunction_FastCallDict(func, args, nargs, kwargs); - } - #endif - #endif - if (kwargs == NULL) { - #if CYTHON_VECTORCALL && !CYTHON_COMPILING_IN_LIMITED_API - vectorcallfunc f = __Pyx_PyVectorcall_Function(func); - if (f) { - return f(func, args, _nargs, NULL); - } - #elif defined(__Pyx_CyFunction_USED) && CYTHON_BACKPORT_VECTORCALL - if (__Pyx_CyFunction_CheckExact(func)) { - __pyx_vectorcallfunc f = __Pyx_CyFunction_func_vectorcall(func); - if (f) return f(func, args, _nargs, NULL); - } - #elif CYTHON_COMPILING_IN_LIMITED_API && CYTHON_VECTORCALL - return PyObject_Vectorcall(func, args, _nargs, NULL); - #endif - } - if (nargs == 0) { - return __Pyx_PyObject_Call(func, __pyx_mstate_global->__pyx_empty_tuple, kwargs); - } - #if PY_VERSION_HEX >= 0x03090000 && !CYTHON_COMPILING_IN_LIMITED_API - return PyObject_VectorcallDict(func, args, (size_t)nargs, kwargs); - #else - return __Pyx_PyObject_FastCall_fallback(func, args, (size_t)nargs, kwargs); - #endif -} - -/* PyObjectVectorCallKwBuilder */ -#if CYTHON_VECTORCALL -static int __Pyx_VectorcallBuilder_AddArg(PyObject *key, PyObject *value, PyObject *builder, PyObject **args, int n) { - (void)__Pyx_PyObject_FastCallDict; - if (__Pyx_PyTuple_SET_ITEM(builder, n, key) != (0)) return -1; - Py_INCREF(key); - args[n] = value; - return 0; -} -CYTHON_UNUSED static int __Pyx_VectorcallBuilder_AddArg_Check(PyObject *key, PyObject *value, PyObject *builder, PyObject **args, int n) { - (void)__Pyx_VectorcallBuilder_AddArgStr; - if (unlikely(!PyUnicode_Check(key))) { - PyErr_SetString(PyExc_TypeError, "keywords must be strings"); - return -1; - } - return __Pyx_VectorcallBuilder_AddArg(key, value, builder, args, n); -} -static int __Pyx_VectorcallBuilder_AddArgStr(const char *key, PyObject *value, PyObject *builder, PyObject **args, int n) { - PyObject *pyKey = PyUnicode_FromString(key); - if (!pyKey) return -1; - return __Pyx_VectorcallBuilder_AddArg(pyKey, value, builder, args, n); -} -#else // CYTHON_VECTORCALL -CYTHON_UNUSED static int __Pyx_VectorcallBuilder_AddArg_Check(PyObject *key, PyObject *value, PyObject *builder, CYTHON_UNUSED PyObject **args, CYTHON_UNUSED int n) { - if (unlikely(!PyUnicode_Check(key))) { - PyErr_SetString(PyExc_TypeError, "keywords must be strings"); - return -1; - } - return PyDict_SetItem(builder, key, value); -} -#endif - -/* CIntToPy */ -static CYTHON_INLINE PyObject* __Pyx_PyLong_From_long(long value) { -#ifdef __Pyx_HAS_GCC_DIAGNOSTIC -#pragma GCC diagnostic push -#pragma GCC diagnostic ignored "-Wconversion" -#endif - const long neg_one = (long) -1, const_zero = (long) 0; -#ifdef __Pyx_HAS_GCC_DIAGNOSTIC -#pragma GCC diagnostic pop -#endif - const int is_unsigned = neg_one > const_zero; - if (is_unsigned) { - if (sizeof(long) < sizeof(long)) { - return PyLong_FromLong((long) value); - } else if (sizeof(long) <= sizeof(unsigned long)) { - return PyLong_FromUnsignedLong((unsigned long) value); -#ifdef HAVE_LONG_LONG - } else if (sizeof(long) <= sizeof(unsigned PY_LONG_LONG)) { - return PyLong_FromUnsignedLongLong((unsigned PY_LONG_LONG) value); -#endif - } - } else { - if (sizeof(long) <= sizeof(long)) { - return PyLong_FromLong((long) value); -#ifdef HAVE_LONG_LONG - } else if (sizeof(long) <= sizeof(PY_LONG_LONG)) { - return PyLong_FromLongLong((PY_LONG_LONG) value); -#endif - } - } - { - unsigned char *bytes = (unsigned char *)&value; -#if !CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX >= 0x030d00A4 - if (is_unsigned) { - return PyLong_FromUnsignedNativeBytes(bytes, sizeof(value), -1); - } else { - return PyLong_FromNativeBytes(bytes, sizeof(value), -1); - } -#elif !CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX < 0x030d0000 - int one = 1; int little = (int)*(unsigned char *)&one; - return _PyLong_FromByteArray(bytes, sizeof(long), - little, !is_unsigned); -#else - int one = 1; int little = (int)*(unsigned char *)&one; - PyObject *from_bytes, *result = NULL, *kwds = NULL; - PyObject *py_bytes = NULL, *order_str = NULL; - from_bytes = PyObject_GetAttrString((PyObject*)&PyLong_Type, "from_bytes"); - if (!from_bytes) return NULL; - py_bytes = PyBytes_FromStringAndSize((char*)bytes, sizeof(long)); - if (!py_bytes) goto limited_bad; - order_str = PyUnicode_FromString(little ? "little" : "big"); - if (!order_str) goto limited_bad; - { - PyObject *args[3+(CYTHON_VECTORCALL ? 1 : 0)] = { NULL, py_bytes, order_str }; - if (!is_unsigned) { - kwds = __Pyx_MakeVectorcallBuilderKwds(1); - if (!kwds) goto limited_bad; - if (__Pyx_VectorcallBuilder_AddArgStr("signed", __Pyx_NewRef(Py_True), kwds, args+3, 0) < 0) goto limited_bad; - } - result = __Pyx_Object_Vectorcall_CallFromBuilder(from_bytes, args+1, 2 | __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET, kwds); - } - limited_bad: - Py_XDECREF(kwds); - Py_XDECREF(order_str); - Py_XDECREF(py_bytes); - Py_XDECREF(from_bytes); - return result; -#endif - } -} - -/* CIntFromPyVerify */ -#define __PYX_VERIFY_RETURN_INT(target_type, func_type, func_value)\ - __PYX__VERIFY_RETURN_INT(target_type, func_type, func_value, 0) -#define __PYX_VERIFY_RETURN_INT_EXC(target_type, func_type, func_value)\ - __PYX__VERIFY_RETURN_INT(target_type, func_type, func_value, 1) -#define __PYX__VERIFY_RETURN_INT(target_type, func_type, func_value, exc)\ - {\ - func_type value = func_value;\ - if (sizeof(target_type) < sizeof(func_type)) {\ - if (unlikely(value != (func_type) (target_type) value)) {\ - func_type zero = 0;\ - if (exc && unlikely(value == (func_type)-1 && PyErr_Occurred()))\ - return (target_type) -1;\ - if (is_unsigned && unlikely(value < zero))\ - goto raise_neg_overflow;\ - else\ - goto raise_overflow;\ - }\ - }\ - return (target_type) value;\ - } - -/* CIntFromPy */ -static CYTHON_INLINE long __Pyx_PyLong_As_long(PyObject *x) { -#ifdef __Pyx_HAS_GCC_DIAGNOSTIC -#pragma GCC diagnostic push -#pragma GCC diagnostic ignored "-Wconversion" -#endif - const long neg_one = (long) -1, const_zero = (long) 0; -#ifdef __Pyx_HAS_GCC_DIAGNOSTIC -#pragma GCC diagnostic pop -#endif - const int is_unsigned = neg_one > const_zero; - if (unlikely(!PyLong_Check(x))) { - long val; - PyObject *tmp = __Pyx_PyNumber_Long(x); - if (!tmp) return (long) -1; - val = __Pyx_PyLong_As_long(tmp); - Py_DECREF(tmp); - return val; - } - if (is_unsigned) { -#if CYTHON_USE_PYLONG_INTERNALS - if (unlikely(__Pyx_PyLong_IsNeg(x))) { - goto raise_neg_overflow; - } else if (__Pyx_PyLong_IsCompact(x)) { - __PYX_VERIFY_RETURN_INT(long, __Pyx_compact_upylong, __Pyx_PyLong_CompactValueUnsigned(x)) - } else { - const digit* digits = __Pyx_PyLong_Digits(x); - assert(__Pyx_PyLong_DigitCount(x) > 1); - switch (__Pyx_PyLong_DigitCount(x)) { - case 2: - if ((8 * sizeof(long) > 1 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 2 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(long, unsigned long, (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(long) >= 2 * PyLong_SHIFT)) { - return (long) (((((long)digits[1]) << PyLong_SHIFT) | (long)digits[0])); - } - } - break; - case 3: - if ((8 * sizeof(long) > 2 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 3 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(long, unsigned long, (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(long) >= 3 * PyLong_SHIFT)) { - return (long) (((((((long)digits[2]) << PyLong_SHIFT) | (long)digits[1]) << PyLong_SHIFT) | (long)digits[0])); - } - } - break; - case 4: - if ((8 * sizeof(long) > 3 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 4 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(long, unsigned long, (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(long) >= 4 * PyLong_SHIFT)) { - return (long) (((((((((long)digits[3]) << PyLong_SHIFT) | (long)digits[2]) << PyLong_SHIFT) | (long)digits[1]) << PyLong_SHIFT) | (long)digits[0])); - } - } - break; - } - } -#endif -#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX < 0x030C00A7 - if (unlikely(Py_SIZE(x) < 0)) { - goto raise_neg_overflow; - } -#else - { - int result = PyObject_RichCompareBool(x, Py_False, Py_LT); - if (unlikely(result < 0)) - return (long) -1; - if (unlikely(result == 1)) - goto raise_neg_overflow; - } -#endif - if ((sizeof(long) <= sizeof(unsigned long))) { - __PYX_VERIFY_RETURN_INT_EXC(long, unsigned long, PyLong_AsUnsignedLong(x)) -#ifdef HAVE_LONG_LONG - } else if ((sizeof(long) <= sizeof(unsigned PY_LONG_LONG))) { - __PYX_VERIFY_RETURN_INT_EXC(long, unsigned PY_LONG_LONG, PyLong_AsUnsignedLongLong(x)) -#endif - } - } else { -#if CYTHON_USE_PYLONG_INTERNALS - if (__Pyx_PyLong_IsCompact(x)) { - __PYX_VERIFY_RETURN_INT(long, __Pyx_compact_pylong, __Pyx_PyLong_CompactValue(x)) - } else { - const digit* digits = __Pyx_PyLong_Digits(x); - assert(__Pyx_PyLong_DigitCount(x) > 1); - switch (__Pyx_PyLong_SignedDigitCount(x)) { - case -2: - if ((8 * sizeof(long) - 1 > 1 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 2 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(long, long, -(long) (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(long) - 1 > 2 * PyLong_SHIFT)) { - return (long) (((long)-1)*(((((long)digits[1]) << PyLong_SHIFT) | (long)digits[0]))); - } - } - break; - case 2: - if ((8 * sizeof(long) > 1 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 2 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(long, unsigned long, (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(long) - 1 > 2 * PyLong_SHIFT)) { - return (long) ((((((long)digits[1]) << PyLong_SHIFT) | (long)digits[0]))); - } - } - break; - case -3: - if ((8 * sizeof(long) - 1 > 2 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 3 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(long, long, -(long) (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(long) - 1 > 3 * PyLong_SHIFT)) { - return (long) (((long)-1)*(((((((long)digits[2]) << PyLong_SHIFT) | (long)digits[1]) << PyLong_SHIFT) | (long)digits[0]))); - } - } - break; - case 3: - if ((8 * sizeof(long) > 2 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 3 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(long, unsigned long, (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(long) - 1 > 3 * PyLong_SHIFT)) { - return (long) ((((((((long)digits[2]) << PyLong_SHIFT) | (long)digits[1]) << PyLong_SHIFT) | (long)digits[0]))); - } - } - break; - case -4: - if ((8 * sizeof(long) - 1 > 3 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 4 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(long, long, -(long) (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(long) - 1 > 4 * PyLong_SHIFT)) { - return (long) (((long)-1)*(((((((((long)digits[3]) << PyLong_SHIFT) | (long)digits[2]) << PyLong_SHIFT) | (long)digits[1]) << PyLong_SHIFT) | (long)digits[0]))); - } - } - break; - case 4: - if ((8 * sizeof(long) > 3 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 4 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(long, unsigned long, (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(long) - 1 > 4 * PyLong_SHIFT)) { - return (long) ((((((((((long)digits[3]) << PyLong_SHIFT) | (long)digits[2]) << PyLong_SHIFT) | (long)digits[1]) << PyLong_SHIFT) | (long)digits[0]))); - } - } - break; - } - } -#endif - if ((sizeof(long) <= sizeof(long))) { - __PYX_VERIFY_RETURN_INT_EXC(long, long, PyLong_AsLong(x)) -#ifdef HAVE_LONG_LONG - } else if ((sizeof(long) <= sizeof(PY_LONG_LONG))) { - __PYX_VERIFY_RETURN_INT_EXC(long, PY_LONG_LONG, PyLong_AsLongLong(x)) -#endif - } - } - { - long val; - int ret = -1; -#if PY_VERSION_HEX >= 0x030d00A6 && !CYTHON_COMPILING_IN_LIMITED_API - Py_ssize_t bytes_copied = PyLong_AsNativeBytes( - x, &val, sizeof(val), Py_ASNATIVEBYTES_NATIVE_ENDIAN | (is_unsigned ? Py_ASNATIVEBYTES_UNSIGNED_BUFFER | Py_ASNATIVEBYTES_REJECT_NEGATIVE : 0)); - if (unlikely(bytes_copied == -1)) { - } else if (unlikely(bytes_copied > (Py_ssize_t) sizeof(val))) { - goto raise_overflow; - } else { - ret = 0; - } -#elif PY_VERSION_HEX < 0x030d0000 && !(CYTHON_COMPILING_IN_PYPY || CYTHON_COMPILING_IN_LIMITED_API) || defined(_PyLong_AsByteArray) - int one = 1; int is_little = (int)*(unsigned char *)&one; - unsigned char *bytes = (unsigned char *)&val; - ret = _PyLong_AsByteArray((PyLongObject *)x, - bytes, sizeof(val), - is_little, !is_unsigned); -#else - PyObject *v; - PyObject *stepval = NULL, *mask = NULL, *shift = NULL; - int bits, remaining_bits, is_negative = 0; - int chunk_size = (sizeof(long) < 8) ? 30 : 62; - if (likely(PyLong_CheckExact(x))) { - v = __Pyx_NewRef(x); - } else { - v = PyNumber_Long(x); - if (unlikely(!v)) return (long) -1; - assert(PyLong_CheckExact(v)); - } - { - int result = PyObject_RichCompareBool(v, Py_False, Py_LT); - if (unlikely(result < 0)) { - Py_DECREF(v); - return (long) -1; - } - is_negative = result == 1; - } - if (is_unsigned && unlikely(is_negative)) { - Py_DECREF(v); - goto raise_neg_overflow; - } else if (is_negative) { - stepval = PyNumber_Invert(v); - Py_DECREF(v); - if (unlikely(!stepval)) - return (long) -1; - } else { - stepval = v; - } - v = NULL; - val = (long) 0; - mask = PyLong_FromLong((1L << chunk_size) - 1); if (unlikely(!mask)) goto done; - shift = PyLong_FromLong(chunk_size); if (unlikely(!shift)) goto done; - for (bits = 0; bits < (int) sizeof(long) * 8 - chunk_size; bits += chunk_size) { - PyObject *tmp, *digit; - long idigit; - digit = PyNumber_And(stepval, mask); - if (unlikely(!digit)) goto done; - idigit = PyLong_AsLong(digit); - Py_DECREF(digit); - if (unlikely(idigit < 0)) goto done; - val |= ((long) idigit) << bits; - tmp = PyNumber_Rshift(stepval, shift); - if (unlikely(!tmp)) goto done; - Py_DECREF(stepval); stepval = tmp; - } - Py_DECREF(shift); shift = NULL; - Py_DECREF(mask); mask = NULL; - { - long idigit = PyLong_AsLong(stepval); - if (unlikely(idigit < 0)) goto done; - remaining_bits = ((int) sizeof(long) * 8) - bits - (is_unsigned ? 0 : 1); - if (unlikely(idigit >= (1L << remaining_bits))) - goto raise_overflow; - val |= ((long) idigit) << bits; - } - if (!is_unsigned) { - if (unlikely(val & (((long) 1) << (sizeof(long) * 8 - 1)))) - goto raise_overflow; - if (is_negative) - val = ~val; - } - ret = 0; - done: - Py_XDECREF(shift); - Py_XDECREF(mask); - Py_XDECREF(stepval); -#endif - if (unlikely(ret)) - return (long) -1; - return val; - } -raise_overflow: - PyErr_SetString(PyExc_OverflowError, - "value too large to convert to long"); - return (long) -1; -raise_neg_overflow: - PyErr_SetString(PyExc_OverflowError, - "can't convert negative value to long"); - return (long) -1; -} - -/* CIntFromPy */ -static CYTHON_INLINE int __Pyx_PyLong_As_int(PyObject *x) { -#ifdef __Pyx_HAS_GCC_DIAGNOSTIC -#pragma GCC diagnostic push -#pragma GCC diagnostic ignored "-Wconversion" -#endif - const int neg_one = (int) -1, const_zero = (int) 0; -#ifdef __Pyx_HAS_GCC_DIAGNOSTIC -#pragma GCC diagnostic pop -#endif - const int is_unsigned = neg_one > const_zero; - if (unlikely(!PyLong_Check(x))) { - int val; - PyObject *tmp = __Pyx_PyNumber_Long(x); - if (!tmp) return (int) -1; - val = __Pyx_PyLong_As_int(tmp); - Py_DECREF(tmp); - return val; - } - if (is_unsigned) { -#if CYTHON_USE_PYLONG_INTERNALS - if (unlikely(__Pyx_PyLong_IsNeg(x))) { - goto raise_neg_overflow; - } else if (__Pyx_PyLong_IsCompact(x)) { - __PYX_VERIFY_RETURN_INT(int, __Pyx_compact_upylong, __Pyx_PyLong_CompactValueUnsigned(x)) - } else { - const digit* digits = __Pyx_PyLong_Digits(x); - assert(__Pyx_PyLong_DigitCount(x) > 1); - switch (__Pyx_PyLong_DigitCount(x)) { - case 2: - if ((8 * sizeof(int) > 1 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 2 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(int, unsigned long, (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(int) >= 2 * PyLong_SHIFT)) { - return (int) (((((int)digits[1]) << PyLong_SHIFT) | (int)digits[0])); - } - } - break; - case 3: - if ((8 * sizeof(int) > 2 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 3 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(int, unsigned long, (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(int) >= 3 * PyLong_SHIFT)) { - return (int) (((((((int)digits[2]) << PyLong_SHIFT) | (int)digits[1]) << PyLong_SHIFT) | (int)digits[0])); - } - } - break; - case 4: - if ((8 * sizeof(int) > 3 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 4 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(int, unsigned long, (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(int) >= 4 * PyLong_SHIFT)) { - return (int) (((((((((int)digits[3]) << PyLong_SHIFT) | (int)digits[2]) << PyLong_SHIFT) | (int)digits[1]) << PyLong_SHIFT) | (int)digits[0])); - } - } - break; - } - } -#endif -#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX < 0x030C00A7 - if (unlikely(Py_SIZE(x) < 0)) { - goto raise_neg_overflow; - } -#else - { - int result = PyObject_RichCompareBool(x, Py_False, Py_LT); - if (unlikely(result < 0)) - return (int) -1; - if (unlikely(result == 1)) - goto raise_neg_overflow; - } -#endif - if ((sizeof(int) <= sizeof(unsigned long))) { - __PYX_VERIFY_RETURN_INT_EXC(int, unsigned long, PyLong_AsUnsignedLong(x)) -#ifdef HAVE_LONG_LONG - } else if ((sizeof(int) <= sizeof(unsigned PY_LONG_LONG))) { - __PYX_VERIFY_RETURN_INT_EXC(int, unsigned PY_LONG_LONG, PyLong_AsUnsignedLongLong(x)) -#endif - } - } else { -#if CYTHON_USE_PYLONG_INTERNALS - if (__Pyx_PyLong_IsCompact(x)) { - __PYX_VERIFY_RETURN_INT(int, __Pyx_compact_pylong, __Pyx_PyLong_CompactValue(x)) - } else { - const digit* digits = __Pyx_PyLong_Digits(x); - assert(__Pyx_PyLong_DigitCount(x) > 1); - switch (__Pyx_PyLong_SignedDigitCount(x)) { - case -2: - if ((8 * sizeof(int) - 1 > 1 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 2 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(int, long, -(long) (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(int) - 1 > 2 * PyLong_SHIFT)) { - return (int) (((int)-1)*(((((int)digits[1]) << PyLong_SHIFT) | (int)digits[0]))); - } - } - break; - case 2: - if ((8 * sizeof(int) > 1 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 2 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(int, unsigned long, (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(int) - 1 > 2 * PyLong_SHIFT)) { - return (int) ((((((int)digits[1]) << PyLong_SHIFT) | (int)digits[0]))); - } - } - break; - case -3: - if ((8 * sizeof(int) - 1 > 2 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 3 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(int, long, -(long) (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(int) - 1 > 3 * PyLong_SHIFT)) { - return (int) (((int)-1)*(((((((int)digits[2]) << PyLong_SHIFT) | (int)digits[1]) << PyLong_SHIFT) | (int)digits[0]))); - } - } - break; - case 3: - if ((8 * sizeof(int) > 2 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 3 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(int, unsigned long, (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(int) - 1 > 3 * PyLong_SHIFT)) { - return (int) ((((((((int)digits[2]) << PyLong_SHIFT) | (int)digits[1]) << PyLong_SHIFT) | (int)digits[0]))); - } - } - break; - case -4: - if ((8 * sizeof(int) - 1 > 3 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 4 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(int, long, -(long) (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(int) - 1 > 4 * PyLong_SHIFT)) { - return (int) (((int)-1)*(((((((((int)digits[3]) << PyLong_SHIFT) | (int)digits[2]) << PyLong_SHIFT) | (int)digits[1]) << PyLong_SHIFT) | (int)digits[0]))); - } - } - break; - case 4: - if ((8 * sizeof(int) > 3 * PyLong_SHIFT)) { - if ((8 * sizeof(unsigned long) > 4 * PyLong_SHIFT)) { - __PYX_VERIFY_RETURN_INT(int, unsigned long, (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) - } else if ((8 * sizeof(int) - 1 > 4 * PyLong_SHIFT)) { - return (int) ((((((((((int)digits[3]) << PyLong_SHIFT) | (int)digits[2]) << PyLong_SHIFT) | (int)digits[1]) << PyLong_SHIFT) | (int)digits[0]))); - } - } - break; - } - } -#endif - if ((sizeof(int) <= sizeof(long))) { - __PYX_VERIFY_RETURN_INT_EXC(int, long, PyLong_AsLong(x)) -#ifdef HAVE_LONG_LONG - } else if ((sizeof(int) <= sizeof(PY_LONG_LONG))) { - __PYX_VERIFY_RETURN_INT_EXC(int, PY_LONG_LONG, PyLong_AsLongLong(x)) -#endif - } - } - { - int val; - int ret = -1; -#if PY_VERSION_HEX >= 0x030d00A6 && !CYTHON_COMPILING_IN_LIMITED_API - Py_ssize_t bytes_copied = PyLong_AsNativeBytes( - x, &val, sizeof(val), Py_ASNATIVEBYTES_NATIVE_ENDIAN | (is_unsigned ? Py_ASNATIVEBYTES_UNSIGNED_BUFFER | Py_ASNATIVEBYTES_REJECT_NEGATIVE : 0)); - if (unlikely(bytes_copied == -1)) { - } else if (unlikely(bytes_copied > (Py_ssize_t) sizeof(val))) { - goto raise_overflow; - } else { - ret = 0; - } -#elif PY_VERSION_HEX < 0x030d0000 && !(CYTHON_COMPILING_IN_PYPY || CYTHON_COMPILING_IN_LIMITED_API) || defined(_PyLong_AsByteArray) - int one = 1; int is_little = (int)*(unsigned char *)&one; - unsigned char *bytes = (unsigned char *)&val; - ret = _PyLong_AsByteArray((PyLongObject *)x, - bytes, sizeof(val), - is_little, !is_unsigned); -#else - PyObject *v; - PyObject *stepval = NULL, *mask = NULL, *shift = NULL; - int bits, remaining_bits, is_negative = 0; - int chunk_size = (sizeof(long) < 8) ? 30 : 62; - if (likely(PyLong_CheckExact(x))) { - v = __Pyx_NewRef(x); - } else { - v = PyNumber_Long(x); - if (unlikely(!v)) return (int) -1; - assert(PyLong_CheckExact(v)); - } - { - int result = PyObject_RichCompareBool(v, Py_False, Py_LT); - if (unlikely(result < 0)) { - Py_DECREF(v); - return (int) -1; - } - is_negative = result == 1; - } - if (is_unsigned && unlikely(is_negative)) { - Py_DECREF(v); - goto raise_neg_overflow; - } else if (is_negative) { - stepval = PyNumber_Invert(v); - Py_DECREF(v); - if (unlikely(!stepval)) - return (int) -1; - } else { - stepval = v; - } - v = NULL; - val = (int) 0; - mask = PyLong_FromLong((1L << chunk_size) - 1); if (unlikely(!mask)) goto done; - shift = PyLong_FromLong(chunk_size); if (unlikely(!shift)) goto done; - for (bits = 0; bits < (int) sizeof(int) * 8 - chunk_size; bits += chunk_size) { - PyObject *tmp, *digit; - long idigit; - digit = PyNumber_And(stepval, mask); - if (unlikely(!digit)) goto done; - idigit = PyLong_AsLong(digit); - Py_DECREF(digit); - if (unlikely(idigit < 0)) goto done; - val |= ((int) idigit) << bits; - tmp = PyNumber_Rshift(stepval, shift); - if (unlikely(!tmp)) goto done; - Py_DECREF(stepval); stepval = tmp; - } - Py_DECREF(shift); shift = NULL; - Py_DECREF(mask); mask = NULL; - { - long idigit = PyLong_AsLong(stepval); - if (unlikely(idigit < 0)) goto done; - remaining_bits = ((int) sizeof(int) * 8) - bits - (is_unsigned ? 0 : 1); - if (unlikely(idigit >= (1L << remaining_bits))) - goto raise_overflow; - val |= ((int) idigit) << bits; - } - if (!is_unsigned) { - if (unlikely(val & (((int) 1) << (sizeof(int) * 8 - 1)))) - goto raise_overflow; - if (is_negative) - val = ~val; - } - ret = 0; - done: - Py_XDECREF(shift); - Py_XDECREF(mask); - Py_XDECREF(stepval); -#endif - if (unlikely(ret)) - return (int) -1; - return val; - } -raise_overflow: - PyErr_SetString(PyExc_OverflowError, - "value too large to convert to int"); - return (int) -1; -raise_neg_overflow: - PyErr_SetString(PyExc_OverflowError, - "can't convert negative value to int"); - return (int) -1; -} - -/* FastTypeChecks */ -#if CYTHON_COMPILING_IN_CPYTHON -static int __Pyx_InBases(PyTypeObject *a, PyTypeObject *b) { - while (a) { - a = __Pyx_PyType_GetSlot(a, tp_base, PyTypeObject*); - if (a == b) - return 1; - } - return b == &PyBaseObject_Type; -} -static CYTHON_INLINE int __Pyx_IsSubtype(PyTypeObject *a, PyTypeObject *b) { - PyObject *mro; - if (a == b) return 1; - mro = a->tp_mro; - if (likely(mro)) { - Py_ssize_t i, n; - n = PyTuple_GET_SIZE(mro); - for (i = 0; i < n; i++) { - if (PyTuple_GET_ITEM(mro, i) == (PyObject *)b) - return 1; - } - return 0; - } - return __Pyx_InBases(a, b); -} -static CYTHON_INLINE int __Pyx_IsAnySubtype2(PyTypeObject *cls, PyTypeObject *a, PyTypeObject *b) { - PyObject *mro; - if (cls == a || cls == b) return 1; - mro = cls->tp_mro; - if (likely(mro)) { - Py_ssize_t i, n; - n = PyTuple_GET_SIZE(mro); - for (i = 0; i < n; i++) { - PyObject *base = PyTuple_GET_ITEM(mro, i); - if (base == (PyObject *)a || base == (PyObject *)b) - return 1; - } - return 0; - } - return __Pyx_InBases(cls, a) || __Pyx_InBases(cls, b); -} -static CYTHON_INLINE int __Pyx_inner_PyErr_GivenExceptionMatches2(PyObject *err, PyObject* exc_type1, PyObject *exc_type2) { - if (exc_type1) { - return __Pyx_IsAnySubtype2((PyTypeObject*)err, (PyTypeObject*)exc_type1, (PyTypeObject*)exc_type2); - } else { - return __Pyx_IsSubtype((PyTypeObject*)err, (PyTypeObject*)exc_type2); - } -} -static int __Pyx_PyErr_GivenExceptionMatchesTuple(PyObject *exc_type, PyObject *tuple) { - Py_ssize_t i, n; - assert(PyExceptionClass_Check(exc_type)); - n = PyTuple_GET_SIZE(tuple); - for (i=0; i= 0x030b0000 - return Py_Version & ~0xFFUL; -#else - static unsigned long __Pyx_cached_runtime_version = 0; - if (__Pyx_cached_runtime_version == 0) { - const char* rt_version = Py_GetVersion(); - unsigned long version = 0; - unsigned long factor = 0x01000000UL; - unsigned int digit = 0; - int i = 0; - while (factor) { - while ('0' <= rt_version[i] && rt_version[i] <= '9') { - digit = digit * 10 + (unsigned int) (rt_version[i] - '0'); - ++i; - } - version += factor * digit; - if (rt_version[i] != '.') - break; - digit = 0; - factor >>= 8; - ++i; - } - __Pyx_cached_runtime_version = version; - } - return __Pyx_cached_runtime_version; -#endif -} - -/* CheckBinaryVersion */ -static int __Pyx_check_binary_version(unsigned long ct_version, unsigned long rt_version, int allow_newer) { - const unsigned long MAJOR_MINOR = 0xFFFF0000UL; - if ((rt_version & MAJOR_MINOR) == (ct_version & MAJOR_MINOR)) - return 0; - if (likely(allow_newer && (rt_version & MAJOR_MINOR) > (ct_version & MAJOR_MINOR))) - return 1; - { - char message[200]; - PyOS_snprintf(message, sizeof(message), - "compile time Python version %d.%d " - "of module '%.100s' " - "%s " - "runtime version %d.%d", - (int) (ct_version >> 24), (int) ((ct_version >> 16) & 0xFF), - __Pyx_MODULE_NAME, - (allow_newer) ? "was newer than" : "does not match", - (int) (rt_version >> 24), (int) ((rt_version >> 16) & 0xFF) - ); - return PyErr_WarnEx(NULL, message, 1); - } -} - -/* InitStrings */ -static int __Pyx_InitStrings(__Pyx_StringTabEntry const *t, PyObject **target, const char* const* encoding_names) { - while (t->s) { - PyObject *str; - if (t->is_unicode) { - if (t->intern) { - str = PyUnicode_InternFromString(t->s); - } else if (t->encoding) { - str = PyUnicode_Decode(t->s, t->n - 1, encoding_names[t->encoding], NULL); - } else { - str = PyUnicode_FromStringAndSize(t->s, t->n - 1); - } - } else { - str = PyBytes_FromStringAndSize(t->s, t->n - 1); - } - if (!str) - return -1; - *target = str; - if (PyObject_Hash(str) == -1) - return -1; - ++t; - ++target; - } - return 0; -} - -#include -static CYTHON_INLINE Py_ssize_t __Pyx_ssize_strlen(const char *s) { - size_t len = strlen(s); - if (unlikely(len > (size_t) PY_SSIZE_T_MAX)) { - PyErr_SetString(PyExc_OverflowError, "byte string is too long"); - return -1; - } - return (Py_ssize_t) len; -} -static CYTHON_INLINE PyObject* __Pyx_PyUnicode_FromString(const char* c_str) { - Py_ssize_t len = __Pyx_ssize_strlen(c_str); - if (unlikely(len < 0)) return NULL; - return __Pyx_PyUnicode_FromStringAndSize(c_str, len); -} -static CYTHON_INLINE PyObject* __Pyx_PyByteArray_FromString(const char* c_str) { - Py_ssize_t len = __Pyx_ssize_strlen(c_str); - if (unlikely(len < 0)) return NULL; - return PyByteArray_FromStringAndSize(c_str, len); -} -static CYTHON_INLINE const char* __Pyx_PyObject_AsString(PyObject* o) { - Py_ssize_t ignore; - return __Pyx_PyObject_AsStringAndSize(o, &ignore); -} -#if __PYX_DEFAULT_STRING_ENCODING_IS_ASCII || __PYX_DEFAULT_STRING_ENCODING_IS_UTF8 -static CYTHON_INLINE const char* __Pyx_PyUnicode_AsStringAndSize(PyObject* o, Py_ssize_t *length) { - if (unlikely(__Pyx_PyUnicode_READY(o) == -1)) return NULL; -#if CYTHON_COMPILING_IN_LIMITED_API - { - const char* result; - Py_ssize_t unicode_length; - CYTHON_MAYBE_UNUSED_VAR(unicode_length); // only for __PYX_DEFAULT_STRING_ENCODING_IS_ASCII - #if __PYX_LIMITED_VERSION_HEX < 0x030A0000 - if (unlikely(PyArg_Parse(o, "s#", &result, length) < 0)) return NULL; - #else - result = PyUnicode_AsUTF8AndSize(o, length); - #endif - #if __PYX_DEFAULT_STRING_ENCODING_IS_ASCII - unicode_length = PyUnicode_GetLength(o); - if (unlikely(unicode_length < 0)) return NULL; - if (unlikely(unicode_length != *length)) { - PyUnicode_AsASCIIString(o); - return NULL; - } - #endif - return result; - } -#else -#if __PYX_DEFAULT_STRING_ENCODING_IS_ASCII - if (likely(PyUnicode_IS_ASCII(o))) { - *length = PyUnicode_GET_LENGTH(o); - return PyUnicode_AsUTF8(o); - } else { - PyUnicode_AsASCIIString(o); - return NULL; - } -#else - return PyUnicode_AsUTF8AndSize(o, length); -#endif -#endif -} -#endif -static CYTHON_INLINE const char* __Pyx_PyObject_AsStringAndSize(PyObject* o, Py_ssize_t *length) { -#if __PYX_DEFAULT_STRING_ENCODING_IS_ASCII || __PYX_DEFAULT_STRING_ENCODING_IS_UTF8 - if (PyUnicode_Check(o)) { - return __Pyx_PyUnicode_AsStringAndSize(o, length); - } else -#endif - if (PyByteArray_Check(o)) { -#if (CYTHON_ASSUME_SAFE_SIZE && CYTHON_ASSUME_SAFE_MACROS) || (CYTHON_COMPILING_IN_PYPY && (defined(PyByteArray_AS_STRING) && defined(PyByteArray_GET_SIZE))) - *length = PyByteArray_GET_SIZE(o); - return PyByteArray_AS_STRING(o); -#else - *length = PyByteArray_Size(o); - if (*length == -1) return NULL; - return PyByteArray_AsString(o); -#endif - } else - { - char* result; - int r = PyBytes_AsStringAndSize(o, &result, length); - if (unlikely(r < 0)) { - return NULL; - } else { - return result; - } - } -} -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 int __Pyx_PyObject_IsTrueAndDecref(PyObject* x) { - int retval; - if (unlikely(!x)) return -1; - retval = __Pyx_PyObject_IsTrue(x); - Py_DECREF(x); - return retval; -} -static PyObject* __Pyx_PyNumber_LongWrongResultType(PyObject* result) { - __Pyx_TypeName result_type_name = __Pyx_PyType_GetFullyQualifiedName(Py_TYPE(result)); - if (PyLong_Check(result)) { - if (PyErr_WarnFormat(PyExc_DeprecationWarning, 1, - "__int__ returned non-int (type " __Pyx_FMT_TYPENAME "). " - "The ability to return an instance of a strict subclass of int is deprecated, " - "and may be removed in a future version of Python.", - result_type_name)) { - __Pyx_DECREF_TypeName(result_type_name); - Py_DECREF(result); - return NULL; - } - __Pyx_DECREF_TypeName(result_type_name); - return result; - } - PyErr_Format(PyExc_TypeError, - "__int__ returned non-int (type " __Pyx_FMT_TYPENAME ")", - result_type_name); - __Pyx_DECREF_TypeName(result_type_name); - Py_DECREF(result); - return NULL; -} -static CYTHON_INLINE PyObject* __Pyx_PyNumber_Long(PyObject* x) { -#if CYTHON_USE_TYPE_SLOTS - PyNumberMethods *m; -#endif - PyObject *res = NULL; - if (likely(PyLong_Check(x))) - return __Pyx_NewRef(x); -#if CYTHON_USE_TYPE_SLOTS - m = Py_TYPE(x)->tp_as_number; - if (likely(m && m->nb_int)) { - res = m->nb_int(x); - } -#else - if (!PyBytes_CheckExact(x) && !PyUnicode_CheckExact(x)) { - res = PyNumber_Long(x); - } -#endif - if (likely(res)) { - if (unlikely(!PyLong_CheckExact(res))) { - return __Pyx_PyNumber_LongWrongResultType(res); - } - } - 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; - if (likely(PyLong_CheckExact(b))) { - #if CYTHON_USE_PYLONG_INTERNALS - if (likely(__Pyx_PyLong_IsCompact(b))) { - return __Pyx_PyLong_CompactValue(b); - } else { - const digit* digits = __Pyx_PyLong_Digits(b); - const Py_ssize_t size = __Pyx_PyLong_SignedDigitCount(b); - switch (size) { - case 2: - if (8 * sizeof(Py_ssize_t) > 2 * PyLong_SHIFT) { - return (Py_ssize_t) (((((size_t)digits[1]) << PyLong_SHIFT) | (size_t)digits[0])); - } - break; - case -2: - if (8 * sizeof(Py_ssize_t) > 2 * PyLong_SHIFT) { - return -(Py_ssize_t) (((((size_t)digits[1]) << PyLong_SHIFT) | (size_t)digits[0])); - } - break; - case 3: - if (8 * sizeof(Py_ssize_t) > 3 * PyLong_SHIFT) { - return (Py_ssize_t) (((((((size_t)digits[2]) << PyLong_SHIFT) | (size_t)digits[1]) << PyLong_SHIFT) | (size_t)digits[0])); - } - break; - case -3: - if (8 * sizeof(Py_ssize_t) > 3 * PyLong_SHIFT) { - return -(Py_ssize_t) (((((((size_t)digits[2]) << PyLong_SHIFT) | (size_t)digits[1]) << PyLong_SHIFT) | (size_t)digits[0])); - } - break; - case 4: - if (8 * sizeof(Py_ssize_t) > 4 * PyLong_SHIFT) { - return (Py_ssize_t) (((((((((size_t)digits[3]) << PyLong_SHIFT) | (size_t)digits[2]) << PyLong_SHIFT) | (size_t)digits[1]) << PyLong_SHIFT) | (size_t)digits[0])); - } - break; - case -4: - if (8 * sizeof(Py_ssize_t) > 4 * PyLong_SHIFT) { - return -(Py_ssize_t) (((((((((size_t)digits[3]) << PyLong_SHIFT) | (size_t)digits[2]) << PyLong_SHIFT) | (size_t)digits[1]) << PyLong_SHIFT) | (size_t)digits[0])); - } - break; - } - } - #endif - return PyLong_AsSsize_t(b); - } - x = PyNumber_Index(b); - if (!x) return -1; - ival = PyLong_AsSsize_t(x); - Py_DECREF(x); - return ival; -} -static CYTHON_INLINE Py_hash_t __Pyx_PyIndex_AsHash_t(PyObject* o) { - if (sizeof(Py_hash_t) == sizeof(Py_ssize_t)) { - return (Py_hash_t) __Pyx_PyIndex_AsSsize_t(o); - } else { - Py_ssize_t ival; - PyObject *x; - x = PyNumber_Index(o); - if (!x) return -1; - ival = PyLong_AsLong(x); - Py_DECREF(x); - return ival; - } -} -static CYTHON_INLINE PyObject *__Pyx_Owned_Py_None(int b) { - CYTHON_UNUSED_VAR(b); - return __Pyx_NewRef(Py_None); -} -static CYTHON_INLINE PyObject * __Pyx_PyBool_FromLong(long b) { - return b ? __Pyx_NewRef(Py_True) : __Pyx_NewRef(Py_False); -} -static CYTHON_INLINE PyObject * __Pyx_PyLong_FromSize_t(size_t ival) { - return PyLong_FromSize_t(ival); -} - - -/* MultiPhaseInitModuleState */ -#if CYTHON_PEP489_MULTI_PHASE_INIT && CYTHON_USE_MODULE_STATE -#ifndef CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE -#if (CYTHON_COMPILING_IN_LIMITED_API || PY_VERSION_HEX >= 0x030C0000) - #define CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE 1 -#else - #define CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE 0 -#endif -#endif -#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE && !CYTHON_ATOMICS -#error "Module state with PEP489 requires atomics. Currently that's one of\ - C11, C++11, gcc atomic intrinsics or MSVC atomic intrinsics" -#endif -#if !CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE -#define __Pyx_ModuleStateLookup_Lock() -#define __Pyx_ModuleStateLookup_Unlock() -#elif !CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX >= 0x030d0000 -static PyMutex __Pyx_ModuleStateLookup_mutex = {0}; -#define __Pyx_ModuleStateLookup_Lock() PyMutex_Lock(&__Pyx_ModuleStateLookup_mutex) -#define __Pyx_ModuleStateLookup_Unlock() PyMutex_Unlock(&__Pyx_ModuleStateLookup_mutex) -#elif defined(__cplusplus) && __cplusplus >= 201103L -#include -static std::mutex __Pyx_ModuleStateLookup_mutex; -#define __Pyx_ModuleStateLookup_Lock() __Pyx_ModuleStateLookup_mutex.lock() -#define __Pyx_ModuleStateLookup_Unlock() __Pyx_ModuleStateLookup_mutex.unlock() -#elif defined(__STDC_VERSION__) && (__STDC_VERSION__ > 201112L) && !defined(__STDC_NO_THREADS__) -#include -static mtx_t __Pyx_ModuleStateLookup_mutex; -static once_flag __Pyx_ModuleStateLookup_mutex_once_flag = ONCE_FLAG_INIT; -static void __Pyx_ModuleStateLookup_initialize_mutex(void) { - mtx_init(&__Pyx_ModuleStateLookup_mutex, mtx_plain); -} -#define __Pyx_ModuleStateLookup_Lock()\ - call_once(&__Pyx_ModuleStateLookup_mutex_once_flag, __Pyx_ModuleStateLookup_initialize_mutex);\ - mtx_lock(&__Pyx_ModuleStateLookup_mutex) -#define __Pyx_ModuleStateLookup_Unlock() mtx_unlock(&__Pyx_ModuleStateLookup_mutex) -#elif defined(HAVE_PTHREAD_H) -#include -static pthread_mutex_t __Pyx_ModuleStateLookup_mutex = PTHREAD_MUTEX_INITIALIZER; -#define __Pyx_ModuleStateLookup_Lock() pthread_mutex_lock(&__Pyx_ModuleStateLookup_mutex) -#define __Pyx_ModuleStateLookup_Unlock() pthread_mutex_unlock(&__Pyx_ModuleStateLookup_mutex) -#elif defined(_WIN32) -#include // synchapi.h on its own doesn't work -static SRWLOCK __Pyx_ModuleStateLookup_mutex = SRWLOCK_INIT; -#define __Pyx_ModuleStateLookup_Lock() AcquireSRWLockExclusive(&__Pyx_ModuleStateLookup_mutex) -#define __Pyx_ModuleStateLookup_Unlock() ReleaseSRWLockExclusive(&__Pyx_ModuleStateLookup_mutex) -#else -#error "No suitable lock available for CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE.\ - Requires C standard >= C11, or C++ standard >= C++11,\ - or pthreads, or the Windows 32 API, or Python >= 3.13." -#endif -typedef struct { - int64_t id; - PyObject *module; -} __Pyx_InterpreterIdAndModule; -typedef struct { - char interpreter_id_as_index; - Py_ssize_t count; - Py_ssize_t allocated; - __Pyx_InterpreterIdAndModule table[1]; -} __Pyx_ModuleStateLookupData; -#define __PYX_MODULE_STATE_LOOKUP_SMALL_SIZE 32 -#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE -static __pyx_atomic_int_type __Pyx_ModuleStateLookup_read_counter = 0; -#endif -#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE -static __pyx_atomic_ptr_type __Pyx_ModuleStateLookup_data = 0; -#else -static __Pyx_ModuleStateLookupData* __Pyx_ModuleStateLookup_data = NULL; -#endif -static __Pyx_InterpreterIdAndModule* __Pyx_State_FindModuleStateLookupTableLowerBound( - __Pyx_InterpreterIdAndModule* table, - Py_ssize_t count, - int64_t interpreterId) { - __Pyx_InterpreterIdAndModule* begin = table; - __Pyx_InterpreterIdAndModule* end = begin + count; - if (begin->id == interpreterId) { - return begin; - } - while ((end - begin) > __PYX_MODULE_STATE_LOOKUP_SMALL_SIZE) { - __Pyx_InterpreterIdAndModule* halfway = begin + (end - begin)/2; - if (halfway->id == interpreterId) { - return halfway; - } - if (halfway->id < interpreterId) { - begin = halfway; - } else { - end = halfway; - } - } - for (; begin < end; ++begin) { - if (begin->id >= interpreterId) return begin; - } - return begin; -} -static PyObject *__Pyx_State_FindModule(CYTHON_UNUSED void* dummy) { - int64_t interpreter_id = PyInterpreterState_GetID(__Pyx_PyInterpreterState_Get()); - if (interpreter_id == -1) return NULL; -#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE - __Pyx_ModuleStateLookupData* data = (__Pyx_ModuleStateLookupData*)__pyx_atomic_pointer_load_relaxed(&__Pyx_ModuleStateLookup_data); - { - __pyx_atomic_incr_acq_rel(&__Pyx_ModuleStateLookup_read_counter); - if (likely(data)) { - __Pyx_ModuleStateLookupData* new_data = (__Pyx_ModuleStateLookupData*)__pyx_atomic_pointer_load_acquire(&__Pyx_ModuleStateLookup_data); - if (likely(data == new_data)) { - goto read_finished; - } - } - __pyx_atomic_decr_acq_rel(&__Pyx_ModuleStateLookup_read_counter); - __Pyx_ModuleStateLookup_Lock(); - __pyx_atomic_incr_relaxed(&__Pyx_ModuleStateLookup_read_counter); - data = (__Pyx_ModuleStateLookupData*)__pyx_atomic_pointer_load_relaxed(&__Pyx_ModuleStateLookup_data); - __Pyx_ModuleStateLookup_Unlock(); - } - read_finished:; -#else - __Pyx_ModuleStateLookupData* data = __Pyx_ModuleStateLookup_data; -#endif - __Pyx_InterpreterIdAndModule* found = NULL; - if (unlikely(!data)) goto end; - if (data->interpreter_id_as_index) { - if (interpreter_id < data->count) { - found = data->table+interpreter_id; - } - } else { - found = __Pyx_State_FindModuleStateLookupTableLowerBound( - data->table, data->count, interpreter_id); - } - end: - { - PyObject *result=NULL; - if (found && found->id == interpreter_id) { - result = found->module; - } -#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE - __pyx_atomic_decr_acq_rel(&__Pyx_ModuleStateLookup_read_counter); -#endif - return result; - } -} -#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE -static void __Pyx_ModuleStateLookup_wait_until_no_readers(void) { - while (__pyx_atomic_load(&__Pyx_ModuleStateLookup_read_counter) != 0); -} -#else -#define __Pyx_ModuleStateLookup_wait_until_no_readers() -#endif -static int __Pyx_State_AddModuleInterpIdAsIndex(__Pyx_ModuleStateLookupData **old_data, PyObject* module, int64_t interpreter_id) { - Py_ssize_t to_allocate = (*old_data)->allocated; - while (to_allocate <= interpreter_id) { - if (to_allocate == 0) to_allocate = 1; - else to_allocate *= 2; - } - __Pyx_ModuleStateLookupData *new_data = *old_data; - if (to_allocate != (*old_data)->allocated) { - new_data = (__Pyx_ModuleStateLookupData *)realloc( - *old_data, - sizeof(__Pyx_ModuleStateLookupData)+(to_allocate-1)*sizeof(__Pyx_InterpreterIdAndModule)); - if (!new_data) { - PyErr_NoMemory(); - return -1; - } - for (Py_ssize_t i = new_data->allocated; i < to_allocate; ++i) { - new_data->table[i].id = i; - new_data->table[i].module = NULL; - } - new_data->allocated = to_allocate; - } - new_data->table[interpreter_id].module = module; - if (new_data->count < interpreter_id+1) { - new_data->count = interpreter_id+1; - } - *old_data = new_data; - return 0; -} -static void __Pyx_State_ConvertFromInterpIdAsIndex(__Pyx_ModuleStateLookupData *data) { - __Pyx_InterpreterIdAndModule *read = data->table; - __Pyx_InterpreterIdAndModule *write = data->table; - __Pyx_InterpreterIdAndModule *end = read + data->count; - for (; readmodule) { - write->id = read->id; - write->module = read->module; - ++write; - } - } - data->count = write - data->table; - for (; writeid = 0; - write->module = NULL; - } - data->interpreter_id_as_index = 0; -} -static int __Pyx_State_AddModule(PyObject* module, CYTHON_UNUSED void* dummy) { - int64_t interpreter_id = PyInterpreterState_GetID(__Pyx_PyInterpreterState_Get()); - if (interpreter_id == -1) return -1; - int result = 0; - __Pyx_ModuleStateLookup_Lock(); -#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE - __Pyx_ModuleStateLookupData *old_data = (__Pyx_ModuleStateLookupData *) - __pyx_atomic_pointer_exchange(&__Pyx_ModuleStateLookup_data, 0); -#else - __Pyx_ModuleStateLookupData *old_data = __Pyx_ModuleStateLookup_data; -#endif - __Pyx_ModuleStateLookupData *new_data = old_data; - if (!new_data) { - new_data = (__Pyx_ModuleStateLookupData *)calloc(1, sizeof(__Pyx_ModuleStateLookupData)); - if (!new_data) { - result = -1; - PyErr_NoMemory(); - goto end; - } - new_data->allocated = 1; - new_data->interpreter_id_as_index = 1; - } - __Pyx_ModuleStateLookup_wait_until_no_readers(); - if (new_data->interpreter_id_as_index) { - if (interpreter_id < __PYX_MODULE_STATE_LOOKUP_SMALL_SIZE) { - result = __Pyx_State_AddModuleInterpIdAsIndex(&new_data, module, interpreter_id); - goto end; - } - __Pyx_State_ConvertFromInterpIdAsIndex(new_data); - } - { - Py_ssize_t insert_at = 0; - { - __Pyx_InterpreterIdAndModule* lower_bound = __Pyx_State_FindModuleStateLookupTableLowerBound( - new_data->table, new_data->count, interpreter_id); - assert(lower_bound); - insert_at = lower_bound - new_data->table; - if (unlikely(insert_at < new_data->count && lower_bound->id == interpreter_id)) { - lower_bound->module = module; - goto end; // already in table, nothing more to do - } - } - if (new_data->count+1 >= new_data->allocated) { - Py_ssize_t to_allocate = (new_data->count+1)*2; - new_data = - (__Pyx_ModuleStateLookupData*)realloc( - new_data, - sizeof(__Pyx_ModuleStateLookupData) + - (to_allocate-1)*sizeof(__Pyx_InterpreterIdAndModule)); - if (!new_data) { - result = -1; - new_data = old_data; - PyErr_NoMemory(); - goto end; - } - new_data->allocated = to_allocate; - } - ++new_data->count; - int64_t last_id = interpreter_id; - PyObject *last_module = module; - for (Py_ssize_t i=insert_at; icount; ++i) { - int64_t current_id = new_data->table[i].id; - new_data->table[i].id = last_id; - last_id = current_id; - PyObject *current_module = new_data->table[i].module; - new_data->table[i].module = last_module; - last_module = current_module; - } - } - end: -#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE - __pyx_atomic_pointer_exchange(&__Pyx_ModuleStateLookup_data, new_data); -#else - __Pyx_ModuleStateLookup_data = new_data; -#endif - __Pyx_ModuleStateLookup_Unlock(); - return result; -} -static int __Pyx_State_RemoveModule(CYTHON_UNUSED void* dummy) { - int64_t interpreter_id = PyInterpreterState_GetID(__Pyx_PyInterpreterState_Get()); - if (interpreter_id == -1) return -1; - __Pyx_ModuleStateLookup_Lock(); -#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE - __Pyx_ModuleStateLookupData *data = (__Pyx_ModuleStateLookupData *) - __pyx_atomic_pointer_exchange(&__Pyx_ModuleStateLookup_data, 0); -#else - __Pyx_ModuleStateLookupData *data = __Pyx_ModuleStateLookup_data; -#endif - if (data->interpreter_id_as_index) { - if (interpreter_id < data->count) { - data->table[interpreter_id].module = NULL; - } - goto done; - } - { - __Pyx_ModuleStateLookup_wait_until_no_readers(); - __Pyx_InterpreterIdAndModule* lower_bound = __Pyx_State_FindModuleStateLookupTableLowerBound( - data->table, data->count, interpreter_id); - if (!lower_bound) goto done; - if (lower_bound->id != interpreter_id) goto done; - __Pyx_InterpreterIdAndModule *end = data->table+data->count; - for (;lower_boundid = (lower_bound+1)->id; - lower_bound->module = (lower_bound+1)->module; - } - } - --data->count; - if (data->count == 0) { - free(data); - data = NULL; - } - done: -#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE - __pyx_atomic_pointer_exchange(&__Pyx_ModuleStateLookup_data, data); -#else - __Pyx_ModuleStateLookup_data = data; -#endif - __Pyx_ModuleStateLookup_Unlock(); - return 0; -} -#endif - -/* #### Code section: utility_code_pragmas_end ### */ -#ifdef _MSC_VER -#pragma warning( pop ) -#endif - - - -/* #### Code section: end ### */ -#endif /* Py_PYTHON_H */ diff --git a/epanet/epanet2_ec.py b/epanet/epanet2_ec.py deleted file mode 100644 index c0df16b..0000000 --- a/epanet/epanet2_ec.py +++ /dev/null @@ -1,92 +0,0 @@ -ERROR_CODE = {} - -# EPANET 2 Error Messages -ERROR_CODE['0'] = "ok" - -ERROR_CODE['10'] = "Warning: model run issued warnings" - -ERROR_CODE['101'] = "insufficient memory available" -ERROR_CODE['102'] = "no network data available" -ERROR_CODE['103'] = "hydraulic solver not opened" -ERROR_CODE['104'] = "no hydraulics for water quality analysis" -ERROR_CODE['105'] = "water quality solver not opened" -ERROR_CODE['106'] = "no results saved to report on" -ERROR_CODE['107'] = "hydraulics supplied from external file" -ERROR_CODE['108'] = "cannot use external file while hydraulics solver is active" -ERROR_CODE['110'] = "cannot solve network hydraulic equations" -ERROR_CODE['120'] = "cannot solve water quality transport equations" - -# These errors apply only to an input file -ERROR_CODE['200'] = "one or more errors in input file" -ERROR_CODE['201'] = "syntax error" - -# These errors apply to both an input file and to API functions -ERROR_CODE['202'] = "illegal numeric value" -ERROR_CODE['203'] = "undefined node" -ERROR_CODE['204'] = "undefined link" -ERROR_CODE['205'] = "undefined time pattern" -ERROR_CODE['206'] = "undefined curve" -ERROR_CODE['207'] = "attempt to control CV/GPV link" -ERROR_CODE['208'] = "illegal PDA pressure limits" -ERROR_CODE['209'] = "illegal node property value" -ERROR_CODE['211'] = "illegal link property value" -ERROR_CODE['212'] = "undefined trace node" -ERROR_CODE['213'] = "invalid option value" -ERROR_CODE['214'] = "too many characters in input line" -ERROR_CODE['215'] = "duplicate ID label" -ERROR_CODE['216'] = "reference to undefined pump" -ERROR_CODE['217'] = "invalid pump energy data" -ERROR_CODE['219'] = "illegal valve connection to tank node" -ERROR_CODE['220'] = "illegal valve connection to another valve" -ERROR_CODE['221'] = "mis-placed rule clause in rule-based control" -ERROR_CODE['222'] = "same start and end nodes for link" - -# These errors apply to network consistency check -ERROR_CODE['223'] = "not enough nodes in network" -ERROR_CODE['224'] = "no tanks or reservoirs in network" -ERROR_CODE['225'] = "invalid lower/upper levels for tank" -ERROR_CODE['226'] = "no head curve or power rating for pump" -ERROR_CODE['227'] = "invalid head curve for pump" -ERROR_CODE['230'] = "nonincreasing x-values for curve" -ERROR_CODE['233'] = "network has unconnected nodes" -ERROR_CODE['234'] = "network has an unconnected node with ID: " - -# These errors apply only to API functions -ERROR_CODE['240'] = "nonexistent source" -ERROR_CODE['241'] = "nonexistent control" -ERROR_CODE['250'] = "invalid format" -ERROR_CODE['251'] = "invalid parameter code" -ERROR_CODE['252'] = "invalid ID name" -ERROR_CODE['253'] = "nonexistent demand category" -ERROR_CODE['254'] = "node with no coordinates" -ERROR_CODE['255'] = "invalid link vertex" -ERROR_CODE['257'] = "nonexistent rule" -ERROR_CODE['258'] = "nonexistent rule clause" -ERROR_CODE['259'] = "attempt to delete a node that still has links connected to it" -ERROR_CODE['260'] = "attempt to delete node assigned as a Trace Node" -ERROR_CODE['261'] = "attempt to delete a node or link contained in a control" -ERROR_CODE['262'] = "attempt to modify network structure while solver is active" -ERROR_CODE['263'] = "node is not a tank" - -# File errors -ERROR_CODE['301'] = "identical file names" -ERROR_CODE['302'] = "cannot open input file" -ERROR_CODE['303'] = "cannot open report file" -ERROR_CODE['304'] = "cannot open binary output file" -ERROR_CODE['305'] = "cannot open hydraulics file" -ERROR_CODE['306'] = "hydraulics file does not match network data" -ERROR_CODE['307'] = "cannot read hydraulics file" -ERROR_CODE['308'] = "cannot save results to file" -ERROR_CODE['309'] = "cannot save results to report file" - -ERROR_CODE['411'] = "Input Error 411: no memory allocated for results" -ERROR_CODE['412'] = "Input Error 412: binary file hasn't been opened" -ERROR_CODE['421'] = "Input Error 421: invalid parameter code" -ERROR_CODE['422'] = "Input Error 422: reporting period index out of range" -ERROR_CODE['423'] = "Input Error 423: element index out of range" - -ERROR_CODE['434'] = "File Error 434: unable to open binary file" -ERROR_CODE['435'] = "File Error 435: invalid binary file type" -ERROR_CODE['436'] = "File Error 436: no results in binary file" - -ERROR_CODE['ERR'] = "Error: An unknown error has occurred" diff --git a/epanet/epanet2_vs_3.md b/epanet/epanet2_vs_3.md deleted file mode 100644 index c66a9b6..0000000 --- a/epanet/epanet2_vs_3.md +++ /dev/null @@ -1,187 +0,0 @@ -### Introduction - -This document summarizes how EPANET 3 differs from EPANET 2. - -_ALL ITEMS ARE SUBJECT TO CHANGE AS EPANET 3 UNDERGOES ADDITIONAL DEVELOPMENT._ - -### Input File Format - -EPANET 3 is capable of reading EPANET 2 input files. However several keywords in the **[OPTIONS]** section of the file were changed to provide more clarity and consistency. The changes are as follows: - -| Old Keyword | New Keyword | -| ------------------ | -------------------- | -| UNITS | FLOW_UNITS | -| PRESSURE | PRESSURE_UNITS | -| HEADLOSS | HEADLOSS_MODEL | -| QUALITY | QUALITY_MODEL | -| VISCOSITY | SPECIFIC_VISCOSITY | -| DIFFUSIVITY | SPECIFIC_DIFFUSIVITY | -| SPECIFIC GRAVITY | SPECIFIC_GRAVITY | -| TRIALS | MAXIMUM_TRIALS | -| ACCURACY | RELATIVE_ACCURACY | -| UNBALANCED | IF_UNBALANCED | -| PATTERN | DEMAND_PATTERN | -| DEMAND MULTIPLIER | DEMAND_MULTIPLIER | -| EMITTER EXPONENT | EMITTER_EXPONENT | -| TOLERANCE | QUALITY_TOLERANCE | -| HYDRAULICS | HYDRAULICS_FILE | -| MAP | MAP_FILE | -| CHECKFREQ | deprecated | -| MAXCHECK | deprecated | -| DAMPlIMIT | deprecated | - -In addition, a number of new keywords have been added to the **[OPTIONS]** section to implement new features added to the code. These are listed below and are covered in more detail in other sections of this document. - -| New Option Keyword | Meaning | -| -------------------- | ------------------------------------------------ | -| DEMAND_MODEL | Choice of pressure-dependent demand model | -| LEAKAGE_MODEL | Choice of pipe leakage model | -| HYDRAULIC_SOLVER | Choice of hydraulic solver | -| MATRIX_SOLVER | Choice of linear equation solver | -| HEAD_TOLERANCE | Tolerance in satisfying head loss equations | -| FLOW_TOLERANCE | Tolerance in satisfying flow continuity | -| FLOW_CHANGE_LIMIT | Convergence limit on link flow change | -| STEP_SIZING | Choice of step sizing method in solving hydraulics | -| TIME_WEIGHT | Backwards difference weight for dynamic tanks | -| MINIMUM_PRESSURE | Global pressure below which demand is zero | -| SERVICE_PRESSURE | Global pressure above which full demand is met | -| PRESSURE_EXPONENT | Global exponent in power demand model | -| LEAKAGE_COEFF1 | Global coefficient used for pipe leakage | -| LEAKAGE_COEFF2 | Global coefficient used for pipe leakage | -| QUALITY_NAME | Name of chemical in water quality analysis | -| QUALITY_UNITS | Concentration units of water quality chemical | -| TRACE_NODE | Name of source node in a water quality trace | - -The **_DURATION_** keyword in the **[TIMES]** section of the file has been replaced with **_TOTAL DURATION_** to make it compatible with the other [TIMES] options that use a pair of keywords. - -In the **[REPORT]** section of the file, **_PAGESIZE_** has been deprecated and the **_STATUS_** option has been split into two separate options, **_STATUS_** **YES/NO** for status reporting and **_TRIALS_** **YES/NO** for reporting individual trials of the hydraulic solver. - -Finally, the names used to identify network elements (e.g., nodes, links, patterns, curves, etc.) are no longer limited to 31 characters. They are, however, still case sensitive. - -### Models and Solvers - -The computational elements in EPANET can be broken down into models for representing particular aspects of network behavior (e.g., pipe head loss, pressure-dependent demands, water quality reactions, etc.) and solvers that compute output results (e.g., hydraulic, sparse matrix, and water quality solvers). EPANET 3 is structured so that its models and solvers are represented by a set of abstract classes that adhere to a specific interface. This makes it easier (in theory) to add alternative models and solvers in the future with a minimum of disruption to the existing code base. The table below lists the **[OPTIONS]** keywords used to specify a choice of model or solver. - -| Option Keyword | Available Choices | -| ---------------- | ------------------------------ | -| HEADLOSS_MODEL | H-W (Hazen-Williams) | -| | D-W (Darcy-Weisbach) | -| | C-M (Chezy-Manning) | -| DEMAND_MODEL | FIXED | -| | CONSTRAINED | -| | POWER | -| | LOGISTIC | -| LEAKAGE_MODEL | NONE | -| | POWER | -| | FAVAD | -| QUALITY_MODEL | NONE | -| | CHEMICAL | -| | TRACE | -| | AGE | -| HYDRAULIC_SOLVER | GGA (Global Gradient Algorithm | -| QUALITY_SOLVER | LTD (Lagrangian Time Driven) | -| MATRIX_SOLVER | SPARSPAK | - -Right now there is only a single choice of each solver but additional alternatives could be added at a later date. Implementations of the various models and solvers can be found in the _Models/_ and _Solvers/_ directories, respectively. - -### API (Toolkit) Usage - -The way in which the API functions are used to analyze a network have changed. The differences between the version 2 and 3 APIs can be summarized as follows: -* Function names now begin with an "EN_" prefix followed by a name in lower camel case. -* You must first call **_EN_createProject_** to create an EPANET project object before using other API functions that include the project as an argument. This allows one to use parallel processing on a number of different projects in a thread safe manner. -* **_ENopen_** has been replaced with **_EN_openReportFile_**, **_EN_openOutputFile_**, and **_EN_loadProject_**. -* **_EN_initSolver_** replaces **_ENopenH_**, **_ENinitH_**, **_ENopenQ_** and **_ENinitQ_**. -* **_EN_runSolver_** replaces **_ENrunH_** for computing hydraulics at the current time period. -* **_EN_advanceSolver_** replaces **_ENnextH_**, **_EN_runQ_**, and **_ENnextQ_**. It advances the simulation to the next time when hydraulics are to be updated while computing water quality over this time interval as need be. -* As implied by the previous item, water quality is now run simultaneously with hydraulics. There is no need to run hydraulics for all time periods first before solving for water quality. -* There is no longer a need for functions like **_ENcloseH_** and **_ENcloseQ_**. You only need to call **_EN_deleteProject_** after all analysis of a project has been completed to insure that all memory is properly released. - -Here is an example of using the new API to run a complete simulation: - -``` -#include "epanet3.h" -void myEpanet3Runner(char* inpFile, char* rptFile) -{ - int t = 0, dt = 0; - EN_Project p = EN_createProject(); - EN_openReportFile(rptFile, p); - EN_loadProject(inpFile, p); - EN_openOutputFile("", p); - EN_initSolver(EN_NOINITFLOW, p); - do { - EN_runSolver(&t, p); - EN_advanceSolver(&dt, p); - } while ( dt > 0 ); - EN_writeReport(p); - EN_deleteProject(p); -} -``` - -### Pressure Dependent Demands - -EPANET 3 offers four different ways of handling consumer demands at network nodes through its **_DEMAND_MODEL_** option: -- **FIXED** (demands are fixed values not dependent on pressure) -- **CONSTRAINED** (demands are reduced so that no net negative pressures occur) -- **POWER** (a node's demand varies as a power function of pressure) -- **LOGISTIC** (a node's demand varies as a logistic function of pressure). - -The **_MINIMUM_PRESSURE_** option is used with choices 2 - 4 to set a pressure below which demand will be 0. Its default value is 0. The **_SERVICE_PRESSURE_** option is used with choices 3 and 4 to set a pressure above which a node's full demand is supplied. The **_PRESSURE_EXPONENT_** option sets the exponent used for **POWER** function demands. - -The implementation of these methods can be found in the _Models/demandmodel.h_ and _Models/demandmodel.cpp_ files as well as in _Core/hydengine.cpp_ for the **CONSTRAINED** option. - -### Pipe Leakage - -Pressure dependent pipe leakage can now be modeled using the new **_LEAKAGE_MODEL_** option. The choices are: -- **NONE** for no leakage modeling. -- **POWER** : -- **FAVAD** : - -For the **Power** model the leakage rate is in flow units/1000 length units of pipe (ft or m), P is the average pressure (psi or m) across the pipe and C1 and C2 are user supplied coefficients. For the **FAVAD** model, the leakage rate is cfs/1000 ft (or cms/km) of pipe, P is the average pressure head (ft or m) across the pipe, C1 is the area (sq. ft. or sq. m) of leaks per 1000 ft or m of pipe and C2 is the change in leakage area per change in pressure head per 1000 length units of pipe. - -The leakage coefficients can be supplied on a global basis using the new option keywords **_LEAKAGE_COEFF1_** and **_LEAKAGE_COEFF2_**. Their default values are 0. The coefficients can also be be supplied on an individual pipe basis by adding a **[LEAKAGE]** section to the input file where each line contains a pipe name and a pair of coefficients. Computed leakage rates are split 50-50 to outflow from the pipe's end nodes. - -Pipe leakage is implemented in the files _Models/leakagemodel.h_, _Models/leakagemodel.cpp_, and _Core/hydbalance.cpp_. - -### Hydraulic Convergence Criteria - -In EPANET 2, convergence to an acceptable hydraulic solution occurred when the sum of all link flow changes divided by the sum of all link flows was below the **_ACCURACY_** (re-named to **_RELATIVE_ACCURACY_**) option value. Unfortunately meeting this criterion did not always guarantee that the network was hydraulically balanced (e.g., that the head loss computed from the flow in each link equaled the difference between the computed heads at the link's end nodes). EPANET 3 introduces a more rigorous set of criteria consisting of the following options: -- **_HEAD_TOLERANCE_** --- the difference between the computed head loss in each link and the heads at its end nodes must be below this value. -- **_FLOW_TOLERANCE_** --- the difference between inflow and outflow at all non-fixed grade nodes must be below this value. -- **_FLOW_CHANGE_LIMIT_** --- the largest change in link flow rate must be below this value. - -The units of the head tolerance are feet (or meters) while the user's choice of flow units apply to the other two. A value of 0 indicates that the criterion doesn't apply. See _Core/hydbalance.h_ and _Core/hydbalance.cpp_ for how the convergence criteria are calculated. - -### Tank Dynamics - -EPANET 2 used a foward difference (or Euler) method to approximate the change in storage tank water level over a time step as a function of the current flows within the network. This could cause instabilities to occur in and around tanks that were hydraulically coupled to one another. To remedy this, EPANET 3 models tank dynamics using the time weighted implicit formula proposed by Todini (2011). A new option named **_TIME_WEIGHT_** sets the weight to be used in this formulation. A value of 0 maintains the forward difference formula of EPANET 2 while a value of 1.0 results in a fully backwards difference formulation. - -### Low Resistance Pipes - -When using the Hazen-Williams (H-W) head loss equation, EPANET 2's hydraulic solver can have problems converging for networks with low resistance or zero flow pipes. To help avoid this, EPANET 3 employs a linear head loss relationship whenever the H-W head loss gradient drops below a minimum threshold (currently set at 1.0e-6 ft/cfs). - -### Check Valves - -The method used by EPANET 2 to find the head loss through an active check valve produced discontinuous gradients and was overly complicated. EPANET 3 uses a simple continuous "barrier" function that is added onto the pipe's normal head loss. It rises rapidly when flow is in the wrong direction but otherwise approaches 0. The details of this function can be found in the _Models/headlossmodel.cpp_ file. - -### Output Variables - -The following quantities have been added to the set of computed results that can be retrieved through the API toolkit: -* node actual demand (which can be less than the full demand due to pressure dependency) -* node total outflow (consisting of actual demand, leakage flow, and emitter flow) -* link leakage flow -* link water quality - -### Binary Output File Format - -The binary file used to store computed results has been modified from the EPANET 2 format to include the new variables reported by EPANET 3. In addition, the file no longer includes the ID names and design data of nodes and links in its prolog section. The new binary file format can be gleaned from the code found in _Output/outputfile.cpp_. - -### Additional Changes -* Emitters are prevented from having flow back into the network. -* The gradient of the Darcy-Weisbach head loss equation now includes the derivative of the friction factor. -* Proper adjustment of the efficiency curve is now made for variable speed pumps. - -### References -Todini (2011) Extending the global gradient algorithm to unsteadyflow extended period simulations of water distributionsystems. Journal of Hydroinformatics, 13(2):167-180 diff --git a/epanet/vcruntime140_1.dll b/epanet/vcruntime140_1.dll deleted file mode 100644 index 3ebabdee66002f6a577fac2e55649ab2f2cc3fe6..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 44312 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 DZTf$7

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 z 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 diff --git a/epanet/epanet2-2.3.0.dll b/epanet/epanet2-2.3.0.dll deleted file mode 100644 index 2a3cab1e84116b9eba9b37c02007428ab63a1cdc..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 466944 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 +nuZN`Z6W5c*u!{=x(##(kMe_PxUC)$(T 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®SK9;{bP@A~Q= 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