Skip to content

Instantly share code, notes, and snippets.

@tvoinarovskyi
Last active September 27, 2017 15:19
Show Gist options
  • Save tvoinarovskyi/574712fe3eb4d27e1c0cb6ce41af383b to your computer and use it in GitHub Desktop.
Save tvoinarovskyi/574712fe3eb4d27e1c0cb6ce41af383b to your computer and use it in GitHub Desktop.
/* Generated by Cython 0.27 */
#define PY_SSIZE_T_CLEAN
#include "Python.h"
#ifndef Py_PYTHON_H
#error Python headers needed to compile C extensions, please install development version of Python.
#elif PY_VERSION_HEX < 0x02060000 || (0x03000000 <= PY_VERSION_HEX && PY_VERSION_HEX < 0x03030000)
#error Cython requires Python 2.6+ or Python 3.3+.
#else
#define CYTHON_ABI "0_27"
#define CYTHON_FUTURE_DIVISION 1
#include <stddef.h>
#ifndef offsetof
#define offsetof(type, member) ( (size_t) & ((type*)0) -> member )
#endif
#if !defined(WIN32) && !defined(MS_WINDOWS)
#ifndef __stdcall
#define __stdcall
#endif
#ifndef __cdecl
#define __cdecl
#endif
#ifndef __fastcall
#define __fastcall
#endif
#endif
#ifndef DL_IMPORT
#define DL_IMPORT(t) t
#endif
#ifndef DL_EXPORT
#define DL_EXPORT(t) t
#endif
#define __PYX_COMMA ,
#ifndef HAVE_LONG_LONG
#if PY_VERSION_HEX >= 0x02070000
#define HAVE_LONG_LONG
#endif
#endif
#ifndef PY_LONG_LONG
#define PY_LONG_LONG LONG_LONG
#endif
#ifndef Py_HUGE_VAL
#define Py_HUGE_VAL HUGE_VAL
#endif
#ifdef PYPY_VERSION
#define CYTHON_COMPILING_IN_PYPY 1
#define CYTHON_COMPILING_IN_PYSTON 0
#define CYTHON_COMPILING_IN_CPYTHON 0
#undef CYTHON_USE_TYPE_SLOTS
#define CYTHON_USE_TYPE_SLOTS 0
#undef CYTHON_USE_PYTYPE_LOOKUP
#define CYTHON_USE_PYTYPE_LOOKUP 0
#if PY_VERSION_HEX < 0x03050000
#undef CYTHON_USE_ASYNC_SLOTS
#define CYTHON_USE_ASYNC_SLOTS 0
#elif !defined(CYTHON_USE_ASYNC_SLOTS)
#define CYTHON_USE_ASYNC_SLOTS 1
#endif
#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_ASSUME_SAFE_MACROS
#define CYTHON_ASSUME_SAFE_MACROS 0
#undef CYTHON_UNPACK_METHODS
#define CYTHON_UNPACK_METHODS 0
#undef CYTHON_FAST_THREAD_STATE
#define CYTHON_FAST_THREAD_STATE 0
#undef CYTHON_FAST_PYCALL
#define CYTHON_FAST_PYCALL 0
#undef CYTHON_PEP489_MULTI_PHASE_INIT
#define CYTHON_PEP489_MULTI_PHASE_INIT 0
#undef CYTHON_USE_TP_FINALIZE
#define CYTHON_USE_TP_FINALIZE 0
#elif defined(PYSTON_VERSION)
#define CYTHON_COMPILING_IN_PYPY 0
#define CYTHON_COMPILING_IN_PYSTON 1
#define CYTHON_COMPILING_IN_CPYTHON 0
#ifndef CYTHON_USE_TYPE_SLOTS
#define CYTHON_USE_TYPE_SLOTS 1
#endif
#undef CYTHON_USE_PYTYPE_LOOKUP
#define CYTHON_USE_PYTYPE_LOOKUP 0
#undef CYTHON_USE_ASYNC_SLOTS
#define CYTHON_USE_ASYNC_SLOTS 0
#undef CYTHON_USE_PYLIST_INTERNALS
#define CYTHON_USE_PYLIST_INTERNALS 0
#ifndef CYTHON_USE_UNICODE_INTERNALS
#define CYTHON_USE_UNICODE_INTERNALS 1
#endif
#undef CYTHON_USE_UNICODE_WRITER
#define CYTHON_USE_UNICODE_WRITER 0
#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_ASSUME_SAFE_MACROS
#define CYTHON_ASSUME_SAFE_MACROS 1
#endif
#ifndef CYTHON_UNPACK_METHODS
#define CYTHON_UNPACK_METHODS 1
#endif
#undef CYTHON_FAST_THREAD_STATE
#define CYTHON_FAST_THREAD_STATE 0
#undef CYTHON_FAST_PYCALL
#define CYTHON_FAST_PYCALL 0
#undef CYTHON_PEP489_MULTI_PHASE_INIT
#define CYTHON_PEP489_MULTI_PHASE_INIT 0
#undef CYTHON_USE_TP_FINALIZE
#define CYTHON_USE_TP_FINALIZE 0
#else
#define CYTHON_COMPILING_IN_PYPY 0
#define CYTHON_COMPILING_IN_PYSTON 0
#define CYTHON_COMPILING_IN_CPYTHON 1
#ifndef CYTHON_USE_TYPE_SLOTS
#define CYTHON_USE_TYPE_SLOTS 1
#endif
#if PY_VERSION_HEX < 0x02070000
#undef CYTHON_USE_PYTYPE_LOOKUP
#define CYTHON_USE_PYTYPE_LOOKUP 0
#elif !defined(CYTHON_USE_PYTYPE_LOOKUP)
#define CYTHON_USE_PYTYPE_LOOKUP 1
#endif
#if PY_MAJOR_VERSION < 3
#undef CYTHON_USE_ASYNC_SLOTS
#define CYTHON_USE_ASYNC_SLOTS 0
#elif !defined(CYTHON_USE_ASYNC_SLOTS)
#define CYTHON_USE_ASYNC_SLOTS 1
#endif
#if PY_VERSION_HEX < 0x02070000
#undef CYTHON_USE_PYLONG_INTERNALS
#define CYTHON_USE_PYLONG_INTERNALS 0
#elif !defined(CYTHON_USE_PYLONG_INTERNALS)
#define CYTHON_USE_PYLONG_INTERNALS 1
#endif
#ifndef CYTHON_USE_PYLIST_INTERNALS
#define CYTHON_USE_PYLIST_INTERNALS 1
#endif
#ifndef CYTHON_USE_UNICODE_INTERNALS
#define CYTHON_USE_UNICODE_INTERNALS 1
#endif
#if PY_VERSION_HEX < 0x030300F0
#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
#ifndef CYTHON_ASSUME_SAFE_MACROS
#define CYTHON_ASSUME_SAFE_MACROS 1
#endif
#ifndef CYTHON_UNPACK_METHODS
#define CYTHON_UNPACK_METHODS 1
#endif
#ifndef CYTHON_FAST_THREAD_STATE
#define CYTHON_FAST_THREAD_STATE 1
#endif
#ifndef CYTHON_FAST_PYCALL
#define CYTHON_FAST_PYCALL 1
#endif
#ifndef CYTHON_PEP489_MULTI_PHASE_INIT
#define CYTHON_PEP489_MULTI_PHASE_INIT (PY_VERSION_HEX >= 0x03050000)
#endif
#ifndef CYTHON_USE_TP_FINALIZE
#define CYTHON_USE_TP_FINALIZE (PY_VERSION_HEX >= 0x030400a1)
#endif
#endif
#if !defined(CYTHON_FAST_PYCCALL)
#define CYTHON_FAST_PYCCALL (CYTHON_FAST_PYCALL && PY_VERSION_HEX >= 0x030600B1)
#endif
#if CYTHON_USE_PYLONG_INTERNALS
#include "longintrepr.h"
#undef SHIFT
#undef BASE
#undef MASK
#endif
#if CYTHON_COMPILING_IN_PYPY && PY_VERSION_HEX < 0x02070600 && !defined(Py_OptimizeFlag)
#define Py_OptimizeFlag 0
#endif
#define __PYX_BUILD_PY_SSIZE_T "n"
#define CYTHON_FORMAT_SSIZE_T "z"
#if PY_MAJOR_VERSION < 3
#define __Pyx_BUILTIN_MODULE_NAME "__builtin__"
#define __Pyx_PyCode_New(a, 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)
#define __Pyx_DefaultClassType PyClass_Type
#else
#define __Pyx_BUILTIN_MODULE_NAME "builtins"
#define __Pyx_PyCode_New(a, 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)
#define __Pyx_DefaultClassType PyType_Type
#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
#if PY_VERSION_HEX < 0x030700A0 || !defined(METH_FASTCALL)
#ifndef METH_FASTCALL
#define METH_FASTCALL 0x80
#endif
typedef PyObject *(*__Pyx_PyCFunctionFast) (PyObject *self, PyObject **args, Py_ssize_t nargs);
typedef PyObject *(*__Pyx_PyCFunctionFastWithKeywords) (PyObject *self, PyObject **args,
Py_ssize_t nargs, PyObject *kwnames);
#else
#define __Pyx_PyCFunctionFast _PyCFunctionFast
#define __Pyx_PyCFunctionFastWithKeywords _PyCFunctionFastWithKeywords
#endif
#if CYTHON_FAST_PYCCALL
#define __Pyx_PyFastCFunction_Check(func)\
((PyCFunction_Check(func) && (METH_FASTCALL == (PyCFunction_GET_FLAGS(func) & ~(METH_CLASS | METH_STATIC | METH_COEXIST | METH_KEYWORDS)))))
#else
#define __Pyx_PyFastCFunction_Check(func) 0
#endif
#if !CYTHON_FAST_THREAD_STATE || PY_VERSION_HEX < 0x02070000
#define __Pyx_PyThreadState_Current PyThreadState_GET()
#elif PY_VERSION_HEX >= 0x03050200
#define __Pyx_PyThreadState_Current _PyThreadState_UncheckedGet()
#elif PY_VERSION_HEX >= 0x03000000
#define __Pyx_PyThreadState_Current PyThreadState_Get()
#else
#define __Pyx_PyThreadState_Current _PyThreadState_Current
#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
#if PY_MAJOR_VERSION >= 3 || CYTHON_FUTURE_DIVISION
#define __Pyx_PyNumber_Divide(x,y) PyNumber_TrueDivide(x,y)
#define __Pyx_PyNumber_InPlaceDivide(x,y) PyNumber_InPlaceTrueDivide(x,y)
#else
#define __Pyx_PyNumber_Divide(x,y) PyNumber_Divide(x,y)
#define __Pyx_PyNumber_InPlaceDivide(x,y) PyNumber_InPlaceDivide(x,y)
#endif
#if PY_VERSION_HEX > 0x03030000 && defined(PyUnicode_KIND)
#define CYTHON_PEP393_ENABLED 1
#define __Pyx_PyUnicode_READY(op) (likely(PyUnicode_IS_READY(op)) ?\
0 : _PyUnicode_Ready((PyObject *)(op)))
#define __Pyx_PyUnicode_GET_LENGTH(u) PyUnicode_GET_LENGTH(u)
#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) 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, ch)
#define __Pyx_PyUnicode_IS_TRUE(u) (0 != (likely(PyUnicode_IS_READY(u)) ? PyUnicode_GET_LENGTH(u) : PyUnicode_GET_SIZE(u)))
#else
#define CYTHON_PEP393_ENABLED 0
#define PyUnicode_1BYTE_KIND 1
#define PyUnicode_2BYTE_KIND 2
#define PyUnicode_4BYTE_KIND 4
#define __Pyx_PyUnicode_READY(op) (0)
#define __Pyx_PyUnicode_GET_LENGTH(u) PyUnicode_GET_SIZE(u)
#define __Pyx_PyUnicode_READ_CHAR(u, i) ((Py_UCS4)(PyUnicode_AS_UNICODE(u)[i]))
#define __Pyx_PyUnicode_MAX_CHAR_VALUE(u) ((sizeof(Py_UNICODE) == 2) ? 65535 : 1114111)
#define __Pyx_PyUnicode_KIND(u) (sizeof(Py_UNICODE))
#define __Pyx_PyUnicode_DATA(u) ((void*)PyUnicode_AS_UNICODE(u))
#define __Pyx_PyUnicode_READ(k, d, i) ((void)(k), (Py_UCS4)(((Py_UNICODE*)d)[i]))
#define __Pyx_PyUnicode_WRITE(k, d, i, ch) (((void)(k)), ((Py_UNICODE*)d)[i] = ch)
#define __Pyx_PyUnicode_IS_TRUE(u) (0 != PyUnicode_GET_SIZE(u))
#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 && !defined(PyUnicode_Contains)
#define PyUnicode_Contains(u, s) PySequence_Contains(u, s)
#endif
#if CYTHON_COMPILING_IN_PYPY && !defined(PyByteArray_Check)
#define PyByteArray_Check(obj) PyObject_TypeCheck(obj, &PyByteArray_Type)
#endif
#if CYTHON_COMPILING_IN_PYPY && !defined(PyObject_Format)
#define PyObject_Format(obj, fmt) PyObject_CallMethod(obj, "__format__", "O", fmt)
#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_PYSTON
#define __Pyx_PyCode_HasFreeVars(co) PyCode_HasFreeVars(co)
#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
#define __Pyx_PyString_FormatSafe(a, b) ((unlikely((a) == Py_None)) ? PyNumber_Remainder(a, b) : __Pyx_PyString_Format(a, b))
#define __Pyx_PyUnicode_FormatSafe(a, b) ((unlikely((a) == Py_None)) ? PyNumber_Remainder(a, b) : PyUnicode_Format(a, b))
#if PY_MAJOR_VERSION >= 3
#define __Pyx_PyString_Format(a, b) PyUnicode_Format(a, b)
#else
#define __Pyx_PyString_Format(a, b) PyString_Format(a, b)
#endif
#if PY_MAJOR_VERSION < 3 && !defined(PyObject_ASCII)
#define PyObject_ASCII(o) PyObject_Repr(o)
#endif
#if PY_MAJOR_VERSION >= 3
#define PyBaseString_Type PyUnicode_Type
#define PyStringObject PyUnicodeObject
#define PyString_Type PyUnicode_Type
#define PyString_Check PyUnicode_Check
#define PyString_CheckExact PyUnicode_CheckExact
#endif
#if PY_MAJOR_VERSION >= 3
#define __Pyx_PyBaseString_Check(obj) PyUnicode_Check(obj)
#define __Pyx_PyBaseString_CheckExact(obj) PyUnicode_CheckExact(obj)
#else
#define __Pyx_PyBaseString_Check(obj) (PyString_Check(obj) || PyUnicode_Check(obj))
#define __Pyx_PyBaseString_CheckExact(obj) (PyString_CheckExact(obj) || PyUnicode_CheckExact(obj))
#endif
#ifndef PySet_CheckExact
#define PySet_CheckExact(obj) (Py_TYPE(obj) == &PySet_Type)
#endif
#define __Pyx_PyException_Check(obj) __Pyx_TypeCheck(obj, PyExc_Exception)
#if PY_MAJOR_VERSION >= 3
#define PyIntObject PyLongObject
#define PyInt_Type PyLong_Type
#define PyInt_Check(op) PyLong_Check(op)
#define PyInt_CheckExact(op) PyLong_CheckExact(op)
#define PyInt_FromString PyLong_FromString
#define PyInt_FromUnicode PyLong_FromUnicode
#define PyInt_FromLong PyLong_FromLong
#define PyInt_FromSize_t PyLong_FromSize_t
#define PyInt_FromSsize_t PyLong_FromSsize_t
#define PyInt_AsLong PyLong_AsLong
#define PyInt_AS_LONG PyLong_AS_LONG
#define PyInt_AsSsize_t PyLong_AsSsize_t
#define PyInt_AsUnsignedLongMask PyLong_AsUnsignedLongMask
#define PyInt_AsUnsignedLongLongMask PyLong_AsUnsignedLongLongMask
#define PyNumber_Int PyNumber_Long
#endif
#if PY_MAJOR_VERSION >= 3
#define PyBoolObject PyLongObject
#endif
#if PY_MAJOR_VERSION >= 3 && CYTHON_COMPILING_IN_PYPY
#ifndef PyUnicode_InternFromString
#define PyUnicode_InternFromString(s) PyUnicode_FromString(s)
#endif
#endif
#if PY_VERSION_HEX < 0x030200A4
typedef long Py_hash_t;
#define __Pyx_PyInt_FromHash_t PyInt_FromLong
#define __Pyx_PyInt_AsHash_t PyInt_AsLong
#else
#define __Pyx_PyInt_FromHash_t PyInt_FromSsize_t
#define __Pyx_PyInt_AsHash_t PyInt_AsSsize_t
#endif
#if PY_MAJOR_VERSION >= 3
#define __Pyx_PyMethod_New(func, self, klass) ((self) ? PyMethod_New(func, self) : PyInstanceMethod_New(func))
#else
#define __Pyx_PyMethod_New(func, self, klass) PyMethod_New(func, self, klass)
#endif
#ifndef __has_attribute
#define __has_attribute(x) 0
#endif
#ifndef __has_cpp_attribute
#define __has_cpp_attribute(x) 0
#endif
#if CYTHON_USE_ASYNC_SLOTS
#if PY_VERSION_HEX >= 0x030500B1
#define __Pyx_PyAsyncMethodsStruct PyAsyncMethods
#define __Pyx_PyType_AsAsync(obj) (Py_TYPE(obj)->tp_as_async)
#else
#define __Pyx_PyType_AsAsync(obj) ((__Pyx_PyAsyncMethodsStruct*) (Py_TYPE(obj)->tp_reserved))
#endif
#else
#define __Pyx_PyType_AsAsync(obj) NULL
#endif
#ifndef __Pyx_PyAsyncMethodsStruct
typedef struct {
unaryfunc am_await;
unaryfunc am_aiter;
unaryfunc am_anext;
} __Pyx_PyAsyncMethodsStruct;
#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(__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_MAYBE_UNUSED_VAR
# if defined(__cplusplus)
template<class T> void CYTHON_MAYBE_UNUSED_VAR( const T& ) { }
# else
# define CYTHON_MAYBE_UNUSED_VAR(x) (void)(x)
# endif
#endif
#ifndef CYTHON_NCP_UNUSED
# if CYTHON_COMPILING_IN_CPYTHON
# define CYTHON_NCP_UNUSED
# else
# define CYTHON_NCP_UNUSED CYTHON_UNUSED
# 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 int uint32_t;
#else
typedef unsigned __int8 uint8_t;
typedef unsigned __int32 uint32_t;
#endif
#endif
#else
#include <stdint.h>
#endif
#ifndef CYTHON_FALLTHROUGH
#ifdef __cplusplus
#if __has_cpp_attribute(fallthrough)
#define CYTHON_FALLTHROUGH [[fallthrough]]
#elif __has_cpp_attribute(clang::fallthrough)
#define CYTHON_FALLTHROUGH [[clang::fallthrough]]
#endif
#endif
#ifndef CYTHON_FALLTHROUGH
#if __has_attribute(fallthrough) || (defined(__GNUC__) && defined(__attribute__))
#define CYTHON_FALLTHROUGH __attribute__((fallthrough))
#else
#define CYTHON_FALLTHROUGH
#endif
#endif
#endif
#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
#if defined(WIN32) || defined(MS_WINDOWS)
#define _USE_MATH_DEFINES
#endif
#include <math.h>
#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
#define __PYX_ERR(f_index, lineno, Ln_error) \
{ \
__pyx_filename = __pyx_f[f_index]; __pyx_lineno = lineno; __pyx_clineno = __LINE__; goto Ln_error; \
}
#ifndef __PYX_EXTERN_C
#ifdef __cplusplus
#define __PYX_EXTERN_C extern "C"
#else
#define __PYX_EXTERN_C extern
#endif
#endif
#define __PYX_HAVE__aiokafka__record___legacy_records
#define __PYX_HAVE_API__aiokafka__record___legacy_records
#include <stdint.h>
#include "winsock2.h"
#include "windows.h"
#include <string.h>
#include <stdio.h>
#include "pythread.h"
#ifdef _OPENMP
#include <omp.h>
#endif /* _OPENMP */
#if defined(PYREX_WITHOUT_ASSERTIONS) && !defined(CYTHON_WITHOUT_ASSERTIONS)
#define CYTHON_WITHOUT_ASSERTIONS
#endif
typedef struct {PyObject **p; const char *s; const Py_ssize_t n; const char* encoding;
const char is_unicode; const char is_str; const char intern; } __Pyx_StringTabEntry;
#define __PYX_DEFAULT_STRING_ENCODING_IS_ASCII 0
#define __PYX_DEFAULT_STRING_ENCODING_IS_DEFAULT 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))) )
#if defined (__cplusplus) && __cplusplus >= 201103L
#include <cstdlib>
#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 const char* __Pyx_PyObject_AsString(PyObject*);
static CYTHON_INLINE const char* __Pyx_PyObject_AsStringAndSize(PyObject*, Py_ssize_t* length);
#define __Pyx_PyByteArray_FromString(s) PyByteArray_FromStringAndSize((const char*)s, strlen((const char*)s))
#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 PY_MAJOR_VERSION < 3
#define __Pyx_PyStr_FromString __Pyx_PyBytes_FromString
#define __Pyx_PyStr_FromStringAndSize __Pyx_PyBytes_FromStringAndSize
#else
#define __Pyx_PyStr_FromString __Pyx_PyUnicode_FromString
#define __Pyx_PyStr_FromStringAndSize __Pyx_PyUnicode_FromStringAndSize
#endif
#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_PyObject_AsWritableString(s) ((char*) __Pyx_PyObject_AsString(s))
#define __Pyx_PyObject_AsWritableSString(s) ((signed char*) __Pyx_PyObject_AsString(s))
#define __Pyx_PyObject_AsWritableUString(s) ((unsigned char*) __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_PyStr_FromCString(s) __Pyx_PyStr_FromString((const char*)s)
#define __Pyx_PyUnicode_FromCString(s) __Pyx_PyUnicode_FromString((const char*)s)
static CYTHON_INLINE size_t __Pyx_Py_UNICODE_strlen(const Py_UNICODE *u) {
const Py_UNICODE *u_end = u;
while (*u_end++) ;
return (size_t)(u_end - u - 1);
}
#define __Pyx_PyUnicode_FromUnicode(u) PyUnicode_FromUnicode(u, __Pyx_Py_UNICODE_strlen(u))
#define __Pyx_PyUnicode_FromUnicodeAndLength PyUnicode_FromUnicode
#define __Pyx_PyUnicode_AsUnicode PyUnicode_AsUnicode
#define __Pyx_NewRef(obj) (Py_INCREF(obj), obj)
#define __Pyx_Owned_Py_None(b) __Pyx_NewRef(Py_None)
#define __Pyx_PyBool_FromLong(b) ((b) ? __Pyx_NewRef(Py_True) : __Pyx_NewRef(Py_False))
static CYTHON_INLINE int __Pyx_PyObject_IsTrue(PyObject*);
static CYTHON_INLINE PyObject* __Pyx_PyNumber_IntOrLong(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_PyInt_FromSize_t(size_t);
#if CYTHON_ASSUME_SAFE_MACROS
#define __pyx_PyFloat_AsDouble(x) (PyFloat_CheckExact(x) ? PyFloat_AS_DOUBLE(x) : PyFloat_AsDouble(x))
#else
#define __pyx_PyFloat_AsDouble(x) PyFloat_AsDouble(x)
#endif
#define __pyx_PyFloat_AsFloat(x) ((float) __pyx_PyFloat_AsDouble(x))
#if PY_MAJOR_VERSION >= 3
#define __Pyx_PyNumber_Int(x) (PyLong_CheckExact(x) ? __Pyx_NewRef(x) : PyNumber_Long(x))
#else
#define __Pyx_PyNumber_Int(x) (PyInt_CheckExact(x) ? __Pyx_NewRef(x) : PyNumber_Int(x))
#endif
#define __Pyx_PyNumber_Float(x) (PyFloat_CheckExact(x) ? __Pyx_NewRef(x) : PyNumber_Float(x))
#if PY_MAJOR_VERSION < 3 && __PYX_DEFAULT_STRING_ENCODING_IS_ASCII
static int __Pyx_sys_getdefaultencoding_not_ascii;
static int __Pyx_init_sys_getdefaultencoding_params(void) {
PyObject* sys;
PyObject* default_encoding = NULL;
PyObject* ascii_chars_u = NULL;
PyObject* ascii_chars_b = NULL;
const char* default_encoding_c;
sys = PyImport_ImportModule("sys");
if (!sys) goto bad;
default_encoding = PyObject_CallMethod(sys, (char*) "getdefaultencoding", NULL);
Py_DECREF(sys);
if (!default_encoding) goto bad;
default_encoding_c = PyBytes_AsString(default_encoding);
if (!default_encoding_c) goto bad;
if (strcmp(default_encoding_c, "ascii") == 0) {
__Pyx_sys_getdefaultencoding_not_ascii = 0;
} else {
char ascii_chars[128];
int c;
for (c = 0; c < 128; c++) {
ascii_chars[c] = c;
}
__Pyx_sys_getdefaultencoding_not_ascii = 1;
ascii_chars_u = PyUnicode_DecodeASCII(ascii_chars, 128, NULL);
if (!ascii_chars_u) goto bad;
ascii_chars_b = PyUnicode_AsEncodedString(ascii_chars_u, default_encoding_c, NULL);
if (!ascii_chars_b || !PyBytes_Check(ascii_chars_b) || memcmp(ascii_chars, PyBytes_AS_STRING(ascii_chars_b), 128) != 0) {
PyErr_Format(
PyExc_ValueError,
"This module compiled with c_string_encoding=ascii, but default encoding '%.200s' is not a superset of ascii.",
default_encoding_c);
goto bad;
}
Py_DECREF(ascii_chars_u);
Py_DECREF(ascii_chars_b);
}
Py_DECREF(default_encoding);
return 0;
bad:
Py_XDECREF(default_encoding);
Py_XDECREF(ascii_chars_u);
Py_XDECREF(ascii_chars_b);
return -1;
}
#endif
#if __PYX_DEFAULT_STRING_ENCODING_IS_DEFAULT && PY_MAJOR_VERSION >= 3
#define __Pyx_PyUnicode_FromStringAndSize(c_str, size) PyUnicode_DecodeUTF8(c_str, size, NULL)
#else
#define __Pyx_PyUnicode_FromStringAndSize(c_str, size) PyUnicode_Decode(c_str, size, __PYX_DEFAULT_STRING_ENCODING, NULL)
#if __PYX_DEFAULT_STRING_ENCODING_IS_DEFAULT
static char* __PYX_DEFAULT_STRING_ENCODING;
static int __Pyx_init_sys_getdefaultencoding_params(void) {
PyObject* sys;
PyObject* default_encoding = NULL;
char* default_encoding_c;
sys = PyImport_ImportModule("sys");
if (!sys) goto bad;
default_encoding = PyObject_CallMethod(sys, (char*) (const char*) "getdefaultencoding", NULL);
Py_DECREF(sys);
if (!default_encoding) goto bad;
default_encoding_c = PyBytes_AsString(default_encoding);
if (!default_encoding_c) goto bad;
__PYX_DEFAULT_STRING_ENCODING = (char*) malloc(strlen(default_encoding_c));
if (!__PYX_DEFAULT_STRING_ENCODING) goto bad;
strcpy(__PYX_DEFAULT_STRING_ENCODING, default_encoding_c);
Py_DECREF(default_encoding);
return 0;
bad:
Py_XDECREF(default_encoding);
return -1;
}
#endif
#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__ */
static CYTHON_INLINE void __Pyx_pretend_to_initialize(void* ptr) { (void)ptr; }
static PyObject *__pyx_m;
static PyObject *__pyx_d;
static PyObject *__pyx_b;
static PyObject *__pyx_cython_runtime;
static PyObject *__pyx_empty_tuple;
static PyObject *__pyx_empty_bytes;
static PyObject *__pyx_empty_unicode;
static int __pyx_lineno;
static int __pyx_clineno = 0;
static const char * __pyx_cfilenm= __FILE__;
static const char *__pyx_filename;
static const char *__pyx_f[] = {
"aiokafka\\record\\_legacy_records.pyx",
"stringsource",
"type.pxd",
"bool.pxd",
"complex.pxd",
};
/*--- Type declarations ---*/
struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython;
union __pyx_t_8aiokafka_6record_5_hton__floatconv;
union __pyx_t_8aiokafka_6record_5_hton__doubleconv;
/* "_hton.pxd":55
*
*
* cdef union _floatconv: # <<<<<<<<<<<<<<
* uint32_t i
* float f
*/
union __pyx_t_8aiokafka_6record_5_hton__floatconv {
uint32_t i;
float f;
};
/* "_hton.pxd":72
*
*
* cdef union _doubleconv: # <<<<<<<<<<<<<<
* uint64_t i
* double f
*/
union __pyx_t_8aiokafka_6record_5_hton__doubleconv {
uint64_t i;
double f;
};
/* "aiokafka/record/_legacy_records.pyx":117
*
*
* cdef class _LegacyRecordBatchBuilderCython: # <<<<<<<<<<<<<<
*
* cdef:
*/
struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython {
PyObject_HEAD
struct __pyx_vtabstruct_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *__pyx_vtab;
char _magic;
char _compression_type;
int _batch_size;
PyObject *_buffer;
};
struct __pyx_vtabstruct_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython {
int (*_maybe_compress)(struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *);
};
static struct __pyx_vtabstruct_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *__pyx_vtabptr_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython;
/* --- Runtime support code (head) --- */
/* Refnanny.proto */
#ifndef CYTHON_REFNANNY
#define CYTHON_REFNANNY 0
#endif
#if CYTHON_REFNANNY
typedef struct {
void (*INCREF)(void*, PyObject*, int);
void (*DECREF)(void*, PyObject*, int);
void (*GOTREF)(void*, PyObject*, int);
void (*GIVEREF)(void*, PyObject*, int);
void* (*SetupContext)(const char*, int, const char*);
void (*FinishContext)(void**);
} __Pyx_RefNannyAPIStruct;
static __Pyx_RefNannyAPIStruct *__Pyx_RefNanny = NULL;
static __Pyx_RefNannyAPIStruct *__Pyx_RefNannyImportAPI(const char *modname);
#define __Pyx_RefNannyDeclarations void *__pyx_refnanny = NULL;
#ifdef WITH_THREAD
#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__);\
}
#else
#define __Pyx_RefNannySetupContext(name, acquire_gil)\
__pyx_refnanny = __Pyx_RefNanny->SetupContext((name), __LINE__, __FILE__)
#endif
#define __Pyx_RefNannyFinishContext()\
__Pyx_RefNanny->FinishContext(&__pyx_refnanny)
#define __Pyx_INCREF(r) __Pyx_RefNanny->INCREF(__pyx_refnanny, (PyObject *)(r), __LINE__)
#define __Pyx_DECREF(r) __Pyx_RefNanny->DECREF(__pyx_refnanny, (PyObject *)(r), __LINE__)
#define __Pyx_GOTREF(r) __Pyx_RefNanny->GOTREF(__pyx_refnanny, (PyObject *)(r), __LINE__)
#define __Pyx_GIVEREF(r) __Pyx_RefNanny->GIVEREF(__pyx_refnanny, (PyObject *)(r), __LINE__)
#define __Pyx_XINCREF(r) do { if((r) != NULL) {__Pyx_INCREF(r); }} while(0)
#define __Pyx_XDECREF(r) do { if((r) != NULL) {__Pyx_DECREF(r); }} while(0)
#define __Pyx_XGOTREF(r) do { if((r) != NULL) {__Pyx_GOTREF(r); }} while(0)
#define __Pyx_XGIVEREF(r) do { if((r) != NULL) {__Pyx_GIVEREF(r);}} while(0)
#else
#define __Pyx_RefNannyDeclarations
#define __Pyx_RefNannySetupContext(name, acquire_gil)
#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_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)
/* PyObjectGetAttrStr.proto */
#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);
#if PY_MAJOR_VERSION < 3
if (likely(tp->tp_getattr))
return tp->tp_getattr(obj, PyString_AS_STRING(attr_name));
#endif
return PyObject_GetAttr(obj, attr_name);
}
#else
#define __Pyx_PyObject_GetAttrStr(o,n) PyObject_GetAttr(o,n)
#endif
/* GetBuiltinName.proto */
static PyObject *__Pyx_GetBuiltinName(PyObject *name);
/* GetModuleGlobalName.proto */
static CYTHON_INLINE PyObject *__Pyx_GetModuleGlobalName(PyObject *name);
/* PyCFunctionFastCall.proto */
#if CYTHON_FAST_PYCCALL
static CYTHON_INLINE PyObject *__Pyx_PyCFunction_FastCall(PyObject *func, PyObject **args, Py_ssize_t nargs);
#else
#define __Pyx_PyCFunction_FastCall(func, args, nargs) (assert(0), NULL)
#endif
/* PyFunctionFastCall.proto */
#if CYTHON_FAST_PYCALL
#define __Pyx_PyFunction_FastCall(func, args, nargs)\
__Pyx_PyFunction_FastCallDict((func), (args), (nargs), NULL)
#if 1 || PY_VERSION_HEX < 0x030600B1
static PyObject *__Pyx_PyFunction_FastCallDict(PyObject *func, PyObject **args, int nargs, PyObject *kwargs);
#else
#define __Pyx_PyFunction_FastCallDict(func, args, nargs, kwargs) _PyFunction_FastCallDict(func, args, nargs, kwargs)
#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
/* PyObjectCallOneArg.proto */
static CYTHON_INLINE PyObject* __Pyx_PyObject_CallOneArg(PyObject *func, PyObject *arg);
/* PyThreadStateGet.proto */
#if CYTHON_FAST_THREAD_STATE
#define __Pyx_PyThreadState_declare PyThreadState *__pyx_tstate;
#define __Pyx_PyErr_Occurred() __pyx_tstate->curexc_type
#if PY_VERSION_HEX >= 0x03050000
#define __Pyx_PyThreadState_assign __pyx_tstate = _PyThreadState_UncheckedGet();
#elif PY_VERSION_HEX >= 0x03000000
#define __Pyx_PyThreadState_assign __pyx_tstate = PyThreadState_Get();
#elif PY_VERSION_HEX >= 0x02070000
#define __Pyx_PyThreadState_assign __pyx_tstate = _PyThreadState_Current;
#else
#define __Pyx_PyThreadState_assign __pyx_tstate = PyThreadState_Get();
#endif
#else
#define __Pyx_PyThreadState_declare
#define __Pyx_PyThreadState_assign
#define __Pyx_PyErr_Occurred() 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
#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_ErrRestore(type, value, tb) PyErr_Restore(type, value, tb)
#define __Pyx_ErrFetch(type, value, tb) PyErr_Fetch(type, value, tb)
#endif
/* WriteUnraisableException.proto */
static void __Pyx_WriteUnraisable(const char *name, int clineno,
int lineno, const char *filename,
int full_traceback, int nogil);
/* 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);
/* RaiseDoubleKeywords.proto */
static void __Pyx_RaiseDoubleKeywordsError(const char* func_name, PyObject* kw_name);
/* ParseKeywords.proto */
static int __Pyx_ParseOptionalKeywords(PyObject *kwds, PyObject **argnames[],\
PyObject *kwds2, PyObject *values[], Py_ssize_t num_pos_args,\
const char* function_name);
/* 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
/* GetAttr.proto */
static CYTHON_INLINE PyObject *__Pyx_GetAttr(PyObject *, PyObject *);
/* GetAttr3.proto */
static CYTHON_INLINE PyObject *__Pyx_GetAttr3(PyObject *, PyObject *, PyObject *);
/* Import.proto */
static PyObject *__Pyx_Import(PyObject *name, PyObject *from_list, int level);
/* ImportFrom.proto */
static PyObject* __Pyx_ImportFrom(PyObject* module, PyObject* name);
/* RaiseException.proto */
static void __Pyx_Raise(PyObject *type, PyObject *value, PyObject *tb, PyObject *cause);
/* 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);
/* HasAttr.proto */
static CYTHON_INLINE int __Pyx_HasAttr(PyObject *, PyObject *);
/* SetVTable.proto */
static int __Pyx_SetVtable(PyObject *dict, void *vtable);
/* SetupReduce.proto */
static int __Pyx_setup_reduce(PyObject* type_obj);
/* CLineInTraceback.proto */
static int __Pyx_CLineForTraceback(int c_line);
/* CodeObjectCache.proto */
typedef struct {
PyCodeObject* code_object;
int code_line;
} __Pyx_CodeObjectCacheEntry;
struct __Pyx_CodeObjectCache {
int count;
int max_count;
__Pyx_CodeObjectCacheEntry* entries;
};
static struct __Pyx_CodeObjectCache __pyx_code_cache = {0,0,NULL};
static int __pyx_bisect_code_objects(__Pyx_CodeObjectCacheEntry* entries, int count, int code_line);
static PyCodeObject *__pyx_find_code_object(int code_line);
static void __pyx_insert_code_object(int code_line, PyCodeObject* code_object);
/* AddTraceback.proto */
static void __Pyx_AddTraceback(const char *funcname, int c_line,
int py_line, const char *filename);
/* CIntToPy.proto */
static CYTHON_INLINE PyObject* __Pyx_PyInt_From_int(int value);
/* CIntToPy.proto */
static CYTHON_INLINE PyObject* __Pyx_PyInt_From_char(char value);
/* CIntToPy.proto */
static CYTHON_INLINE PyObject* __Pyx_PyInt_From_long(long value);
/* CIntFromPy.proto */
static CYTHON_INLINE int __Pyx_PyInt_As_int(PyObject *);
/* CIntFromPy.proto */
static CYTHON_INLINE char __Pyx_PyInt_As_char(PyObject *);
/* CIntFromPy.proto */
static CYTHON_INLINE long __Pyx_PyInt_As_long(PyObject *);
/* CIntFromPy.proto */
static CYTHON_INLINE ULONGLONG __Pyx_PyInt_As_ULONGLONG(PyObject *);
/* FastTypeChecks.proto */
#if CYTHON_COMPILING_IN_CPYTHON
#define __Pyx_TypeCheck(obj, type) __Pyx_IsSubtype(Py_TYPE(obj), (PyTypeObject *)type)
static CYTHON_INLINE int __Pyx_IsSubtype(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_PyErr_GivenExceptionMatches(err, type) PyErr_GivenExceptionMatches(err, type)
#define __Pyx_PyErr_GivenExceptionMatches2(err, type1, type2) (PyErr_GivenExceptionMatches(err, type1) || PyErr_GivenExceptionMatches(err, type2))
#endif
/* CheckBinaryVersion.proto */
static int __Pyx_check_binary_version(void);
/* PyIdentifierFromString.proto */
#if !defined(__Pyx_PyIdentifier_FromString)
#if PY_MAJOR_VERSION < 3
#define __Pyx_PyIdentifier_FromString(s) PyString_FromString(s)
#else
#define __Pyx_PyIdentifier_FromString(s) PyUnicode_FromString(s)
#endif
#endif
/* ModuleImport.proto */
static PyObject *__Pyx_ImportModule(const char *name);
/* TypeImport.proto */
static PyTypeObject *__Pyx_ImportType(const char *module_name, const char *class_name, size_t size, int strict);
/* InitStrings.proto */
static int __Pyx_InitStrings(__Pyx_StringTabEntry *t);
static int __pyx_f_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython__maybe_compress(struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *__pyx_v_self); /* proto*/
/* Module declarations from 'aiokafka.record' */
/* Module declarations from 'libc.stdint' */
/* Module declarations from 'aiokafka.record._hton' */
static CYTHON_INLINE void __pyx_f_8aiokafka_6record_5_hton_pack_int32(char *, int32_t); /*proto*/
static CYTHON_INLINE int32_t __pyx_f_8aiokafka_6record_5_hton_unpack_int32(char const *); /*proto*/
static CYTHON_INLINE void __pyx_f_8aiokafka_6record_5_hton_pack_int64(char *, int64_t); /*proto*/
static CYTHON_INLINE int64_t __pyx_f_8aiokafka_6record_5_hton_unpack_int64(char const *); /*proto*/
/* Module declarations from 'cpython.version' */
/* Module declarations from '__builtin__' */
/* Module declarations from 'cpython.type' */
static PyTypeObject *__pyx_ptype_7cpython_4type_type = 0;
/* Module declarations from 'libc.string' */
/* Module declarations from 'libc.stdio' */
/* Module declarations from 'cpython.object' */
/* Module declarations from 'cpython.ref' */
/* Module declarations from 'cpython.exc' */
/* Module declarations from 'cpython.module' */
/* Module declarations from 'cpython.mem' */
/* Module declarations from 'cpython.tuple' */
/* Module declarations from 'cpython.list' */
/* Module declarations from 'cpython.sequence' */
/* Module declarations from 'cpython.mapping' */
/* Module declarations from 'cpython.iterator' */
/* Module declarations from 'cpython.number' */
/* Module declarations from 'cpython.int' */
/* Module declarations from '__builtin__' */
/* Module declarations from 'cpython.bool' */
static PyTypeObject *__pyx_ptype_7cpython_4bool_bool = 0;
/* Module declarations from 'cpython.long' */
/* Module declarations from 'cpython.float' */
/* Module declarations from '__builtin__' */
/* Module declarations from 'cpython.complex' */
static PyTypeObject *__pyx_ptype_7cpython_7complex_complex = 0;
/* Module declarations from 'cpython.string' */
/* Module declarations from 'cpython.unicode' */
/* Module declarations from 'cpython.dict' */
/* Module declarations from 'cpython.instance' */
/* Module declarations from 'cpython.function' */
/* Module declarations from 'cpython.method' */
/* Module declarations from 'cpython.weakref' */
/* Module declarations from 'cpython.getargs' */
/* Module declarations from 'cpython.pythread' */
/* Module declarations from 'cpython.pystate' */
/* Module declarations from 'cpython.cobject' */
/* Module declarations from 'cpython.oldbuffer' */
/* Module declarations from 'cpython.set' */
/* Module declarations from 'cpython.buffer' */
/* Module declarations from 'cpython.bytes' */
/* Module declarations from 'cpython.pycapsule' */
/* Module declarations from 'cpython' */
/* Module declarations from 'cython' */
/* Module declarations from 'aiokafka.record._legacy_records' */
static PyTypeObject *__pyx_ptype_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython = 0;
static long __pyx_f_8aiokafka_6record_15_legacy_records_crc32(unsigned long, unsigned char *, int); /*proto*/
static long __pyx_f_8aiokafka_6record_15_legacy_records_get_time_as_unix_ms(void); /*proto*/
static int __pyx_f_8aiokafka_6record_15_legacy_records__size_in_bytes(char, PyObject *, PyObject *); /*proto*/
static PyObject *__pyx_f_8aiokafka_6record_15_legacy_records__encode_msg(char, int, char *, long, long, PyObject *, PyObject *, char); /*proto*/
static PyObject *__pyx_f_8aiokafka_6record_15_legacy_records___pyx_unpickle__LegacyRecordBatchBuilderCython__set_state(struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *, PyObject *); /*proto*/
#define __Pyx_MODULE_NAME "aiokafka.record._legacy_records"
int __pyx_module_is_main_aiokafka__record___legacy_records = 0;
/* Implementation of 'aiokafka.record._legacy_records' */
static const char __pyx_k_key[] = "key";
static const char __pyx_k_new[] = "__new__";
static const char __pyx_k_dict[] = "__dict__";
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_zlib[] = "zlib";
static const char __pyx_k_crc32[] = "crc32";
static const char __pyx_k_magic[] = "magic";
static const char __pyx_k_value[] = "value";
static const char __pyx_k_import[] = "__import__";
static const char __pyx_k_offset[] = "offset";
static const char __pyx_k_pickle[] = "pickle";
static const char __pyx_k_reduce[] = "__reduce__";
static const char __pyx_k_update[] = "update";
static const char __pyx_k_getstate[] = "__getstate__";
static const char __pyx_k_py_crc32[] = "py_crc32";
static const char __pyx_k_pyx_type[] = "__pyx_type";
static const char __pyx_k_setstate[] = "__setstate__";
static const char __pyx_k_CODEC_LZ4[] = "CODEC_LZ4";
static const char __pyx_k_pyx_state[] = "__pyx_state";
static const char __pyx_k_reduce_ex[] = "__reduce_ex__";
static const char __pyx_k_timestamp[] = "timestamp";
static const char __pyx_k_CODEC_GZIP[] = "CODEC_GZIP";
static const char __pyx_k_batch_size[] = "batch_size";
static const char __pyx_k_lz4_encode[] = "lz4_encode";
static const char __pyx_k_pyx_result[] = "__pyx_result";
static const char __pyx_k_pyx_vtable[] = "__pyx_vtable__";
static const char __pyx_k_PickleError[] = "PickleError";
static const char __pyx_k_gzip_encode[] = "gzip_encode";
static const char __pyx_k_kafka_codec[] = "kafka.codec";
static const char __pyx_k_CODEC_SNAPPY[] = "CODEC_SNAPPY";
static const char __pyx_k_pyx_checksum[] = "__pyx_checksum";
static const char __pyx_k_stringsource[] = "stringsource";
static const char __pyx_k_reduce_cython[] = "__reduce_cython__";
static const char __pyx_k_snappy_encode[] = "snappy_encode";
static const char __pyx_k_pyx_PickleError[] = "__pyx_PickleError";
static const char __pyx_k_setstate_cython[] = "__setstate_cython__";
static const char __pyx_k_compression_type[] = "compression_type";
static const char __pyx_k_cline_in_traceback[] = "cline_in_traceback";
static const char __pyx_k_lz4_encode_old_kafka[] = "lz4_encode_old_kafka";
static const char __pyx_k_pyx_unpickle__LegacyRecordBatc[] = "__pyx_unpickle__LegacyRecordBatchBuilderCython";
static const char __pyx_k_aiokafka_record__legacy_records[] = "aiokafka.record._legacy_records";
static const char __pyx_k_Incompatible_checksums_s_vs_0x53[] = "Incompatible checksums (%s vs 0x53be9b3 = (_batch_size, _buffer, _compression_type, _magic))";
static PyObject *__pyx_n_s_CODEC_GZIP;
static PyObject *__pyx_n_s_CODEC_LZ4;
static PyObject *__pyx_n_s_CODEC_SNAPPY;
static PyObject *__pyx_kp_s_Incompatible_checksums_s_vs_0x53;
static PyObject *__pyx_n_s_PickleError;
static PyObject *__pyx_n_s_aiokafka_record__legacy_records;
static PyObject *__pyx_n_s_batch_size;
static PyObject *__pyx_n_s_cline_in_traceback;
static PyObject *__pyx_n_s_compression_type;
static PyObject *__pyx_n_s_crc32;
static PyObject *__pyx_n_s_dict;
static PyObject *__pyx_n_s_getstate;
static PyObject *__pyx_n_s_gzip_encode;
static PyObject *__pyx_n_s_import;
static PyObject *__pyx_n_s_kafka_codec;
static PyObject *__pyx_n_s_key;
static PyObject *__pyx_n_s_lz4_encode;
static PyObject *__pyx_n_s_lz4_encode_old_kafka;
static PyObject *__pyx_n_s_magic;
static PyObject *__pyx_n_s_main;
static PyObject *__pyx_n_s_name;
static PyObject *__pyx_n_s_new;
static PyObject *__pyx_n_s_offset;
static PyObject *__pyx_n_s_pickle;
static PyObject *__pyx_n_s_py_crc32;
static PyObject *__pyx_n_s_pyx_PickleError;
static PyObject *__pyx_n_s_pyx_checksum;
static PyObject *__pyx_n_s_pyx_result;
static PyObject *__pyx_n_s_pyx_state;
static PyObject *__pyx_n_s_pyx_type;
static PyObject *__pyx_n_s_pyx_unpickle__LegacyRecordBatc;
static PyObject *__pyx_n_s_pyx_vtable;
static PyObject *__pyx_n_s_reduce;
static PyObject *__pyx_n_s_reduce_cython;
static PyObject *__pyx_n_s_reduce_ex;
static PyObject *__pyx_n_s_setstate;
static PyObject *__pyx_n_s_setstate_cython;
static PyObject *__pyx_n_s_snappy_encode;
static PyObject *__pyx_kp_s_stringsource;
static PyObject *__pyx_n_s_test;
static PyObject *__pyx_n_s_timestamp;
static PyObject *__pyx_n_s_update;
static PyObject *__pyx_n_s_value;
static PyObject *__pyx_n_s_zlib;
static int __pyx_pf_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython___init__(struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *__pyx_v_self, char __pyx_v_magic, char __pyx_v_compression_type, int __pyx_v_batch_size); /* proto */
static PyObject *__pyx_pf_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_2append(struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *__pyx_v_self, long __pyx_v_offset, PyObject *__pyx_v_timestamp, PyObject *__pyx_v_key, PyObject *__pyx_v_value); /* proto */
static PyObject *__pyx_pf_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_4size(struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *__pyx_v_self); /* proto */
static PyObject *__pyx_pf_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_6size_in_bytes(struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *__pyx_v_self, CYTHON_UNUSED PyObject *__pyx_v_offset, CYTHON_UNUSED PyObject *__pyx_v_timestamp, PyObject *__pyx_v_key, PyObject *__pyx_v_value); /* proto */
static PyObject *__pyx_pf_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_8build(struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *__pyx_v_self); /* proto */
static PyObject *__pyx_pf_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_10__reduce_cython__(struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *__pyx_v_self); /* proto */
static PyObject *__pyx_pf_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_12__setstate_cython__(struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *__pyx_v_self, PyObject *__pyx_v___pyx_state); /* proto */
static PyObject *__pyx_pf_8aiokafka_6record_15_legacy_records___pyx_unpickle__LegacyRecordBatchBuilderCython(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v___pyx_type, long __pyx_v___pyx_checksum, PyObject *__pyx_v___pyx_state); /* proto */
static PyObject *__pyx_tp_new_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython(PyTypeObject *t, PyObject *a, PyObject *k); /*proto*/
static PyObject *__pyx_int_0;
static PyObject *__pyx_int_1;
static PyObject *__pyx_int_2;
static PyObject *__pyx_int_3;
static PyObject *__pyx_int_87812531;
static PyObject *__pyx_tuple_;
static PyObject *__pyx_tuple__2;
static PyObject *__pyx_codeobj__3;
/* "aiokafka/record/_legacy_records.pyx":16
* IF UNAME_SYSNAME == "Windows":
* from zlib import crc32 as py_crc32
* cdef long crc32(unsigned long crc, unsigned char *buf, int len): # <<<<<<<<<<<<<<
* cdef:
* object memview
*/
static long __pyx_f_8aiokafka_6record_15_legacy_records_crc32(CYTHON_UNUSED unsigned long __pyx_v_crc, unsigned char *__pyx_v_buf, int __pyx_v_len) {
PyObject *__pyx_v_memview = 0;
long __pyx_r;
__Pyx_RefNannyDeclarations
PyObject *__pyx_t_1 = NULL;
PyObject *__pyx_t_2 = NULL;
PyObject *__pyx_t_3 = NULL;
PyObject *__pyx_t_4 = NULL;
long __pyx_t_5;
__Pyx_RefNannySetupContext("crc32", 0);
/* "aiokafka/record/_legacy_records.pyx":19
* cdef:
* object memview
* memview = PyMemoryView_FromMemory(<char *>buf, <ssize_t>len, PyBUF_READ) # <<<<<<<<<<<<<<
* return py_crc32(memview)
* ELSE:
*/
__pyx_t_1 = PyMemoryView_FromMemory(((char *)__pyx_v_buf), ((Py_ssize_t)__pyx_v_len), PyBUF_READ); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 19, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_1);
__pyx_v_memview = __pyx_t_1;
__pyx_t_1 = 0;
/* "aiokafka/record/_legacy_records.pyx":20
* object memview
* memview = PyMemoryView_FromMemory(<char *>buf, <ssize_t>len, PyBUF_READ)
* return py_crc32(memview) # <<<<<<<<<<<<<<
* ELSE:
* cdef extern from "zlib.h":
*/
__pyx_t_2 = __Pyx_GetModuleGlobalName(__pyx_n_s_py_crc32); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 20, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_2);
__pyx_t_3 = NULL;
if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_2))) {
__pyx_t_3 = PyMethod_GET_SELF(__pyx_t_2);
if (likely(__pyx_t_3)) {
PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
__Pyx_INCREF(__pyx_t_3);
__Pyx_INCREF(function);
__Pyx_DECREF_SET(__pyx_t_2, function);
}
}
if (!__pyx_t_3) {
__pyx_t_1 = __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_v_memview); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 20, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_1);
} else {
#if CYTHON_FAST_PYCALL
if (PyFunction_Check(__pyx_t_2)) {
PyObject *__pyx_temp[2] = {__pyx_t_3, __pyx_v_memview};
__pyx_t_1 = __Pyx_PyFunction_FastCall(__pyx_t_2, __pyx_temp+1-1, 1+1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 20, __pyx_L1_error)
__Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
__Pyx_GOTREF(__pyx_t_1);
} else
#endif
#if CYTHON_FAST_PYCCALL
if (__Pyx_PyFastCFunction_Check(__pyx_t_2)) {
PyObject *__pyx_temp[2] = {__pyx_t_3, __pyx_v_memview};
__pyx_t_1 = __Pyx_PyCFunction_FastCall(__pyx_t_2, __pyx_temp+1-1, 1+1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 20, __pyx_L1_error)
__Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
__Pyx_GOTREF(__pyx_t_1);
} else
#endif
{
__pyx_t_4 = PyTuple_New(1+1); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 20, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_4);
__Pyx_GIVEREF(__pyx_t_3); PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_3); __pyx_t_3 = NULL;
__Pyx_INCREF(__pyx_v_memview);
__Pyx_GIVEREF(__pyx_v_memview);
PyTuple_SET_ITEM(__pyx_t_4, 0+1, __pyx_v_memview);
__pyx_t_1 = __Pyx_PyObject_Call(__pyx_t_2, __pyx_t_4, NULL); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 20, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_1);
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
}
}
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
__pyx_t_5 = __Pyx_PyInt_As_long(__pyx_t_1); if (unlikely((__pyx_t_5 == (long)-1) && PyErr_Occurred())) __PYX_ERR(0, 20, __pyx_L1_error)
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
__pyx_r = __pyx_t_5;
goto __pyx_L0;
/* "aiokafka/record/_legacy_records.pyx":16
* IF UNAME_SYSNAME == "Windows":
* from zlib import crc32 as py_crc32
* cdef long crc32(unsigned long crc, unsigned char *buf, int len): # <<<<<<<<<<<<<<
* cdef:
* object memview
*/
/* 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_WriteUnraisable("aiokafka.record._legacy_records.crc32", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
__pyx_r = 0;
__pyx_L0:;
__Pyx_XDECREF(__pyx_v_memview);
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
/* "aiokafka/record/_legacy_records.pyx":53
* void GetSystemTimeAsFileTime(FILETIME *time)
*
* cdef long get_time_as_unix_ms(): # <<<<<<<<<<<<<<
* cdef:
* FILETIME system_time
*/
static long __pyx_f_8aiokafka_6record_15_legacy_records_get_time_as_unix_ms(void) {
struct FILETIME __pyx_v_system_time;
union ULARGE_INTEGER __pyx_v_large;
long __pyx_r;
__Pyx_RefNannyDeclarations
DWORD __pyx_t_1;
__Pyx_RefNannySetupContext("get_time_as_unix_ms", 0);
/* "aiokafka/record/_legacy_records.pyx":58
* ULARGE_INTEGER large
*
* GetSystemTimeAsFileTime(&system_time) # <<<<<<<<<<<<<<
* large.u.LowPart = system_time.dwLowDateTime
* large.u.HighPart = system_time.dwHighDateTime
*/
GetSystemTimeAsFileTime((&__pyx_v_system_time));
/* "aiokafka/record/_legacy_records.pyx":59
*
* GetSystemTimeAsFileTime(&system_time)
* large.u.LowPart = system_time.dwLowDateTime # <<<<<<<<<<<<<<
* large.u.HighPart = system_time.dwHighDateTime
* # 11,644,473,600,000,000,000: number of nanoseconds between
*/
__pyx_t_1 = __pyx_v_system_time.dwLowDateTime;
__pyx_v_large.u.LowPart = __pyx_t_1;
/* "aiokafka/record/_legacy_records.pyx":60
* GetSystemTimeAsFileTime(&system_time)
* large.u.LowPart = system_time.dwLowDateTime
* large.u.HighPart = system_time.dwHighDateTime # <<<<<<<<<<<<<<
* # 11,644,473,600,000,000,000: number of nanoseconds between
* # the 1st january 1601 and the 1st january 1970 (369 years + 89 leap
*/
__pyx_t_1 = __pyx_v_system_time.dwHighDateTime;
__pyx_v_large.u.HighPart = __pyx_t_1;
/* "aiokafka/record/_legacy_records.pyx":64
* # the 1st january 1601 and the 1st january 1970 (369 years + 89 leap
* # days).
* large.QuadPart = large.QuadPart * 100 - <ULONGLONG> 11644473600000000000 # <<<<<<<<<<<<<<
* return <long> (large.QuadPart / NS_TO_MS)
*
*/
__pyx_v_large.QuadPart = ((__pyx_v_large.QuadPart * 0x64) - ((ULONGLONG)0xA1997B0B4C6A0000));
/* "aiokafka/record/_legacy_records.pyx":65
* # days).
* large.QuadPart = large.QuadPart * 100 - <ULONGLONG> 11644473600000000000
* return <long> (large.QuadPart / NS_TO_MS) # <<<<<<<<<<<<<<
*
* ELSE:
*/
__pyx_r = ((long)(((double)__pyx_v_large.QuadPart) / 1000000.0));
goto __pyx_L0;
/* "aiokafka/record/_legacy_records.pyx":53
* void GetSystemTimeAsFileTime(FILETIME *time)
*
* cdef long get_time_as_unix_ms(): # <<<<<<<<<<<<<<
* cdef:
* FILETIME system_time
*/
/* function exit code */
__pyx_L0:;
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
/* "aiokafka/record/_legacy_records.pyx":129
* CODEC_LZ4 = ATTR_CODEC_LZ4
*
* def __init__(self, char magic, char compression_type, int batch_size): # <<<<<<<<<<<<<<
* self._magic = magic
* self._compression_type = compression_type
*/
/* Python wrapper */
static int __pyx_pw_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_1__init__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static int __pyx_pw_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_1__init__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
char __pyx_v_magic;
char __pyx_v_compression_type;
int __pyx_v_batch_size;
int __pyx_r;
__Pyx_RefNannyDeclarations
__Pyx_RefNannySetupContext("__init__ (wrapper)", 0);
{
static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_magic,&__pyx_n_s_compression_type,&__pyx_n_s_batch_size,0};
PyObject* values[3] = {0,0,0};
if (unlikely(__pyx_kwds)) {
Py_ssize_t kw_args;
const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
switch (pos_args) {
case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
CYTHON_FALLTHROUGH;
case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
CYTHON_FALLTHROUGH;
case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
CYTHON_FALLTHROUGH;
case 0: break;
default: goto __pyx_L5_argtuple_error;
}
kw_args = PyDict_Size(__pyx_kwds);
switch (pos_args) {
case 0:
if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s_magic)) != 0)) kw_args--;
else goto __pyx_L5_argtuple_error;
CYTHON_FALLTHROUGH;
case 1:
if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s_compression_type)) != 0)) kw_args--;
else {
__Pyx_RaiseArgtupleInvalid("__init__", 1, 3, 3, 1); __PYX_ERR(0, 129, __pyx_L3_error)
}
CYTHON_FALLTHROUGH;
case 2:
if (likely((values[2] = PyDict_GetItem(__pyx_kwds, __pyx_n_s_batch_size)) != 0)) kw_args--;
else {
__Pyx_RaiseArgtupleInvalid("__init__", 1, 3, 3, 2); __PYX_ERR(0, 129, __pyx_L3_error)
}
}
if (unlikely(kw_args > 0)) {
if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "__init__") < 0)) __PYX_ERR(0, 129, __pyx_L3_error)
}
} else if (PyTuple_GET_SIZE(__pyx_args) != 3) {
goto __pyx_L5_argtuple_error;
} else {
values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
}
__pyx_v_magic = __Pyx_PyInt_As_char(values[0]); if (unlikely((__pyx_v_magic == (char)-1) && PyErr_Occurred())) __PYX_ERR(0, 129, __pyx_L3_error)
__pyx_v_compression_type = __Pyx_PyInt_As_char(values[1]); if (unlikely((__pyx_v_compression_type == (char)-1) && PyErr_Occurred())) __PYX_ERR(0, 129, __pyx_L3_error)
__pyx_v_batch_size = __Pyx_PyInt_As_int(values[2]); if (unlikely((__pyx_v_batch_size == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 129, __pyx_L3_error)
}
goto __pyx_L4_argument_unpacking_done;
__pyx_L5_argtuple_error:;
__Pyx_RaiseArgtupleInvalid("__init__", 1, 3, 3, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 129, __pyx_L3_error)
__pyx_L3_error:;
__Pyx_AddTraceback("aiokafka.record._legacy_records._LegacyRecordBatchBuilderCython.__init__", __pyx_clineno, __pyx_lineno, __pyx_filename);
__Pyx_RefNannyFinishContext();
return -1;
__pyx_L4_argument_unpacking_done:;
__pyx_r = __pyx_pf_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython___init__(((struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *)__pyx_v_self), __pyx_v_magic, __pyx_v_compression_type, __pyx_v_batch_size);
/* function exit code */
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
static int __pyx_pf_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython___init__(struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *__pyx_v_self, char __pyx_v_magic, char __pyx_v_compression_type, int __pyx_v_batch_size) {
int __pyx_r;
__Pyx_RefNannyDeclarations
PyObject *__pyx_t_1 = NULL;
__Pyx_RefNannySetupContext("__init__", 0);
/* "aiokafka/record/_legacy_records.pyx":130
*
* def __init__(self, char magic, char compression_type, int batch_size):
* self._magic = magic # <<<<<<<<<<<<<<
* self._compression_type = compression_type
* self._batch_size = batch_size
*/
__pyx_v_self->_magic = __pyx_v_magic;
/* "aiokafka/record/_legacy_records.pyx":131
* def __init__(self, char magic, char compression_type, int batch_size):
* self._magic = magic
* self._compression_type = compression_type # <<<<<<<<<<<<<<
* self._batch_size = batch_size
* self._buffer = bytearray()
*/
__pyx_v_self->_compression_type = __pyx_v_compression_type;
/* "aiokafka/record/_legacy_records.pyx":132
* self._magic = magic
* self._compression_type = compression_type
* self._batch_size = batch_size # <<<<<<<<<<<<<<
* self._buffer = bytearray()
*
*/
__pyx_v_self->_batch_size = __pyx_v_batch_size;
/* "aiokafka/record/_legacy_records.pyx":133
* self._compression_type = compression_type
* self._batch_size = batch_size
* self._buffer = bytearray() # <<<<<<<<<<<<<<
*
* def append(self, long offset, timestamp, key, value):
*/
__pyx_t_1 = __Pyx_PyObject_Call(((PyObject *)(&PyByteArray_Type)), __pyx_empty_tuple, NULL); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 133, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_1);
__Pyx_GIVEREF(__pyx_t_1);
__Pyx_GOTREF(__pyx_v_self->_buffer);
__Pyx_DECREF(__pyx_v_self->_buffer);
__pyx_v_self->_buffer = ((PyObject*)__pyx_t_1);
__pyx_t_1 = 0;
/* "aiokafka/record/_legacy_records.pyx":129
* CODEC_LZ4 = ATTR_CODEC_LZ4
*
* def __init__(self, char magic, char compression_type, int batch_size): # <<<<<<<<<<<<<<
* self._magic = magic
* self._compression_type = compression_type
*/
/* function exit code */
__pyx_r = 0;
goto __pyx_L0;
__pyx_L1_error:;
__Pyx_XDECREF(__pyx_t_1);
__Pyx_AddTraceback("aiokafka.record._legacy_records._LegacyRecordBatchBuilderCython.__init__", __pyx_clineno, __pyx_lineno, __pyx_filename);
__pyx_r = -1;
__pyx_L0:;
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
/* "aiokafka/record/_legacy_records.pyx":135
* self._buffer = bytearray()
*
* def append(self, long offset, timestamp, key, value): # <<<<<<<<<<<<<<
* """ Append message to batch.
* """
*/
/* Python wrapper */
static PyObject *__pyx_pw_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_3append(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_2append[] = " Append message to batch.\n ";
static PyObject *__pyx_pw_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_3append(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
long __pyx_v_offset;
PyObject *__pyx_v_timestamp = 0;
PyObject *__pyx_v_key = 0;
PyObject *__pyx_v_value = 0;
PyObject *__pyx_r = 0;
__Pyx_RefNannyDeclarations
__Pyx_RefNannySetupContext("append (wrapper)", 0);
{
static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_offset,&__pyx_n_s_timestamp,&__pyx_n_s_key,&__pyx_n_s_value,0};
PyObject* values[4] = {0,0,0,0};
if (unlikely(__pyx_kwds)) {
Py_ssize_t kw_args;
const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
switch (pos_args) {
case 4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
CYTHON_FALLTHROUGH;
case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
CYTHON_FALLTHROUGH;
case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
CYTHON_FALLTHROUGH;
case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
CYTHON_FALLTHROUGH;
case 0: break;
default: goto __pyx_L5_argtuple_error;
}
kw_args = PyDict_Size(__pyx_kwds);
switch (pos_args) {
case 0:
if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s_offset)) != 0)) kw_args--;
else goto __pyx_L5_argtuple_error;
CYTHON_FALLTHROUGH;
case 1:
if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s_timestamp)) != 0)) kw_args--;
else {
__Pyx_RaiseArgtupleInvalid("append", 1, 4, 4, 1); __PYX_ERR(0, 135, __pyx_L3_error)
}
CYTHON_FALLTHROUGH;
case 2:
if (likely((values[2] = PyDict_GetItem(__pyx_kwds, __pyx_n_s_key)) != 0)) kw_args--;
else {
__Pyx_RaiseArgtupleInvalid("append", 1, 4, 4, 2); __PYX_ERR(0, 135, __pyx_L3_error)
}
CYTHON_FALLTHROUGH;
case 3:
if (likely((values[3] = PyDict_GetItem(__pyx_kwds, __pyx_n_s_value)) != 0)) kw_args--;
else {
__Pyx_RaiseArgtupleInvalid("append", 1, 4, 4, 3); __PYX_ERR(0, 135, __pyx_L3_error)
}
}
if (unlikely(kw_args > 0)) {
if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "append") < 0)) __PYX_ERR(0, 135, __pyx_L3_error)
}
} else if (PyTuple_GET_SIZE(__pyx_args) != 4) {
goto __pyx_L5_argtuple_error;
} else {
values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
}
__pyx_v_offset = __Pyx_PyInt_As_long(values[0]); if (unlikely((__pyx_v_offset == (long)-1) && PyErr_Occurred())) __PYX_ERR(0, 135, __pyx_L3_error)
__pyx_v_timestamp = values[1];
__pyx_v_key = values[2];
__pyx_v_value = values[3];
}
goto __pyx_L4_argument_unpacking_done;
__pyx_L5_argtuple_error:;
__Pyx_RaiseArgtupleInvalid("append", 1, 4, 4, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 135, __pyx_L3_error)
__pyx_L3_error:;
__Pyx_AddTraceback("aiokafka.record._legacy_records._LegacyRecordBatchBuilderCython.append", __pyx_clineno, __pyx_lineno, __pyx_filename);
__Pyx_RefNannyFinishContext();
return NULL;
__pyx_L4_argument_unpacking_done:;
__pyx_r = __pyx_pf_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_2append(((struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *)__pyx_v_self), __pyx_v_offset, __pyx_v_timestamp, __pyx_v_key, __pyx_v_value);
/* function exit code */
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
static PyObject *__pyx_pf_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_2append(struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *__pyx_v_self, long __pyx_v_offset, PyObject *__pyx_v_timestamp, PyObject *__pyx_v_key, PyObject *__pyx_v_value) {
int __pyx_v_pos;
int __pyx_v_size;
char *__pyx_v_buf;
long __pyx_v_ts;
PyObject *__pyx_v_crc = NULL;
PyObject *__pyx_r = NULL;
__Pyx_RefNannyDeclarations
int __pyx_t_1;
int __pyx_t_2;
long __pyx_t_3;
PyObject *__pyx_t_4 = NULL;
int __pyx_t_5;
PyObject *__pyx_t_6 = NULL;
__Pyx_RefNannySetupContext("append", 0);
/* "aiokafka/record/_legacy_records.pyx":144
*
* long ts
* if timestamp is None: # <<<<<<<<<<<<<<
* ts = get_time_as_unix_ms()
* else:
*/
__pyx_t_1 = (__pyx_v_timestamp == Py_None);
__pyx_t_2 = (__pyx_t_1 != 0);
if (__pyx_t_2) {
/* "aiokafka/record/_legacy_records.pyx":145
* long ts
* if timestamp is None:
* ts = get_time_as_unix_ms() # <<<<<<<<<<<<<<
* else:
* ts = timestamp
*/
__pyx_v_ts = __pyx_f_8aiokafka_6record_15_legacy_records_get_time_as_unix_ms();
/* "aiokafka/record/_legacy_records.pyx":144
*
* long ts
* if timestamp is None: # <<<<<<<<<<<<<<
* ts = get_time_as_unix_ms()
* else:
*/
goto __pyx_L3;
}
/* "aiokafka/record/_legacy_records.pyx":147
* ts = get_time_as_unix_ms()
* else:
* ts = timestamp # <<<<<<<<<<<<<<
*
* # Check if we have room for another message
*/
/*else*/ {
__pyx_t_3 = __Pyx_PyInt_As_long(__pyx_v_timestamp); if (unlikely((__pyx_t_3 == (long)-1) && PyErr_Occurred())) __PYX_ERR(0, 147, __pyx_L1_error)
__pyx_v_ts = __pyx_t_3;
}
__pyx_L3:;
/* "aiokafka/record/_legacy_records.pyx":150
*
* # Check if we have room for another message
* pos = PyByteArray_GET_SIZE(self._buffer) # <<<<<<<<<<<<<<
* size = _size_in_bytes(self._magic, key, value)
* # We always allow at least one record to be appended
*/
__pyx_t_4 = __pyx_v_self->_buffer;
__Pyx_INCREF(__pyx_t_4);
__pyx_v_pos = PyByteArray_GET_SIZE(__pyx_t_4);
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
/* "aiokafka/record/_legacy_records.pyx":151
* # Check if we have room for another message
* pos = PyByteArray_GET_SIZE(self._buffer)
* size = _size_in_bytes(self._magic, key, value) # <<<<<<<<<<<<<<
* # We always allow at least one record to be appended
* if offset != 0 and pos + size >= self._batch_size:
*/
__pyx_t_5 = __pyx_f_8aiokafka_6record_15_legacy_records__size_in_bytes(__pyx_v_self->_magic, __pyx_v_key, __pyx_v_value); if (unlikely(__pyx_t_5 == -1)) __PYX_ERR(0, 151, __pyx_L1_error)
__pyx_v_size = __pyx_t_5;
/* "aiokafka/record/_legacy_records.pyx":153
* size = _size_in_bytes(self._magic, key, value)
* # We always allow at least one record to be appended
* if offset != 0 and pos + size >= self._batch_size: # <<<<<<<<<<<<<<
* return None, 0
*
*/
__pyx_t_1 = ((__pyx_v_offset != 0) != 0);
if (__pyx_t_1) {
} else {
__pyx_t_2 = __pyx_t_1;
goto __pyx_L5_bool_binop_done;
}
__pyx_t_1 = (((__pyx_v_pos + __pyx_v_size) >= __pyx_v_self->_batch_size) != 0);
__pyx_t_2 = __pyx_t_1;
__pyx_L5_bool_binop_done:;
if (__pyx_t_2) {
/* "aiokafka/record/_legacy_records.pyx":154
* # We always allow at least one record to be appended
* if offset != 0 and pos + size >= self._batch_size:
* return None, 0 # <<<<<<<<<<<<<<
*
* # Allocate proper buffer length
*/
__Pyx_XDECREF(__pyx_r);
__Pyx_INCREF(__pyx_tuple_);
__pyx_r = __pyx_tuple_;
goto __pyx_L0;
/* "aiokafka/record/_legacy_records.pyx":153
* size = _size_in_bytes(self._magic, key, value)
* # We always allow at least one record to be appended
* if offset != 0 and pos + size >= self._batch_size: # <<<<<<<<<<<<<<
* return None, 0
*
*/
}
/* "aiokafka/record/_legacy_records.pyx":157
*
* # Allocate proper buffer length
* PyByteArray_Resize(self._buffer, pos + size) # <<<<<<<<<<<<<<
*
* # Encode message
*/
__pyx_t_4 = __pyx_v_self->_buffer;
__Pyx_INCREF(__pyx_t_4);
__pyx_t_5 = PyByteArray_Resize(__pyx_t_4, (__pyx_v_pos + __pyx_v_size)); if (unlikely(__pyx_t_5 == -1)) __PYX_ERR(0, 157, __pyx_L1_error)
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
/* "aiokafka/record/_legacy_records.pyx":160
*
* # Encode message
* buf = PyByteArray_AS_STRING(self._buffer) # <<<<<<<<<<<<<<
* crc = _encode_msg(
* self._magic, pos, buf,
*/
__pyx_t_4 = __pyx_v_self->_buffer;
__Pyx_INCREF(__pyx_t_4);
__pyx_v_buf = PyByteArray_AS_STRING(((PyObject*)__pyx_t_4));
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
/* "aiokafka/record/_legacy_records.pyx":161
* # Encode message
* buf = PyByteArray_AS_STRING(self._buffer)
* crc = _encode_msg( # <<<<<<<<<<<<<<
* self._magic, pos, buf,
* offset, ts, key, value, 0)
*/
__pyx_t_4 = __pyx_f_8aiokafka_6record_15_legacy_records__encode_msg(__pyx_v_self->_magic, __pyx_v_pos, __pyx_v_buf, __pyx_v_offset, __pyx_v_ts, __pyx_v_key, __pyx_v_value, 0); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 161, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_4);
__pyx_v_crc = __pyx_t_4;
__pyx_t_4 = 0;
/* "aiokafka/record/_legacy_records.pyx":165
* offset, ts, key, value, 0)
*
* return crc, size # <<<<<<<<<<<<<<
*
* def size(self):
*/
__Pyx_XDECREF(__pyx_r);
__pyx_t_4 = __Pyx_PyInt_From_int(__pyx_v_size); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 165, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_4);
__pyx_t_6 = PyTuple_New(2); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 165, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_6);
__Pyx_INCREF(__pyx_v_crc);
__Pyx_GIVEREF(__pyx_v_crc);
PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_v_crc);
__Pyx_GIVEREF(__pyx_t_4);
PyTuple_SET_ITEM(__pyx_t_6, 1, __pyx_t_4);
__pyx_t_4 = 0;
__pyx_r = __pyx_t_6;
__pyx_t_6 = 0;
goto __pyx_L0;
/* "aiokafka/record/_legacy_records.pyx":135
* self._buffer = bytearray()
*
* def append(self, long offset, timestamp, key, value): # <<<<<<<<<<<<<<
* """ Append message to batch.
* """
*/
/* function exit code */
__pyx_L1_error:;
__Pyx_XDECREF(__pyx_t_4);
__Pyx_XDECREF(__pyx_t_6);
__Pyx_AddTraceback("aiokafka.record._legacy_records._LegacyRecordBatchBuilderCython.append", __pyx_clineno, __pyx_lineno, __pyx_filename);
__pyx_r = NULL;
__pyx_L0:;
__Pyx_XDECREF(__pyx_v_crc);
__Pyx_XGIVEREF(__pyx_r);
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
/* "aiokafka/record/_legacy_records.pyx":167
* return crc, size
*
* def size(self): # <<<<<<<<<<<<<<
* """ Return current size of data written to buffer
* """
*/
/* Python wrapper */
static PyObject *__pyx_pw_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_5size(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused); /*proto*/
static char __pyx_doc_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_4size[] = " Return current size of data written to buffer\n ";
static PyObject *__pyx_pw_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_5size(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused) {
PyObject *__pyx_r = 0;
__Pyx_RefNannyDeclarations
__Pyx_RefNannySetupContext("size (wrapper)", 0);
__pyx_r = __pyx_pf_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_4size(((struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *)__pyx_v_self));
/* function exit code */
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
static PyObject *__pyx_pf_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_4size(struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *__pyx_v_self) {
PyObject *__pyx_r = NULL;
__Pyx_RefNannyDeclarations
PyObject *__pyx_t_1 = NULL;
PyObject *__pyx_t_2 = NULL;
__Pyx_RefNannySetupContext("size", 0);
/* "aiokafka/record/_legacy_records.pyx":170
* """ Return current size of data written to buffer
* """
* return PyByteArray_GET_SIZE(self._buffer) # <<<<<<<<<<<<<<
*
* # Size calculations. Just copied Java's implementation
*/
__Pyx_XDECREF(__pyx_r);
__pyx_t_1 = __pyx_v_self->_buffer;
__Pyx_INCREF(__pyx_t_1);
__pyx_t_2 = PyInt_FromSsize_t(PyByteArray_GET_SIZE(__pyx_t_1)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 170, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_2);
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
__pyx_r = __pyx_t_2;
__pyx_t_2 = 0;
goto __pyx_L0;
/* "aiokafka/record/_legacy_records.pyx":167
* return crc, size
*
* def size(self): # <<<<<<<<<<<<<<
* """ Return current size of data written to buffer
* """
*/
/* function exit code */
__pyx_L1_error:;
__Pyx_XDECREF(__pyx_t_1);
__Pyx_XDECREF(__pyx_t_2);
__Pyx_AddTraceback("aiokafka.record._legacy_records._LegacyRecordBatchBuilderCython.size", __pyx_clineno, __pyx_lineno, __pyx_filename);
__pyx_r = NULL;
__pyx_L0:;
__Pyx_XGIVEREF(__pyx_r);
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
/* "aiokafka/record/_legacy_records.pyx":174
* # Size calculations. Just copied Java's implementation
*
* def size_in_bytes(self, offset, timestamp, key, value): # <<<<<<<<<<<<<<
* """ Actual size of message to add
* """
*/
/* Python wrapper */
static PyObject *__pyx_pw_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_7size_in_bytes(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_6size_in_bytes[] = " Actual size of message to add\n ";
static PyObject *__pyx_pw_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_7size_in_bytes(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
CYTHON_UNUSED PyObject *__pyx_v_offset = 0;
CYTHON_UNUSED PyObject *__pyx_v_timestamp = 0;
PyObject *__pyx_v_key = 0;
PyObject *__pyx_v_value = 0;
PyObject *__pyx_r = 0;
__Pyx_RefNannyDeclarations
__Pyx_RefNannySetupContext("size_in_bytes (wrapper)", 0);
{
static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_offset,&__pyx_n_s_timestamp,&__pyx_n_s_key,&__pyx_n_s_value,0};
PyObject* values[4] = {0,0,0,0};
if (unlikely(__pyx_kwds)) {
Py_ssize_t kw_args;
const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
switch (pos_args) {
case 4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
CYTHON_FALLTHROUGH;
case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
CYTHON_FALLTHROUGH;
case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
CYTHON_FALLTHROUGH;
case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
CYTHON_FALLTHROUGH;
case 0: break;
default: goto __pyx_L5_argtuple_error;
}
kw_args = PyDict_Size(__pyx_kwds);
switch (pos_args) {
case 0:
if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s_offset)) != 0)) kw_args--;
else goto __pyx_L5_argtuple_error;
CYTHON_FALLTHROUGH;
case 1:
if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s_timestamp)) != 0)) kw_args--;
else {
__Pyx_RaiseArgtupleInvalid("size_in_bytes", 1, 4, 4, 1); __PYX_ERR(0, 174, __pyx_L3_error)
}
CYTHON_FALLTHROUGH;
case 2:
if (likely((values[2] = PyDict_GetItem(__pyx_kwds, __pyx_n_s_key)) != 0)) kw_args--;
else {
__Pyx_RaiseArgtupleInvalid("size_in_bytes", 1, 4, 4, 2); __PYX_ERR(0, 174, __pyx_L3_error)
}
CYTHON_FALLTHROUGH;
case 3:
if (likely((values[3] = PyDict_GetItem(__pyx_kwds, __pyx_n_s_value)) != 0)) kw_args--;
else {
__Pyx_RaiseArgtupleInvalid("size_in_bytes", 1, 4, 4, 3); __PYX_ERR(0, 174, __pyx_L3_error)
}
}
if (unlikely(kw_args > 0)) {
if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "size_in_bytes") < 0)) __PYX_ERR(0, 174, __pyx_L3_error)
}
} else if (PyTuple_GET_SIZE(__pyx_args) != 4) {
goto __pyx_L5_argtuple_error;
} else {
values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
}
__pyx_v_offset = values[0];
__pyx_v_timestamp = values[1];
__pyx_v_key = values[2];
__pyx_v_value = values[3];
}
goto __pyx_L4_argument_unpacking_done;
__pyx_L5_argtuple_error:;
__Pyx_RaiseArgtupleInvalid("size_in_bytes", 1, 4, 4, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 174, __pyx_L3_error)
__pyx_L3_error:;
__Pyx_AddTraceback("aiokafka.record._legacy_records._LegacyRecordBatchBuilderCython.size_in_bytes", __pyx_clineno, __pyx_lineno, __pyx_filename);
__Pyx_RefNannyFinishContext();
return NULL;
__pyx_L4_argument_unpacking_done:;
__pyx_r = __pyx_pf_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_6size_in_bytes(((struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *)__pyx_v_self), __pyx_v_offset, __pyx_v_timestamp, __pyx_v_key, __pyx_v_value);
/* function exit code */
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
static PyObject *__pyx_pf_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_6size_in_bytes(struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *__pyx_v_self, CYTHON_UNUSED PyObject *__pyx_v_offset, CYTHON_UNUSED PyObject *__pyx_v_timestamp, PyObject *__pyx_v_key, PyObject *__pyx_v_value) {
PyObject *__pyx_r = NULL;
__Pyx_RefNannyDeclarations
int __pyx_t_1;
PyObject *__pyx_t_2 = NULL;
__Pyx_RefNannySetupContext("size_in_bytes", 0);
/* "aiokafka/record/_legacy_records.pyx":177
* """ Actual size of message to add
* """
* return _size_in_bytes(self._magic, key, value) # <<<<<<<<<<<<<<
*
* cdef int _maybe_compress(self) except -1:
*/
__Pyx_XDECREF(__pyx_r);
__pyx_t_1 = __pyx_f_8aiokafka_6record_15_legacy_records__size_in_bytes(__pyx_v_self->_magic, __pyx_v_key, __pyx_v_value); if (unlikely(__pyx_t_1 == -1)) __PYX_ERR(0, 177, __pyx_L1_error)
__pyx_t_2 = __Pyx_PyInt_From_int(__pyx_t_1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 177, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_2);
__pyx_r = __pyx_t_2;
__pyx_t_2 = 0;
goto __pyx_L0;
/* "aiokafka/record/_legacy_records.pyx":174
* # Size calculations. Just copied Java's implementation
*
* def size_in_bytes(self, offset, timestamp, key, value): # <<<<<<<<<<<<<<
* """ Actual size of message to add
* """
*/
/* function exit code */
__pyx_L1_error:;
__Pyx_XDECREF(__pyx_t_2);
__Pyx_AddTraceback("aiokafka.record._legacy_records._LegacyRecordBatchBuilderCython.size_in_bytes", __pyx_clineno, __pyx_lineno, __pyx_filename);
__pyx_r = NULL;
__pyx_L0:;
__Pyx_XGIVEREF(__pyx_r);
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
/* "aiokafka/record/_legacy_records.pyx":179
* return _size_in_bytes(self._magic, key, value)
*
* cdef int _maybe_compress(self) except -1: # <<<<<<<<<<<<<<
* cdef:
* object compressed
*/
static int __pyx_f_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython__maybe_compress(struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *__pyx_v_self) {
PyObject *__pyx_v_compressed = 0;
char *__pyx_v_buf;
int __pyx_v_size;
int __pyx_r;
__Pyx_RefNannyDeclarations
int __pyx_t_1;
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;
int __pyx_t_7;
__Pyx_RefNannySetupContext("_maybe_compress", 0);
/* "aiokafka/record/_legacy_records.pyx":185
* int size
*
* if self._compression_type != 0: # <<<<<<<<<<<<<<
* if self._compression_type == ATTR_CODEC_GZIP:
* compressed = gzip_encode(self._buffer)
*/
__pyx_t_1 = ((__pyx_v_self->_compression_type != 0) != 0);
if (__pyx_t_1) {
/* "aiokafka/record/_legacy_records.pyx":186
*
* if self._compression_type != 0:
* if self._compression_type == ATTR_CODEC_GZIP: # <<<<<<<<<<<<<<
* compressed = gzip_encode(self._buffer)
* elif self._compression_type == ATTR_CODEC_SNAPPY:
*/
switch (__pyx_v_self->_compression_type) {
case 1:
/* "aiokafka/record/_legacy_records.pyx":187
* if self._compression_type != 0:
* if self._compression_type == ATTR_CODEC_GZIP:
* compressed = gzip_encode(self._buffer) # <<<<<<<<<<<<<<
* elif self._compression_type == ATTR_CODEC_SNAPPY:
* compressed = snappy_encode(self._buffer)
*/
__pyx_t_3 = __Pyx_GetModuleGlobalName(__pyx_n_s_gzip_encode); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 187, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_3);
__pyx_t_4 = NULL;
if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_3))) {
__pyx_t_4 = PyMethod_GET_SELF(__pyx_t_3);
if (likely(__pyx_t_4)) {
PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
__Pyx_INCREF(__pyx_t_4);
__Pyx_INCREF(function);
__Pyx_DECREF_SET(__pyx_t_3, function);
}
}
if (!__pyx_t_4) {
__pyx_t_2 = __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_v_self->_buffer); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 187, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_2);
} else {
#if CYTHON_FAST_PYCALL
if (PyFunction_Check(__pyx_t_3)) {
PyObject *__pyx_temp[2] = {__pyx_t_4, __pyx_v_self->_buffer};
__pyx_t_2 = __Pyx_PyFunction_FastCall(__pyx_t_3, __pyx_temp+1-1, 1+1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 187, __pyx_L1_error)
__Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
__Pyx_GOTREF(__pyx_t_2);
} else
#endif
#if CYTHON_FAST_PYCCALL
if (__Pyx_PyFastCFunction_Check(__pyx_t_3)) {
PyObject *__pyx_temp[2] = {__pyx_t_4, __pyx_v_self->_buffer};
__pyx_t_2 = __Pyx_PyCFunction_FastCall(__pyx_t_3, __pyx_temp+1-1, 1+1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 187, __pyx_L1_error)
__Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
__Pyx_GOTREF(__pyx_t_2);
} else
#endif
{
__pyx_t_5 = PyTuple_New(1+1); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 187, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_5);
__Pyx_GIVEREF(__pyx_t_4); PyTuple_SET_ITEM(__pyx_t_5, 0, __pyx_t_4); __pyx_t_4 = NULL;
__Pyx_INCREF(__pyx_v_self->_buffer);
__Pyx_GIVEREF(__pyx_v_self->_buffer);
PyTuple_SET_ITEM(__pyx_t_5, 0+1, __pyx_v_self->_buffer);
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_t_3, __pyx_t_5, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 187, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_2);
__Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
}
}
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
__pyx_v_compressed = __pyx_t_2;
__pyx_t_2 = 0;
/* "aiokafka/record/_legacy_records.pyx":186
*
* if self._compression_type != 0:
* if self._compression_type == ATTR_CODEC_GZIP: # <<<<<<<<<<<<<<
* compressed = gzip_encode(self._buffer)
* elif self._compression_type == ATTR_CODEC_SNAPPY:
*/
break;
/* "aiokafka/record/_legacy_records.pyx":188
* if self._compression_type == ATTR_CODEC_GZIP:
* compressed = gzip_encode(self._buffer)
* elif self._compression_type == ATTR_CODEC_SNAPPY: # <<<<<<<<<<<<<<
* compressed = snappy_encode(self._buffer)
* elif self._compression_type == ATTR_CODEC_LZ4:
*/
case 2:
/* "aiokafka/record/_legacy_records.pyx":189
* compressed = gzip_encode(self._buffer)
* elif self._compression_type == ATTR_CODEC_SNAPPY:
* compressed = snappy_encode(self._buffer) # <<<<<<<<<<<<<<
* elif self._compression_type == ATTR_CODEC_LZ4:
* if self._magic == 0:
*/
__pyx_t_3 = __Pyx_GetModuleGlobalName(__pyx_n_s_snappy_encode); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 189, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_3);
__pyx_t_5 = NULL;
if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_3))) {
__pyx_t_5 = PyMethod_GET_SELF(__pyx_t_3);
if (likely(__pyx_t_5)) {
PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
__Pyx_INCREF(__pyx_t_5);
__Pyx_INCREF(function);
__Pyx_DECREF_SET(__pyx_t_3, function);
}
}
if (!__pyx_t_5) {
__pyx_t_2 = __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_v_self->_buffer); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 189, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_2);
} else {
#if CYTHON_FAST_PYCALL
if (PyFunction_Check(__pyx_t_3)) {
PyObject *__pyx_temp[2] = {__pyx_t_5, __pyx_v_self->_buffer};
__pyx_t_2 = __Pyx_PyFunction_FastCall(__pyx_t_3, __pyx_temp+1-1, 1+1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 189, __pyx_L1_error)
__Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
__Pyx_GOTREF(__pyx_t_2);
} else
#endif
#if CYTHON_FAST_PYCCALL
if (__Pyx_PyFastCFunction_Check(__pyx_t_3)) {
PyObject *__pyx_temp[2] = {__pyx_t_5, __pyx_v_self->_buffer};
__pyx_t_2 = __Pyx_PyCFunction_FastCall(__pyx_t_3, __pyx_temp+1-1, 1+1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 189, __pyx_L1_error)
__Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
__Pyx_GOTREF(__pyx_t_2);
} else
#endif
{
__pyx_t_4 = PyTuple_New(1+1); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 189, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_4);
__Pyx_GIVEREF(__pyx_t_5); PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_5); __pyx_t_5 = NULL;
__Pyx_INCREF(__pyx_v_self->_buffer);
__Pyx_GIVEREF(__pyx_v_self->_buffer);
PyTuple_SET_ITEM(__pyx_t_4, 0+1, __pyx_v_self->_buffer);
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_t_3, __pyx_t_4, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 189, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_2);
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
}
}
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
__pyx_v_compressed = __pyx_t_2;
__pyx_t_2 = 0;
/* "aiokafka/record/_legacy_records.pyx":188
* if self._compression_type == ATTR_CODEC_GZIP:
* compressed = gzip_encode(self._buffer)
* elif self._compression_type == ATTR_CODEC_SNAPPY: # <<<<<<<<<<<<<<
* compressed = snappy_encode(self._buffer)
* elif self._compression_type == ATTR_CODEC_LZ4:
*/
break;
/* "aiokafka/record/_legacy_records.pyx":190
* elif self._compression_type == ATTR_CODEC_SNAPPY:
* compressed = snappy_encode(self._buffer)
* elif self._compression_type == ATTR_CODEC_LZ4: # <<<<<<<<<<<<<<
* if self._magic == 0:
* compressed = lz4_encode_old_kafka(bytes(self._buffer))
*/
case 3:
/* "aiokafka/record/_legacy_records.pyx":191
* compressed = snappy_encode(self._buffer)
* elif self._compression_type == ATTR_CODEC_LZ4:
* if self._magic == 0: # <<<<<<<<<<<<<<
* compressed = lz4_encode_old_kafka(bytes(self._buffer))
* else:
*/
__pyx_t_1 = ((__pyx_v_self->_magic == 0) != 0);
if (__pyx_t_1) {
/* "aiokafka/record/_legacy_records.pyx":192
* elif self._compression_type == ATTR_CODEC_LZ4:
* if self._magic == 0:
* compressed = lz4_encode_old_kafka(bytes(self._buffer)) # <<<<<<<<<<<<<<
* else:
* compressed = lz4_encode(bytes(self._buffer))
*/
__pyx_t_3 = __Pyx_GetModuleGlobalName(__pyx_n_s_lz4_encode_old_kafka); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 192, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_3);
__pyx_t_4 = PyTuple_New(1); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 192, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_4);
__Pyx_INCREF(__pyx_v_self->_buffer);
__Pyx_GIVEREF(__pyx_v_self->_buffer);
PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_v_self->_buffer);
__pyx_t_5 = __Pyx_PyObject_Call(((PyObject *)(&PyBytes_Type)), __pyx_t_4, NULL); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 192, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_5);
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
__pyx_t_4 = NULL;
if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_3))) {
__pyx_t_4 = PyMethod_GET_SELF(__pyx_t_3);
if (likely(__pyx_t_4)) {
PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
__Pyx_INCREF(__pyx_t_4);
__Pyx_INCREF(function);
__Pyx_DECREF_SET(__pyx_t_3, function);
}
}
if (!__pyx_t_4) {
__pyx_t_2 = __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_t_5); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 192, __pyx_L1_error)
__Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
__Pyx_GOTREF(__pyx_t_2);
} else {
#if CYTHON_FAST_PYCALL
if (PyFunction_Check(__pyx_t_3)) {
PyObject *__pyx_temp[2] = {__pyx_t_4, __pyx_t_5};
__pyx_t_2 = __Pyx_PyFunction_FastCall(__pyx_t_3, __pyx_temp+1-1, 1+1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 192, __pyx_L1_error)
__Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
__Pyx_GOTREF(__pyx_t_2);
__Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
} else
#endif
#if CYTHON_FAST_PYCCALL
if (__Pyx_PyFastCFunction_Check(__pyx_t_3)) {
PyObject *__pyx_temp[2] = {__pyx_t_4, __pyx_t_5};
__pyx_t_2 = __Pyx_PyCFunction_FastCall(__pyx_t_3, __pyx_temp+1-1, 1+1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 192, __pyx_L1_error)
__Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
__Pyx_GOTREF(__pyx_t_2);
__Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
} else
#endif
{
__pyx_t_6 = PyTuple_New(1+1); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 192, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_6);
__Pyx_GIVEREF(__pyx_t_4); PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_4); __pyx_t_4 = NULL;
__Pyx_GIVEREF(__pyx_t_5);
PyTuple_SET_ITEM(__pyx_t_6, 0+1, __pyx_t_5);
__pyx_t_5 = 0;
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_t_3, __pyx_t_6, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 192, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_2);
__Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
}
}
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
__pyx_v_compressed = __pyx_t_2;
__pyx_t_2 = 0;
/* "aiokafka/record/_legacy_records.pyx":191
* compressed = snappy_encode(self._buffer)
* elif self._compression_type == ATTR_CODEC_LZ4:
* if self._magic == 0: # <<<<<<<<<<<<<<
* compressed = lz4_encode_old_kafka(bytes(self._buffer))
* else:
*/
goto __pyx_L4;
}
/* "aiokafka/record/_legacy_records.pyx":194
* compressed = lz4_encode_old_kafka(bytes(self._buffer))
* else:
* compressed = lz4_encode(bytes(self._buffer)) # <<<<<<<<<<<<<<
* else:
* return 0
*/
/*else*/ {
__pyx_t_3 = __Pyx_GetModuleGlobalName(__pyx_n_s_lz4_encode); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 194, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_3);
__pyx_t_6 = PyTuple_New(1); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 194, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_6);
__Pyx_INCREF(__pyx_v_self->_buffer);
__Pyx_GIVEREF(__pyx_v_self->_buffer);
PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_v_self->_buffer);
__pyx_t_5 = __Pyx_PyObject_Call(((PyObject *)(&PyBytes_Type)), __pyx_t_6, NULL); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 194, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_5);
__Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
__pyx_t_6 = NULL;
if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_3))) {
__pyx_t_6 = PyMethod_GET_SELF(__pyx_t_3);
if (likely(__pyx_t_6)) {
PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
__Pyx_INCREF(__pyx_t_6);
__Pyx_INCREF(function);
__Pyx_DECREF_SET(__pyx_t_3, function);
}
}
if (!__pyx_t_6) {
__pyx_t_2 = __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_t_5); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 194, __pyx_L1_error)
__Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
__Pyx_GOTREF(__pyx_t_2);
} else {
#if CYTHON_FAST_PYCALL
if (PyFunction_Check(__pyx_t_3)) {
PyObject *__pyx_temp[2] = {__pyx_t_6, __pyx_t_5};
__pyx_t_2 = __Pyx_PyFunction_FastCall(__pyx_t_3, __pyx_temp+1-1, 1+1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 194, __pyx_L1_error)
__Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
__Pyx_GOTREF(__pyx_t_2);
__Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
} else
#endif
#if CYTHON_FAST_PYCCALL
if (__Pyx_PyFastCFunction_Check(__pyx_t_3)) {
PyObject *__pyx_temp[2] = {__pyx_t_6, __pyx_t_5};
__pyx_t_2 = __Pyx_PyCFunction_FastCall(__pyx_t_3, __pyx_temp+1-1, 1+1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 194, __pyx_L1_error)
__Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
__Pyx_GOTREF(__pyx_t_2);
__Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
} else
#endif
{
__pyx_t_4 = PyTuple_New(1+1); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 194, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_4);
__Pyx_GIVEREF(__pyx_t_6); PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_6); __pyx_t_6 = NULL;
__Pyx_GIVEREF(__pyx_t_5);
PyTuple_SET_ITEM(__pyx_t_4, 0+1, __pyx_t_5);
__pyx_t_5 = 0;
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_t_3, __pyx_t_4, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 194, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_2);
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
}
}
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
__pyx_v_compressed = __pyx_t_2;
__pyx_t_2 = 0;
}
__pyx_L4:;
/* "aiokafka/record/_legacy_records.pyx":190
* elif self._compression_type == ATTR_CODEC_SNAPPY:
* compressed = snappy_encode(self._buffer)
* elif self._compression_type == ATTR_CODEC_LZ4: # <<<<<<<<<<<<<<
* if self._magic == 0:
* compressed = lz4_encode_old_kafka(bytes(self._buffer))
*/
break;
default:
/* "aiokafka/record/_legacy_records.pyx":196
* compressed = lz4_encode(bytes(self._buffer))
* else:
* return 0 # <<<<<<<<<<<<<<
* size = _size_in_bytes(self._magic, key=None, value=compressed)
* # We will just write the result into the same memory space.
*/
__pyx_r = 0;
goto __pyx_L0;
break;
}
/* "aiokafka/record/_legacy_records.pyx":197
* else:
* return 0
* size = _size_in_bytes(self._magic, key=None, value=compressed) # <<<<<<<<<<<<<<
* # We will just write the result into the same memory space.
* PyByteArray_Resize(self._buffer, size)
*/
__pyx_t_7 = __pyx_f_8aiokafka_6record_15_legacy_records__size_in_bytes(__pyx_v_self->_magic, Py_None, __pyx_v_compressed); if (unlikely(__pyx_t_7 == -1)) __PYX_ERR(0, 197, __pyx_L1_error)
__pyx_v_size = __pyx_t_7;
/* "aiokafka/record/_legacy_records.pyx":199
* size = _size_in_bytes(self._magic, key=None, value=compressed)
* # We will just write the result into the same memory space.
* PyByteArray_Resize(self._buffer, size) # <<<<<<<<<<<<<<
*
* buf = PyByteArray_AS_STRING(self._buffer)
*/
__pyx_t_2 = __pyx_v_self->_buffer;
__Pyx_INCREF(__pyx_t_2);
__pyx_t_7 = PyByteArray_Resize(__pyx_t_2, __pyx_v_size); if (unlikely(__pyx_t_7 == -1)) __PYX_ERR(0, 199, __pyx_L1_error)
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
/* "aiokafka/record/_legacy_records.pyx":201
* PyByteArray_Resize(self._buffer, size)
*
* buf = PyByteArray_AS_STRING(self._buffer) # <<<<<<<<<<<<<<
* _encode_msg(
* self._magic, 0, buf,
*/
__pyx_t_2 = __pyx_v_self->_buffer;
__Pyx_INCREF(__pyx_t_2);
__pyx_v_buf = PyByteArray_AS_STRING(((PyObject*)__pyx_t_2));
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
/* "aiokafka/record/_legacy_records.pyx":202
*
* buf = PyByteArray_AS_STRING(self._buffer)
* _encode_msg( # <<<<<<<<<<<<<<
* self._magic, 0, buf,
* offset=0, timestamp=0, key=None, value=compressed,
*/
__pyx_t_2 = __pyx_f_8aiokafka_6record_15_legacy_records__encode_msg(__pyx_v_self->_magic, 0, __pyx_v_buf, 0, 0, Py_None, __pyx_v_compressed, __pyx_v_self->_compression_type); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 202, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_2);
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
/* "aiokafka/record/_legacy_records.pyx":206
* offset=0, timestamp=0, key=None, value=compressed,
* attributes=self._compression_type)
* return 1 # <<<<<<<<<<<<<<
* return 0
*
*/
__pyx_r = 1;
goto __pyx_L0;
/* "aiokafka/record/_legacy_records.pyx":185
* int size
*
* if self._compression_type != 0: # <<<<<<<<<<<<<<
* if self._compression_type == ATTR_CODEC_GZIP:
* compressed = gzip_encode(self._buffer)
*/
}
/* "aiokafka/record/_legacy_records.pyx":207
* attributes=self._compression_type)
* return 1
* return 0 # <<<<<<<<<<<<<<
*
* def build(self):
*/
__pyx_r = 0;
goto __pyx_L0;
/* "aiokafka/record/_legacy_records.pyx":179
* return _size_in_bytes(self._magic, key, value)
*
* cdef int _maybe_compress(self) except -1: # <<<<<<<<<<<<<<
* cdef:
* object compressed
*/
/* function exit code */
__pyx_L1_error:;
__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_AddTraceback("aiokafka.record._legacy_records._LegacyRecordBatchBuilderCython._maybe_compress", __pyx_clineno, __pyx_lineno, __pyx_filename);
__pyx_r = -1;
__pyx_L0:;
__Pyx_XDECREF(__pyx_v_compressed);
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
/* "aiokafka/record/_legacy_records.pyx":209
* return 0
*
* def build(self): # <<<<<<<<<<<<<<
* """Compress batch to be ready for send"""
* self._maybe_compress()
*/
/* Python wrapper */
static PyObject *__pyx_pw_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_9build(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused); /*proto*/
static char __pyx_doc_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_8build[] = "Compress batch to be ready for send";
static PyObject *__pyx_pw_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_9build(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused) {
PyObject *__pyx_r = 0;
__Pyx_RefNannyDeclarations
__Pyx_RefNannySetupContext("build (wrapper)", 0);
__pyx_r = __pyx_pf_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_8build(((struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *)__pyx_v_self));
/* function exit code */
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
static PyObject *__pyx_pf_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_8build(struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *__pyx_v_self) {
PyObject *__pyx_r = NULL;
__Pyx_RefNannyDeclarations
int __pyx_t_1;
__Pyx_RefNannySetupContext("build", 0);
/* "aiokafka/record/_legacy_records.pyx":211
* def build(self):
* """Compress batch to be ready for send"""
* self._maybe_compress() # <<<<<<<<<<<<<<
* return self._buffer
*
*/
__pyx_t_1 = ((struct __pyx_vtabstruct_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *)__pyx_v_self->__pyx_vtab)->_maybe_compress(__pyx_v_self); if (unlikely(__pyx_t_1 == -1)) __PYX_ERR(0, 211, __pyx_L1_error)
/* "aiokafka/record/_legacy_records.pyx":212
* """Compress batch to be ready for send"""
* self._maybe_compress()
* return self._buffer # <<<<<<<<<<<<<<
*
*
*/
__Pyx_XDECREF(__pyx_r);
__Pyx_INCREF(__pyx_v_self->_buffer);
__pyx_r = __pyx_v_self->_buffer;
goto __pyx_L0;
/* "aiokafka/record/_legacy_records.pyx":209
* return 0
*
* def build(self): # <<<<<<<<<<<<<<
* """Compress batch to be ready for send"""
* self._maybe_compress()
*/
/* function exit code */
__pyx_L1_error:;
__Pyx_AddTraceback("aiokafka.record._legacy_records._LegacyRecordBatchBuilderCython.build", __pyx_clineno, __pyx_lineno, __pyx_filename);
__pyx_r = NULL;
__pyx_L0:;
__Pyx_XGIVEREF(__pyx_r);
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
/* "(tree fragment)":1
* def __reduce_cython__(self): # <<<<<<<<<<<<<<
* cdef bint use_setstate
* state = (self._batch_size, self._buffer, self._compression_type, self._magic)
*/
/* Python wrapper */
static PyObject *__pyx_pw_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_11__reduce_cython__(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused); /*proto*/
static PyObject *__pyx_pw_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_11__reduce_cython__(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused) {
PyObject *__pyx_r = 0;
__Pyx_RefNannyDeclarations
__Pyx_RefNannySetupContext("__reduce_cython__ (wrapper)", 0);
__pyx_r = __pyx_pf_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_10__reduce_cython__(((struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *)__pyx_v_self));
/* function exit code */
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
static PyObject *__pyx_pf_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_10__reduce_cython__(struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *__pyx_v_self) {
int __pyx_v_use_setstate;
PyObject *__pyx_v_state = NULL;
PyObject *__pyx_v__dict = 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;
int __pyx_t_5;
int __pyx_t_6;
__Pyx_RefNannySetupContext("__reduce_cython__", 0);
/* "(tree fragment)":3
* def __reduce_cython__(self):
* cdef bint use_setstate
* state = (self._batch_size, self._buffer, self._compression_type, self._magic) # <<<<<<<<<<<<<<
* _dict = getattr(self, '__dict__', None)
* if _dict is not None:
*/
__pyx_t_1 = __Pyx_PyInt_From_int(__pyx_v_self->_batch_size); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 3, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_1);
__pyx_t_2 = __Pyx_PyInt_From_char(__pyx_v_self->_compression_type); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 3, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_2);
__pyx_t_3 = __Pyx_PyInt_From_char(__pyx_v_self->_magic); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 3, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_3);
__pyx_t_4 = PyTuple_New(4); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_4);
__Pyx_GIVEREF(__pyx_t_1);
PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_1);
__Pyx_INCREF(__pyx_v_self->_buffer);
__Pyx_GIVEREF(__pyx_v_self->_buffer);
PyTuple_SET_ITEM(__pyx_t_4, 1, __pyx_v_self->_buffer);
__Pyx_GIVEREF(__pyx_t_2);
PyTuple_SET_ITEM(__pyx_t_4, 2, __pyx_t_2);
__Pyx_GIVEREF(__pyx_t_3);
PyTuple_SET_ITEM(__pyx_t_4, 3, __pyx_t_3);
__pyx_t_1 = 0;
__pyx_t_2 = 0;
__pyx_t_3 = 0;
__pyx_v_state = ((PyObject*)__pyx_t_4);
__pyx_t_4 = 0;
/* "(tree fragment)":4
* cdef bint use_setstate
* state = (self._batch_size, self._buffer, self._compression_type, self._magic)
* _dict = getattr(self, '__dict__', None) # <<<<<<<<<<<<<<
* if _dict is not None:
* state += (_dict,)
*/
__pyx_t_4 = __Pyx_GetAttr3(((PyObject *)__pyx_v_self), __pyx_n_s_dict, Py_None); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_4);
__pyx_v__dict = __pyx_t_4;
__pyx_t_4 = 0;
/* "(tree fragment)":5
* state = (self._batch_size, self._buffer, self._compression_type, self._magic)
* _dict = getattr(self, '__dict__', None)
* if _dict is not None: # <<<<<<<<<<<<<<
* state += (_dict,)
* use_setstate = True
*/
__pyx_t_5 = (__pyx_v__dict != Py_None);
__pyx_t_6 = (__pyx_t_5 != 0);
if (__pyx_t_6) {
/* "(tree fragment)":6
* _dict = getattr(self, '__dict__', None)
* if _dict is not None:
* state += (_dict,) # <<<<<<<<<<<<<<
* use_setstate = True
* else:
*/
__pyx_t_4 = PyTuple_New(1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 6, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_4);
__Pyx_INCREF(__pyx_v__dict);
__Pyx_GIVEREF(__pyx_v__dict);
PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_v__dict);
__pyx_t_3 = PyNumber_InPlaceAdd(__pyx_v_state, __pyx_t_4); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 6, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_3);
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
__Pyx_DECREF_SET(__pyx_v_state, ((PyObject*)__pyx_t_3));
__pyx_t_3 = 0;
/* "(tree fragment)":7
* if _dict is not None:
* state += (_dict,)
* use_setstate = True # <<<<<<<<<<<<<<
* else:
* use_setstate = self._buffer is not None
*/
__pyx_v_use_setstate = 1;
/* "(tree fragment)":5
* state = (self._batch_size, self._buffer, self._compression_type, self._magic)
* _dict = getattr(self, '__dict__', None)
* if _dict is not None: # <<<<<<<<<<<<<<
* state += (_dict,)
* use_setstate = True
*/
goto __pyx_L3;
}
/* "(tree fragment)":9
* use_setstate = True
* else:
* use_setstate = self._buffer is not None # <<<<<<<<<<<<<<
* if use_setstate:
* return __pyx_unpickle__LegacyRecordBatchBuilderCython, (type(self), 0x53be9b3, None), state
*/
/*else*/ {
__pyx_t_6 = (__pyx_v_self->_buffer != ((PyObject*)Py_None));
__pyx_v_use_setstate = __pyx_t_6;
}
__pyx_L3:;
/* "(tree fragment)":10
* else:
* use_setstate = self._buffer is not None
* if use_setstate: # <<<<<<<<<<<<<<
* return __pyx_unpickle__LegacyRecordBatchBuilderCython, (type(self), 0x53be9b3, None), state
* else:
*/
__pyx_t_6 = (__pyx_v_use_setstate != 0);
if (__pyx_t_6) {
/* "(tree fragment)":11
* use_setstate = self._buffer is not None
* if use_setstate:
* return __pyx_unpickle__LegacyRecordBatchBuilderCython, (type(self), 0x53be9b3, None), state # <<<<<<<<<<<<<<
* else:
* return __pyx_unpickle__LegacyRecordBatchBuilderCython, (type(self), 0x53be9b3, state)
*/
__Pyx_XDECREF(__pyx_r);
__pyx_t_3 = __Pyx_GetModuleGlobalName(__pyx_n_s_pyx_unpickle__LegacyRecordBatc); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 11, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_3);
__pyx_t_4 = PyTuple_New(3); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 11, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_4);
__Pyx_INCREF(((PyObject *)Py_TYPE(((PyObject *)__pyx_v_self))));
__Pyx_GIVEREF(((PyObject *)Py_TYPE(((PyObject *)__pyx_v_self))));
PyTuple_SET_ITEM(__pyx_t_4, 0, ((PyObject *)Py_TYPE(((PyObject *)__pyx_v_self))));
__Pyx_INCREF(__pyx_int_87812531);
__Pyx_GIVEREF(__pyx_int_87812531);
PyTuple_SET_ITEM(__pyx_t_4, 1, __pyx_int_87812531);
__Pyx_INCREF(Py_None);
__Pyx_GIVEREF(Py_None);
PyTuple_SET_ITEM(__pyx_t_4, 2, Py_None);
__pyx_t_2 = PyTuple_New(3); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 11, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_2);
__Pyx_GIVEREF(__pyx_t_3);
PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_3);
__Pyx_GIVEREF(__pyx_t_4);
PyTuple_SET_ITEM(__pyx_t_2, 1, __pyx_t_4);
__Pyx_INCREF(__pyx_v_state);
__Pyx_GIVEREF(__pyx_v_state);
PyTuple_SET_ITEM(__pyx_t_2, 2, __pyx_v_state);
__pyx_t_3 = 0;
__pyx_t_4 = 0;
__pyx_r = __pyx_t_2;
__pyx_t_2 = 0;
goto __pyx_L0;
/* "(tree fragment)":10
* else:
* use_setstate = self._buffer is not None
* if use_setstate: # <<<<<<<<<<<<<<
* return __pyx_unpickle__LegacyRecordBatchBuilderCython, (type(self), 0x53be9b3, None), state
* else:
*/
}
/* "(tree fragment)":13
* return __pyx_unpickle__LegacyRecordBatchBuilderCython, (type(self), 0x53be9b3, None), state
* else:
* return __pyx_unpickle__LegacyRecordBatchBuilderCython, (type(self), 0x53be9b3, state) # <<<<<<<<<<<<<<
* def __setstate_cython__(self, __pyx_state):
* __pyx_unpickle__LegacyRecordBatchBuilderCython__set_state(self, __pyx_state)
*/
/*else*/ {
__Pyx_XDECREF(__pyx_r);
__pyx_t_2 = __Pyx_GetModuleGlobalName(__pyx_n_s_pyx_unpickle__LegacyRecordBatc); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 13, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_2);
__pyx_t_4 = PyTuple_New(3); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 13, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_4);
__Pyx_INCREF(((PyObject *)Py_TYPE(((PyObject *)__pyx_v_self))));
__Pyx_GIVEREF(((PyObject *)Py_TYPE(((PyObject *)__pyx_v_self))));
PyTuple_SET_ITEM(__pyx_t_4, 0, ((PyObject *)Py_TYPE(((PyObject *)__pyx_v_self))));
__Pyx_INCREF(__pyx_int_87812531);
__Pyx_GIVEREF(__pyx_int_87812531);
PyTuple_SET_ITEM(__pyx_t_4, 1, __pyx_int_87812531);
__Pyx_INCREF(__pyx_v_state);
__Pyx_GIVEREF(__pyx_v_state);
PyTuple_SET_ITEM(__pyx_t_4, 2, __pyx_v_state);
__pyx_t_3 = PyTuple_New(2); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 13, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_3);
__Pyx_GIVEREF(__pyx_t_2);
PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_2);
__Pyx_GIVEREF(__pyx_t_4);
PyTuple_SET_ITEM(__pyx_t_3, 1, __pyx_t_4);
__pyx_t_2 = 0;
__pyx_t_4 = 0;
__pyx_r = __pyx_t_3;
__pyx_t_3 = 0;
goto __pyx_L0;
}
/* "(tree fragment)":1
* def __reduce_cython__(self): # <<<<<<<<<<<<<<
* cdef bint use_setstate
* state = (self._batch_size, self._buffer, self._compression_type, self._magic)
*/
/* 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_AddTraceback("aiokafka.record._legacy_records._LegacyRecordBatchBuilderCython.__reduce_cython__", __pyx_clineno, __pyx_lineno, __pyx_filename);
__pyx_r = NULL;
__pyx_L0:;
__Pyx_XDECREF(__pyx_v_state);
__Pyx_XDECREF(__pyx_v__dict);
__Pyx_XGIVEREF(__pyx_r);
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
/* "(tree fragment)":14
* else:
* return __pyx_unpickle__LegacyRecordBatchBuilderCython, (type(self), 0x53be9b3, state)
* def __setstate_cython__(self, __pyx_state): # <<<<<<<<<<<<<<
* __pyx_unpickle__LegacyRecordBatchBuilderCython__set_state(self, __pyx_state)
*/
/* Python wrapper */
static PyObject *__pyx_pw_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_13__setstate_cython__(PyObject *__pyx_v_self, PyObject *__pyx_v___pyx_state); /*proto*/
static PyObject *__pyx_pw_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_13__setstate_cython__(PyObject *__pyx_v_self, PyObject *__pyx_v___pyx_state) {
PyObject *__pyx_r = 0;
__Pyx_RefNannyDeclarations
__Pyx_RefNannySetupContext("__setstate_cython__ (wrapper)", 0);
__pyx_r = __pyx_pf_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_12__setstate_cython__(((struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *)__pyx_v_self), ((PyObject *)__pyx_v___pyx_state));
/* function exit code */
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
static PyObject *__pyx_pf_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_12__setstate_cython__(struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *__pyx_v_self, PyObject *__pyx_v___pyx_state) {
PyObject *__pyx_r = NULL;
__Pyx_RefNannyDeclarations
PyObject *__pyx_t_1 = NULL;
__Pyx_RefNannySetupContext("__setstate_cython__", 0);
/* "(tree fragment)":15
* return __pyx_unpickle__LegacyRecordBatchBuilderCython, (type(self), 0x53be9b3, state)
* def __setstate_cython__(self, __pyx_state):
* __pyx_unpickle__LegacyRecordBatchBuilderCython__set_state(self, __pyx_state) # <<<<<<<<<<<<<<
*/
if (!(likely(PyTuple_CheckExact(__pyx_v___pyx_state))||((__pyx_v___pyx_state) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected %.16s, got %.200s", "tuple", Py_TYPE(__pyx_v___pyx_state)->tp_name), 0))) __PYX_ERR(1, 15, __pyx_L1_error)
__pyx_t_1 = __pyx_f_8aiokafka_6record_15_legacy_records___pyx_unpickle__LegacyRecordBatchBuilderCython__set_state(__pyx_v_self, ((PyObject*)__pyx_v___pyx_state)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 15, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_1);
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
/* "(tree fragment)":14
* else:
* return __pyx_unpickle__LegacyRecordBatchBuilderCython, (type(self), 0x53be9b3, state)
* def __setstate_cython__(self, __pyx_state): # <<<<<<<<<<<<<<
* __pyx_unpickle__LegacyRecordBatchBuilderCython__set_state(self, __pyx_state)
*/
/* function exit code */
__pyx_r = Py_None; __Pyx_INCREF(Py_None);
goto __pyx_L0;
__pyx_L1_error:;
__Pyx_XDECREF(__pyx_t_1);
__Pyx_AddTraceback("aiokafka.record._legacy_records._LegacyRecordBatchBuilderCython.__setstate_cython__", __pyx_clineno, __pyx_lineno, __pyx_filename);
__pyx_r = NULL;
__pyx_L0:;
__Pyx_XGIVEREF(__pyx_r);
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
/* "aiokafka/record/_legacy_records.pyx":215
*
*
* cdef int _size_in_bytes(char magic, object key, object value) except -1: # <<<<<<<<<<<<<<
* """ Actual size of message to add
* """
*/
static int __pyx_f_8aiokafka_6record_15_legacy_records__size_in_bytes(char __pyx_v_magic, PyObject *__pyx_v_key, PyObject *__pyx_v_value) {
Py_buffer __pyx_v_buf;
int __pyx_v_key_len;
int __pyx_v_value_len;
int __pyx_r;
__Pyx_RefNannyDeclarations
int __pyx_t_1;
int __pyx_t_2;
int __pyx_t_3;
Py_ssize_t __pyx_t_4;
__Pyx_RefNannySetupContext("_size_in_bytes", 0);
/* "aiokafka/record/_legacy_records.pyx":223
* int value_len
*
* if key is None: # <<<<<<<<<<<<<<
* key_len = 0
* else:
*/
__pyx_t_1 = (__pyx_v_key == Py_None);
__pyx_t_2 = (__pyx_t_1 != 0);
if (__pyx_t_2) {
/* "aiokafka/record/_legacy_records.pyx":224
*
* if key is None:
* key_len = 0 # <<<<<<<<<<<<<<
* else:
* PyObject_GetBuffer(key, &buf, PyBUF_SIMPLE)
*/
__pyx_v_key_len = 0;
/* "aiokafka/record/_legacy_records.pyx":223
* int value_len
*
* if key is None: # <<<<<<<<<<<<<<
* key_len = 0
* else:
*/
goto __pyx_L3;
}
/* "aiokafka/record/_legacy_records.pyx":226
* key_len = 0
* else:
* PyObject_GetBuffer(key, &buf, PyBUF_SIMPLE) # <<<<<<<<<<<<<<
* key_len = buf.len
* PyBuffer_Release(&buf)
*/
/*else*/ {
__pyx_t_3 = PyObject_GetBuffer(__pyx_v_key, (&__pyx_v_buf), PyBUF_SIMPLE); if (unlikely(__pyx_t_3 == -1)) __PYX_ERR(0, 226, __pyx_L1_error)
/* "aiokafka/record/_legacy_records.pyx":227
* else:
* PyObject_GetBuffer(key, &buf, PyBUF_SIMPLE)
* key_len = buf.len # <<<<<<<<<<<<<<
* PyBuffer_Release(&buf)
*
*/
__pyx_t_4 = __pyx_v_buf.len;
__pyx_v_key_len = __pyx_t_4;
/* "aiokafka/record/_legacy_records.pyx":228
* PyObject_GetBuffer(key, &buf, PyBUF_SIMPLE)
* key_len = buf.len
* PyBuffer_Release(&buf) # <<<<<<<<<<<<<<
*
* if value is None:
*/
PyBuffer_Release((&__pyx_v_buf));
}
__pyx_L3:;
/* "aiokafka/record/_legacy_records.pyx":230
* PyBuffer_Release(&buf)
*
* if value is None: # <<<<<<<<<<<<<<
* value_len = 0
* else:
*/
__pyx_t_2 = (__pyx_v_value == Py_None);
__pyx_t_1 = (__pyx_t_2 != 0);
if (__pyx_t_1) {
/* "aiokafka/record/_legacy_records.pyx":231
*
* if value is None:
* value_len = 0 # <<<<<<<<<<<<<<
* else:
* PyObject_GetBuffer(value, &buf, PyBUF_SIMPLE)
*/
__pyx_v_value_len = 0;
/* "aiokafka/record/_legacy_records.pyx":230
* PyBuffer_Release(&buf)
*
* if value is None: # <<<<<<<<<<<<<<
* value_len = 0
* else:
*/
goto __pyx_L4;
}
/* "aiokafka/record/_legacy_records.pyx":233
* value_len = 0
* else:
* PyObject_GetBuffer(value, &buf, PyBUF_SIMPLE) # <<<<<<<<<<<<<<
* value_len = buf.len
* PyBuffer_Release(&buf)
*/
/*else*/ {
__pyx_t_3 = PyObject_GetBuffer(__pyx_v_value, (&__pyx_v_buf), PyBUF_SIMPLE); if (unlikely(__pyx_t_3 == -1)) __PYX_ERR(0, 233, __pyx_L1_error)
/* "aiokafka/record/_legacy_records.pyx":234
* else:
* PyObject_GetBuffer(value, &buf, PyBUF_SIMPLE)
* value_len = buf.len # <<<<<<<<<<<<<<
* PyBuffer_Release(&buf)
*
*/
__pyx_t_4 = __pyx_v_buf.len;
__pyx_v_value_len = __pyx_t_4;
/* "aiokafka/record/_legacy_records.pyx":235
* PyObject_GetBuffer(value, &buf, PyBUF_SIMPLE)
* value_len = buf.len
* PyBuffer_Release(&buf) # <<<<<<<<<<<<<<
*
* if magic == 0:
*/
PyBuffer_Release((&__pyx_v_buf));
}
__pyx_L4:;
/* "aiokafka/record/_legacy_records.pyx":237
* PyBuffer_Release(&buf)
*
* if magic == 0: # <<<<<<<<<<<<<<
* return LOG_OVERHEAD + RECORD_OVERHEAD_V0 + key_len + value_len
* else:
*/
__pyx_t_1 = ((__pyx_v_magic == 0) != 0);
if (__pyx_t_1) {
/* "aiokafka/record/_legacy_records.pyx":238
*
* if magic == 0:
* return LOG_OVERHEAD + RECORD_OVERHEAD_V0 + key_len + value_len # <<<<<<<<<<<<<<
* else:
* return LOG_OVERHEAD + RECORD_OVERHEAD_V1 + key_len + value_len
*/
__pyx_r = ((26 + __pyx_v_key_len) + __pyx_v_value_len);
goto __pyx_L0;
/* "aiokafka/record/_legacy_records.pyx":237
* PyBuffer_Release(&buf)
*
* if magic == 0: # <<<<<<<<<<<<<<
* return LOG_OVERHEAD + RECORD_OVERHEAD_V0 + key_len + value_len
* else:
*/
}
/* "aiokafka/record/_legacy_records.pyx":240
* return LOG_OVERHEAD + RECORD_OVERHEAD_V0 + key_len + value_len
* else:
* return LOG_OVERHEAD + RECORD_OVERHEAD_V1 + key_len + value_len # <<<<<<<<<<<<<<
*
*
*/
/*else*/ {
__pyx_r = ((34 + __pyx_v_key_len) + __pyx_v_value_len);
goto __pyx_L0;
}
/* "aiokafka/record/_legacy_records.pyx":215
*
*
* cdef int _size_in_bytes(char magic, object key, object value) except -1: # <<<<<<<<<<<<<<
* """ Actual size of message to add
* """
*/
/* function exit code */
__pyx_L1_error:;
__Pyx_AddTraceback("aiokafka.record._legacy_records._size_in_bytes", __pyx_clineno, __pyx_lineno, __pyx_filename);
__pyx_r = -1;
__pyx_L0:;
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
/* "aiokafka/record/_legacy_records.pyx":243
*
*
* cdef object _encode_msg( # <<<<<<<<<<<<<<
* char magic, int start_pos, char *buf,
* long offset, long timestamp, object key, object value,
*/
static PyObject *__pyx_f_8aiokafka_6record_15_legacy_records__encode_msg(char __pyx_v_magic, int __pyx_v_start_pos, char *__pyx_v_buf, long __pyx_v_offset, long __pyx_v_timestamp, PyObject *__pyx_v_key, PyObject *__pyx_v_value, char __pyx_v_attributes) {
Py_buffer __pyx_v_key_val_buf;
int __pyx_v_pos;
int __pyx_v_length;
int __pyx_v_crc;
PyObject *__pyx_r = NULL;
__Pyx_RefNannyDeclarations
long __pyx_t_1;
int __pyx_t_2;
int __pyx_t_3;
int __pyx_t_4;
PyObject *__pyx_t_5 = NULL;
__Pyx_RefNannySetupContext("_encode_msg", 0);
/* "aiokafka/record/_legacy_records.pyx":252
* cdef:
* Py_buffer key_val_buf
* int pos = start_pos # <<<<<<<<<<<<<<
* int length
* int crc
*/
__pyx_v_pos = __pyx_v_start_pos;
/* "aiokafka/record/_legacy_records.pyx":257
*
* # Write key and value
* pos += KEY_OFFSET_V0 if magic == 0 else KEY_OFFSET_V1 # <<<<<<<<<<<<<<
*
* if key is None:
*/
if (((__pyx_v_magic == 0) != 0)) {
__pyx_t_1 = 18;
} else {
__pyx_t_1 = 26;
}
__pyx_v_pos = (__pyx_v_pos + __pyx_t_1);
/* "aiokafka/record/_legacy_records.pyx":259
* pos += KEY_OFFSET_V0 if magic == 0 else KEY_OFFSET_V1
*
* if key is None: # <<<<<<<<<<<<<<
* hton.pack_int32(&buf[pos], -1)
* pos += KEY_LENGTH
*/
__pyx_t_2 = (__pyx_v_key == Py_None);
__pyx_t_3 = (__pyx_t_2 != 0);
if (__pyx_t_3) {
/* "aiokafka/record/_legacy_records.pyx":260
*
* if key is None:
* hton.pack_int32(&buf[pos], -1) # <<<<<<<<<<<<<<
* pos += KEY_LENGTH
* else:
*/
__pyx_f_8aiokafka_6record_5_hton_pack_int32((&(__pyx_v_buf[__pyx_v_pos])), -1);
/* "aiokafka/record/_legacy_records.pyx":261
* if key is None:
* hton.pack_int32(&buf[pos], -1)
* pos += KEY_LENGTH # <<<<<<<<<<<<<<
* else:
* PyObject_GetBuffer(key, &key_val_buf, PyBUF_SIMPLE)
*/
__pyx_v_pos = (__pyx_v_pos + 4);
/* "aiokafka/record/_legacy_records.pyx":259
* pos += KEY_OFFSET_V0 if magic == 0 else KEY_OFFSET_V1
*
* if key is None: # <<<<<<<<<<<<<<
* hton.pack_int32(&buf[pos], -1)
* pos += KEY_LENGTH
*/
goto __pyx_L3;
}
/* "aiokafka/record/_legacy_records.pyx":263
* pos += KEY_LENGTH
* else:
* PyObject_GetBuffer(key, &key_val_buf, PyBUF_SIMPLE) # <<<<<<<<<<<<<<
* hton.pack_int32(&buf[pos], <int32_t>key_val_buf.len)
* pos += KEY_LENGTH
*/
/*else*/ {
__pyx_t_4 = PyObject_GetBuffer(__pyx_v_key, (&__pyx_v_key_val_buf), PyBUF_SIMPLE); if (unlikely(__pyx_t_4 == -1)) __PYX_ERR(0, 263, __pyx_L1_error)
/* "aiokafka/record/_legacy_records.pyx":264
* else:
* PyObject_GetBuffer(key, &key_val_buf, PyBUF_SIMPLE)
* hton.pack_int32(&buf[pos], <int32_t>key_val_buf.len) # <<<<<<<<<<<<<<
* pos += KEY_LENGTH
* memcpy(&buf[pos], <char*>key_val_buf.buf, <size_t>key_val_buf.len)
*/
__pyx_f_8aiokafka_6record_5_hton_pack_int32((&(__pyx_v_buf[__pyx_v_pos])), ((int32_t)__pyx_v_key_val_buf.len));
/* "aiokafka/record/_legacy_records.pyx":265
* PyObject_GetBuffer(key, &key_val_buf, PyBUF_SIMPLE)
* hton.pack_int32(&buf[pos], <int32_t>key_val_buf.len)
* pos += KEY_LENGTH # <<<<<<<<<<<<<<
* memcpy(&buf[pos], <char*>key_val_buf.buf, <size_t>key_val_buf.len)
* pos += <int>key_val_buf.len
*/
__pyx_v_pos = (__pyx_v_pos + 4);
/* "aiokafka/record/_legacy_records.pyx":266
* hton.pack_int32(&buf[pos], <int32_t>key_val_buf.len)
* pos += KEY_LENGTH
* memcpy(&buf[pos], <char*>key_val_buf.buf, <size_t>key_val_buf.len) # <<<<<<<<<<<<<<
* pos += <int>key_val_buf.len
* PyBuffer_Release(&key_val_buf)
*/
memcpy((&(__pyx_v_buf[__pyx_v_pos])), ((char *)__pyx_v_key_val_buf.buf), ((size_t)__pyx_v_key_val_buf.len));
/* "aiokafka/record/_legacy_records.pyx":267
* pos += KEY_LENGTH
* memcpy(&buf[pos], <char*>key_val_buf.buf, <size_t>key_val_buf.len)
* pos += <int>key_val_buf.len # <<<<<<<<<<<<<<
* PyBuffer_Release(&key_val_buf)
*
*/
__pyx_v_pos = (__pyx_v_pos + ((int)__pyx_v_key_val_buf.len));
/* "aiokafka/record/_legacy_records.pyx":268
* memcpy(&buf[pos], <char*>key_val_buf.buf, <size_t>key_val_buf.len)
* pos += <int>key_val_buf.len
* PyBuffer_Release(&key_val_buf) # <<<<<<<<<<<<<<
*
* if value is None:
*/
PyBuffer_Release((&__pyx_v_key_val_buf));
}
__pyx_L3:;
/* "aiokafka/record/_legacy_records.pyx":270
* PyBuffer_Release(&key_val_buf)
*
* if value is None: # <<<<<<<<<<<<<<
* hton.pack_int32(&buf[pos], -1)
* pos += VALUE_LENGTH
*/
__pyx_t_3 = (__pyx_v_value == Py_None);
__pyx_t_2 = (__pyx_t_3 != 0);
if (__pyx_t_2) {
/* "aiokafka/record/_legacy_records.pyx":271
*
* if value is None:
* hton.pack_int32(&buf[pos], -1) # <<<<<<<<<<<<<<
* pos += VALUE_LENGTH
* else:
*/
__pyx_f_8aiokafka_6record_5_hton_pack_int32((&(__pyx_v_buf[__pyx_v_pos])), -1);
/* "aiokafka/record/_legacy_records.pyx":272
* if value is None:
* hton.pack_int32(&buf[pos], -1)
* pos += VALUE_LENGTH # <<<<<<<<<<<<<<
* else:
* PyObject_GetBuffer(value, &key_val_buf, PyBUF_SIMPLE)
*/
__pyx_v_pos = (__pyx_v_pos + 4);
/* "aiokafka/record/_legacy_records.pyx":270
* PyBuffer_Release(&key_val_buf)
*
* if value is None: # <<<<<<<<<<<<<<
* hton.pack_int32(&buf[pos], -1)
* pos += VALUE_LENGTH
*/
goto __pyx_L4;
}
/* "aiokafka/record/_legacy_records.pyx":274
* pos += VALUE_LENGTH
* else:
* PyObject_GetBuffer(value, &key_val_buf, PyBUF_SIMPLE) # <<<<<<<<<<<<<<
* hton.pack_int32(&buf[pos], <int32_t>key_val_buf.len)
* pos += VALUE_LENGTH
*/
/*else*/ {
__pyx_t_4 = PyObject_GetBuffer(__pyx_v_value, (&__pyx_v_key_val_buf), PyBUF_SIMPLE); if (unlikely(__pyx_t_4 == -1)) __PYX_ERR(0, 274, __pyx_L1_error)
/* "aiokafka/record/_legacy_records.pyx":275
* else:
* PyObject_GetBuffer(value, &key_val_buf, PyBUF_SIMPLE)
* hton.pack_int32(&buf[pos], <int32_t>key_val_buf.len) # <<<<<<<<<<<<<<
* pos += VALUE_LENGTH
* memcpy(&buf[pos], <char*>key_val_buf.buf, <size_t>key_val_buf.len)
*/
__pyx_f_8aiokafka_6record_5_hton_pack_int32((&(__pyx_v_buf[__pyx_v_pos])), ((int32_t)__pyx_v_key_val_buf.len));
/* "aiokafka/record/_legacy_records.pyx":276
* PyObject_GetBuffer(value, &key_val_buf, PyBUF_SIMPLE)
* hton.pack_int32(&buf[pos], <int32_t>key_val_buf.len)
* pos += VALUE_LENGTH # <<<<<<<<<<<<<<
* memcpy(&buf[pos], <char*>key_val_buf.buf, <size_t>key_val_buf.len)
* pos += <int>key_val_buf.len
*/
__pyx_v_pos = (__pyx_v_pos + 4);
/* "aiokafka/record/_legacy_records.pyx":277
* hton.pack_int32(&buf[pos], <int32_t>key_val_buf.len)
* pos += VALUE_LENGTH
* memcpy(&buf[pos], <char*>key_val_buf.buf, <size_t>key_val_buf.len) # <<<<<<<<<<<<<<
* pos += <int>key_val_buf.len
* PyBuffer_Release(&key_val_buf)
*/
memcpy((&(__pyx_v_buf[__pyx_v_pos])), ((char *)__pyx_v_key_val_buf.buf), ((size_t)__pyx_v_key_val_buf.len));
/* "aiokafka/record/_legacy_records.pyx":278
* pos += VALUE_LENGTH
* memcpy(&buf[pos], <char*>key_val_buf.buf, <size_t>key_val_buf.len)
* pos += <int>key_val_buf.len # <<<<<<<<<<<<<<
* PyBuffer_Release(&key_val_buf)
* length = (pos - start_pos) - LOG_OVERHEAD
*/
__pyx_v_pos = (__pyx_v_pos + ((int)__pyx_v_key_val_buf.len));
/* "aiokafka/record/_legacy_records.pyx":279
* memcpy(&buf[pos], <char*>key_val_buf.buf, <size_t>key_val_buf.len)
* pos += <int>key_val_buf.len
* PyBuffer_Release(&key_val_buf) # <<<<<<<<<<<<<<
* length = (pos - start_pos) - LOG_OVERHEAD
*
*/
PyBuffer_Release((&__pyx_v_key_val_buf));
}
__pyx_L4:;
/* "aiokafka/record/_legacy_records.pyx":280
* pos += <int>key_val_buf.len
* PyBuffer_Release(&key_val_buf)
* length = (pos - start_pos) - LOG_OVERHEAD # <<<<<<<<<<<<<<
*
* # Write msg header. Note, that Crc will be updated later
*/
__pyx_v_length = ((__pyx_v_pos - __pyx_v_start_pos) - 12);
/* "aiokafka/record/_legacy_records.pyx":283
*
* # Write msg header. Note, that Crc will be updated later
* hton.pack_int64(&buf[start_pos], <int64_t>offset) # <<<<<<<<<<<<<<
* hton.pack_int32(&buf[start_pos + LENGTH_OFFSET], <int32_t>length)
* buf[start_pos + MAGIC_OFFSET] = magic
*/
__pyx_f_8aiokafka_6record_5_hton_pack_int64((&(__pyx_v_buf[__pyx_v_start_pos])), ((int64_t)__pyx_v_offset));
/* "aiokafka/record/_legacy_records.pyx":284
* # Write msg header. Note, that Crc will be updated later
* hton.pack_int64(&buf[start_pos], <int64_t>offset)
* hton.pack_int32(&buf[start_pos + LENGTH_OFFSET], <int32_t>length) # <<<<<<<<<<<<<<
* buf[start_pos + MAGIC_OFFSET] = magic
* buf[start_pos + ATTRIBUTES_OFFSET] = attributes
*/
__pyx_f_8aiokafka_6record_5_hton_pack_int32((&(__pyx_v_buf[(__pyx_v_start_pos + 8)])), ((int32_t)__pyx_v_length));
/* "aiokafka/record/_legacy_records.pyx":285
* hton.pack_int64(&buf[start_pos], <int64_t>offset)
* hton.pack_int32(&buf[start_pos + LENGTH_OFFSET], <int32_t>length)
* buf[start_pos + MAGIC_OFFSET] = magic # <<<<<<<<<<<<<<
* buf[start_pos + ATTRIBUTES_OFFSET] = attributes
* if magic == 1:
*/
(__pyx_v_buf[(__pyx_v_start_pos + 16)]) = __pyx_v_magic;
/* "aiokafka/record/_legacy_records.pyx":286
* hton.pack_int32(&buf[start_pos + LENGTH_OFFSET], <int32_t>length)
* buf[start_pos + MAGIC_OFFSET] = magic
* buf[start_pos + ATTRIBUTES_OFFSET] = attributes # <<<<<<<<<<<<<<
* if magic == 1:
* hton.pack_int64(&buf[start_pos + TIMESTAMP_OFFSET], <int64_t>timestamp)
*/
(__pyx_v_buf[(__pyx_v_start_pos + 17)]) = __pyx_v_attributes;
/* "aiokafka/record/_legacy_records.pyx":287
* buf[start_pos + MAGIC_OFFSET] = magic
* buf[start_pos + ATTRIBUTES_OFFSET] = attributes
* if magic == 1: # <<<<<<<<<<<<<<
* hton.pack_int64(&buf[start_pos + TIMESTAMP_OFFSET], <int64_t>timestamp)
*
*/
__pyx_t_2 = ((__pyx_v_magic == 1) != 0);
if (__pyx_t_2) {
/* "aiokafka/record/_legacy_records.pyx":288
* buf[start_pos + ATTRIBUTES_OFFSET] = attributes
* if magic == 1:
* hton.pack_int64(&buf[start_pos + TIMESTAMP_OFFSET], <int64_t>timestamp) # <<<<<<<<<<<<<<
*
* # Calculate CRC for msg
*/
__pyx_f_8aiokafka_6record_5_hton_pack_int64((&(__pyx_v_buf[(__pyx_v_start_pos + 18)])), ((int64_t)__pyx_v_timestamp));
/* "aiokafka/record/_legacy_records.pyx":287
* buf[start_pos + MAGIC_OFFSET] = magic
* buf[start_pos + ATTRIBUTES_OFFSET] = attributes
* if magic == 1: # <<<<<<<<<<<<<<
* hton.pack_int64(&buf[start_pos + TIMESTAMP_OFFSET], <int64_t>timestamp)
*
*/
}
/* "aiokafka/record/_legacy_records.pyx":291
*
* # Calculate CRC for msg
* crc = crc32( # <<<<<<<<<<<<<<
* 0,
* <unsigned char*>&buf[start_pos + MAGIC_OFFSET],
*/
__pyx_v_crc = __pyx_f_8aiokafka_6record_15_legacy_records_crc32(0, ((unsigned char *)(&(__pyx_v_buf[(__pyx_v_start_pos + 16)]))), (__pyx_v_pos - (__pyx_v_start_pos + 16)));
/* "aiokafka/record/_legacy_records.pyx":296
* pos - (start_pos + MAGIC_OFFSET)
* )
* hton.pack_int32(&buf[start_pos + CRC_OFFSET], <uint32_t>crc) # <<<<<<<<<<<<<<
*
* return crc
*/
__pyx_f_8aiokafka_6record_5_hton_pack_int32((&(__pyx_v_buf[(__pyx_v_start_pos + 12)])), ((uint32_t)__pyx_v_crc));
/* "aiokafka/record/_legacy_records.pyx":298
* hton.pack_int32(&buf[start_pos + CRC_OFFSET], <uint32_t>crc)
*
* return crc # <<<<<<<<<<<<<<
*/
__Pyx_XDECREF(__pyx_r);
__pyx_t_5 = __Pyx_PyInt_From_int(__pyx_v_crc); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 298, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_5);
__pyx_r = __pyx_t_5;
__pyx_t_5 = 0;
goto __pyx_L0;
/* "aiokafka/record/_legacy_records.pyx":243
*
*
* cdef object _encode_msg( # <<<<<<<<<<<<<<
* char magic, int start_pos, char *buf,
* long offset, long timestamp, object key, object value,
*/
/* function exit code */
__pyx_L1_error:;
__Pyx_XDECREF(__pyx_t_5);
__Pyx_AddTraceback("aiokafka.record._legacy_records._encode_msg", __pyx_clineno, __pyx_lineno, __pyx_filename);
__pyx_r = 0;
__pyx_L0:;
__Pyx_XGIVEREF(__pyx_r);
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
/* "(tree fragment)":1
* def __pyx_unpickle__LegacyRecordBatchBuilderCython(__pyx_type, long __pyx_checksum, __pyx_state): # <<<<<<<<<<<<<<
* if __pyx_checksum != 0x53be9b3:
* from pickle import PickleError as __pyx_PickleError
*/
/* Python wrapper */
static PyObject *__pyx_pw_8aiokafka_6record_15_legacy_records_1__pyx_unpickle__LegacyRecordBatchBuilderCython(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static PyMethodDef __pyx_mdef_8aiokafka_6record_15_legacy_records_1__pyx_unpickle__LegacyRecordBatchBuilderCython = {"__pyx_unpickle__LegacyRecordBatchBuilderCython", (PyCFunction)__pyx_pw_8aiokafka_6record_15_legacy_records_1__pyx_unpickle__LegacyRecordBatchBuilderCython, METH_VARARGS|METH_KEYWORDS, 0};
static PyObject *__pyx_pw_8aiokafka_6record_15_legacy_records_1__pyx_unpickle__LegacyRecordBatchBuilderCython(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
PyObject *__pyx_v___pyx_type = 0;
long __pyx_v___pyx_checksum;
PyObject *__pyx_v___pyx_state = 0;
PyObject *__pyx_r = 0;
__Pyx_RefNannyDeclarations
__Pyx_RefNannySetupContext("__pyx_unpickle__LegacyRecordBatchBuilderCython (wrapper)", 0);
{
static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_pyx_type,&__pyx_n_s_pyx_checksum,&__pyx_n_s_pyx_state,0};
PyObject* values[3] = {0,0,0};
if (unlikely(__pyx_kwds)) {
Py_ssize_t kw_args;
const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
switch (pos_args) {
case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
CYTHON_FALLTHROUGH;
case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
CYTHON_FALLTHROUGH;
case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
CYTHON_FALLTHROUGH;
case 0: break;
default: goto __pyx_L5_argtuple_error;
}
kw_args = PyDict_Size(__pyx_kwds);
switch (pos_args) {
case 0:
if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s_pyx_type)) != 0)) kw_args--;
else goto __pyx_L5_argtuple_error;
CYTHON_FALLTHROUGH;
case 1:
if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s_pyx_checksum)) != 0)) kw_args--;
else {
__Pyx_RaiseArgtupleInvalid("__pyx_unpickle__LegacyRecordBatchBuilderCython", 1, 3, 3, 1); __PYX_ERR(1, 1, __pyx_L3_error)
}
CYTHON_FALLTHROUGH;
case 2:
if (likely((values[2] = PyDict_GetItem(__pyx_kwds, __pyx_n_s_pyx_state)) != 0)) kw_args--;
else {
__Pyx_RaiseArgtupleInvalid("__pyx_unpickle__LegacyRecordBatchBuilderCython", 1, 3, 3, 2); __PYX_ERR(1, 1, __pyx_L3_error)
}
}
if (unlikely(kw_args > 0)) {
if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "__pyx_unpickle__LegacyRecordBatchBuilderCython") < 0)) __PYX_ERR(1, 1, __pyx_L3_error)
}
} else if (PyTuple_GET_SIZE(__pyx_args) != 3) {
goto __pyx_L5_argtuple_error;
} else {
values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
}
__pyx_v___pyx_type = values[0];
__pyx_v___pyx_checksum = __Pyx_PyInt_As_long(values[1]); if (unlikely((__pyx_v___pyx_checksum == (long)-1) && PyErr_Occurred())) __PYX_ERR(1, 1, __pyx_L3_error)
__pyx_v___pyx_state = values[2];
}
goto __pyx_L4_argument_unpacking_done;
__pyx_L5_argtuple_error:;
__Pyx_RaiseArgtupleInvalid("__pyx_unpickle__LegacyRecordBatchBuilderCython", 1, 3, 3, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 1, __pyx_L3_error)
__pyx_L3_error:;
__Pyx_AddTraceback("aiokafka.record._legacy_records.__pyx_unpickle__LegacyRecordBatchBuilderCython", __pyx_clineno, __pyx_lineno, __pyx_filename);
__Pyx_RefNannyFinishContext();
return NULL;
__pyx_L4_argument_unpacking_done:;
__pyx_r = __pyx_pf_8aiokafka_6record_15_legacy_records___pyx_unpickle__LegacyRecordBatchBuilderCython(__pyx_self, __pyx_v___pyx_type, __pyx_v___pyx_checksum, __pyx_v___pyx_state);
/* function exit code */
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
static PyObject *__pyx_pf_8aiokafka_6record_15_legacy_records___pyx_unpickle__LegacyRecordBatchBuilderCython(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v___pyx_type, long __pyx_v___pyx_checksum, PyObject *__pyx_v___pyx_state) {
PyObject *__pyx_v___pyx_PickleError = NULL;
PyObject *__pyx_v___pyx_result = NULL;
PyObject *__pyx_r = NULL;
__Pyx_RefNannyDeclarations
int __pyx_t_1;
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;
int __pyx_t_7;
__Pyx_RefNannySetupContext("__pyx_unpickle__LegacyRecordBatchBuilderCython", 0);
/* "(tree fragment)":2
* def __pyx_unpickle__LegacyRecordBatchBuilderCython(__pyx_type, long __pyx_checksum, __pyx_state):
* if __pyx_checksum != 0x53be9b3: # <<<<<<<<<<<<<<
* from pickle import PickleError as __pyx_PickleError
* raise __pyx_PickleError("Incompatible checksums (%s vs 0x53be9b3 = (_batch_size, _buffer, _compression_type, _magic))" % __pyx_checksum)
*/
__pyx_t_1 = ((__pyx_v___pyx_checksum != 0x53be9b3) != 0);
if (__pyx_t_1) {
/* "(tree fragment)":3
* def __pyx_unpickle__LegacyRecordBatchBuilderCython(__pyx_type, long __pyx_checksum, __pyx_state):
* if __pyx_checksum != 0x53be9b3:
* from pickle import PickleError as __pyx_PickleError # <<<<<<<<<<<<<<
* raise __pyx_PickleError("Incompatible checksums (%s vs 0x53be9b3 = (_batch_size, _buffer, _compression_type, _magic))" % __pyx_checksum)
* __pyx_result = _LegacyRecordBatchBuilderCython.__new__(__pyx_type)
*/
__pyx_t_2 = PyList_New(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 3, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_2);
__Pyx_INCREF(__pyx_n_s_PickleError);
__Pyx_GIVEREF(__pyx_n_s_PickleError);
PyList_SET_ITEM(__pyx_t_2, 0, __pyx_n_s_PickleError);
__pyx_t_3 = __Pyx_Import(__pyx_n_s_pickle, __pyx_t_2, 0); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 3, __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_n_s_PickleError); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 3, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_2);
__Pyx_INCREF(__pyx_t_2);
__pyx_v___pyx_PickleError = __pyx_t_2;
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
/* "(tree fragment)":4
* if __pyx_checksum != 0x53be9b3:
* from pickle import PickleError as __pyx_PickleError
* raise __pyx_PickleError("Incompatible checksums (%s vs 0x53be9b3 = (_batch_size, _buffer, _compression_type, _magic))" % __pyx_checksum) # <<<<<<<<<<<<<<
* __pyx_result = _LegacyRecordBatchBuilderCython.__new__(__pyx_type)
* if __pyx_state is not None:
*/
__pyx_t_2 = __Pyx_PyInt_From_long(__pyx_v___pyx_checksum); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_2);
__pyx_t_4 = __Pyx_PyString_Format(__pyx_kp_s_Incompatible_checksums_s_vs_0x53, __pyx_t_2); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_4);
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
__Pyx_INCREF(__pyx_v___pyx_PickleError);
__pyx_t_2 = __pyx_v___pyx_PickleError; __pyx_t_5 = NULL;
if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_2))) {
__pyx_t_5 = PyMethod_GET_SELF(__pyx_t_2);
if (likely(__pyx_t_5)) {
PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
__Pyx_INCREF(__pyx_t_5);
__Pyx_INCREF(function);
__Pyx_DECREF_SET(__pyx_t_2, function);
}
}
if (!__pyx_t_5) {
__pyx_t_3 = __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_t_4); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 4, __pyx_L1_error)
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
__Pyx_GOTREF(__pyx_t_3);
} else {
#if CYTHON_FAST_PYCALL
if (PyFunction_Check(__pyx_t_2)) {
PyObject *__pyx_temp[2] = {__pyx_t_5, __pyx_t_4};
__pyx_t_3 = __Pyx_PyFunction_FastCall(__pyx_t_2, __pyx_temp+1-1, 1+1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 4, __pyx_L1_error)
__Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
__Pyx_GOTREF(__pyx_t_3);
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
} else
#endif
#if CYTHON_FAST_PYCCALL
if (__Pyx_PyFastCFunction_Check(__pyx_t_2)) {
PyObject *__pyx_temp[2] = {__pyx_t_5, __pyx_t_4};
__pyx_t_3 = __Pyx_PyCFunction_FastCall(__pyx_t_2, __pyx_temp+1-1, 1+1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 4, __pyx_L1_error)
__Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
__Pyx_GOTREF(__pyx_t_3);
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
} else
#endif
{
__pyx_t_6 = PyTuple_New(1+1); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 4, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_6);
__Pyx_GIVEREF(__pyx_t_5); PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_5); __pyx_t_5 = NULL;
__Pyx_GIVEREF(__pyx_t_4);
PyTuple_SET_ITEM(__pyx_t_6, 0+1, __pyx_t_4);
__pyx_t_4 = 0;
__pyx_t_3 = __Pyx_PyObject_Call(__pyx_t_2, __pyx_t_6, NULL); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 4, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_3);
__Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
}
}
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
__Pyx_Raise(__pyx_t_3, 0, 0, 0);
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
__PYX_ERR(1, 4, __pyx_L1_error)
/* "(tree fragment)":2
* def __pyx_unpickle__LegacyRecordBatchBuilderCython(__pyx_type, long __pyx_checksum, __pyx_state):
* if __pyx_checksum != 0x53be9b3: # <<<<<<<<<<<<<<
* from pickle import PickleError as __pyx_PickleError
* raise __pyx_PickleError("Incompatible checksums (%s vs 0x53be9b3 = (_batch_size, _buffer, _compression_type, _magic))" % __pyx_checksum)
*/
}
/* "(tree fragment)":5
* from pickle import PickleError as __pyx_PickleError
* raise __pyx_PickleError("Incompatible checksums (%s vs 0x53be9b3 = (_batch_size, _buffer, _compression_type, _magic))" % __pyx_checksum)
* __pyx_result = _LegacyRecordBatchBuilderCython.__new__(__pyx_type) # <<<<<<<<<<<<<<
* if __pyx_state is not None:
* __pyx_unpickle__LegacyRecordBatchBuilderCython__set_state(<_LegacyRecordBatchBuilderCython> __pyx_result, __pyx_state)
*/
__pyx_t_2 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_ptype_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython), __pyx_n_s_new); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_2);
__pyx_t_6 = NULL;
if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_2))) {
__pyx_t_6 = PyMethod_GET_SELF(__pyx_t_2);
if (likely(__pyx_t_6)) {
PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
__Pyx_INCREF(__pyx_t_6);
__Pyx_INCREF(function);
__Pyx_DECREF_SET(__pyx_t_2, function);
}
}
if (!__pyx_t_6) {
__pyx_t_3 = __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_v___pyx_type); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_3);
} else {
#if CYTHON_FAST_PYCALL
if (PyFunction_Check(__pyx_t_2)) {
PyObject *__pyx_temp[2] = {__pyx_t_6, __pyx_v___pyx_type};
__pyx_t_3 = __Pyx_PyFunction_FastCall(__pyx_t_2, __pyx_temp+1-1, 1+1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5, __pyx_L1_error)
__Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
__Pyx_GOTREF(__pyx_t_3);
} else
#endif
#if CYTHON_FAST_PYCCALL
if (__Pyx_PyFastCFunction_Check(__pyx_t_2)) {
PyObject *__pyx_temp[2] = {__pyx_t_6, __pyx_v___pyx_type};
__pyx_t_3 = __Pyx_PyCFunction_FastCall(__pyx_t_2, __pyx_temp+1-1, 1+1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5, __pyx_L1_error)
__Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
__Pyx_GOTREF(__pyx_t_3);
} else
#endif
{
__pyx_t_4 = PyTuple_New(1+1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_4);
__Pyx_GIVEREF(__pyx_t_6); PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_6); __pyx_t_6 = NULL;
__Pyx_INCREF(__pyx_v___pyx_type);
__Pyx_GIVEREF(__pyx_v___pyx_type);
PyTuple_SET_ITEM(__pyx_t_4, 0+1, __pyx_v___pyx_type);
__pyx_t_3 = __Pyx_PyObject_Call(__pyx_t_2, __pyx_t_4, NULL); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_3);
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
}
}
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
__pyx_v___pyx_result = __pyx_t_3;
__pyx_t_3 = 0;
/* "(tree fragment)":6
* raise __pyx_PickleError("Incompatible checksums (%s vs 0x53be9b3 = (_batch_size, _buffer, _compression_type, _magic))" % __pyx_checksum)
* __pyx_result = _LegacyRecordBatchBuilderCython.__new__(__pyx_type)
* if __pyx_state is not None: # <<<<<<<<<<<<<<
* __pyx_unpickle__LegacyRecordBatchBuilderCython__set_state(<_LegacyRecordBatchBuilderCython> __pyx_result, __pyx_state)
* return __pyx_result
*/
__pyx_t_1 = (__pyx_v___pyx_state != Py_None);
__pyx_t_7 = (__pyx_t_1 != 0);
if (__pyx_t_7) {
/* "(tree fragment)":7
* __pyx_result = _LegacyRecordBatchBuilderCython.__new__(__pyx_type)
* if __pyx_state is not None:
* __pyx_unpickle__LegacyRecordBatchBuilderCython__set_state(<_LegacyRecordBatchBuilderCython> __pyx_result, __pyx_state) # <<<<<<<<<<<<<<
* return __pyx_result
* cdef __pyx_unpickle__LegacyRecordBatchBuilderCython__set_state(_LegacyRecordBatchBuilderCython __pyx_result, tuple __pyx_state):
*/
if (!(likely(PyTuple_CheckExact(__pyx_v___pyx_state))||((__pyx_v___pyx_state) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected %.16s, got %.200s", "tuple", Py_TYPE(__pyx_v___pyx_state)->tp_name), 0))) __PYX_ERR(1, 7, __pyx_L1_error)
__pyx_t_3 = __pyx_f_8aiokafka_6record_15_legacy_records___pyx_unpickle__LegacyRecordBatchBuilderCython__set_state(((struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *)__pyx_v___pyx_result), ((PyObject*)__pyx_v___pyx_state)); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 7, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_3);
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
/* "(tree fragment)":6
* raise __pyx_PickleError("Incompatible checksums (%s vs 0x53be9b3 = (_batch_size, _buffer, _compression_type, _magic))" % __pyx_checksum)
* __pyx_result = _LegacyRecordBatchBuilderCython.__new__(__pyx_type)
* if __pyx_state is not None: # <<<<<<<<<<<<<<
* __pyx_unpickle__LegacyRecordBatchBuilderCython__set_state(<_LegacyRecordBatchBuilderCython> __pyx_result, __pyx_state)
* return __pyx_result
*/
}
/* "(tree fragment)":8
* if __pyx_state is not None:
* __pyx_unpickle__LegacyRecordBatchBuilderCython__set_state(<_LegacyRecordBatchBuilderCython> __pyx_result, __pyx_state)
* return __pyx_result # <<<<<<<<<<<<<<
* cdef __pyx_unpickle__LegacyRecordBatchBuilderCython__set_state(_LegacyRecordBatchBuilderCython __pyx_result, tuple __pyx_state):
* __pyx_result._batch_size = __pyx_state[0]; __pyx_result._buffer = __pyx_state[1]; __pyx_result._compression_type = __pyx_state[2]; __pyx_result._magic = __pyx_state[3]
*/
__Pyx_XDECREF(__pyx_r);
__Pyx_INCREF(__pyx_v___pyx_result);
__pyx_r = __pyx_v___pyx_result;
goto __pyx_L0;
/* "(tree fragment)":1
* def __pyx_unpickle__LegacyRecordBatchBuilderCython(__pyx_type, long __pyx_checksum, __pyx_state): # <<<<<<<<<<<<<<
* if __pyx_checksum != 0x53be9b3:
* from pickle import PickleError as __pyx_PickleError
*/
/* function exit code */
__pyx_L1_error:;
__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_AddTraceback("aiokafka.record._legacy_records.__pyx_unpickle__LegacyRecordBatchBuilderCython", __pyx_clineno, __pyx_lineno, __pyx_filename);
__pyx_r = NULL;
__pyx_L0:;
__Pyx_XDECREF(__pyx_v___pyx_PickleError);
__Pyx_XDECREF(__pyx_v___pyx_result);
__Pyx_XGIVEREF(__pyx_r);
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
/* "(tree fragment)":9
* __pyx_unpickle__LegacyRecordBatchBuilderCython__set_state(<_LegacyRecordBatchBuilderCython> __pyx_result, __pyx_state)
* return __pyx_result
* cdef __pyx_unpickle__LegacyRecordBatchBuilderCython__set_state(_LegacyRecordBatchBuilderCython __pyx_result, tuple __pyx_state): # <<<<<<<<<<<<<<
* __pyx_result._batch_size = __pyx_state[0]; __pyx_result._buffer = __pyx_state[1]; __pyx_result._compression_type = __pyx_state[2]; __pyx_result._magic = __pyx_state[3]
* if len(__pyx_state) > 4 and hasattr(__pyx_result, '__dict__'):
*/
static PyObject *__pyx_f_8aiokafka_6record_15_legacy_records___pyx_unpickle__LegacyRecordBatchBuilderCython__set_state(struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *__pyx_v___pyx_result, PyObject *__pyx_v___pyx_state) {
PyObject *__pyx_r = NULL;
__Pyx_RefNannyDeclarations
PyObject *__pyx_t_1 = NULL;
int __pyx_t_2;
char __pyx_t_3;
int __pyx_t_4;
Py_ssize_t __pyx_t_5;
int __pyx_t_6;
int __pyx_t_7;
PyObject *__pyx_t_8 = NULL;
PyObject *__pyx_t_9 = NULL;
PyObject *__pyx_t_10 = NULL;
PyObject *__pyx_t_11 = NULL;
__Pyx_RefNannySetupContext("__pyx_unpickle__LegacyRecordBatchBuilderCython__set_state", 0);
/* "(tree fragment)":10
* return __pyx_result
* cdef __pyx_unpickle__LegacyRecordBatchBuilderCython__set_state(_LegacyRecordBatchBuilderCython __pyx_result, tuple __pyx_state):
* __pyx_result._batch_size = __pyx_state[0]; __pyx_result._buffer = __pyx_state[1]; __pyx_result._compression_type = __pyx_state[2]; __pyx_result._magic = __pyx_state[3] # <<<<<<<<<<<<<<
* if len(__pyx_state) > 4 and hasattr(__pyx_result, '__dict__'):
* __pyx_result.__dict__.update(__pyx_state[4])
*/
if (unlikely(__pyx_v___pyx_state == Py_None)) {
PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable");
__PYX_ERR(1, 10, __pyx_L1_error)
}
__pyx_t_1 = __Pyx_GetItemInt_Tuple(__pyx_v___pyx_state, 0, long, 1, __Pyx_PyInt_From_long, 0, 0, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 10, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_1);
__pyx_t_2 = __Pyx_PyInt_As_int(__pyx_t_1); if (unlikely((__pyx_t_2 == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 10, __pyx_L1_error)
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
__pyx_v___pyx_result->_batch_size = __pyx_t_2;
if (unlikely(__pyx_v___pyx_state == Py_None)) {
PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable");
__PYX_ERR(1, 10, __pyx_L1_error)
}
__pyx_t_1 = __Pyx_GetItemInt_Tuple(__pyx_v___pyx_state, 1, long, 1, __Pyx_PyInt_From_long, 0, 0, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 10, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_1);
if (!(likely(PyByteArray_CheckExact(__pyx_t_1))||((__pyx_t_1) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected %.16s, got %.200s", "bytearray", Py_TYPE(__pyx_t_1)->tp_name), 0))) __PYX_ERR(1, 10, __pyx_L1_error)
__Pyx_GIVEREF(__pyx_t_1);
__Pyx_GOTREF(__pyx_v___pyx_result->_buffer);
__Pyx_DECREF(__pyx_v___pyx_result->_buffer);
__pyx_v___pyx_result->_buffer = ((PyObject*)__pyx_t_1);
__pyx_t_1 = 0;
if (unlikely(__pyx_v___pyx_state == Py_None)) {
PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable");
__PYX_ERR(1, 10, __pyx_L1_error)
}
__pyx_t_1 = __Pyx_GetItemInt_Tuple(__pyx_v___pyx_state, 2, long, 1, __Pyx_PyInt_From_long, 0, 0, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 10, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_1);
__pyx_t_3 = __Pyx_PyInt_As_char(__pyx_t_1); if (unlikely((__pyx_t_3 == (char)-1) && PyErr_Occurred())) __PYX_ERR(1, 10, __pyx_L1_error)
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
__pyx_v___pyx_result->_compression_type = __pyx_t_3;
if (unlikely(__pyx_v___pyx_state == Py_None)) {
PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable");
__PYX_ERR(1, 10, __pyx_L1_error)
}
__pyx_t_1 = __Pyx_GetItemInt_Tuple(__pyx_v___pyx_state, 3, long, 1, __Pyx_PyInt_From_long, 0, 0, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 10, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_1);
__pyx_t_3 = __Pyx_PyInt_As_char(__pyx_t_1); if (unlikely((__pyx_t_3 == (char)-1) && PyErr_Occurred())) __PYX_ERR(1, 10, __pyx_L1_error)
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
__pyx_v___pyx_result->_magic = __pyx_t_3;
/* "(tree fragment)":11
* cdef __pyx_unpickle__LegacyRecordBatchBuilderCython__set_state(_LegacyRecordBatchBuilderCython __pyx_result, tuple __pyx_state):
* __pyx_result._batch_size = __pyx_state[0]; __pyx_result._buffer = __pyx_state[1]; __pyx_result._compression_type = __pyx_state[2]; __pyx_result._magic = __pyx_state[3]
* if len(__pyx_state) > 4 and hasattr(__pyx_result, '__dict__'): # <<<<<<<<<<<<<<
* __pyx_result.__dict__.update(__pyx_state[4])
*/
if (unlikely(__pyx_v___pyx_state == Py_None)) {
PyErr_SetString(PyExc_TypeError, "object of type 'NoneType' has no len()");
__PYX_ERR(1, 11, __pyx_L1_error)
}
__pyx_t_5 = PyTuple_GET_SIZE(__pyx_v___pyx_state); if (unlikely(__pyx_t_5 == -1)) __PYX_ERR(1, 11, __pyx_L1_error)
__pyx_t_6 = ((__pyx_t_5 > 4) != 0);
if (__pyx_t_6) {
} else {
__pyx_t_4 = __pyx_t_6;
goto __pyx_L4_bool_binop_done;
}
__pyx_t_6 = __Pyx_HasAttr(((PyObject *)__pyx_v___pyx_result), __pyx_n_s_dict); if (unlikely(__pyx_t_6 == -1)) __PYX_ERR(1, 11, __pyx_L1_error)
__pyx_t_7 = (__pyx_t_6 != 0);
__pyx_t_4 = __pyx_t_7;
__pyx_L4_bool_binop_done:;
if (__pyx_t_4) {
/* "(tree fragment)":12
* __pyx_result._batch_size = __pyx_state[0]; __pyx_result._buffer = __pyx_state[1]; __pyx_result._compression_type = __pyx_state[2]; __pyx_result._magic = __pyx_state[3]
* if len(__pyx_state) > 4 and hasattr(__pyx_result, '__dict__'):
* __pyx_result.__dict__.update(__pyx_state[4]) # <<<<<<<<<<<<<<
*/
__pyx_t_8 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v___pyx_result), __pyx_n_s_dict); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 12, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_8);
__pyx_t_9 = __Pyx_PyObject_GetAttrStr(__pyx_t_8, __pyx_n_s_update); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 12, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_9);
__Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
if (unlikely(__pyx_v___pyx_state == Py_None)) {
PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable");
__PYX_ERR(1, 12, __pyx_L1_error)
}
__pyx_t_8 = __Pyx_GetItemInt_Tuple(__pyx_v___pyx_state, 4, long, 1, __Pyx_PyInt_From_long, 0, 0, 1); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 12, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_8);
__pyx_t_10 = NULL;
if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_9))) {
__pyx_t_10 = PyMethod_GET_SELF(__pyx_t_9);
if (likely(__pyx_t_10)) {
PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_9);
__Pyx_INCREF(__pyx_t_10);
__Pyx_INCREF(function);
__Pyx_DECREF_SET(__pyx_t_9, function);
}
}
if (!__pyx_t_10) {
__pyx_t_1 = __Pyx_PyObject_CallOneArg(__pyx_t_9, __pyx_t_8); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 12, __pyx_L1_error)
__Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
__Pyx_GOTREF(__pyx_t_1);
} else {
#if CYTHON_FAST_PYCALL
if (PyFunction_Check(__pyx_t_9)) {
PyObject *__pyx_temp[2] = {__pyx_t_10, __pyx_t_8};
__pyx_t_1 = __Pyx_PyFunction_FastCall(__pyx_t_9, __pyx_temp+1-1, 1+1); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 12, __pyx_L1_error)
__Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0;
__Pyx_GOTREF(__pyx_t_1);
__Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
} else
#endif
#if CYTHON_FAST_PYCCALL
if (__Pyx_PyFastCFunction_Check(__pyx_t_9)) {
PyObject *__pyx_temp[2] = {__pyx_t_10, __pyx_t_8};
__pyx_t_1 = __Pyx_PyCFunction_FastCall(__pyx_t_9, __pyx_temp+1-1, 1+1); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 12, __pyx_L1_error)
__Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0;
__Pyx_GOTREF(__pyx_t_1);
__Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
} else
#endif
{
__pyx_t_11 = PyTuple_New(1+1); if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 12, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_11);
__Pyx_GIVEREF(__pyx_t_10); PyTuple_SET_ITEM(__pyx_t_11, 0, __pyx_t_10); __pyx_t_10 = NULL;
__Pyx_GIVEREF(__pyx_t_8);
PyTuple_SET_ITEM(__pyx_t_11, 0+1, __pyx_t_8);
__pyx_t_8 = 0;
__pyx_t_1 = __Pyx_PyObject_Call(__pyx_t_9, __pyx_t_11, NULL); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 12, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_1);
__Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
}
}
__Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
/* "(tree fragment)":11
* cdef __pyx_unpickle__LegacyRecordBatchBuilderCython__set_state(_LegacyRecordBatchBuilderCython __pyx_result, tuple __pyx_state):
* __pyx_result._batch_size = __pyx_state[0]; __pyx_result._buffer = __pyx_state[1]; __pyx_result._compression_type = __pyx_state[2]; __pyx_result._magic = __pyx_state[3]
* if len(__pyx_state) > 4 and hasattr(__pyx_result, '__dict__'): # <<<<<<<<<<<<<<
* __pyx_result.__dict__.update(__pyx_state[4])
*/
}
/* "(tree fragment)":9
* __pyx_unpickle__LegacyRecordBatchBuilderCython__set_state(<_LegacyRecordBatchBuilderCython> __pyx_result, __pyx_state)
* return __pyx_result
* cdef __pyx_unpickle__LegacyRecordBatchBuilderCython__set_state(_LegacyRecordBatchBuilderCython __pyx_result, tuple __pyx_state): # <<<<<<<<<<<<<<
* __pyx_result._batch_size = __pyx_state[0]; __pyx_result._buffer = __pyx_state[1]; __pyx_result._compression_type = __pyx_state[2]; __pyx_result._magic = __pyx_state[3]
* if len(__pyx_state) > 4 and hasattr(__pyx_result, '__dict__'):
*/
/* 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_8);
__Pyx_XDECREF(__pyx_t_9);
__Pyx_XDECREF(__pyx_t_10);
__Pyx_XDECREF(__pyx_t_11);
__Pyx_AddTraceback("aiokafka.record._legacy_records.__pyx_unpickle__LegacyRecordBatchBuilderCython__set_state", __pyx_clineno, __pyx_lineno, __pyx_filename);
__pyx_r = 0;
__pyx_L0:;
__Pyx_XGIVEREF(__pyx_r);
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
/* "_hton.pxd":27
*
*
* cdef inline void pack_int16(char* buf, int16_t x): # <<<<<<<<<<<<<<
* (<uint16_t*>buf)[0] = htons(<uint16_t>x)
*
*/
static CYTHON_INLINE void __pyx_f_8aiokafka_6record_5_hton_pack_int16(char *__pyx_v_buf, int16_t __pyx_v_x) {
__Pyx_RefNannyDeclarations
__Pyx_RefNannySetupContext("pack_int16", 0);
/* "_hton.pxd":28
*
* cdef inline void pack_int16(char* buf, int16_t x):
* (<uint16_t*>buf)[0] = htons(<uint16_t>x) # <<<<<<<<<<<<<<
*
*
*/
(((uint16_t *)__pyx_v_buf)[0]) = htons(((uint16_t)__pyx_v_x));
/* "_hton.pxd":27
*
*
* cdef inline void pack_int16(char* buf, int16_t x): # <<<<<<<<<<<<<<
* (<uint16_t*>buf)[0] = htons(<uint16_t>x)
*
*/
/* function exit code */
__Pyx_RefNannyFinishContext();
}
/* "_hton.pxd":31
*
*
* cdef inline int16_t unpack_int16(const char* buf): # <<<<<<<<<<<<<<
* return <int16_t>ntohs((<uint16_t*>buf)[0])
*
*/
static CYTHON_INLINE int16_t __pyx_f_8aiokafka_6record_5_hton_unpack_int16(char const *__pyx_v_buf) {
int16_t __pyx_r;
__Pyx_RefNannyDeclarations
__Pyx_RefNannySetupContext("unpack_int16", 0);
/* "_hton.pxd":32
*
* cdef inline int16_t unpack_int16(const char* buf):
* return <int16_t>ntohs((<uint16_t*>buf)[0]) # <<<<<<<<<<<<<<
*
*
*/
__pyx_r = ((int16_t)ntohs((((uint16_t *)__pyx_v_buf)[0])));
goto __pyx_L0;
/* "_hton.pxd":31
*
*
* cdef inline int16_t unpack_int16(const char* buf): # <<<<<<<<<<<<<<
* return <int16_t>ntohs((<uint16_t*>buf)[0])
*
*/
/* function exit code */
__pyx_L0:;
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
/* "_hton.pxd":35
*
*
* cdef inline void pack_int32(char* buf, int32_t x): # <<<<<<<<<<<<<<
* (<uint32_t*>buf)[0] = htonl(<uint32_t>x)
*
*/
static CYTHON_INLINE void __pyx_f_8aiokafka_6record_5_hton_pack_int32(char *__pyx_v_buf, int32_t __pyx_v_x) {
__Pyx_RefNannyDeclarations
__Pyx_RefNannySetupContext("pack_int32", 0);
/* "_hton.pxd":36
*
* cdef inline void pack_int32(char* buf, int32_t x):
* (<uint32_t*>buf)[0] = htonl(<uint32_t>x) # <<<<<<<<<<<<<<
*
*
*/
(((uint32_t *)__pyx_v_buf)[0]) = htonl(((uint32_t)__pyx_v_x));
/* "_hton.pxd":35
*
*
* cdef inline void pack_int32(char* buf, int32_t x): # <<<<<<<<<<<<<<
* (<uint32_t*>buf)[0] = htonl(<uint32_t>x)
*
*/
/* function exit code */
__Pyx_RefNannyFinishContext();
}
/* "_hton.pxd":39
*
*
* cdef inline int32_t unpack_int32(const char* buf): # <<<<<<<<<<<<<<
* return <int32_t>ntohl((<uint32_t*>buf)[0])
*
*/
static CYTHON_INLINE int32_t __pyx_f_8aiokafka_6record_5_hton_unpack_int32(char const *__pyx_v_buf) {
int32_t __pyx_r;
__Pyx_RefNannyDeclarations
__Pyx_RefNannySetupContext("unpack_int32", 0);
/* "_hton.pxd":40
*
* cdef inline int32_t unpack_int32(const char* buf):
* return <int32_t>ntohl((<uint32_t*>buf)[0]) # <<<<<<<<<<<<<<
*
*
*/
__pyx_r = ((int32_t)ntohl((((uint32_t *)__pyx_v_buf)[0])));
goto __pyx_L0;
/* "_hton.pxd":39
*
*
* cdef inline int32_t unpack_int32(const char* buf): # <<<<<<<<<<<<<<
* return <int32_t>ntohl((<uint32_t*>buf)[0])
*
*/
/* function exit code */
__pyx_L0:;
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
/* "_hton.pxd":43
*
*
* cdef inline void pack_int64(char* buf, int64_t x): # <<<<<<<<<<<<<<
* (<uint32_t*>buf)[0] = htonl(<uint32_t>(<uint64_t>(x) >> 32))
* (<uint32_t*>&buf[4])[0] = htonl(<uint32_t>(x))
*/
static CYTHON_INLINE void __pyx_f_8aiokafka_6record_5_hton_pack_int64(char *__pyx_v_buf, int64_t __pyx_v_x) {
__Pyx_RefNannyDeclarations
__Pyx_RefNannySetupContext("pack_int64", 0);
/* "_hton.pxd":44
*
* cdef inline void pack_int64(char* buf, int64_t x):
* (<uint32_t*>buf)[0] = htonl(<uint32_t>(<uint64_t>(x) >> 32)) # <<<<<<<<<<<<<<
* (<uint32_t*>&buf[4])[0] = htonl(<uint32_t>(x))
*
*/
(((uint32_t *)__pyx_v_buf)[0]) = htonl(((uint32_t)(((uint64_t)__pyx_v_x) >> 32)));
/* "_hton.pxd":45
* cdef inline void pack_int64(char* buf, int64_t x):
* (<uint32_t*>buf)[0] = htonl(<uint32_t>(<uint64_t>(x) >> 32))
* (<uint32_t*>&buf[4])[0] = htonl(<uint32_t>(x)) # <<<<<<<<<<<<<<
*
*
*/
(((uint32_t *)(&(__pyx_v_buf[4])))[0]) = htonl(((uint32_t)__pyx_v_x));
/* "_hton.pxd":43
*
*
* cdef inline void pack_int64(char* buf, int64_t x): # <<<<<<<<<<<<<<
* (<uint32_t*>buf)[0] = htonl(<uint32_t>(<uint64_t>(x) >> 32))
* (<uint32_t*>&buf[4])[0] = htonl(<uint32_t>(x))
*/
/* function exit code */
__Pyx_RefNannyFinishContext();
}
/* "_hton.pxd":48
*
*
* cdef inline int64_t unpack_int64(const char* buf): # <<<<<<<<<<<<<<
* cdef int64_t hh = unpack_int32(buf)
* cdef uint32_t hl = <uint32_t>unpack_int32(&buf[4])
*/
static CYTHON_INLINE int64_t __pyx_f_8aiokafka_6record_5_hton_unpack_int64(char const *__pyx_v_buf) {
int64_t __pyx_v_hh;
uint32_t __pyx_v_hl;
int64_t __pyx_r;
__Pyx_RefNannyDeclarations
__Pyx_RefNannySetupContext("unpack_int64", 0);
/* "_hton.pxd":49
*
* cdef inline int64_t unpack_int64(const char* buf):
* cdef int64_t hh = unpack_int32(buf) # <<<<<<<<<<<<<<
* cdef uint32_t hl = <uint32_t>unpack_int32(&buf[4])
*
*/
__pyx_v_hh = __pyx_f_8aiokafka_6record_5_hton_unpack_int32(__pyx_v_buf);
/* "_hton.pxd":50
* cdef inline int64_t unpack_int64(const char* buf):
* cdef int64_t hh = unpack_int32(buf)
* cdef uint32_t hl = <uint32_t>unpack_int32(&buf[4]) # <<<<<<<<<<<<<<
*
* return (hh << 32) | hl
*/
__pyx_v_hl = ((uint32_t)__pyx_f_8aiokafka_6record_5_hton_unpack_int32((&(__pyx_v_buf[4]))));
/* "_hton.pxd":52
* cdef uint32_t hl = <uint32_t>unpack_int32(&buf[4])
*
* return (hh << 32) | hl # <<<<<<<<<<<<<<
*
*
*/
__pyx_r = ((__pyx_v_hh << 32) | __pyx_v_hl);
goto __pyx_L0;
/* "_hton.pxd":48
*
*
* cdef inline int64_t unpack_int64(const char* buf): # <<<<<<<<<<<<<<
* cdef int64_t hh = unpack_int32(buf)
* cdef uint32_t hl = <uint32_t>unpack_int32(&buf[4])
*/
/* function exit code */
__pyx_L0:;
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
/* "_hton.pxd":60
*
*
* cdef inline int32_t pack_float(char* buf, float f): # <<<<<<<<<<<<<<
* cdef _floatconv v
* v.f = f
*/
static CYTHON_INLINE int32_t __pyx_f_8aiokafka_6record_5_hton_pack_float(char *__pyx_v_buf, float __pyx_v_f) {
union __pyx_t_8aiokafka_6record_5_hton__floatconv __pyx_v_v;
int32_t __pyx_r;
__Pyx_RefNannyDeclarations
__Pyx_RefNannySetupContext("pack_float", 0);
/* "_hton.pxd":62
* cdef inline int32_t pack_float(char* buf, float f):
* cdef _floatconv v
* v.f = f # <<<<<<<<<<<<<<
* pack_int32(buf, <int32_t>v.i)
*
*/
__pyx_v_v.f = __pyx_v_f;
/* "_hton.pxd":63
* cdef _floatconv v
* v.f = f
* pack_int32(buf, <int32_t>v.i) # <<<<<<<<<<<<<<
*
*
*/
__pyx_f_8aiokafka_6record_5_hton_pack_int32(__pyx_v_buf, ((int32_t)__pyx_v_v.i));
/* "_hton.pxd":60
*
*
* cdef inline int32_t pack_float(char* buf, float f): # <<<<<<<<<<<<<<
* cdef _floatconv v
* v.f = f
*/
/* function exit code */
__pyx_r = 0;
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
/* "_hton.pxd":66
*
*
* cdef inline float unpack_float(const char* buf): # <<<<<<<<<<<<<<
* cdef _floatconv v
* v.i = <uint32_t>unpack_int32(buf)
*/
static CYTHON_INLINE float __pyx_f_8aiokafka_6record_5_hton_unpack_float(char const *__pyx_v_buf) {
union __pyx_t_8aiokafka_6record_5_hton__floatconv __pyx_v_v;
float __pyx_r;
__Pyx_RefNannyDeclarations
__Pyx_RefNannySetupContext("unpack_float", 0);
/* "_hton.pxd":68
* cdef inline float unpack_float(const char* buf):
* cdef _floatconv v
* v.i = <uint32_t>unpack_int32(buf) # <<<<<<<<<<<<<<
* return v.f
*
*/
__pyx_v_v.i = ((uint32_t)__pyx_f_8aiokafka_6record_5_hton_unpack_int32(__pyx_v_buf));
/* "_hton.pxd":69
* cdef _floatconv v
* v.i = <uint32_t>unpack_int32(buf)
* return v.f # <<<<<<<<<<<<<<
*
*
*/
__pyx_r = __pyx_v_v.f;
goto __pyx_L0;
/* "_hton.pxd":66
*
*
* cdef inline float unpack_float(const char* buf): # <<<<<<<<<<<<<<
* cdef _floatconv v
* v.i = <uint32_t>unpack_int32(buf)
*/
/* function exit code */
__pyx_L0:;
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
/* "_hton.pxd":77
*
*
* cdef inline int64_t pack_double(char* buf, double f): # <<<<<<<<<<<<<<
* cdef _doubleconv v
* v.f = f
*/
static CYTHON_INLINE int64_t __pyx_f_8aiokafka_6record_5_hton_pack_double(char *__pyx_v_buf, double __pyx_v_f) {
union __pyx_t_8aiokafka_6record_5_hton__doubleconv __pyx_v_v;
int64_t __pyx_r;
__Pyx_RefNannyDeclarations
__Pyx_RefNannySetupContext("pack_double", 0);
/* "_hton.pxd":79
* cdef inline int64_t pack_double(char* buf, double f):
* cdef _doubleconv v
* v.f = f # <<<<<<<<<<<<<<
* pack_int64(buf, <int64_t>v.i)
*
*/
__pyx_v_v.f = __pyx_v_f;
/* "_hton.pxd":80
* cdef _doubleconv v
* v.f = f
* pack_int64(buf, <int64_t>v.i) # <<<<<<<<<<<<<<
*
*
*/
__pyx_f_8aiokafka_6record_5_hton_pack_int64(__pyx_v_buf, ((int64_t)__pyx_v_v.i));
/* "_hton.pxd":77
*
*
* cdef inline int64_t pack_double(char* buf, double f): # <<<<<<<<<<<<<<
* cdef _doubleconv v
* v.f = f
*/
/* function exit code */
__pyx_r = 0;
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
/* "_hton.pxd":83
*
*
* cdef inline double unpack_double(const char* buf): # <<<<<<<<<<<<<<
* cdef _doubleconv v
* v.i = <uint64_t>unpack_int64(buf)
*/
static CYTHON_INLINE double __pyx_f_8aiokafka_6record_5_hton_unpack_double(char const *__pyx_v_buf) {
union __pyx_t_8aiokafka_6record_5_hton__doubleconv __pyx_v_v;
double __pyx_r;
__Pyx_RefNannyDeclarations
__Pyx_RefNannySetupContext("unpack_double", 0);
/* "_hton.pxd":85
* cdef inline double unpack_double(const char* buf):
* cdef _doubleconv v
* v.i = <uint64_t>unpack_int64(buf) # <<<<<<<<<<<<<<
* return v.f
*/
__pyx_v_v.i = ((uint64_t)__pyx_f_8aiokafka_6record_5_hton_unpack_int64(__pyx_v_buf));
/* "_hton.pxd":86
* cdef _doubleconv v
* v.i = <uint64_t>unpack_int64(buf)
* return v.f # <<<<<<<<<<<<<<
*/
__pyx_r = __pyx_v_v.f;
goto __pyx_L0;
/* "_hton.pxd":83
*
*
* cdef inline double unpack_double(const char* buf): # <<<<<<<<<<<<<<
* cdef _doubleconv v
* v.i = <uint64_t>unpack_int64(buf)
*/
/* function exit code */
__pyx_L0:;
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
static struct __pyx_vtabstruct_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython __pyx_vtable_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython;
static PyObject *__pyx_tp_new_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython(PyTypeObject *t, CYTHON_UNUSED PyObject *a, CYTHON_UNUSED PyObject *k) {
struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *p;
PyObject *o;
if (likely((t->tp_flags & Py_TPFLAGS_IS_ABSTRACT) == 0)) {
o = (*t->tp_alloc)(t, 0);
} else {
o = (PyObject *) PyBaseObject_Type.tp_new(t, __pyx_empty_tuple, 0);
}
if (unlikely(!o)) return 0;
p = ((struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *)o);
p->__pyx_vtab = __pyx_vtabptr_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython;
p->_buffer = ((PyObject*)Py_None); Py_INCREF(Py_None);
return o;
}
static void __pyx_tp_dealloc_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython(PyObject *o) {
struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *p = (struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *)o;
#if CYTHON_USE_TP_FINALIZE
if (unlikely(PyType_HasFeature(Py_TYPE(o), Py_TPFLAGS_HAVE_FINALIZE) && Py_TYPE(o)->tp_finalize) && (!PyType_IS_GC(Py_TYPE(o)) || !_PyGC_FINALIZED(o))) {
if (PyObject_CallFinalizerFromDealloc(o)) return;
}
#endif
Py_CLEAR(p->_buffer);
(*Py_TYPE(o)->tp_free)(o);
}
static PyMethodDef __pyx_methods_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython[] = {
{"append", (PyCFunction)__pyx_pw_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_3append, METH_VARARGS|METH_KEYWORDS, __pyx_doc_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_2append},
{"size", (PyCFunction)__pyx_pw_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_5size, METH_NOARGS, __pyx_doc_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_4size},
{"size_in_bytes", (PyCFunction)__pyx_pw_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_7size_in_bytes, METH_VARARGS|METH_KEYWORDS, __pyx_doc_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_6size_in_bytes},
{"build", (PyCFunction)__pyx_pw_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_9build, METH_NOARGS, __pyx_doc_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_8build},
{"__reduce_cython__", (PyCFunction)__pyx_pw_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_11__reduce_cython__, METH_NOARGS, 0},
{"__setstate_cython__", (PyCFunction)__pyx_pw_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_13__setstate_cython__, METH_O, 0},
{0, 0, 0, 0}
};
static PyTypeObject __pyx_type_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython = {
PyVarObject_HEAD_INIT(0, 0)
"aiokafka.record._legacy_records._LegacyRecordBatchBuilderCython", /*tp_name*/
sizeof(struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython), /*tp_basicsize*/
0, /*tp_itemsize*/
__pyx_tp_dealloc_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython, /*tp_dealloc*/
0, /*tp_print*/
0, /*tp_getattr*/
0, /*tp_setattr*/
#if PY_MAJOR_VERSION < 3
0, /*tp_compare*/
#endif
#if PY_MAJOR_VERSION >= 3
0, /*tp_as_async*/
#endif
0, /*tp_repr*/
0, /*tp_as_number*/
0, /*tp_as_sequence*/
0, /*tp_as_mapping*/
0, /*tp_hash*/
0, /*tp_call*/
0, /*tp_str*/
0, /*tp_getattro*/
0, /*tp_setattro*/
0, /*tp_as_buffer*/
Py_TPFLAGS_DEFAULT|Py_TPFLAGS_HAVE_VERSION_TAG|Py_TPFLAGS_CHECKTYPES|Py_TPFLAGS_HAVE_NEWBUFFER|Py_TPFLAGS_BASETYPE, /*tp_flags*/
0, /*tp_doc*/
0, /*tp_traverse*/
0, /*tp_clear*/
0, /*tp_richcompare*/
0, /*tp_weaklistoffset*/
0, /*tp_iter*/
0, /*tp_iternext*/
__pyx_methods_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython, /*tp_methods*/
0, /*tp_members*/
0, /*tp_getset*/
0, /*tp_base*/
0, /*tp_dict*/
0, /*tp_descr_get*/
0, /*tp_descr_set*/
0, /*tp_dictoffset*/
__pyx_pw_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython_1__init__, /*tp_init*/
0, /*tp_alloc*/
__pyx_tp_new_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython, /*tp_new*/
0, /*tp_free*/
0, /*tp_is_gc*/
0, /*tp_bases*/
0, /*tp_mro*/
0, /*tp_cache*/
0, /*tp_subclasses*/
0, /*tp_weaklist*/
0, /*tp_del*/
0, /*tp_version_tag*/
#if PY_VERSION_HEX >= 0x030400a1
0, /*tp_finalize*/
#endif
};
static PyMethodDef __pyx_methods[] = {
{0, 0, 0, 0}
};
#if PY_MAJOR_VERSION >= 3
#if CYTHON_PEP489_MULTI_PHASE_INIT
static PyObject* __pyx_pymod_create(PyObject *spec, PyModuleDef *def); /*proto*/
static int __pyx_pymod_exec__legacy_records(PyObject* module); /*proto*/
static PyModuleDef_Slot __pyx_moduledef_slots[] = {
{Py_mod_create, (void*)__pyx_pymod_create},
{Py_mod_exec, (void*)__pyx_pymod_exec__legacy_records},
{0, NULL}
};
#endif
static struct PyModuleDef __pyx_moduledef = {
PyModuleDef_HEAD_INIT,
"_legacy_records",
0, /* m_doc */
#if CYTHON_PEP489_MULTI_PHASE_INIT
0, /* m_size */
#else
-1, /* m_size */
#endif
__pyx_methods /* m_methods */,
#if CYTHON_PEP489_MULTI_PHASE_INIT
__pyx_moduledef_slots, /* m_slots */
#else
NULL, /* m_reload */
#endif
NULL, /* m_traverse */
NULL, /* m_clear */
NULL /* m_free */
};
#endif
static __Pyx_StringTabEntry __pyx_string_tab[] = {
{&__pyx_n_s_CODEC_GZIP, __pyx_k_CODEC_GZIP, sizeof(__pyx_k_CODEC_GZIP), 0, 0, 1, 1},
{&__pyx_n_s_CODEC_LZ4, __pyx_k_CODEC_LZ4, sizeof(__pyx_k_CODEC_LZ4), 0, 0, 1, 1},
{&__pyx_n_s_CODEC_SNAPPY, __pyx_k_CODEC_SNAPPY, sizeof(__pyx_k_CODEC_SNAPPY), 0, 0, 1, 1},
{&__pyx_kp_s_Incompatible_checksums_s_vs_0x53, __pyx_k_Incompatible_checksums_s_vs_0x53, sizeof(__pyx_k_Incompatible_checksums_s_vs_0x53), 0, 0, 1, 0},
{&__pyx_n_s_PickleError, __pyx_k_PickleError, sizeof(__pyx_k_PickleError), 0, 0, 1, 1},
{&__pyx_n_s_aiokafka_record__legacy_records, __pyx_k_aiokafka_record__legacy_records, sizeof(__pyx_k_aiokafka_record__legacy_records), 0, 0, 1, 1},
{&__pyx_n_s_batch_size, __pyx_k_batch_size, sizeof(__pyx_k_batch_size), 0, 0, 1, 1},
{&__pyx_n_s_cline_in_traceback, __pyx_k_cline_in_traceback, sizeof(__pyx_k_cline_in_traceback), 0, 0, 1, 1},
{&__pyx_n_s_compression_type, __pyx_k_compression_type, sizeof(__pyx_k_compression_type), 0, 0, 1, 1},
{&__pyx_n_s_crc32, __pyx_k_crc32, sizeof(__pyx_k_crc32), 0, 0, 1, 1},
{&__pyx_n_s_dict, __pyx_k_dict, sizeof(__pyx_k_dict), 0, 0, 1, 1},
{&__pyx_n_s_getstate, __pyx_k_getstate, sizeof(__pyx_k_getstate), 0, 0, 1, 1},
{&__pyx_n_s_gzip_encode, __pyx_k_gzip_encode, sizeof(__pyx_k_gzip_encode), 0, 0, 1, 1},
{&__pyx_n_s_import, __pyx_k_import, sizeof(__pyx_k_import), 0, 0, 1, 1},
{&__pyx_n_s_kafka_codec, __pyx_k_kafka_codec, sizeof(__pyx_k_kafka_codec), 0, 0, 1, 1},
{&__pyx_n_s_key, __pyx_k_key, sizeof(__pyx_k_key), 0, 0, 1, 1},
{&__pyx_n_s_lz4_encode, __pyx_k_lz4_encode, sizeof(__pyx_k_lz4_encode), 0, 0, 1, 1},
{&__pyx_n_s_lz4_encode_old_kafka, __pyx_k_lz4_encode_old_kafka, sizeof(__pyx_k_lz4_encode_old_kafka), 0, 0, 1, 1},
{&__pyx_n_s_magic, __pyx_k_magic, sizeof(__pyx_k_magic), 0, 0, 1, 1},
{&__pyx_n_s_main, __pyx_k_main, sizeof(__pyx_k_main), 0, 0, 1, 1},
{&__pyx_n_s_name, __pyx_k_name, sizeof(__pyx_k_name), 0, 0, 1, 1},
{&__pyx_n_s_new, __pyx_k_new, sizeof(__pyx_k_new), 0, 0, 1, 1},
{&__pyx_n_s_offset, __pyx_k_offset, sizeof(__pyx_k_offset), 0, 0, 1, 1},
{&__pyx_n_s_pickle, __pyx_k_pickle, sizeof(__pyx_k_pickle), 0, 0, 1, 1},
{&__pyx_n_s_py_crc32, __pyx_k_py_crc32, sizeof(__pyx_k_py_crc32), 0, 0, 1, 1},
{&__pyx_n_s_pyx_PickleError, __pyx_k_pyx_PickleError, sizeof(__pyx_k_pyx_PickleError), 0, 0, 1, 1},
{&__pyx_n_s_pyx_checksum, __pyx_k_pyx_checksum, sizeof(__pyx_k_pyx_checksum), 0, 0, 1, 1},
{&__pyx_n_s_pyx_result, __pyx_k_pyx_result, sizeof(__pyx_k_pyx_result), 0, 0, 1, 1},
{&__pyx_n_s_pyx_state, __pyx_k_pyx_state, sizeof(__pyx_k_pyx_state), 0, 0, 1, 1},
{&__pyx_n_s_pyx_type, __pyx_k_pyx_type, sizeof(__pyx_k_pyx_type), 0, 0, 1, 1},
{&__pyx_n_s_pyx_unpickle__LegacyRecordBatc, __pyx_k_pyx_unpickle__LegacyRecordBatc, sizeof(__pyx_k_pyx_unpickle__LegacyRecordBatc), 0, 0, 1, 1},
{&__pyx_n_s_pyx_vtable, __pyx_k_pyx_vtable, sizeof(__pyx_k_pyx_vtable), 0, 0, 1, 1},
{&__pyx_n_s_reduce, __pyx_k_reduce, sizeof(__pyx_k_reduce), 0, 0, 1, 1},
{&__pyx_n_s_reduce_cython, __pyx_k_reduce_cython, sizeof(__pyx_k_reduce_cython), 0, 0, 1, 1},
{&__pyx_n_s_reduce_ex, __pyx_k_reduce_ex, sizeof(__pyx_k_reduce_ex), 0, 0, 1, 1},
{&__pyx_n_s_setstate, __pyx_k_setstate, sizeof(__pyx_k_setstate), 0, 0, 1, 1},
{&__pyx_n_s_setstate_cython, __pyx_k_setstate_cython, sizeof(__pyx_k_setstate_cython), 0, 0, 1, 1},
{&__pyx_n_s_snappy_encode, __pyx_k_snappy_encode, sizeof(__pyx_k_snappy_encode), 0, 0, 1, 1},
{&__pyx_kp_s_stringsource, __pyx_k_stringsource, sizeof(__pyx_k_stringsource), 0, 0, 1, 0},
{&__pyx_n_s_test, __pyx_k_test, sizeof(__pyx_k_test), 0, 0, 1, 1},
{&__pyx_n_s_timestamp, __pyx_k_timestamp, sizeof(__pyx_k_timestamp), 0, 0, 1, 1},
{&__pyx_n_s_update, __pyx_k_update, sizeof(__pyx_k_update), 0, 0, 1, 1},
{&__pyx_n_s_value, __pyx_k_value, sizeof(__pyx_k_value), 0, 0, 1, 1},
{&__pyx_n_s_zlib, __pyx_k_zlib, sizeof(__pyx_k_zlib), 0, 0, 1, 1},
{0, 0, 0, 0, 0, 0, 0}
};
static int __Pyx_InitCachedBuiltins(void) {
return 0;
}
static int __Pyx_InitCachedConstants(void) {
__Pyx_RefNannyDeclarations
__Pyx_RefNannySetupContext("__Pyx_InitCachedConstants", 0);
/* "aiokafka/record/_legacy_records.pyx":154
* # We always allow at least one record to be appended
* if offset != 0 and pos + size >= self._batch_size:
* return None, 0 # <<<<<<<<<<<<<<
*
* # Allocate proper buffer length
*/
__pyx_tuple_ = PyTuple_Pack(2, Py_None, __pyx_int_0); if (unlikely(!__pyx_tuple_)) __PYX_ERR(0, 154, __pyx_L1_error)
__Pyx_GOTREF(__pyx_tuple_);
__Pyx_GIVEREF(__pyx_tuple_);
/* "(tree fragment)":1
* def __pyx_unpickle__LegacyRecordBatchBuilderCython(__pyx_type, long __pyx_checksum, __pyx_state): # <<<<<<<<<<<<<<
* if __pyx_checksum != 0x53be9b3:
* from pickle import PickleError as __pyx_PickleError
*/
__pyx_tuple__2 = PyTuple_Pack(5, __pyx_n_s_pyx_type, __pyx_n_s_pyx_checksum, __pyx_n_s_pyx_state, __pyx_n_s_pyx_PickleError, __pyx_n_s_pyx_result); if (unlikely(!__pyx_tuple__2)) __PYX_ERR(1, 1, __pyx_L1_error)
__Pyx_GOTREF(__pyx_tuple__2);
__Pyx_GIVEREF(__pyx_tuple__2);
__pyx_codeobj__3 = (PyObject*)__Pyx_PyCode_New(3, 0, 5, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__2, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_stringsource, __pyx_n_s_pyx_unpickle__LegacyRecordBatc, 1, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__3)) __PYX_ERR(1, 1, __pyx_L1_error)
__Pyx_RefNannyFinishContext();
return 0;
__pyx_L1_error:;
__Pyx_RefNannyFinishContext();
return -1;
}
static int __Pyx_InitGlobals(void) {
if (__Pyx_InitStrings(__pyx_string_tab) < 0) __PYX_ERR(0, 1, __pyx_L1_error);
__pyx_int_0 = PyInt_FromLong(0); if (unlikely(!__pyx_int_0)) __PYX_ERR(0, 1, __pyx_L1_error)
__pyx_int_1 = PyInt_FromLong(1); if (unlikely(!__pyx_int_1)) __PYX_ERR(0, 1, __pyx_L1_error)
__pyx_int_2 = PyInt_FromLong(2); if (unlikely(!__pyx_int_2)) __PYX_ERR(0, 1, __pyx_L1_error)
__pyx_int_3 = PyInt_FromLong(3); if (unlikely(!__pyx_int_3)) __PYX_ERR(0, 1, __pyx_L1_error)
__pyx_int_87812531 = PyInt_FromLong(87812531L); if (unlikely(!__pyx_int_87812531)) __PYX_ERR(0, 1, __pyx_L1_error)
return 0;
__pyx_L1_error:;
return -1;
}
#if PY_MAJOR_VERSION < 3
PyMODINIT_FUNC init_legacy_records(void); /*proto*/
PyMODINIT_FUNC init_legacy_records(void)
#else
PyMODINIT_FUNC PyInit__legacy_records(void); /*proto*/
PyMODINIT_FUNC PyInit__legacy_records(void)
#if CYTHON_PEP489_MULTI_PHASE_INIT
{
return PyModuleDef_Init(&__pyx_moduledef);
}
static int __Pyx_copy_spec_to_module(PyObject *spec, PyObject *moddict, const char* from_name, const char* to_name) {
PyObject *value = PyObject_GetAttrString(spec, from_name);
int result = 0;
if (likely(value)) {
result = PyDict_SetItemString(moddict, to_name, value);
Py_DECREF(value);
} else if (PyErr_ExceptionMatches(PyExc_AttributeError)) {
PyErr_Clear();
} else {
result = -1;
}
return result;
}
static PyObject* __pyx_pymod_create(PyObject *spec, CYTHON_UNUSED PyModuleDef *def) {
PyObject *module = NULL, *moddict, *modname;
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__") < 0)) goto bad;
if (unlikely(__Pyx_copy_spec_to_module(spec, moddict, "origin", "__file__") < 0)) goto bad;
if (unlikely(__Pyx_copy_spec_to_module(spec, moddict, "parent", "__package__") < 0)) goto bad;
if (unlikely(__Pyx_copy_spec_to_module(spec, moddict, "submodule_search_locations", "__path__") < 0)) goto bad;
return module;
bad:
Py_XDECREF(module);
return NULL;
}
static int __pyx_pymod_exec__legacy_records(PyObject *__pyx_pyinit_module)
#endif
#endif
{
PyObject *__pyx_t_1 = NULL;
PyObject *__pyx_t_2 = NULL;
__Pyx_RefNannyDeclarations
#if CYTHON_REFNANNY
__Pyx_RefNanny = __Pyx_RefNannyImportAPI("refnanny");
if (!__Pyx_RefNanny) {
PyErr_Clear();
__Pyx_RefNanny = __Pyx_RefNannyImportAPI("Cython.Runtime.refnanny");
if (!__Pyx_RefNanny)
Py_FatalError("failed to import 'refnanny' module");
}
#endif
__Pyx_RefNannySetupContext("PyMODINIT_FUNC PyInit__legacy_records(void)", 0);
if (__Pyx_check_binary_version() < 0) __PYX_ERR(0, 1, __pyx_L1_error)
__pyx_empty_tuple = PyTuple_New(0); if (unlikely(!__pyx_empty_tuple)) __PYX_ERR(0, 1, __pyx_L1_error)
__pyx_empty_bytes = PyBytes_FromStringAndSize("", 0); if (unlikely(!__pyx_empty_bytes)) __PYX_ERR(0, 1, __pyx_L1_error)
__pyx_empty_unicode = PyUnicode_FromStringAndSize("", 0); if (unlikely(!__pyx_empty_unicode)) __PYX_ERR(0, 1, __pyx_L1_error)
#ifdef __Pyx_CyFunction_USED
if (__pyx_CyFunction_init() < 0) __PYX_ERR(0, 1, __pyx_L1_error)
#endif
#ifdef __Pyx_FusedFunction_USED
if (__pyx_FusedFunction_init() < 0) __PYX_ERR(0, 1, __pyx_L1_error)
#endif
#ifdef __Pyx_Coroutine_USED
if (__pyx_Coroutine_init() < 0) __PYX_ERR(0, 1, __pyx_L1_error)
#endif
#ifdef __Pyx_Generator_USED
if (__pyx_Generator_init() < 0) __PYX_ERR(0, 1, __pyx_L1_error)
#endif
#ifdef __Pyx_AsyncGen_USED
if (__pyx_AsyncGen_init() < 0) __PYX_ERR(0, 1, __pyx_L1_error)
#endif
#ifdef __Pyx_StopAsyncIteration_USED
if (__pyx_StopAsyncIteration_init() < 0) __PYX_ERR(0, 1, __pyx_L1_error)
#endif
/*--- Library function declarations ---*/
/*--- Threads initialization code ---*/
#if defined(__PYX_FORCE_INIT_THREADS) && __PYX_FORCE_INIT_THREADS
#ifdef WITH_THREAD /* Python build with threading support? */
PyEval_InitThreads();
#endif
#endif
/*--- Module creation code ---*/
#if CYTHON_PEP489_MULTI_PHASE_INIT
__pyx_m = __pyx_pyinit_module;
Py_INCREF(__pyx_m);
#else
#if PY_MAJOR_VERSION < 3
__pyx_m = Py_InitModule4("_legacy_records", __pyx_methods, 0, 0, PYTHON_API_VERSION); Py_XINCREF(__pyx_m);
#else
__pyx_m = PyModule_Create(&__pyx_moduledef);
#endif
if (unlikely(!__pyx_m)) __PYX_ERR(0, 1, __pyx_L1_error)
#endif
__pyx_d = PyModule_GetDict(__pyx_m); if (unlikely(!__pyx_d)) __PYX_ERR(0, 1, __pyx_L1_error)
Py_INCREF(__pyx_d);
__pyx_b = PyImport_AddModule(__Pyx_BUILTIN_MODULE_NAME); if (unlikely(!__pyx_b)) __PYX_ERR(0, 1, __pyx_L1_error)
__pyx_cython_runtime = PyImport_AddModule((char *) "cython_runtime"); if (unlikely(!__pyx_cython_runtime)) __PYX_ERR(0, 1, __pyx_L1_error)
#if CYTHON_COMPILING_IN_PYPY
Py_INCREF(__pyx_b);
#endif
if (PyObject_SetAttrString(__pyx_m, "__builtins__", __pyx_b) < 0) __PYX_ERR(0, 1, __pyx_L1_error);
/*--- Initialize various global constants etc. ---*/
if (__Pyx_InitGlobals() < 0) __PYX_ERR(0, 1, __pyx_L1_error)
#if PY_MAJOR_VERSION < 3 && (__PYX_DEFAULT_STRING_ENCODING_IS_ASCII || __PYX_DEFAULT_STRING_ENCODING_IS_DEFAULT)
if (__Pyx_init_sys_getdefaultencoding_params() < 0) __PYX_ERR(0, 1, __pyx_L1_error)
#endif
if (__pyx_module_is_main_aiokafka__record___legacy_records) {
if (PyObject_SetAttrString(__pyx_m, "__name__", __pyx_n_s_main) < 0) __PYX_ERR(0, 1, __pyx_L1_error)
}
#if PY_MAJOR_VERSION >= 3
{
PyObject *modules = PyImport_GetModuleDict(); if (unlikely(!modules)) __PYX_ERR(0, 1, __pyx_L1_error)
if (!PyDict_GetItemString(modules, "aiokafka.record._legacy_records")) {
if (unlikely(PyDict_SetItemString(modules, "aiokafka.record._legacy_records", __pyx_m) < 0)) __PYX_ERR(0, 1, __pyx_L1_error)
}
}
#endif
/*--- Builtin init code ---*/
if (__Pyx_InitCachedBuiltins() < 0) __PYX_ERR(0, 1, __pyx_L1_error)
/*--- Constants init code ---*/
if (__Pyx_InitCachedConstants() < 0) __PYX_ERR(0, 1, __pyx_L1_error)
/*--- Global init code ---*/
/*--- Variable export code ---*/
/*--- Function export code ---*/
/*--- Type init code ---*/
__pyx_vtabptr_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython = &__pyx_vtable_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython;
__pyx_vtable_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython._maybe_compress = (int (*)(struct __pyx_obj_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython *))__pyx_f_8aiokafka_6record_15_legacy_records_31_LegacyRecordBatchBuilderCython__maybe_compress;
if (PyType_Ready(&__pyx_type_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython) < 0) __PYX_ERR(0, 117, __pyx_L1_error)
__pyx_type_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython.tp_print = 0;
if (__Pyx_SetVtable(__pyx_type_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython.tp_dict, __pyx_vtabptr_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython) < 0) __PYX_ERR(0, 117, __pyx_L1_error)
if (PyObject_SetAttrString(__pyx_m, "_LegacyRecordBatchBuilderCython", (PyObject *)&__pyx_type_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython) < 0) __PYX_ERR(0, 117, __pyx_L1_error)
if (__Pyx_setup_reduce((PyObject*)&__pyx_type_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython) < 0) __PYX_ERR(0, 117, __pyx_L1_error)
__pyx_ptype_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython = &__pyx_type_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython;
/*--- Type import code ---*/
__pyx_ptype_7cpython_4type_type = __Pyx_ImportType(__Pyx_BUILTIN_MODULE_NAME, "type",
#if CYTHON_COMPILING_IN_PYPY
sizeof(PyTypeObject),
#else
sizeof(PyHeapTypeObject),
#endif
0); if (unlikely(!__pyx_ptype_7cpython_4type_type)) __PYX_ERR(2, 9, __pyx_L1_error)
__pyx_ptype_7cpython_4bool_bool = __Pyx_ImportType(__Pyx_BUILTIN_MODULE_NAME, "bool", sizeof(PyBoolObject), 0); if (unlikely(!__pyx_ptype_7cpython_4bool_bool)) __PYX_ERR(3, 8, __pyx_L1_error)
__pyx_ptype_7cpython_7complex_complex = __Pyx_ImportType(__Pyx_BUILTIN_MODULE_NAME, "complex", sizeof(PyComplexObject), 0); if (unlikely(!__pyx_ptype_7cpython_7complex_complex)) __PYX_ERR(4, 15, __pyx_L1_error)
/*--- Variable import code ---*/
/*--- Function import code ---*/
/*--- Execution code ---*/
#if defined(__Pyx_Generator_USED) || defined(__Pyx_Coroutine_USED)
if (__Pyx_patch_abc() < 0) __PYX_ERR(0, 1, __pyx_L1_error)
#endif
/* "aiokafka/record/_legacy_records.pyx":4
*
* from kafka.codec import (
* gzip_encode, snappy_encode, lz4_encode, lz4_encode_old_kafka, # <<<<<<<<<<<<<<
* )
*
*/
__pyx_t_1 = PyList_New(4); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 4, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_1);
__Pyx_INCREF(__pyx_n_s_gzip_encode);
__Pyx_GIVEREF(__pyx_n_s_gzip_encode);
PyList_SET_ITEM(__pyx_t_1, 0, __pyx_n_s_gzip_encode);
__Pyx_INCREF(__pyx_n_s_snappy_encode);
__Pyx_GIVEREF(__pyx_n_s_snappy_encode);
PyList_SET_ITEM(__pyx_t_1, 1, __pyx_n_s_snappy_encode);
__Pyx_INCREF(__pyx_n_s_lz4_encode);
__Pyx_GIVEREF(__pyx_n_s_lz4_encode);
PyList_SET_ITEM(__pyx_t_1, 2, __pyx_n_s_lz4_encode);
__Pyx_INCREF(__pyx_n_s_lz4_encode_old_kafka);
__Pyx_GIVEREF(__pyx_n_s_lz4_encode_old_kafka);
PyList_SET_ITEM(__pyx_t_1, 3, __pyx_n_s_lz4_encode_old_kafka);
/* "aiokafka/record/_legacy_records.pyx":3
* #cython: language_level=3
*
* from kafka.codec import ( # <<<<<<<<<<<<<<
* gzip_encode, snappy_encode, lz4_encode, lz4_encode_old_kafka,
* )
*/
__pyx_t_2 = __Pyx_Import(__pyx_n_s_kafka_codec, __pyx_t_1, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 3, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_2);
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
__pyx_t_1 = __Pyx_ImportFrom(__pyx_t_2, __pyx_n_s_gzip_encode); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 3, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_1);
if (PyDict_SetItem(__pyx_d, __pyx_n_s_gzip_encode, __pyx_t_1) < 0) __PYX_ERR(0, 4, __pyx_L1_error)
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
__pyx_t_1 = __Pyx_ImportFrom(__pyx_t_2, __pyx_n_s_snappy_encode); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 3, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_1);
if (PyDict_SetItem(__pyx_d, __pyx_n_s_snappy_encode, __pyx_t_1) < 0) __PYX_ERR(0, 4, __pyx_L1_error)
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
__pyx_t_1 = __Pyx_ImportFrom(__pyx_t_2, __pyx_n_s_lz4_encode); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 3, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_1);
if (PyDict_SetItem(__pyx_d, __pyx_n_s_lz4_encode, __pyx_t_1) < 0) __PYX_ERR(0, 4, __pyx_L1_error)
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
__pyx_t_1 = __Pyx_ImportFrom(__pyx_t_2, __pyx_n_s_lz4_encode_old_kafka); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 3, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_1);
if (PyDict_SetItem(__pyx_d, __pyx_n_s_lz4_encode_old_kafka, __pyx_t_1) < 0) __PYX_ERR(0, 4, __pyx_L1_error)
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
/* "aiokafka/record/_legacy_records.pyx":15
*
* IF UNAME_SYSNAME == "Windows":
* from zlib import crc32 as py_crc32 # <<<<<<<<<<<<<<
* cdef long crc32(unsigned long crc, unsigned char *buf, int len):
* cdef:
*/
__pyx_t_2 = PyList_New(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 15, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_2);
__Pyx_INCREF(__pyx_n_s_crc32);
__Pyx_GIVEREF(__pyx_n_s_crc32);
PyList_SET_ITEM(__pyx_t_2, 0, __pyx_n_s_crc32);
__pyx_t_1 = __Pyx_Import(__pyx_n_s_zlib, __pyx_t_2, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 15, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_1);
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
__pyx_t_2 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_crc32); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 15, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_2);
if (PyDict_SetItem(__pyx_d, __pyx_n_s_py_crc32, __pyx_t_2) < 0) __PYX_ERR(0, 15, __pyx_L1_error)
__Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
/* "aiokafka/record/_legacy_records.pyx":125
* bytearray _buffer
*
* CODEC_GZIP = ATTR_CODEC_GZIP # <<<<<<<<<<<<<<
* CODEC_SNAPPY = ATTR_CODEC_SNAPPY
* CODEC_LZ4 = ATTR_CODEC_LZ4
*/
if (PyDict_SetItem((PyObject *)__pyx_ptype_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython->tp_dict, __pyx_n_s_CODEC_GZIP, __pyx_int_1) < 0) __PYX_ERR(0, 125, __pyx_L1_error)
PyType_Modified(__pyx_ptype_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython);
/* "aiokafka/record/_legacy_records.pyx":126
*
* CODEC_GZIP = ATTR_CODEC_GZIP
* CODEC_SNAPPY = ATTR_CODEC_SNAPPY # <<<<<<<<<<<<<<
* CODEC_LZ4 = ATTR_CODEC_LZ4
*
*/
if (PyDict_SetItem((PyObject *)__pyx_ptype_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython->tp_dict, __pyx_n_s_CODEC_SNAPPY, __pyx_int_2) < 0) __PYX_ERR(0, 126, __pyx_L1_error)
PyType_Modified(__pyx_ptype_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython);
/* "aiokafka/record/_legacy_records.pyx":127
* CODEC_GZIP = ATTR_CODEC_GZIP
* CODEC_SNAPPY = ATTR_CODEC_SNAPPY
* CODEC_LZ4 = ATTR_CODEC_LZ4 # <<<<<<<<<<<<<<
*
* def __init__(self, char magic, char compression_type, int batch_size):
*/
if (PyDict_SetItem((PyObject *)__pyx_ptype_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython->tp_dict, __pyx_n_s_CODEC_LZ4, __pyx_int_3) < 0) __PYX_ERR(0, 127, __pyx_L1_error)
PyType_Modified(__pyx_ptype_8aiokafka_6record_15_legacy_records__LegacyRecordBatchBuilderCython);
/* "(tree fragment)":1
* def __pyx_unpickle__LegacyRecordBatchBuilderCython(__pyx_type, long __pyx_checksum, __pyx_state): # <<<<<<<<<<<<<<
* if __pyx_checksum != 0x53be9b3:
* from pickle import PickleError as __pyx_PickleError
*/
__pyx_t_1 = PyCFunction_NewEx(&__pyx_mdef_8aiokafka_6record_15_legacy_records_1__pyx_unpickle__LegacyRecordBatchBuilderCython, NULL, __pyx_n_s_aiokafka_record__legacy_records); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_1);
if (PyDict_SetItem(__pyx_d, __pyx_n_s_pyx_unpickle__LegacyRecordBatc, __pyx_t_1) < 0) __PYX_ERR(1, 1, __pyx_L1_error)
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
/* "aiokafka/record/_legacy_records.pyx":1
* #cython: language_level=3 # <<<<<<<<<<<<<<
*
* from kafka.codec import (
*/
__pyx_t_1 = __Pyx_PyDict_NewPresized(0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_1);
if (PyDict_SetItem(__pyx_d, __pyx_n_s_test, __pyx_t_1) < 0) __PYX_ERR(0, 1, __pyx_L1_error)
__Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
/* "_hton.pxd":83
*
*
* cdef inline double unpack_double(const char* buf): # <<<<<<<<<<<<<<
* cdef _doubleconv v
* v.i = <uint64_t>unpack_int64(buf)
*/
/*--- Wrapped vars code ---*/
goto __pyx_L0;
__pyx_L1_error:;
__Pyx_XDECREF(__pyx_t_1);
__Pyx_XDECREF(__pyx_t_2);
if (__pyx_m) {
if (__pyx_d) {
__Pyx_AddTraceback("init aiokafka.record._legacy_records", 0, __pyx_lineno, __pyx_filename);
}
Py_DECREF(__pyx_m); __pyx_m = 0;
} else if (!PyErr_Occurred()) {
PyErr_SetString(PyExc_ImportError, "init aiokafka.record._legacy_records");
}
__pyx_L0:;
__Pyx_RefNannyFinishContext();
#if CYTHON_PEP489_MULTI_PHASE_INIT
return (__pyx_m != NULL) ? 0 : -1;
#elif PY_MAJOR_VERSION >= 3
return __pyx_m;
#else
return;
#endif
}
/* --- 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((char *)modname);
if (!m) goto end;
p = PyObject_GetAttrString(m, (char *)"RefNannyAPI");
if (!p) goto end;
r = PyLong_AsVoidPtr(p);
end:
Py_XDECREF(p);
Py_XDECREF(m);
return (__Pyx_RefNannyAPIStruct *)r;
}
#endif
/* GetBuiltinName */
static PyObject *__Pyx_GetBuiltinName(PyObject *name) {
PyObject* result = __Pyx_PyObject_GetAttrStr(__pyx_b, name);
if (unlikely(!result)) {
PyErr_Format(PyExc_NameError,
#if PY_MAJOR_VERSION >= 3
"name '%U' is not defined", name);
#else
"name '%.200s' is not defined", PyString_AS_STRING(name));
#endif
}
return result;
}
/* GetModuleGlobalName */
static CYTHON_INLINE PyObject *__Pyx_GetModuleGlobalName(PyObject *name) {
PyObject *result;
#if !CYTHON_AVOID_BORROWED_REFS
result = PyDict_GetItem(__pyx_d, name);
if (likely(result)) {
Py_INCREF(result);
} else {
#else
result = PyObject_GetItem(__pyx_d, name);
if (!result) {
PyErr_Clear();
#endif
result = __Pyx_GetBuiltinName(name);
}
return result;
}
/* PyCFunctionFastCall */
#if CYTHON_FAST_PYCCALL
static CYTHON_INLINE PyObject * __Pyx_PyCFunction_FastCall(PyObject *func_obj, PyObject **args, Py_ssize_t nargs) {
PyCFunctionObject *func = (PyCFunctionObject*)func_obj;
PyCFunction meth = PyCFunction_GET_FUNCTION(func);
PyObject *self = PyCFunction_GET_SELF(func);
int flags = PyCFunction_GET_FLAGS(func);
assert(PyCFunction_Check(func));
assert(METH_FASTCALL == (flags & ~(METH_CLASS | METH_STATIC | METH_COEXIST | METH_KEYWORDS)));
assert(nargs >= 0);
assert(nargs == 0 || args != NULL);
/* _PyCFunction_FastCallDict() must not be called with an exception set,
because it may clear it (directly or indirectly) and so the
caller loses its exception */
assert(!PyErr_Occurred());
if ((PY_VERSION_HEX < 0x030700A0) || unlikely(flags & METH_KEYWORDS)) {
return (*((__Pyx_PyCFunctionFastWithKeywords)meth)) (self, args, nargs, NULL);
} else {
return (*((__Pyx_PyCFunctionFast)meth)) (self, args, nargs);
}
}
#endif
/* PyFunctionFastCall */
#if CYTHON_FAST_PYCALL
#include "frameobject.h"
static PyObject* __Pyx_PyFunction_FastCallNoKw(PyCodeObject *co, PyObject **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 = f->f_localsplus;
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;
}
#if 1 || PY_VERSION_HEX < 0x030600B1
static PyObject *__Pyx_PyFunction_FastCallDict(PyObject *func, PyObject **args, int nargs, PyObject *kwargs) {
PyCodeObject *co = (PyCodeObject *)PyFunction_GET_CODE(func);
PyObject *globals = PyFunction_GET_GLOBALS(func);
PyObject *argdefs = PyFunction_GET_DEFAULTS(func);
PyObject *closure;
#if PY_MAJOR_VERSION >= 3
PyObject *kwdefs;
#endif
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 (Py_EnterRecursiveCall((char*)" while calling a Python object")) {
return NULL;
}
if (
#if PY_MAJOR_VERSION >= 3
co->co_kwonlyargcount == 0 &&
#endif
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);
#if PY_MAJOR_VERSION >= 3
kwdefs = PyFunction_GET_KW_DEFAULTS(func);
#endif
if (argdefs != NULL) {
d = &PyTuple_GET_ITEM(argdefs, 0);
nd = Py_SIZE(argdefs);
}
else {
d = NULL;
nd = 0;
}
#if PY_MAJOR_VERSION >= 3
result = PyEval_EvalCodeEx((PyObject*)co, globals, (PyObject *)NULL,
args, nargs,
k, (int)nk,
d, (int)nd, kwdefs, closure);
#else
result = PyEval_EvalCodeEx(co, globals, (PyObject *)NULL,
args, nargs,
k, (int)nk,
d, (int)nd, closure);
#endif
Py_XDECREF(kwtuple);
done:
Py_LeaveRecursiveCall();
return result;
}
#endif
#endif
/* PyObjectCall */
#if CYTHON_COMPILING_IN_CPYTHON
static CYTHON_INLINE PyObject* __Pyx_PyObject_Call(PyObject *func, PyObject *arg, PyObject *kw) {
PyObject *result;
ternaryfunc call = func->ob_type->tp_call;
if (unlikely(!call))
return PyObject_Call(func, arg, kw);
if (unlikely(Py_EnterRecursiveCall((char*)" 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 = PyCFunction_GET_FUNCTION(func);
self = PyCFunction_GET_SELF(func);
if (unlikely(Py_EnterRecursiveCall((char*)" 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
/* PyObjectCallOneArg */
#if CYTHON_COMPILING_IN_CPYTHON
static PyObject* __Pyx__PyObject_CallOneArg(PyObject *func, PyObject *arg) {
PyObject *result;
PyObject *args = PyTuple_New(1);
if (unlikely(!args)) return NULL;
Py_INCREF(arg);
PyTuple_SET_ITEM(args, 0, arg);
result = __Pyx_PyObject_Call(func, args, NULL);
Py_DECREF(args);
return result;
}
static CYTHON_INLINE PyObject* __Pyx_PyObject_CallOneArg(PyObject *func, PyObject *arg) {
#if CYTHON_FAST_PYCALL
if (PyFunction_Check(func)) {
return __Pyx_PyFunction_FastCall(func, &arg, 1);
}
#endif
if (likely(PyCFunction_Check(func))) {
if (likely(PyCFunction_GET_FLAGS(func) & METH_O)) {
return __Pyx_PyObject_CallMethO(func, arg);
#if CYTHON_FAST_PYCCALL
} else if (PyCFunction_GET_FLAGS(func) & METH_FASTCALL) {
return __Pyx_PyCFunction_FastCall(func, &arg, 1);
#endif
}
}
return __Pyx__PyObject_CallOneArg(func, arg);
}
#else
static CYTHON_INLINE PyObject* __Pyx_PyObject_CallOneArg(PyObject *func, PyObject *arg) {
PyObject *result;
PyObject *args = PyTuple_Pack(1, arg);
if (unlikely(!args)) return NULL;
result = __Pyx_PyObject_Call(func, args, NULL);
Py_DECREF(args);
return result;
}
#endif
/* PyErrFetchRestore */
#if CYTHON_FAST_THREAD_STATE
static CYTHON_INLINE void __Pyx_ErrRestoreInState(PyThreadState *tstate, PyObject *type, PyObject *value, PyObject *tb) {
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);
}
static CYTHON_INLINE void __Pyx_ErrFetchInState(PyThreadState *tstate, PyObject **type, PyObject **value, PyObject **tb) {
*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
/* WriteUnraisableException */
static void __Pyx_WriteUnraisable(const char *name, CYTHON_UNUSED int clineno,
CYTHON_UNUSED int lineno, CYTHON_UNUSED const char *filename,
int full_traceback, CYTHON_UNUSED int nogil) {
PyObject *old_exc, *old_val, *old_tb;
PyObject *ctx;
__Pyx_PyThreadState_declare
#ifdef WITH_THREAD
PyGILState_STATE state;
if (nogil)
state = PyGILState_Ensure();
#ifdef _MSC_VER
else state = (PyGILState_STATE)-1;
#endif
#endif
__Pyx_PyThreadState_assign
__Pyx_ErrFetch(&old_exc, &old_val, &old_tb);
if (full_traceback) {
Py_XINCREF(old_exc);
Py_XINCREF(old_val);
Py_XINCREF(old_tb);
__Pyx_ErrRestore(old_exc, old_val, old_tb);
PyErr_PrintEx(1);
}
#if PY_MAJOR_VERSION < 3
ctx = PyString_FromString(name);
#else
ctx = PyUnicode_FromString(name);
#endif
__Pyx_ErrRestore(old_exc, old_val, old_tb);
if (!ctx) {
PyErr_WriteUnraisable(Py_None);
} else {
PyErr_WriteUnraisable(ctx);
Py_DECREF(ctx);
}
#ifdef WITH_THREAD
if (nogil)
PyGILState_Release(state);
#endif
}
/* 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);
}
/* RaiseDoubleKeywords */
static void __Pyx_RaiseDoubleKeywordsError(
const char* func_name,
PyObject* kw_name)
{
PyErr_Format(PyExc_TypeError,
#if PY_MAJOR_VERSION >= 3
"%s() got multiple values for keyword argument '%U'", func_name, kw_name);
#else
"%s() got multiple values for keyword argument '%s'", func_name,
PyString_AsString(kw_name));
#endif
}
/* ParseKeywords */
static int __Pyx_ParseOptionalKeywords(
PyObject *kwds,
PyObject **argnames[],
PyObject *kwds2,
PyObject *values[],
Py_ssize_t num_pos_args,
const char* function_name)
{
PyObject *key = 0, *value = 0;
Py_ssize_t pos = 0;
PyObject*** name;
PyObject*** first_kw_arg = argnames + num_pos_args;
while (PyDict_Next(kwds, &pos, &key, &value)) {
name = first_kw_arg;
while (*name && (**name != key)) name++;
if (*name) {
values[name-argnames] = value;
continue;
}
name = first_kw_arg;
#if PY_MAJOR_VERSION < 3
if (likely(PyString_CheckExact(key)) || likely(PyString_Check(key))) {
while (*name) {
if ((CYTHON_COMPILING_IN_PYPY || PyString_GET_SIZE(**name) == PyString_GET_SIZE(key))
&& _PyString_Eq(**name, key)) {
values[name-argnames] = value;
break;
}
name++;
}
if (*name) continue;
else {
PyObject*** argname = argnames;
while (argname != first_kw_arg) {
if ((**argname == key) || (
(CYTHON_COMPILING_IN_PYPY || PyString_GET_SIZE(**argname) == PyString_GET_SIZE(key))
&& _PyString_Eq(**argname, key))) {
goto arg_passed_twice;
}
argname++;
}
}
} else
#endif
if (likely(PyUnicode_Check(key))) {
while (*name) {
int cmp = (**name == key) ? 0 :
#if !CYTHON_COMPILING_IN_PYPY && PY_MAJOR_VERSION >= 3
(PyUnicode_GET_SIZE(**name) != PyUnicode_GET_SIZE(key)) ? 1 :
#endif
PyUnicode_Compare(**name, key);
if (cmp < 0 && unlikely(PyErr_Occurred())) goto bad;
if (cmp == 0) {
values[name-argnames] = value;
break;
}
name++;
}
if (*name) continue;
else {
PyObject*** argname = argnames;
while (argname != first_kw_arg) {
int cmp = (**argname == key) ? 0 :
#if !CYTHON_COMPILING_IN_PYPY && PY_MAJOR_VERSION >= 3
(PyUnicode_GET_SIZE(**argname) != PyUnicode_GET_SIZE(key)) ? 1 :
#endif
PyUnicode_Compare(**argname, key);
if (cmp < 0 && unlikely(PyErr_Occurred())) goto bad;
if (cmp == 0) goto arg_passed_twice;
argname++;
}
}
} else
goto invalid_keyword_type;
if (kwds2) {
if (unlikely(PyDict_SetItem(kwds2, key, value))) goto bad;
} else {
goto invalid_keyword;
}
}
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;
invalid_keyword:
PyErr_Format(PyExc_TypeError,
#if PY_MAJOR_VERSION < 3
"%.200s() got an unexpected keyword argument '%.200s'",
function_name, PyString_AsString(key));
#else
"%s() got an unexpected keyword argument '%U'",
function_name, key);
#endif
bad:
return -1;
}
/* 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);
#if PY_MAJOR_VERSION >= 3
for (i=0; i<n; i++) {
if (exc_type == PyTuple_GET_ITEM(tuple, i)) return 1;
}
#endif
for (i=0; i<n; i++) {
if (__Pyx_PyErr_GivenExceptionMatches(exc_type, PyTuple_GET_ITEM(tuple, i))) return 1;
}
return 0;
}
static CYTHON_INLINE int __Pyx_PyErr_ExceptionMatchesInState(PyThreadState* tstate, PyObject* err) {
PyObject *exc_type = tstate->curexc_type;
if (exc_type == err) return 1;
if (unlikely(!exc_type)) return 0;
if (unlikely(PyTuple_Check(err)))
return __Pyx_PyErr_ExceptionMatchesTuple(exc_type, err);
return __Pyx_PyErr_GivenExceptionMatches(exc_type, err);
}
#endif
/* GetAttr */
static CYTHON_INLINE PyObject *__Pyx_GetAttr(PyObject *o, PyObject *n) {
#if CYTHON_USE_TYPE_SLOTS
#if PY_MAJOR_VERSION >= 3
if (likely(PyUnicode_Check(n)))
#else
if (likely(PyString_Check(n)))
#endif
return __Pyx_PyObject_GetAttrStr(o, n);
#endif
return PyObject_GetAttr(o, n);
}
/* GetAttr3 */
static PyObject *__Pyx_GetAttr3Default(PyObject *d) {
__Pyx_PyThreadState_declare
__Pyx_PyThreadState_assign
if (unlikely(!__Pyx_PyErr_ExceptionMatches(PyExc_AttributeError)))
return NULL;
__Pyx_PyErr_Clear();
Py_INCREF(d);
return d;
}
static CYTHON_INLINE PyObject *__Pyx_GetAttr3(PyObject *o, PyObject *n, PyObject *d) {
PyObject *r = __Pyx_GetAttr(o, n);
return (likely(r)) ? r : __Pyx_GetAttr3Default(d);
}
/* Import */
static PyObject *__Pyx_Import(PyObject *name, PyObject *from_list, int level) {
PyObject *empty_list = 0;
PyObject *module = 0;
PyObject *global_dict = 0;
PyObject *empty_dict = 0;
PyObject *list;
#if PY_MAJOR_VERSION < 3
PyObject *py_import;
py_import = __Pyx_PyObject_GetAttrStr(__pyx_b, __pyx_n_s_import);
if (!py_import)
goto bad;
#endif
if (from_list)
list = from_list;
else {
empty_list = PyList_New(0);
if (!empty_list)
goto bad;
list = empty_list;
}
global_dict = PyModule_GetDict(__pyx_m);
if (!global_dict)
goto bad;
empty_dict = PyDict_New();
if (!empty_dict)
goto bad;
{
#if PY_MAJOR_VERSION >= 3
if (level == -1) {
if (strchr(__Pyx_MODULE_NAME, '.')) {
module = PyImport_ImportModuleLevelObject(
name, global_dict, empty_dict, list, 1);
if (!module) {
if (!PyErr_ExceptionMatches(PyExc_ImportError))
goto bad;
PyErr_Clear();
}
}
level = 0;
}
#endif
if (!module) {
#if PY_MAJOR_VERSION < 3
PyObject *py_level = PyInt_FromLong(level);
if (!py_level)
goto bad;
module = PyObject_CallFunctionObjArgs(py_import,
name, global_dict, empty_dict, list, py_level, NULL);
Py_DECREF(py_level);
#else
module = PyImport_ImportModuleLevelObject(
name, global_dict, empty_dict, list, level);
#endif
}
}
bad:
#if PY_MAJOR_VERSION < 3
Py_XDECREF(py_import);
#endif
Py_XDECREF(empty_list);
Py_XDECREF(empty_dict);
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)) {
PyErr_Format(PyExc_ImportError,
#if PY_MAJOR_VERSION < 3
"cannot import name %.230s", PyString_AS_STRING(name));
#else
"cannot import name %S", name);
#endif
}
return value;
}
/* RaiseException */
#if PY_MAJOR_VERSION < 3
static void __Pyx_Raise(PyObject *type, PyObject *value, PyObject *tb,
CYTHON_UNUSED PyObject *cause) {
__Pyx_PyThreadState_declare
Py_XINCREF(type);
if (!value || value == Py_None)
value = NULL;
else
Py_INCREF(value);
if (!tb || tb == Py_None)
tb = NULL;
else {
Py_INCREF(tb);
if (!PyTraceBack_Check(tb)) {
PyErr_SetString(PyExc_TypeError,
"raise: arg 3 must be a traceback or None");
goto raise_error;
}
}
if (PyType_Check(type)) {
#if CYTHON_COMPILING_IN_PYPY
if (!value) {
Py_INCREF(Py_None);
value = Py_None;
}
#endif
PyErr_NormalizeException(&type, &value, &tb);
} else {
if (value) {
PyErr_SetString(PyExc_TypeError,
"instance exception may not have a separate value");
goto raise_error;
}
value = type;
type = (PyObject*) Py_TYPE(type);
Py_INCREF(type);
if (!PyType_IsSubtype((PyTypeObject *)type, (PyTypeObject *)PyExc_BaseException)) {
PyErr_SetString(PyExc_TypeError,
"raise: exception class must be a subclass of BaseException");
goto raise_error;
}
}
__Pyx_PyThreadState_assign
__Pyx_ErrRestore(type, value, tb);
return;
raise_error:
Py_XDECREF(value);
Py_XDECREF(type);
Py_XDECREF(tb);
return;
}
#else
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 CYTHON_COMPILING_IN_PYPY
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);
#else
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);
}
#endif
}
bad:
Py_XDECREF(owned_instance);
return;
}
#endif
/* GetItemInt */
static PyObject *__Pyx_GetItemInt_Generic(PyObject *o, PyObject* j) {
PyObject *r;
if (!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_AVOID_BORROWED_REFS
Py_ssize_t wrapped_i = i;
if (wraparound & unlikely(i < 0)) {
wrapped_i += PyList_GET_SIZE(o);
}
if ((!boundscheck) || likely((0 <= wrapped_i) & (wrapped_i < PyList_GET_SIZE(o)))) {
PyObject *r = PyList_GET_ITEM(o, wrapped_i);
Py_INCREF(r);
return r;
}
return __Pyx_GetItemInt_Generic(o, PyInt_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_AVOID_BORROWED_REFS
Py_ssize_t wrapped_i = i;
if (wraparound & unlikely(i < 0)) {
wrapped_i += PyTuple_GET_SIZE(o);
}
if ((!boundscheck) || likely((0 <= wrapped_i) & (wrapped_i < PyTuple_GET_SIZE(o)))) {
PyObject *r = PyTuple_GET_ITEM(o, wrapped_i);
Py_INCREF(r);
return r;
}
return __Pyx_GetItemInt_Generic(o, PyInt_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_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((n >= 0) & (n < PyList_GET_SIZE(o))))) {
PyObject *r = PyList_GET_ITEM(o, n);
Py_INCREF(r);
return r;
}
}
else if (PyTuple_CheckExact(o)) {
Py_ssize_t n = ((!wraparound) | likely(i >= 0)) ? i : i + PyTuple_GET_SIZE(o);
if ((!boundscheck) || likely((n >= 0) & (n < PyTuple_GET_SIZE(o)))) {
PyObject *r = PyTuple_GET_ITEM(o, n);
Py_INCREF(r);
return r;
}
} else {
PySequenceMethods *m = Py_TYPE(o)->tp_as_sequence;
if (likely(m && m->sq_item)) {
if (wraparound && unlikely(i < 0) && likely(m->sq_length)) {
Py_ssize_t l = m->sq_length(o);
if (likely(l >= 0)) {
i += l;
} else {
if (!PyErr_ExceptionMatches(PyExc_OverflowError))
return NULL;
PyErr_Clear();
}
}
return m->sq_item(o, i);
}
}
#else
if (is_list || PySequence_Check(o)) {
return PySequence_GetItem(o, i);
}
#endif
return __Pyx_GetItemInt_Generic(o, PyInt_FromSsize_t(i));
}
/* HasAttr */
static CYTHON_INLINE int __Pyx_HasAttr(PyObject *o, PyObject *n) {
PyObject *r;
if (unlikely(!__Pyx_PyBaseString_Check(n))) {
PyErr_SetString(PyExc_TypeError,
"hasattr(): attribute name must be string");
return -1;
}
r = __Pyx_GetAttr(o, n);
if (unlikely(!r)) {
PyErr_Clear();
return 0;
} else {
Py_DECREF(r);
return 1;
}
}
/* SetVTable */
static int __Pyx_SetVtable(PyObject *dict, void *vtable) {
#if PY_VERSION_HEX >= 0x02070000
PyObject *ob = PyCapsule_New(vtable, 0, 0);
#else
PyObject *ob = PyCObject_FromVoidPtr(vtable, 0);
#endif
if (!ob)
goto bad;
if (PyDict_SetItem(dict, __pyx_n_s_pyx_vtable, ob) < 0)
goto bad;
Py_DECREF(ob);
return 0;
bad:
Py_XDECREF(ob);
return -1;
}
/* SetupReduce */
static int __Pyx_setup_reduce_is_named(PyObject* meth, PyObject* name) {
int ret;
PyObject *name_attr;
name_attr = __Pyx_PyObject_GetAttrStr(meth, __pyx_n_s_name);
if (likely(name_attr)) {
ret = PyObject_RichCompareBool(name_attr, name, Py_EQ);
} else {
ret = -1;
}
if (unlikely(ret < 0)) {
PyErr_Clear();
ret = 0;
}
Py_XDECREF(name_attr);
return ret;
}
static int __Pyx_setup_reduce(PyObject* type_obj) {
int ret = 0;
PyObject *object_reduce = NULL;
PyObject *object_reduce_ex = NULL;
PyObject *reduce = NULL;
PyObject *reduce_ex = NULL;
PyObject *reduce_cython = NULL;
PyObject *setstate = NULL;
PyObject *setstate_cython = NULL;
#if CYTHON_USE_PYTYPE_LOOKUP
if (_PyType_Lookup((PyTypeObject*)type_obj, __pyx_n_s_getstate)) goto GOOD;
#else
if (PyObject_HasAttr(type_obj, __pyx_n_s_getstate)) goto GOOD;
#endif
#if CYTHON_USE_PYTYPE_LOOKUP
object_reduce_ex = _PyType_Lookup(&PyBaseObject_Type, __pyx_n_s_reduce_ex); if (!object_reduce_ex) goto BAD;
#else
object_reduce_ex = __Pyx_PyObject_GetAttrStr((PyObject*)&PyBaseObject_Type, __pyx_n_s_reduce_ex); if (!object_reduce_ex) goto BAD;
#endif
reduce_ex = __Pyx_PyObject_GetAttrStr(type_obj, __pyx_n_s_reduce_ex); if (unlikely(!reduce_ex)) goto BAD;
if (reduce_ex == object_reduce_ex) {
#if CYTHON_USE_PYTYPE_LOOKUP
object_reduce = _PyType_Lookup(&PyBaseObject_Type, __pyx_n_s_reduce); if (!object_reduce) goto BAD;
#else
object_reduce = __Pyx_PyObject_GetAttrStr((PyObject*)&PyBaseObject_Type, __pyx_n_s_reduce); if (!object_reduce) goto BAD;
#endif
reduce = __Pyx_PyObject_GetAttrStr(type_obj, __pyx_n_s_reduce); if (unlikely(!reduce)) goto BAD;
if (reduce == object_reduce || __Pyx_setup_reduce_is_named(reduce, __pyx_n_s_reduce_cython)) {
reduce_cython = __Pyx_PyObject_GetAttrStr(type_obj, __pyx_n_s_reduce_cython); if (unlikely(!reduce_cython)) goto BAD;
ret = PyDict_SetItem(((PyTypeObject*)type_obj)->tp_dict, __pyx_n_s_reduce, reduce_cython); if (unlikely(ret < 0)) goto BAD;
ret = PyDict_DelItem(((PyTypeObject*)type_obj)->tp_dict, __pyx_n_s_reduce_cython); if (unlikely(ret < 0)) goto BAD;
setstate = __Pyx_PyObject_GetAttrStr(type_obj, __pyx_n_s_setstate);
if (!setstate) PyErr_Clear();
if (!setstate || __Pyx_setup_reduce_is_named(setstate, __pyx_n_s_setstate_cython)) {
setstate_cython = __Pyx_PyObject_GetAttrStr(type_obj, __pyx_n_s_setstate_cython); if (unlikely(!setstate_cython)) goto BAD;
ret = PyDict_SetItem(((PyTypeObject*)type_obj)->tp_dict, __pyx_n_s_setstate, setstate_cython); if (unlikely(ret < 0)) goto BAD;
ret = PyDict_DelItem(((PyTypeObject*)type_obj)->tp_dict, __pyx_n_s_setstate_cython); if (unlikely(ret < 0)) goto BAD;
}
PyType_Modified((PyTypeObject*)type_obj);
}
}
goto GOOD;
BAD:
if (!PyErr_Occurred())
PyErr_Format(PyExc_RuntimeError, "Unable to initialize pickling for %s", ((PyTypeObject*)type_obj)->tp_name);
ret = -1;
GOOD:
#if !CYTHON_COMPILING_IN_CPYTHON
Py_XDECREF(object_reduce);
Py_XDECREF(object_reduce_ex);
#endif
Py_XDECREF(reduce);
Py_XDECREF(reduce_ex);
Py_XDECREF(reduce_cython);
Py_XDECREF(setstate);
Py_XDECREF(setstate_cython);
return ret;
}
/* CLineInTraceback */
static int __Pyx_CLineForTraceback(int c_line) {
#ifdef CYTHON_CLINE_IN_TRACEBACK
return ((CYTHON_CLINE_IN_TRACEBACK)) ? c_line : 0;
#else
PyObject *use_cline;
#if CYTHON_COMPILING_IN_CPYTHON
PyObject **cython_runtime_dict = _PyObject_GetDictPtr(__pyx_cython_runtime);
if (likely(cython_runtime_dict)) {
use_cline = PyDict_GetItem(*cython_runtime_dict, __pyx_n_s_cline_in_traceback);
} else
#endif
{
PyObject *ptype, *pvalue, *ptraceback;
PyObject *use_cline_obj;
PyErr_Fetch(&ptype, &pvalue, &ptraceback);
use_cline_obj = __Pyx_PyObject_GetAttrStr(__pyx_cython_runtime, __pyx_n_s_cline_in_traceback);
if (use_cline_obj) {
use_cline = PyObject_Not(use_cline_obj) ? Py_False : Py_True;
Py_DECREF(use_cline_obj);
} else {
use_cline = NULL;
}
PyErr_Restore(ptype, pvalue, ptraceback);
}
if (!use_cline) {
c_line = 0;
PyObject_SetAttr(__pyx_cython_runtime, __pyx_n_s_cline_in_traceback, Py_False);
}
else if (PyObject_Not(use_cline) != 0) {
c_line = 0;
}
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 PyCodeObject *__pyx_find_code_object(int code_line) {
PyCodeObject* code_object;
int pos;
if (unlikely(!code_line) || unlikely(!__pyx_code_cache.entries)) {
return NULL;
}
pos = __pyx_bisect_code_objects(__pyx_code_cache.entries, __pyx_code_cache.count, code_line);
if (unlikely(pos >= __pyx_code_cache.count) || unlikely(__pyx_code_cache.entries[pos].code_line != code_line)) {
return NULL;
}
code_object = __pyx_code_cache.entries[pos].code_object;
Py_INCREF(code_object);
return code_object;
}
static void __pyx_insert_code_object(int code_line, PyCodeObject* code_object) {
int pos, i;
__Pyx_CodeObjectCacheEntry* entries = __pyx_code_cache.entries;
if (unlikely(!code_line)) {
return;
}
if (unlikely(!entries)) {
entries = (__Pyx_CodeObjectCacheEntry*)PyMem_Malloc(64*sizeof(__Pyx_CodeObjectCacheEntry));
if (likely(entries)) {
__pyx_code_cache.entries = entries;
__pyx_code_cache.max_count = 64;
__pyx_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(__pyx_code_cache.entries, __pyx_code_cache.count, code_line);
if ((pos < __pyx_code_cache.count) && unlikely(__pyx_code_cache.entries[pos].code_line == code_line)) {
PyCodeObject* tmp = entries[pos].code_object;
entries[pos].code_object = code_object;
Py_DECREF(tmp);
return;
}
if (__pyx_code_cache.count == __pyx_code_cache.max_count) {
int new_max = __pyx_code_cache.max_count + 64;
entries = (__Pyx_CodeObjectCacheEntry*)PyMem_Realloc(
__pyx_code_cache.entries, (size_t)new_max*sizeof(__Pyx_CodeObjectCacheEntry));
if (unlikely(!entries)) {
return;
}
__pyx_code_cache.entries = entries;
__pyx_code_cache.max_count = new_max;
}
for (i=__pyx_code_cache.count; i>pos; i--) {
entries[i] = entries[i-1];
}
entries[pos].code_line = code_line;
entries[pos].code_object = code_object;
__pyx_code_cache.count++;
Py_INCREF(code_object);
}
/* AddTraceback */
#include "compile.h"
#include "frameobject.h"
#include "traceback.h"
static PyCodeObject* __Pyx_CreateCodeObjectForTraceback(
const char *funcname, int c_line,
int py_line, const char *filename) {
PyCodeObject *py_code = 0;
PyObject *py_srcfile = 0;
PyObject *py_funcname = 0;
#if PY_MAJOR_VERSION < 3
py_srcfile = PyString_FromString(filename);
#else
py_srcfile = PyUnicode_FromString(filename);
#endif
if (!py_srcfile) goto bad;
if (c_line) {
#if PY_MAJOR_VERSION < 3
py_funcname = PyString_FromFormat( "%s (%s:%d)", funcname, __pyx_cfilenm, c_line);
#else
py_funcname = PyUnicode_FromFormat( "%s (%s:%d)", funcname, __pyx_cfilenm, c_line);
#endif
}
else {
#if PY_MAJOR_VERSION < 3
py_funcname = PyString_FromString(funcname);
#else
py_funcname = PyUnicode_FromString(funcname);
#endif
}
if (!py_funcname) goto bad;
py_code = __Pyx_PyCode_New(
0,
0,
0,
0,
0,
__pyx_empty_bytes, /*PyObject *code,*/
__pyx_empty_tuple, /*PyObject *consts,*/
__pyx_empty_tuple, /*PyObject *names,*/
__pyx_empty_tuple, /*PyObject *varnames,*/
__pyx_empty_tuple, /*PyObject *freevars,*/
__pyx_empty_tuple, /*PyObject *cellvars,*/
py_srcfile, /*PyObject *filename,*/
py_funcname, /*PyObject *name,*/
py_line,
__pyx_empty_bytes /*PyObject *lnotab*/
);
Py_DECREF(py_srcfile);
Py_DECREF(py_funcname);
return py_code;
bad:
Py_XDECREF(py_srcfile);
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;
if (c_line) {
c_line = __Pyx_CLineForTraceback(c_line);
}
py_code = __pyx_find_code_object(c_line ? -c_line : py_line);
if (!py_code) {
py_code = __Pyx_CreateCodeObjectForTraceback(
funcname, c_line, py_line, filename);
if (!py_code) goto bad;
__pyx_insert_code_object(c_line ? -c_line : py_line, py_code);
}
py_frame = PyFrame_New(
__Pyx_PyThreadState_Current, /*PyThreadState *tstate,*/
py_code, /*PyCodeObject *code,*/
__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);
}
/* CIntToPy */
static CYTHON_INLINE PyObject* __Pyx_PyInt_From_int(int value) {
const int neg_one = (int) -1, const_zero = (int) 0;
const int is_unsigned = neg_one > const_zero;
if (is_unsigned) {
if (sizeof(int) < sizeof(long)) {
return PyInt_FromLong((long) value);
} else if (sizeof(int) <= sizeof(unsigned long)) {
return PyLong_FromUnsignedLong((unsigned long) value);
#ifdef HAVE_LONG_LONG
} else if (sizeof(int) <= sizeof(unsigned PY_LONG_LONG)) {
return PyLong_FromUnsignedLongLong((unsigned PY_LONG_LONG) value);
#endif
}
} else {
if (sizeof(int) <= sizeof(long)) {
return PyInt_FromLong((long) value);
#ifdef HAVE_LONG_LONG
} else if (sizeof(int) <= sizeof(PY_LONG_LONG)) {
return PyLong_FromLongLong((PY_LONG_LONG) value);
#endif
}
}
{
int one = 1; int little = (int)*(unsigned char *)&one;
unsigned char *bytes = (unsigned char *)&value;
return _PyLong_FromByteArray(bytes, sizeof(int),
little, !is_unsigned);
}
}
/* 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;\
}
/* CIntToPy */
static CYTHON_INLINE PyObject* __Pyx_PyInt_From_char(char value) {
const char neg_one = (char) -1, const_zero = (char) 0;
const int is_unsigned = neg_one > const_zero;
if (is_unsigned) {
if (sizeof(char) < sizeof(long)) {
return PyInt_FromLong((long) value);
} else if (sizeof(char) <= sizeof(unsigned long)) {
return PyLong_FromUnsignedLong((unsigned long) value);
#ifdef HAVE_LONG_LONG
} else if (sizeof(char) <= sizeof(unsigned PY_LONG_LONG)) {
return PyLong_FromUnsignedLongLong((unsigned PY_LONG_LONG) value);
#endif
}
} else {
if (sizeof(char) <= sizeof(long)) {
return PyInt_FromLong((long) value);
#ifdef HAVE_LONG_LONG
} else if (sizeof(char) <= sizeof(PY_LONG_LONG)) {
return PyLong_FromLongLong((PY_LONG_LONG) value);
#endif
}
}
{
int one = 1; int little = (int)*(unsigned char *)&one;
unsigned char *bytes = (unsigned char *)&value;
return _PyLong_FromByteArray(bytes, sizeof(char),
little, !is_unsigned);
}
}
/* CIntToPy */
static CYTHON_INLINE PyObject* __Pyx_PyInt_From_long(long value) {
const long neg_one = (long) -1, const_zero = (long) 0;
const int is_unsigned = neg_one > const_zero;
if (is_unsigned) {
if (sizeof(long) < sizeof(long)) {
return PyInt_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 PyInt_FromLong((long) value);
#ifdef HAVE_LONG_LONG
} else if (sizeof(long) <= sizeof(PY_LONG_LONG)) {
return PyLong_FromLongLong((PY_LONG_LONG) value);
#endif
}
}
{
int one = 1; int little = (int)*(unsigned char *)&one;
unsigned char *bytes = (unsigned char *)&value;
return _PyLong_FromByteArray(bytes, sizeof(long),
little, !is_unsigned);
}
}
/* CIntFromPy */
static CYTHON_INLINE int __Pyx_PyInt_As_int(PyObject *x) {
const int neg_one = (int) -1, const_zero = (int) 0;
const int is_unsigned = neg_one > const_zero;
#if PY_MAJOR_VERSION < 3
if (likely(PyInt_Check(x))) {
if (sizeof(int) < sizeof(long)) {
__PYX_VERIFY_RETURN_INT(int, long, PyInt_AS_LONG(x))
} else {
long val = PyInt_AS_LONG(x);
if (is_unsigned && unlikely(val < 0)) {
goto raise_neg_overflow;
}
return (int) val;
}
} else
#endif
if (likely(PyLong_Check(x))) {
if (is_unsigned) {
#if CYTHON_USE_PYLONG_INTERNALS
const digit* digits = ((PyLongObject*)x)->ob_digit;
switch (Py_SIZE(x)) {
case 0: return (int) 0;
case 1: __PYX_VERIFY_RETURN_INT(int, digit, digits[0])
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
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
const digit* digits = ((PyLongObject*)x)->ob_digit;
switch (Py_SIZE(x)) {
case 0: return (int) 0;
case -1: __PYX_VERIFY_RETURN_INT(int, sdigit, (sdigit) (-(sdigit)digits[0]))
case 1: __PYX_VERIFY_RETURN_INT(int, digit, +digits[0])
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
}
}
{
#if CYTHON_COMPILING_IN_PYPY && !defined(_PyLong_AsByteArray)
PyErr_SetString(PyExc_RuntimeError,
"_PyLong_AsByteArray() not available in PyPy, cannot convert large numbers");
#else
int val;
PyObject *v = __Pyx_PyNumber_IntOrLong(x);
#if PY_MAJOR_VERSION < 3
if (likely(v) && !PyLong_Check(v)) {
PyObject *tmp = v;
v = PyNumber_Long(tmp);
Py_DECREF(tmp);
}
#endif
if (likely(v)) {
int one = 1; int is_little = (int)*(unsigned char *)&one;
unsigned char *bytes = (unsigned char *)&val;
int ret = _PyLong_AsByteArray((PyLongObject *)v,
bytes, sizeof(val),
is_little, !is_unsigned);
Py_DECREF(v);
if (likely(!ret))
return val;
}
#endif
return (int) -1;
}
} else {
int val;
PyObject *tmp = __Pyx_PyNumber_IntOrLong(x);
if (!tmp) return (int) -1;
val = __Pyx_PyInt_As_int(tmp);
Py_DECREF(tmp);
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;
}
/* CIntFromPy */
static CYTHON_INLINE char __Pyx_PyInt_As_char(PyObject *x) {
const char neg_one = (char) -1, const_zero = (char) 0;
const int is_unsigned = neg_one > const_zero;
#if PY_MAJOR_VERSION < 3
if (likely(PyInt_Check(x))) {
if (sizeof(char) < sizeof(long)) {
__PYX_VERIFY_RETURN_INT(char, long, PyInt_AS_LONG(x))
} else {
long val = PyInt_AS_LONG(x);
if (is_unsigned && unlikely(val < 0)) {
goto raise_neg_overflow;
}
return (char) val;
}
} else
#endif
if (likely(PyLong_Check(x))) {
if (is_unsigned) {
#if CYTHON_USE_PYLONG_INTERNALS
const digit* digits = ((PyLongObject*)x)->ob_digit;
switch (Py_SIZE(x)) {
case 0: return (char) 0;
case 1: __PYX_VERIFY_RETURN_INT(char, digit, digits[0])
case 2:
if (8 * sizeof(char) > 1 * PyLong_SHIFT) {
if (8 * sizeof(unsigned long) > 2 * PyLong_SHIFT) {
__PYX_VERIFY_RETURN_INT(char, unsigned long, (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])))
} else if (8 * sizeof(char) >= 2 * PyLong_SHIFT) {
return (char) (((((char)digits[1]) << PyLong_SHIFT) | (char)digits[0]));
}
}
break;
case 3:
if (8 * sizeof(char) > 2 * PyLong_SHIFT) {
if (8 * sizeof(unsigned long) > 3 * PyLong_SHIFT) {
__PYX_VERIFY_RETURN_INT(char, unsigned long, (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])))
} else if (8 * sizeof(char) >= 3 * PyLong_SHIFT) {
return (char) (((((((char)digits[2]) << PyLong_SHIFT) | (char)digits[1]) << PyLong_SHIFT) | (char)digits[0]));
}
}
break;
case 4:
if (8 * sizeof(char) > 3 * PyLong_SHIFT) {
if (8 * sizeof(unsigned long) > 4 * PyLong_SHIFT) {
__PYX_VERIFY_RETURN_INT(char, 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(char) >= 4 * PyLong_SHIFT) {
return (char) (((((((((char)digits[3]) << PyLong_SHIFT) | (char)digits[2]) << PyLong_SHIFT) | (char)digits[1]) << PyLong_SHIFT) | (char)digits[0]));
}
}
break;
}
#endif
#if CYTHON_COMPILING_IN_CPYTHON
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 (char) -1;
if (unlikely(result == 1))
goto raise_neg_overflow;
}
#endif
if (sizeof(char) <= sizeof(unsigned long)) {
__PYX_VERIFY_RETURN_INT_EXC(char, unsigned long, PyLong_AsUnsignedLong(x))
#ifdef HAVE_LONG_LONG
} else if (sizeof(char) <= sizeof(unsigned PY_LONG_LONG)) {
__PYX_VERIFY_RETURN_INT_EXC(char, unsigned PY_LONG_LONG, PyLong_AsUnsignedLongLong(x))
#endif
}
} else {
#if CYTHON_USE_PYLONG_INTERNALS
const digit* digits = ((PyLongObject*)x)->ob_digit;
switch (Py_SIZE(x)) {
case 0: return (char) 0;
case -1: __PYX_VERIFY_RETURN_INT(char, sdigit, (sdigit) (-(sdigit)digits[0]))
case 1: __PYX_VERIFY_RETURN_INT(char, digit, +digits[0])
case -2:
if (8 * sizeof(char) - 1 > 1 * PyLong_SHIFT) {
if (8 * sizeof(unsigned long) > 2 * PyLong_SHIFT) {
__PYX_VERIFY_RETURN_INT(char, long, -(long) (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])))
} else if (8 * sizeof(char) - 1 > 2 * PyLong_SHIFT) {
return (char) (((char)-1)*(((((char)digits[1]) << PyLong_SHIFT) | (char)digits[0])));
}
}
break;
case 2:
if (8 * sizeof(char) > 1 * PyLong_SHIFT) {
if (8 * sizeof(unsigned long) > 2 * PyLong_SHIFT) {
__PYX_VERIFY_RETURN_INT(char, unsigned long, (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])))
} else if (8 * sizeof(char) - 1 > 2 * PyLong_SHIFT) {
return (char) ((((((char)digits[1]) << PyLong_SHIFT) | (char)digits[0])));
}
}
break;
case -3:
if (8 * sizeof(char) - 1 > 2 * PyLong_SHIFT) {
if (8 * sizeof(unsigned long) > 3 * PyLong_SHIFT) {
__PYX_VERIFY_RETURN_INT(char, long, -(long) (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])))
} else if (8 * sizeof(char) - 1 > 3 * PyLong_SHIFT) {
return (char) (((char)-1)*(((((((char)digits[2]) << PyLong_SHIFT) | (char)digits[1]) << PyLong_SHIFT) | (char)digits[0])));
}
}
break;
case 3:
if (8 * sizeof(char) > 2 * PyLong_SHIFT) {
if (8 * sizeof(unsigned long) > 3 * PyLong_SHIFT) {
__PYX_VERIFY_RETURN_INT(char, unsigned long, (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])))
} else if (8 * sizeof(char) - 1 > 3 * PyLong_SHIFT) {
return (char) ((((((((char)digits[2]) << PyLong_SHIFT) | (char)digits[1]) << PyLong_SHIFT) | (char)digits[0])));
}
}
break;
case -4:
if (8 * sizeof(char) - 1 > 3 * PyLong_SHIFT) {
if (8 * sizeof(unsigned long) > 4 * PyLong_SHIFT) {
__PYX_VERIFY_RETURN_INT(char, 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(char) - 1 > 4 * PyLong_SHIFT) {
return (char) (((char)-1)*(((((((((char)digits[3]) << PyLong_SHIFT) | (char)digits[2]) << PyLong_SHIFT) | (char)digits[1]) << PyLong_SHIFT) | (char)digits[0])));
}
}
break;
case 4:
if (8 * sizeof(char) > 3 * PyLong_SHIFT) {
if (8 * sizeof(unsigned long) > 4 * PyLong_SHIFT) {
__PYX_VERIFY_RETURN_INT(char, 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(char) - 1 > 4 * PyLong_SHIFT) {
return (char) ((((((((((char)digits[3]) << PyLong_SHIFT) | (char)digits[2]) << PyLong_SHIFT) | (char)digits[1]) << PyLong_SHIFT) | (char)digits[0])));
}
}
break;
}
#endif
if (sizeof(char) <= sizeof(long)) {
__PYX_VERIFY_RETURN_INT_EXC(char, long, PyLong_AsLong(x))
#ifdef HAVE_LONG_LONG
} else if (sizeof(char) <= sizeof(PY_LONG_LONG)) {
__PYX_VERIFY_RETURN_INT_EXC(char, PY_LONG_LONG, PyLong_AsLongLong(x))
#endif
}
}
{
#if CYTHON_COMPILING_IN_PYPY && !defined(_PyLong_AsByteArray)
PyErr_SetString(PyExc_RuntimeError,
"_PyLong_AsByteArray() not available in PyPy, cannot convert large numbers");
#else
char val;
PyObject *v = __Pyx_PyNumber_IntOrLong(x);
#if PY_MAJOR_VERSION < 3
if (likely(v) && !PyLong_Check(v)) {
PyObject *tmp = v;
v = PyNumber_Long(tmp);
Py_DECREF(tmp);
}
#endif
if (likely(v)) {
int one = 1; int is_little = (int)*(unsigned char *)&one;
unsigned char *bytes = (unsigned char *)&val;
int ret = _PyLong_AsByteArray((PyLongObject *)v,
bytes, sizeof(val),
is_little, !is_unsigned);
Py_DECREF(v);
if (likely(!ret))
return val;
}
#endif
return (char) -1;
}
} else {
char val;
PyObject *tmp = __Pyx_PyNumber_IntOrLong(x);
if (!tmp) return (char) -1;
val = __Pyx_PyInt_As_char(tmp);
Py_DECREF(tmp);
return val;
}
raise_overflow:
PyErr_SetString(PyExc_OverflowError,
"value too large to convert to char");
return (char) -1;
raise_neg_overflow:
PyErr_SetString(PyExc_OverflowError,
"can't convert negative value to char");
return (char) -1;
}
/* CIntFromPy */
static CYTHON_INLINE long __Pyx_PyInt_As_long(PyObject *x) {
const long neg_one = (long) -1, const_zero = (long) 0;
const int is_unsigned = neg_one > const_zero;
#if PY_MAJOR_VERSION < 3
if (likely(PyInt_Check(x))) {
if (sizeof(long) < sizeof(long)) {
__PYX_VERIFY_RETURN_INT(long, long, PyInt_AS_LONG(x))
} else {
long val = PyInt_AS_LONG(x);
if (is_unsigned && unlikely(val < 0)) {
goto raise_neg_overflow;
}
return (long) val;
}
} else
#endif
if (likely(PyLong_Check(x))) {
if (is_unsigned) {
#if CYTHON_USE_PYLONG_INTERNALS
const digit* digits = ((PyLongObject*)x)->ob_digit;
switch (Py_SIZE(x)) {
case 0: return (long) 0;
case 1: __PYX_VERIFY_RETURN_INT(long, digit, digits[0])
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
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
const digit* digits = ((PyLongObject*)x)->ob_digit;
switch (Py_SIZE(x)) {
case 0: return (long) 0;
case -1: __PYX_VERIFY_RETURN_INT(long, sdigit, (sdigit) (-(sdigit)digits[0]))
case 1: __PYX_VERIFY_RETURN_INT(long, digit, +digits[0])
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
}
}
{
#if CYTHON_COMPILING_IN_PYPY && !defined(_PyLong_AsByteArray)
PyErr_SetString(PyExc_RuntimeError,
"_PyLong_AsByteArray() not available in PyPy, cannot convert large numbers");
#else
long val;
PyObject *v = __Pyx_PyNumber_IntOrLong(x);
#if PY_MAJOR_VERSION < 3
if (likely(v) && !PyLong_Check(v)) {
PyObject *tmp = v;
v = PyNumber_Long(tmp);
Py_DECREF(tmp);
}
#endif
if (likely(v)) {
int one = 1; int is_little = (int)*(unsigned char *)&one;
unsigned char *bytes = (unsigned char *)&val;
int ret = _PyLong_AsByteArray((PyLongObject *)v,
bytes, sizeof(val),
is_little, !is_unsigned);
Py_DECREF(v);
if (likely(!ret))
return val;
}
#endif
return (long) -1;
}
} else {
long val;
PyObject *tmp = __Pyx_PyNumber_IntOrLong(x);
if (!tmp) return (long) -1;
val = __Pyx_PyInt_As_long(tmp);
Py_DECREF(tmp);
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 ULONGLONG __Pyx_PyInt_As_ULONGLONG(PyObject *x) {
const ULONGLONG neg_one = (ULONGLONG) -1, const_zero = (ULONGLONG) 0;
const int is_unsigned = neg_one > const_zero;
#if PY_MAJOR_VERSION < 3
if (likely(PyInt_Check(x))) {
if (sizeof(ULONGLONG) < sizeof(long)) {
__PYX_VERIFY_RETURN_INT(ULONGLONG, long, PyInt_AS_LONG(x))
} else {
long val = PyInt_AS_LONG(x);
if (is_unsigned && unlikely(val < 0)) {
goto raise_neg_overflow;
}
return (ULONGLONG) val;
}
} else
#endif
if (likely(PyLong_Check(x))) {
if (is_unsigned) {
#if CYTHON_USE_PYLONG_INTERNALS
const digit* digits = ((PyLongObject*)x)->ob_digit;
switch (Py_SIZE(x)) {
case 0: return (ULONGLONG) 0;
case 1: __PYX_VERIFY_RETURN_INT(ULONGLONG, digit, digits[0])
case 2:
if (8 * sizeof(ULONGLONG) > 1 * PyLong_SHIFT) {
if (8 * sizeof(unsigned long) > 2 * PyLong_SHIFT) {
__PYX_VERIFY_RETURN_INT(ULONGLONG, unsigned long, (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])))
} else if (8 * sizeof(ULONGLONG) >= 2 * PyLong_SHIFT) {
return (ULONGLONG) (((((ULONGLONG)digits[1]) << PyLong_SHIFT) | (ULONGLONG)digits[0]));
}
}
break;
case 3:
if (8 * sizeof(ULONGLONG) > 2 * PyLong_SHIFT) {
if (8 * sizeof(unsigned long) > 3 * PyLong_SHIFT) {
__PYX_VERIFY_RETURN_INT(ULONGLONG, unsigned long, (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])))
} else if (8 * sizeof(ULONGLONG) >= 3 * PyLong_SHIFT) {
return (ULONGLONG) (((((((ULONGLONG)digits[2]) << PyLong_SHIFT) | (ULONGLONG)digits[1]) << PyLong_SHIFT) | (ULONGLONG)digits[0]));
}
}
break;
case 4:
if (8 * sizeof(ULONGLONG) > 3 * PyLong_SHIFT) {
if (8 * sizeof(unsigned long) > 4 * PyLong_SHIFT) {
__PYX_VERIFY_RETURN_INT(ULONGLONG, 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(ULONGLONG) >= 4 * PyLong_SHIFT) {
return (ULONGLONG) (((((((((ULONGLONG)digits[3]) << PyLong_SHIFT) | (ULONGLONG)digits[2]) << PyLong_SHIFT) | (ULONGLONG)digits[1]) << PyLong_SHIFT) | (ULONGLONG)digits[0]));
}
}
break;
}
#endif
#if CYTHON_COMPILING_IN_CPYTHON
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 (ULONGLONG) -1;
if (unlikely(result == 1))
goto raise_neg_overflow;
}
#endif
if (sizeof(ULONGLONG) <= sizeof(unsigned long)) {
__PYX_VERIFY_RETURN_INT_EXC(ULONGLONG, unsigned long, PyLong_AsUnsignedLong(x))
#ifdef HAVE_LONG_LONG
} else if (sizeof(ULONGLONG) <= sizeof(unsigned PY_LONG_LONG)) {
__PYX_VERIFY_RETURN_INT_EXC(ULONGLONG, unsigned PY_LONG_LONG, PyLong_AsUnsignedLongLong(x))
#endif
}
} else {
#if CYTHON_USE_PYLONG_INTERNALS
const digit* digits = ((PyLongObject*)x)->ob_digit;
switch (Py_SIZE(x)) {
case 0: return (ULONGLONG) 0;
case -1: __PYX_VERIFY_RETURN_INT(ULONGLONG, sdigit, (sdigit) (-(sdigit)digits[0]))
case 1: __PYX_VERIFY_RETURN_INT(ULONGLONG, digit, +digits[0])
case -2:
if (8 * sizeof(ULONGLONG) - 1 > 1 * PyLong_SHIFT) {
if (8 * sizeof(unsigned long) > 2 * PyLong_SHIFT) {
__PYX_VERIFY_RETURN_INT(ULONGLONG, long, -(long) (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])))
} else if (8 * sizeof(ULONGLONG) - 1 > 2 * PyLong_SHIFT) {
return (ULONGLONG) (((ULONGLONG)-1)*(((((ULONGLONG)digits[1]) << PyLong_SHIFT) | (ULONGLONG)digits[0])));
}
}
break;
case 2:
if (8 * sizeof(ULONGLONG) > 1 * PyLong_SHIFT) {
if (8 * sizeof(unsigned long) > 2 * PyLong_SHIFT) {
__PYX_VERIFY_RETURN_INT(ULONGLONG, unsigned long, (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])))
} else if (8 * sizeof(ULONGLONG) - 1 > 2 * PyLong_SHIFT) {
return (ULONGLONG) ((((((ULONGLONG)digits[1]) << PyLong_SHIFT) | (ULONGLONG)digits[0])));
}
}
break;
case -3:
if (8 * sizeof(ULONGLONG) - 1 > 2 * PyLong_SHIFT) {
if (8 * sizeof(unsigned long) > 3 * PyLong_SHIFT) {
__PYX_VERIFY_RETURN_INT(ULONGLONG, long, -(long) (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])))
} else if (8 * sizeof(ULONGLONG) - 1 > 3 * PyLong_SHIFT) {
return (ULONGLONG) (((ULONGLONG)-1)*(((((((ULONGLONG)digits[2]) << PyLong_SHIFT) | (ULONGLONG)digits[1]) << PyLong_SHIFT) | (ULONGLONG)digits[0])));
}
}
break;
case 3:
if (8 * sizeof(ULONGLONG) > 2 * PyLong_SHIFT) {
if (8 * sizeof(unsigned long) > 3 * PyLong_SHIFT) {
__PYX_VERIFY_RETURN_INT(ULONGLONG, unsigned long, (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])))
} else if (8 * sizeof(ULONGLONG) - 1 > 3 * PyLong_SHIFT) {
return (ULONGLONG) ((((((((ULONGLONG)digits[2]) << PyLong_SHIFT) | (ULONGLONG)digits[1]) << PyLong_SHIFT) | (ULONGLONG)digits[0])));
}
}
break;
case -4:
if (8 * sizeof(ULONGLONG) - 1 > 3 * PyLong_SHIFT) {
if (8 * sizeof(unsigned long) > 4 * PyLong_SHIFT) {
__PYX_VERIFY_RETURN_INT(ULONGLONG, 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(ULONGLONG) - 1 > 4 * PyLong_SHIFT) {
return (ULONGLONG) (((ULONGLONG)-1)*(((((((((ULONGLONG)digits[3]) << PyLong_SHIFT) | (ULONGLONG)digits[2]) << PyLong_SHIFT) | (ULONGLONG)digits[1]) << PyLong_SHIFT) | (ULONGLONG)digits[0])));
}
}
break;
case 4:
if (8 * sizeof(ULONGLONG) > 3 * PyLong_SHIFT) {
if (8 * sizeof(unsigned long) > 4 * PyLong_SHIFT) {
__PYX_VERIFY_RETURN_INT(ULONGLONG, 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(ULONGLONG) - 1 > 4 * PyLong_SHIFT) {
return (ULONGLONG) ((((((((((ULONGLONG)digits[3]) << PyLong_SHIFT) | (ULONGLONG)digits[2]) << PyLong_SHIFT) | (ULONGLONG)digits[1]) << PyLong_SHIFT) | (ULONGLONG)digits[0])));
}
}
break;
}
#endif
if (sizeof(ULONGLONG) <= sizeof(long)) {
__PYX_VERIFY_RETURN_INT_EXC(ULONGLONG, long, PyLong_AsLong(x))
#ifdef HAVE_LONG_LONG
} else if (sizeof(ULONGLONG) <= sizeof(PY_LONG_LONG)) {
__PYX_VERIFY_RETURN_INT_EXC(ULONGLONG, PY_LONG_LONG, PyLong_AsLongLong(x))
#endif
}
}
{
#if CYTHON_COMPILING_IN_PYPY && !defined(_PyLong_AsByteArray)
PyErr_SetString(PyExc_RuntimeError,
"_PyLong_AsByteArray() not available in PyPy, cannot convert large numbers");
#else
ULONGLONG val;
PyObject *v = __Pyx_PyNumber_IntOrLong(x);
#if PY_MAJOR_VERSION < 3
if (likely(v) && !PyLong_Check(v)) {
PyObject *tmp = v;
v = PyNumber_Long(tmp);
Py_DECREF(tmp);
}
#endif
if (likely(v)) {
int one = 1; int is_little = (int)*(unsigned char *)&one;
unsigned char *bytes = (unsigned char *)&val;
int ret = _PyLong_AsByteArray((PyLongObject *)v,
bytes, sizeof(val),
is_little, !is_unsigned);
Py_DECREF(v);
if (likely(!ret))
return val;
}
#endif
return (ULONGLONG) -1;
}
} else {
ULONGLONG val;
PyObject *tmp = __Pyx_PyNumber_IntOrLong(x);
if (!tmp) return (ULONGLONG) -1;
val = __Pyx_PyInt_As_ULONGLONG(tmp);
Py_DECREF(tmp);
return val;
}
raise_overflow:
PyErr_SetString(PyExc_OverflowError,
"value too large to convert to ULONGLONG");
return (ULONGLONG) -1;
raise_neg_overflow:
PyErr_SetString(PyExc_OverflowError,
"can't convert negative value to ULONGLONG");
return (ULONGLONG) -1;
}
/* FastTypeChecks */
#if CYTHON_COMPILING_IN_CPYTHON
static int __Pyx_InBases(PyTypeObject *a, PyTypeObject *b) {
while (a) {
a = a->tp_base;
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);
}
#if PY_MAJOR_VERSION == 2
static int __Pyx_inner_PyErr_GivenExceptionMatches2(PyObject *err, PyObject* exc_type1, PyObject* exc_type2) {
PyObject *exception, *value, *tb;
int res;
__Pyx_PyThreadState_declare
__Pyx_PyThreadState_assign
__Pyx_ErrFetch(&exception, &value, &tb);
res = exc_type1 ? PyObject_IsSubclass(err, exc_type1) : 0;
if (unlikely(res == -1)) {
PyErr_WriteUnraisable(err);
res = 0;
}
if (!res) {
res = PyObject_IsSubclass(err, exc_type2);
if (unlikely(res == -1)) {
PyErr_WriteUnraisable(err);
res = 0;
}
}
__Pyx_ErrRestore(exception, value, tb);
return res;
}
#else
static CYTHON_INLINE int __Pyx_inner_PyErr_GivenExceptionMatches2(PyObject *err, PyObject* exc_type1, PyObject *exc_type2) {
int res = exc_type1 ? __Pyx_IsSubtype((PyTypeObject*)err, (PyTypeObject*)exc_type1) : 0;
if (!res) {
res = __Pyx_IsSubtype((PyTypeObject*)err, (PyTypeObject*)exc_type2);
}
return res;
}
#endif
static CYTHON_INLINE int __Pyx_PyErr_GivenExceptionMatches(PyObject *err, PyObject* exc_type) {
if (likely(err == exc_type)) return 1;
if (likely(PyExceptionClass_Check(err))) {
return __Pyx_inner_PyErr_GivenExceptionMatches2(err, NULL, exc_type);
}
return PyErr_GivenExceptionMatches(err, exc_type);
}
static CYTHON_INLINE int __Pyx_PyErr_GivenExceptionMatches2(PyObject *err, PyObject *exc_type1, PyObject *exc_type2) {
if (likely(err == exc_type1 || err == exc_type2)) return 1;
if (likely(PyExceptionClass_Check(err))) {
return __Pyx_inner_PyErr_GivenExceptionMatches2(err, exc_type1, exc_type2);
}
return (PyErr_GivenExceptionMatches(err, exc_type1) || PyErr_GivenExceptionMatches(err, exc_type2));
}
#endif
/* CheckBinaryVersion */
static int __Pyx_check_binary_version(void) {
char ctversion[4], rtversion[4];
PyOS_snprintf(ctversion, 4, "%d.%d", PY_MAJOR_VERSION, PY_MINOR_VERSION);
PyOS_snprintf(rtversion, 4, "%s", Py_GetVersion());
if (ctversion[0] != rtversion[0] || ctversion[2] != rtversion[2]) {
char message[200];
PyOS_snprintf(message, sizeof(message),
"compiletime version %s of module '%.100s' "
"does not match runtime version %s",
ctversion, __Pyx_MODULE_NAME, rtversion);
return PyErr_WarnEx(NULL, message, 1);
}
return 0;
}
/* ModuleImport */
#ifndef __PYX_HAVE_RT_ImportModule
#define __PYX_HAVE_RT_ImportModule
static PyObject *__Pyx_ImportModule(const char *name) {
PyObject *py_name = 0;
PyObject *py_module = 0;
py_name = __Pyx_PyIdentifier_FromString(name);
if (!py_name)
goto bad;
py_module = PyImport_Import(py_name);
Py_DECREF(py_name);
return py_module;
bad:
Py_XDECREF(py_name);
return 0;
}
#endif
/* TypeImport */
#ifndef __PYX_HAVE_RT_ImportType
#define __PYX_HAVE_RT_ImportType
static PyTypeObject *__Pyx_ImportType(const char *module_name, const char *class_name,
size_t size, int strict)
{
PyObject *py_module = 0;
PyObject *result = 0;
PyObject *py_name = 0;
char warning[200];
Py_ssize_t basicsize;
#ifdef Py_LIMITED_API
PyObject *py_basicsize;
#endif
py_module = __Pyx_ImportModule(module_name);
if (!py_module)
goto bad;
py_name = __Pyx_PyIdentifier_FromString(class_name);
if (!py_name)
goto bad;
result = PyObject_GetAttr(py_module, py_name);
Py_DECREF(py_name);
py_name = 0;
Py_DECREF(py_module);
py_module = 0;
if (!result)
goto bad;
if (!PyType_Check(result)) {
PyErr_Format(PyExc_TypeError,
"%.200s.%.200s is not a type object",
module_name, class_name);
goto bad;
}
#ifndef Py_LIMITED_API
basicsize = ((PyTypeObject *)result)->tp_basicsize;
#else
py_basicsize = PyObject_GetAttrString(result, "__basicsize__");
if (!py_basicsize)
goto bad;
basicsize = PyLong_AsSsize_t(py_basicsize);
Py_DECREF(py_basicsize);
py_basicsize = 0;
if (basicsize == (Py_ssize_t)-1 && PyErr_Occurred())
goto bad;
#endif
if (!strict && (size_t)basicsize > size) {
PyOS_snprintf(warning, sizeof(warning),
"%s.%s size changed, may indicate binary incompatibility. Expected %zd, got %zd",
module_name, class_name, basicsize, size);
if (PyErr_WarnEx(NULL, warning, 0) < 0) goto bad;
}
else if ((size_t)basicsize != size) {
PyErr_Format(PyExc_ValueError,
"%.200s.%.200s has the wrong size, try recompiling. Expected %zd, got %zd",
module_name, class_name, basicsize, size);
goto bad;
}
return (PyTypeObject *)result;
bad:
Py_XDECREF(py_module);
Py_XDECREF(result);
return NULL;
}
#endif
/* InitStrings */
static int __Pyx_InitStrings(__Pyx_StringTabEntry *t) {
while (t->p) {
#if PY_MAJOR_VERSION < 3
if (t->is_unicode) {
*t->p = PyUnicode_DecodeUTF8(t->s, t->n - 1, NULL);
} else if (t->intern) {
*t->p = PyString_InternFromString(t->s);
} else {
*t->p = PyString_FromStringAndSize(t->s, t->n - 1);
}
#else
if (t->is_unicode | t->is_str) {
if (t->intern) {
*t->p = PyUnicode_InternFromString(t->s);
} else if (t->encoding) {
*t->p = PyUnicode_Decode(t->s, t->n - 1, t->encoding, NULL);
} else {
*t->p = PyUnicode_FromStringAndSize(t->s, t->n - 1);
}
} else {
*t->p = PyBytes_FromStringAndSize(t->s, t->n - 1);
}
#endif
if (!*t->p)
return -1;
if (PyObject_Hash(*t->p) == -1)
PyErr_Clear();
++t;
}
return 0;
}
static CYTHON_INLINE PyObject* __Pyx_PyUnicode_FromString(const char* c_str) {
return __Pyx_PyUnicode_FromStringAndSize(c_str, (Py_ssize_t)strlen(c_str));
}
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_DEFAULT
#if !CYTHON_PEP393_ENABLED
static const char* __Pyx_PyUnicode_AsStringAndSize(PyObject* o, Py_ssize_t *length) {
char* defenc_c;
PyObject* defenc = _PyUnicode_AsDefaultEncodedString(o, NULL);
if (!defenc) return NULL;
defenc_c = PyBytes_AS_STRING(defenc);
#if __PYX_DEFAULT_STRING_ENCODING_IS_ASCII
{
char* end = defenc_c + PyBytes_GET_SIZE(defenc);
char* c;
for (c = defenc_c; c < end; c++) {
if ((unsigned char) (*c) >= 128) {
PyUnicode_AsASCIIString(o);
return NULL;
}
}
}
#endif
*length = PyBytes_GET_SIZE(defenc);
return defenc_c;
}
#else
static CYTHON_INLINE const char* __Pyx_PyUnicode_AsStringAndSize(PyObject* o, Py_ssize_t *length) {
if (unlikely(__Pyx_PyUnicode_READY(o) == -1)) return NULL;
#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_DEFAULT
if (
#if PY_MAJOR_VERSION < 3 && __PYX_DEFAULT_STRING_ENCODING_IS_ASCII
__Pyx_sys_getdefaultencoding_not_ascii &&
#endif
PyUnicode_Check(o)) {
return __Pyx_PyUnicode_AsStringAndSize(o, length);
} else
#endif
#if (!CYTHON_COMPILING_IN_PYPY) || (defined(PyByteArray_AS_STRING) && defined(PyByteArray_GET_SIZE))
if (PyByteArray_Check(o)) {
*length = PyByteArray_GET_SIZE(o);
return PyByteArray_AS_STRING(o);
} else
#endif
{
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 PyObject* __Pyx_PyNumber_IntOrLongWrongResultType(PyObject* result, const char* type_name) {
#if PY_MAJOR_VERSION >= 3
if (PyLong_Check(result)) {
if (PyErr_WarnFormat(PyExc_DeprecationWarning, 1,
"__int__ returned non-int (type %.200s). "
"The ability to return an instance of a strict subclass of int "
"is deprecated, and may be removed in a future version of Python.",
Py_TYPE(result)->tp_name)) {
Py_DECREF(result);
return NULL;
}
return result;
}
#endif
PyErr_Format(PyExc_TypeError,
"__%.4s__ returned non-%.4s (type %.200s)",
type_name, type_name, Py_TYPE(result)->tp_name);
Py_DECREF(result);
return NULL;
}
static CYTHON_INLINE PyObject* __Pyx_PyNumber_IntOrLong(PyObject* x) {
#if CYTHON_USE_TYPE_SLOTS
PyNumberMethods *m;
#endif
const char *name = NULL;
PyObject *res = NULL;
#if PY_MAJOR_VERSION < 3
if (likely(PyInt_Check(x) || PyLong_Check(x)))
#else
if (likely(PyLong_Check(x)))
#endif
return __Pyx_NewRef(x);
#if CYTHON_USE_TYPE_SLOTS
m = Py_TYPE(x)->tp_as_number;
#if PY_MAJOR_VERSION < 3
if (m && m->nb_int) {
name = "int";
res = m->nb_int(x);
}
else if (m && m->nb_long) {
name = "long";
res = m->nb_long(x);
}
#else
if (likely(m && m->nb_int)) {
name = "int";
res = m->nb_int(x);
}
#endif
#else
if (!PyBytes_CheckExact(x) && !PyUnicode_CheckExact(x)) {
res = PyNumber_Int(x);
}
#endif
if (likely(res)) {
#if PY_MAJOR_VERSION < 3
if (unlikely(!PyInt_Check(res) && !PyLong_Check(res))) {
#else
if (unlikely(!PyLong_CheckExact(res))) {
#endif
return __Pyx_PyNumber_IntOrLongWrongResultType(res, name);
}
}
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 PY_MAJOR_VERSION < 3
if (likely(PyInt_CheckExact(b))) {
if (sizeof(Py_ssize_t) >= sizeof(long))
return PyInt_AS_LONG(b);
else
return PyInt_AsSsize_t(x);
}
#endif
if (likely(PyLong_CheckExact(b))) {
#if CYTHON_USE_PYLONG_INTERNALS
const digit* digits = ((PyLongObject*)b)->ob_digit;
const Py_ssize_t size = Py_SIZE(b);
if (likely(__Pyx_sst_abs(size) <= 1)) {
ival = likely(size) ? digits[0] : 0;
if (size == -1) ival = -ival;
return ival;
} else {
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 = PyInt_AsSsize_t(x);
Py_DECREF(x);
return ival;
}
static CYTHON_INLINE PyObject * __Pyx_PyInt_FromSize_t(size_t ival) {
return PyInt_FromSize_t(ival);
}
#endif /* Py_PYTHON_H */
#cython: language_level=3
from kafka.codec import (
gzip_encode, snappy_encode, lz4_encode, lz4_encode_old_kafka,
)
cdef extern from "Python.h":
ssize_t PyByteArray_GET_SIZE(object)
char* PyByteArray_AS_STRING(bytearray ba)
int PyByteArray_Resize(object, ssize_t) except -1
object PyMemoryView_FromMemory(char *mem, ssize_t size, int flags)
IF UNAME_SYSNAME == "Windows":
from zlib import crc32 as py_crc32
cdef long crc32(unsigned long crc, unsigned char *buf, int len):
cdef:
object memview
memview = PyMemoryView_FromMemory(<char *>buf, <ssize_t>len, PyBUF_READ)
return py_crc32(memview)
ELSE:
cdef extern from "zlib.h":
long crc32(unsigned long crc, const unsigned char *buf, int len)
# This should be here to generate include for `winsock2.h` before `windows.h`
from aiokafka.record cimport _hton as hton
# Time implementation ported from Python/pytime.c
DEF NS_TO_MS = (1000 * 1000)
DEF SEC_TO_NS = (1000 * 1000 * 1000)
DEF US_TO_NS = 1000
IF UNAME_SYSNAME == "Windows":
cdef extern from "windows.h":
# File types
ctypedef unsigned long DWORD
ctypedef unsigned long long ULONGLONG
# Structs
cdef struct FILETIME:
DWORD dwLowDateTime
DWORD dwHighDateTime
cdef struct __inner_ulonglong:
DWORD LowPart;
DWORD HighPart;
cdef union ULARGE_INTEGER:
__inner_ulonglong u
ULONGLONG QuadPart
void GetSystemTimeAsFileTime(FILETIME *time)
cdef long get_time_as_unix_ms():
cdef:
FILETIME system_time
ULARGE_INTEGER large
GetSystemTimeAsFileTime(&system_time)
large.u.LowPart = system_time.dwLowDateTime
large.u.HighPart = system_time.dwHighDateTime
# 11,644,473,600,000,000,000: number of nanoseconds between
# the 1st january 1601 and the 1st january 1970 (369 years + 89 leap
# days).
large.QuadPart = large.QuadPart * 100 - <ULONGLONG> 11644473600000000000
return <long> (large.QuadPart / NS_TO_MS)
ELSE:
from posix.time cimport gettimeofday, timeval, timezone
cdef long get_time_as_unix_ms():
cdef:
timeval tv
long long res
int err
err = gettimeofday(&tv, <timezone *>NULL) # Fixme: handle error?
if err:
return -1
res = (<long long> tv.tv_sec) * SEC_TO_NS
res += tv.tv_usec * US_TO_NS
return <long> (res / NS_TO_MS)
# END: Time implementation
from cpython cimport PyObject_GetBuffer, PyBuffer_Release, PyBUF_WRITABLE, \
PyBUF_SIMPLE, PyBUF_READ, Py_buffer
from libc.stdint cimport int32_t, int64_t, uint32_t
from libc.string cimport memcpy
cimport cython
# Those are used for fast size calculations
DEF RECORD_OVERHEAD_V0 = 14
DEF RECORD_OVERHEAD_V1 = 22
DEF KEY_OFFSET_V0 = 18
DEF KEY_OFFSET_V1 = 26
DEF LOG_OVERHEAD = 12
DEF KEY_LENGTH = 4
DEF VALUE_LENGTH = 4
# Field offsets
DEF LENGTH_OFFSET = 8
DEF CRC_OFFSET = LENGTH_OFFSET + 4
DEF MAGIC_OFFSET = CRC_OFFSET + 4
DEF ATTRIBUTES_OFFSET = MAGIC_OFFSET + 1
DEF TIMESTAMP_OFFSET = ATTRIBUTES_OFFSET + 1
# Compression flags
DEF ATTR_CODEC_MASK = 0x07
DEF ATTR_CODEC_GZIP = 0x01
DEF ATTR_CODEC_SNAPPY = 0x02
DEF ATTR_CODEC_LZ4 = 0x03
cdef class _LegacyRecordBatchBuilderCython:
cdef:
char _magic
char _compression_type
int _batch_size
bytearray _buffer
CODEC_GZIP = ATTR_CODEC_GZIP
CODEC_SNAPPY = ATTR_CODEC_SNAPPY
CODEC_LZ4 = ATTR_CODEC_LZ4
def __init__(self, char magic, char compression_type, int batch_size):
self._magic = magic
self._compression_type = compression_type
self._batch_size = batch_size
self._buffer = bytearray()
def append(self, long offset, timestamp, key, value):
""" Append message to batch.
"""
cdef:
int pos
int size
char *buf
long ts
if timestamp is None:
ts = get_time_as_unix_ms()
else:
ts = timestamp
# Check if we have room for another message
pos = PyByteArray_GET_SIZE(self._buffer)
size = _size_in_bytes(self._magic, key, value)
# We always allow at least one record to be appended
if offset != 0 and pos + size >= self._batch_size:
return None, 0
# Allocate proper buffer length
PyByteArray_Resize(self._buffer, pos + size)
# Encode message
buf = PyByteArray_AS_STRING(self._buffer)
crc = _encode_msg(
self._magic, pos, buf,
offset, ts, key, value, 0)
return crc, size
def size(self):
""" Return current size of data written to buffer
"""
return PyByteArray_GET_SIZE(self._buffer)
# Size calculations. Just copied Java's implementation
def size_in_bytes(self, offset, timestamp, key, value):
""" Actual size of message to add
"""
return _size_in_bytes(self._magic, key, value)
cdef int _maybe_compress(self) except -1:
cdef:
object compressed
char *buf
int size
if self._compression_type != 0:
if self._compression_type == ATTR_CODEC_GZIP:
compressed = gzip_encode(self._buffer)
elif self._compression_type == ATTR_CODEC_SNAPPY:
compressed = snappy_encode(self._buffer)
elif self._compression_type == ATTR_CODEC_LZ4:
if self._magic == 0:
compressed = lz4_encode_old_kafka(bytes(self._buffer))
else:
compressed = lz4_encode(bytes(self._buffer))
else:
return 0
size = _size_in_bytes(self._magic, key=None, value=compressed)
# We will just write the result into the same memory space.
PyByteArray_Resize(self._buffer, size)
buf = PyByteArray_AS_STRING(self._buffer)
_encode_msg(
self._magic, 0, buf,
offset=0, timestamp=0, key=None, value=compressed,
attributes=self._compression_type)
return 1
return 0
def build(self):
"""Compress batch to be ready for send"""
self._maybe_compress()
return self._buffer
cdef int _size_in_bytes(char magic, object key, object value) except -1:
""" Actual size of message to add
"""
cdef:
Py_buffer buf
int key_len
int value_len
if key is None:
key_len = 0
else:
PyObject_GetBuffer(key, &buf, PyBUF_SIMPLE)
key_len = buf.len
PyBuffer_Release(&buf)
if value is None:
value_len = 0
else:
PyObject_GetBuffer(value, &buf, PyBUF_SIMPLE)
value_len = buf.len
PyBuffer_Release(&buf)
if magic == 0:
return LOG_OVERHEAD + RECORD_OVERHEAD_V0 + key_len + value_len
else:
return LOG_OVERHEAD + RECORD_OVERHEAD_V1 + key_len + value_len
cdef object _encode_msg(
char magic, int start_pos, char *buf,
long offset, long timestamp, object key, object value,
char attributes):
""" Encode msg data into the `msg_buffer`, which should be allocated
to at least the size of this message.
"""
cdef:
Py_buffer key_val_buf
int pos = start_pos
int length
int crc
# Write key and value
pos += KEY_OFFSET_V0 if magic == 0 else KEY_OFFSET_V1
if key is None:
hton.pack_int32(&buf[pos], -1)
pos += KEY_LENGTH
else:
PyObject_GetBuffer(key, &key_val_buf, PyBUF_SIMPLE)
hton.pack_int32(&buf[pos], <int32_t>key_val_buf.len)
pos += KEY_LENGTH
memcpy(&buf[pos], <char*>key_val_buf.buf, <size_t>key_val_buf.len)
pos += <int>key_val_buf.len
PyBuffer_Release(&key_val_buf)
if value is None:
hton.pack_int32(&buf[pos], -1)
pos += VALUE_LENGTH
else:
PyObject_GetBuffer(value, &key_val_buf, PyBUF_SIMPLE)
hton.pack_int32(&buf[pos], <int32_t>key_val_buf.len)
pos += VALUE_LENGTH
memcpy(&buf[pos], <char*>key_val_buf.buf, <size_t>key_val_buf.len)
pos += <int>key_val_buf.len
PyBuffer_Release(&key_val_buf)
length = (pos - start_pos) - LOG_OVERHEAD
# Write msg header. Note, that Crc will be updated later
hton.pack_int64(&buf[start_pos], <int64_t>offset)
hton.pack_int32(&buf[start_pos + LENGTH_OFFSET], <int32_t>length)
buf[start_pos + MAGIC_OFFSET] = magic
buf[start_pos + ATTRIBUTES_OFFSET] = attributes
if magic == 1:
hton.pack_int64(&buf[start_pos + TIMESTAMP_OFFSET], <int64_t>timestamp)
# Calculate CRC for msg
crc = crc32(
0,
<unsigned char*>&buf[start_pos + MAGIC_OFFSET],
pos - (start_pos + MAGIC_OFFSET)
)
hton.pack_int32(&buf[start_pos + CRC_OFFSET], <uint32_t>crc)
return crc
aiokafka/record/_legacy_records.pyx: cannot find cimported module 'aiokafka.record'
running develop
running egg_info
writing aiokafka.egg-info\PKG-INFO
writing dependency_links to aiokafka.egg-info\dependency_links.txt
writing requirements to aiokafka.egg-info\requires.txt
writing top-level names to aiokafka.egg-info\top_level.txt
reading manifest file 'aiokafka.egg-info\SOURCES.txt'
reading manifest template 'MANIFEST.in'
writing manifest file 'aiokafka.egg-info\SOURCES.txt'
running build_ext
building 'aiokafka.record._legacy_records' extension
C:\Program Files (x86)\Microsoft Visual Studio 14.0\VC\BIN\cl.exe /c /nologo /Ox /W3 /GL /DNDEBUG /MD -Ic:\users\taras\appdata\local\programs\python\python36-32\include -Ic:\users\taras\appdata\local\programs\python\python36-32\include "-IC:\Program Files (x86)\Microsoft Visual Studio 14.0\VC\INCLUDE" "-IC:\Program Files (x86)\Windows Kits\10\include\10.0.10240.0\ucrt" "-IC:\Program Files (x86)\Windows Kits\8.1\include\shared" "-IC:\Program Files (x86)\Windows Kits\8.1\include\um" "-IC:\Program Files (x86)\Windows Kits\8.1\include\winrt" /Tcaiokafka/record/_legacy_records.c /Fobuild\temp.win32-3.6\Release\aiokafka/record/_legacy_records.obj
_legacy_records.c
aiokafka/record/_legacy_records.c(1424): error C2079: '__pyx_v_system_time' uses undefined struct 'FILETIME'
aiokafka/record/_legacy_records.c(1425): error C2079: '__pyx_v_large' uses undefined union 'ULARGE_INTEGER'
aiokafka/record/_legacy_records.c(1438): warning C4133: 'function': incompatible types - from 'int *' to 'LPFILETIME'
aiokafka/record/_legacy_records.c(1447): error C2224: left of '.dwLowDateTime' must have struct/union type
aiokafka/record/_legacy_records.c(1448): error C2224: left of '.u' must have struct/union type
aiokafka/record/_legacy_records.c(1457): error C2224: left of '.dwHighDateTime' must have struct/union type
aiokafka/record/_legacy_records.c(1458): error C2224: left of '.u' must have struct/union type
aiokafka/record/_legacy_records.c(1467): error C2224: left of '.QuadPart' must have struct/union type
aiokafka/record/_legacy_records.c(1476): error C2224: left of '.QuadPart' must have struct/union type
************************************************************
Cannot compile C accelerator module, use pure python version
************************************************************
running develop
running egg_info
writing aiokafka.egg-info\PKG-INFO
writing dependency_links to aiokafka.egg-info\dependency_links.txt
writing requirements to aiokafka.egg-info\requires.txt
writing top-level names to aiokafka.egg-info\top_level.txt
reading manifest file 'aiokafka.egg-info\SOURCES.txt'
reading manifest template 'MANIFEST.in'
writing manifest file 'aiokafka.egg-info\SOURCES.txt'
running build_ext
Creating c:\users\taras\workspace\.aiokafka\lib\site-packages\aiokafka.egg-link (link to .)
aiokafka 0.3.2.dev0 is already the active version in easy-install.pth
Installed c:\users\taras\workspace\aiokafka
Processing dependencies for aiokafka==0.3.2.dev0
Searching for kafka-python==1.3.3
Best match: kafka-python 1.3.3
Processing kafka_python-1.3.3-py3.6.egg
kafka-python 1.3.3 is already the active version in easy-install.pth
Using c:\users\taras\workspace\.aiokafka\lib\site-packages\kafka_python-1.3.3-py3.6.egg
Finished processing dependencies for aiokafka==0.3.2.dev0
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment