| /*[clinic input] |
| preserve |
| [clinic start generated code]*/ |
| |
| #if defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_MODULE) |
| # include "pycore_gc.h" // PyGC_Head |
| # include "pycore_runtime.h" // _Py_ID() |
| #endif |
| #include "pycore_abstract.h" // _PyNumber_Index() |
| #include "pycore_modsupport.h" // _PyArg_BadArgument() |
| |
| PyDoc_STRVAR(_bz2_BZ2Compressor_compress__doc__, |
| "compress($self, data, /)\n" |
| "--\n" |
| "\n" |
| "Provide data to the compressor object.\n" |
| "\n" |
| "Returns a chunk of compressed data if possible, or b\'\' otherwise.\n" |
| "\n" |
| "When you have finished providing data to the compressor, call the\n" |
| "flush() method to finish the compression process."); |
| |
| #define _BZ2_BZ2COMPRESSOR_COMPRESS_METHODDEF \ |
| {"compress", (PyCFunction)_bz2_BZ2Compressor_compress, METH_O, _bz2_BZ2Compressor_compress__doc__}, |
| |
| static PyObject * |
| _bz2_BZ2Compressor_compress_impl(BZ2Compressor *self, Py_buffer *data); |
| |
| static PyObject * |
| _bz2_BZ2Compressor_compress(BZ2Compressor *self, PyObject *arg) |
| { |
| PyObject *return_value = NULL; |
| Py_buffer data = {NULL, NULL}; |
| |
| if (PyObject_GetBuffer(arg, &data, PyBUF_SIMPLE) != 0) { |
| goto exit; |
| } |
| return_value = _bz2_BZ2Compressor_compress_impl(self, &data); |
| |
| exit: |
| /* Cleanup for data */ |
| if (data.obj) { |
| PyBuffer_Release(&data); |
| } |
| |
| return return_value; |
| } |
| |
| PyDoc_STRVAR(_bz2_BZ2Compressor_flush__doc__, |
| "flush($self, /)\n" |
| "--\n" |
| "\n" |
| "Finish the compression process.\n" |
| "\n" |
| "Returns the compressed data left in internal buffers.\n" |
| "\n" |
| "The compressor object may not be used after this method is called."); |
| |
| #define _BZ2_BZ2COMPRESSOR_FLUSH_METHODDEF \ |
| {"flush", (PyCFunction)_bz2_BZ2Compressor_flush, METH_NOARGS, _bz2_BZ2Compressor_flush__doc__}, |
| |
| static PyObject * |
| _bz2_BZ2Compressor_flush_impl(BZ2Compressor *self); |
| |
| static PyObject * |
| _bz2_BZ2Compressor_flush(BZ2Compressor *self, PyObject *Py_UNUSED(ignored)) |
| { |
| return _bz2_BZ2Compressor_flush_impl(self); |
| } |
| |
| PyDoc_STRVAR(_bz2_BZ2Compressor__doc__, |
| "BZ2Compressor(compresslevel=9, /)\n" |
| "--\n" |
| "\n" |
| "Create a compressor object for compressing data incrementally.\n" |
| "\n" |
| " compresslevel\n" |
| " Compression level, as a number between 1 and 9.\n" |
| "\n" |
| "For one-shot compression, use the compress() function instead."); |
| |
| static PyObject * |
| _bz2_BZ2Compressor_impl(PyTypeObject *type, int compresslevel); |
| |
| static PyObject * |
| _bz2_BZ2Compressor(PyTypeObject *type, PyObject *args, PyObject *kwargs) |
| { |
| PyObject *return_value = NULL; |
| PyTypeObject *base_tp = clinic_state()->bz2_compressor_type; |
| int compresslevel = 9; |
| |
| if ((type == base_tp || type->tp_init == base_tp->tp_init) && |
| !_PyArg_NoKeywords("BZ2Compressor", kwargs)) { |
| goto exit; |
| } |
| if (!_PyArg_CheckPositional("BZ2Compressor", PyTuple_GET_SIZE(args), 0, 1)) { |
| goto exit; |
| } |
| if (PyTuple_GET_SIZE(args) < 1) { |
| goto skip_optional; |
| } |
| compresslevel = PyLong_AsInt(PyTuple_GET_ITEM(args, 0)); |
| if (compresslevel == -1 && PyErr_Occurred()) { |
| goto exit; |
| } |
| skip_optional: |
| return_value = _bz2_BZ2Compressor_impl(type, compresslevel); |
| |
| exit: |
| return return_value; |
| } |
| |
| PyDoc_STRVAR(_bz2_BZ2Decompressor_decompress__doc__, |
| "decompress($self, /, data, max_length=-1)\n" |
| "--\n" |
| "\n" |
| "Decompress *data*, returning uncompressed data as bytes.\n" |
| "\n" |
| "If *max_length* is nonnegative, returns at most *max_length* bytes of\n" |
| "decompressed data. If this limit is reached and further output can be\n" |
| "produced, *self.needs_input* will be set to ``False``. In this case, the next\n" |
| "call to *decompress()* may provide *data* as b\'\' to obtain more of the output.\n" |
| "\n" |
| "If all of the input data was decompressed and returned (either because this\n" |
| "was less than *max_length* bytes, or because *max_length* was negative),\n" |
| "*self.needs_input* will be set to True.\n" |
| "\n" |
| "Attempting to decompress data after the end of stream is reached raises an\n" |
| "EOFError. Any data found after the end of the stream is ignored and saved in\n" |
| "the unused_data attribute."); |
| |
| #define _BZ2_BZ2DECOMPRESSOR_DECOMPRESS_METHODDEF \ |
| {"decompress", _PyCFunction_CAST(_bz2_BZ2Decompressor_decompress), METH_FASTCALL|METH_KEYWORDS, _bz2_BZ2Decompressor_decompress__doc__}, |
| |
| static PyObject * |
| _bz2_BZ2Decompressor_decompress_impl(BZ2Decompressor *self, Py_buffer *data, |
| Py_ssize_t max_length); |
| |
| static PyObject * |
| _bz2_BZ2Decompressor_decompress(BZ2Decompressor *self, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames) |
| { |
| PyObject *return_value = NULL; |
| #if defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_MODULE) |
| |
| #define NUM_KEYWORDS 2 |
| static struct { |
| PyGC_Head _this_is_not_used; |
| PyObject_VAR_HEAD |
| PyObject *ob_item[NUM_KEYWORDS]; |
| } _kwtuple = { |
| .ob_base = PyVarObject_HEAD_INIT(&PyTuple_Type, NUM_KEYWORDS) |
| .ob_item = { &_Py_ID(data), &_Py_ID(max_length), }, |
| }; |
| #undef NUM_KEYWORDS |
| #define KWTUPLE (&_kwtuple.ob_base.ob_base) |
| |
| #else // !Py_BUILD_CORE |
| # define KWTUPLE NULL |
| #endif // !Py_BUILD_CORE |
| |
| static const char * const _keywords[] = {"data", "max_length", NULL}; |
| static _PyArg_Parser _parser = { |
| .keywords = _keywords, |
| .fname = "decompress", |
| .kwtuple = KWTUPLE, |
| }; |
| #undef KWTUPLE |
| PyObject *argsbuf[2]; |
| Py_ssize_t noptargs = nargs + (kwnames ? PyTuple_GET_SIZE(kwnames) : 0) - 1; |
| Py_buffer data = {NULL, NULL}; |
| Py_ssize_t max_length = -1; |
| |
| args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 1, 2, 0, argsbuf); |
| if (!args) { |
| goto exit; |
| } |
| if (PyObject_GetBuffer(args[0], &data, PyBUF_SIMPLE) != 0) { |
| goto exit; |
| } |
| if (!noptargs) { |
| goto skip_optional_pos; |
| } |
| { |
| Py_ssize_t ival = -1; |
| PyObject *iobj = _PyNumber_Index(args[1]); |
| if (iobj != NULL) { |
| ival = PyLong_AsSsize_t(iobj); |
| Py_DECREF(iobj); |
| } |
| if (ival == -1 && PyErr_Occurred()) { |
| goto exit; |
| } |
| max_length = ival; |
| } |
| skip_optional_pos: |
| return_value = _bz2_BZ2Decompressor_decompress_impl(self, &data, max_length); |
| |
| exit: |
| /* Cleanup for data */ |
| if (data.obj) { |
| PyBuffer_Release(&data); |
| } |
| |
| return return_value; |
| } |
| |
| PyDoc_STRVAR(_bz2_BZ2Decompressor__doc__, |
| "BZ2Decompressor()\n" |
| "--\n" |
| "\n" |
| "Create a decompressor object for decompressing data incrementally.\n" |
| "\n" |
| "For one-shot decompression, use the decompress() function instead."); |
| |
| static PyObject * |
| _bz2_BZ2Decompressor_impl(PyTypeObject *type); |
| |
| static PyObject * |
| _bz2_BZ2Decompressor(PyTypeObject *type, PyObject *args, PyObject *kwargs) |
| { |
| PyObject *return_value = NULL; |
| PyTypeObject *base_tp = clinic_state()->bz2_decompressor_type; |
| |
| if ((type == base_tp || type->tp_init == base_tp->tp_init) && |
| !_PyArg_NoPositional("BZ2Decompressor", args)) { |
| goto exit; |
| } |
| if ((type == base_tp || type->tp_init == base_tp->tp_init) && |
| !_PyArg_NoKeywords("BZ2Decompressor", kwargs)) { |
| goto exit; |
| } |
| return_value = _bz2_BZ2Decompressor_impl(type); |
| |
| exit: |
| return return_value; |
| } |
| /*[clinic end generated code: output=8daa62f47cc4853d input=a9049054013a1b77]*/ |