mirror of https://github.com/python/cpython
353 lines
10 KiB
C
353 lines
10 KiB
C
/*[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_critical_section.h"// Py_BEGIN_CRITICAL_SECTION()
|
|
#include "pycore_modsupport.h" // _PyArg_NoKeywords()
|
|
|
|
PyDoc_STRVAR(simplequeue_new__doc__,
|
|
"SimpleQueue()\n"
|
|
"--\n"
|
|
"\n"
|
|
"Simple, unbounded, reentrant FIFO queue.");
|
|
|
|
static PyObject *
|
|
simplequeue_new_impl(PyTypeObject *type);
|
|
|
|
static PyObject *
|
|
simplequeue_new(PyTypeObject *type, PyObject *args, PyObject *kwargs)
|
|
{
|
|
PyObject *return_value = NULL;
|
|
PyTypeObject *base_tp = simplequeue_get_state_by_type(type)->SimpleQueueType;
|
|
|
|
if ((type == base_tp || type->tp_init == base_tp->tp_init) &&
|
|
!_PyArg_NoPositional("SimpleQueue", args)) {
|
|
goto exit;
|
|
}
|
|
if ((type == base_tp || type->tp_init == base_tp->tp_init) &&
|
|
!_PyArg_NoKeywords("SimpleQueue", kwargs)) {
|
|
goto exit;
|
|
}
|
|
return_value = simplequeue_new_impl(type);
|
|
|
|
exit:
|
|
return return_value;
|
|
}
|
|
|
|
PyDoc_STRVAR(_queue_SimpleQueue_put__doc__,
|
|
"put($self, /, item, block=True, timeout=None)\n"
|
|
"--\n"
|
|
"\n"
|
|
"Put the item on the queue.\n"
|
|
"\n"
|
|
"The optional \'block\' and \'timeout\' arguments are ignored, as this method\n"
|
|
"never blocks. They are provided for compatibility with the Queue class.");
|
|
|
|
#define _QUEUE_SIMPLEQUEUE_PUT_METHODDEF \
|
|
{"put", _PyCFunction_CAST(_queue_SimpleQueue_put), METH_FASTCALL|METH_KEYWORDS, _queue_SimpleQueue_put__doc__},
|
|
|
|
static PyObject *
|
|
_queue_SimpleQueue_put_impl(simplequeueobject *self, PyObject *item,
|
|
int block, PyObject *timeout);
|
|
|
|
static PyObject *
|
|
_queue_SimpleQueue_put(simplequeueobject *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 3
|
|
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(item), &_Py_ID(block), &_Py_ID(timeout), },
|
|
};
|
|
#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[] = {"item", "block", "timeout", NULL};
|
|
static _PyArg_Parser _parser = {
|
|
.keywords = _keywords,
|
|
.fname = "put",
|
|
.kwtuple = KWTUPLE,
|
|
};
|
|
#undef KWTUPLE
|
|
PyObject *argsbuf[3];
|
|
Py_ssize_t noptargs = nargs + (kwnames ? PyTuple_GET_SIZE(kwnames) : 0) - 1;
|
|
PyObject *item;
|
|
int block = 1;
|
|
PyObject *timeout = Py_None;
|
|
|
|
args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 1, 3, 0, argsbuf);
|
|
if (!args) {
|
|
goto exit;
|
|
}
|
|
item = args[0];
|
|
if (!noptargs) {
|
|
goto skip_optional_pos;
|
|
}
|
|
if (args[1]) {
|
|
block = PyObject_IsTrue(args[1]);
|
|
if (block < 0) {
|
|
goto exit;
|
|
}
|
|
if (!--noptargs) {
|
|
goto skip_optional_pos;
|
|
}
|
|
}
|
|
timeout = args[2];
|
|
skip_optional_pos:
|
|
Py_BEGIN_CRITICAL_SECTION(self);
|
|
return_value = _queue_SimpleQueue_put_impl(self, item, block, timeout);
|
|
Py_END_CRITICAL_SECTION();
|
|
|
|
exit:
|
|
return return_value;
|
|
}
|
|
|
|
PyDoc_STRVAR(_queue_SimpleQueue_put_nowait__doc__,
|
|
"put_nowait($self, /, item)\n"
|
|
"--\n"
|
|
"\n"
|
|
"Put an item into the queue without blocking.\n"
|
|
"\n"
|
|
"This is exactly equivalent to `put(item)` and is only provided\n"
|
|
"for compatibility with the Queue class.");
|
|
|
|
#define _QUEUE_SIMPLEQUEUE_PUT_NOWAIT_METHODDEF \
|
|
{"put_nowait", _PyCFunction_CAST(_queue_SimpleQueue_put_nowait), METH_FASTCALL|METH_KEYWORDS, _queue_SimpleQueue_put_nowait__doc__},
|
|
|
|
static PyObject *
|
|
_queue_SimpleQueue_put_nowait_impl(simplequeueobject *self, PyObject *item);
|
|
|
|
static PyObject *
|
|
_queue_SimpleQueue_put_nowait(simplequeueobject *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 1
|
|
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(item), },
|
|
};
|
|
#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[] = {"item", NULL};
|
|
static _PyArg_Parser _parser = {
|
|
.keywords = _keywords,
|
|
.fname = "put_nowait",
|
|
.kwtuple = KWTUPLE,
|
|
};
|
|
#undef KWTUPLE
|
|
PyObject *argsbuf[1];
|
|
PyObject *item;
|
|
|
|
args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 1, 1, 0, argsbuf);
|
|
if (!args) {
|
|
goto exit;
|
|
}
|
|
item = args[0];
|
|
Py_BEGIN_CRITICAL_SECTION(self);
|
|
return_value = _queue_SimpleQueue_put_nowait_impl(self, item);
|
|
Py_END_CRITICAL_SECTION();
|
|
|
|
exit:
|
|
return return_value;
|
|
}
|
|
|
|
PyDoc_STRVAR(_queue_SimpleQueue_get__doc__,
|
|
"get($self, /, block=True, timeout=None)\n"
|
|
"--\n"
|
|
"\n"
|
|
"Remove and return an item from the queue.\n"
|
|
"\n"
|
|
"If optional args \'block\' is true and \'timeout\' is None (the default),\n"
|
|
"block if necessary until an item is available. If \'timeout\' is\n"
|
|
"a non-negative number, it blocks at most \'timeout\' seconds and raises\n"
|
|
"the Empty exception if no item was available within that time.\n"
|
|
"Otherwise (\'block\' is false), return an item if one is immediately\n"
|
|
"available, else raise the Empty exception (\'timeout\' is ignored\n"
|
|
"in that case).");
|
|
|
|
#define _QUEUE_SIMPLEQUEUE_GET_METHODDEF \
|
|
{"get", _PyCFunction_CAST(_queue_SimpleQueue_get), METH_METHOD|METH_FASTCALL|METH_KEYWORDS, _queue_SimpleQueue_get__doc__},
|
|
|
|
static PyObject *
|
|
_queue_SimpleQueue_get_impl(simplequeueobject *self, PyTypeObject *cls,
|
|
int block, PyObject *timeout_obj);
|
|
|
|
static PyObject *
|
|
_queue_SimpleQueue_get(simplequeueobject *self, PyTypeObject *cls, 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(block), &_Py_ID(timeout), },
|
|
};
|
|
#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[] = {"block", "timeout", NULL};
|
|
static _PyArg_Parser _parser = {
|
|
.keywords = _keywords,
|
|
.fname = "get",
|
|
.kwtuple = KWTUPLE,
|
|
};
|
|
#undef KWTUPLE
|
|
PyObject *argsbuf[2];
|
|
Py_ssize_t noptargs = nargs + (kwnames ? PyTuple_GET_SIZE(kwnames) : 0) - 0;
|
|
int block = 1;
|
|
PyObject *timeout_obj = Py_None;
|
|
|
|
args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 0, 2, 0, argsbuf);
|
|
if (!args) {
|
|
goto exit;
|
|
}
|
|
if (!noptargs) {
|
|
goto skip_optional_pos;
|
|
}
|
|
if (args[0]) {
|
|
block = PyObject_IsTrue(args[0]);
|
|
if (block < 0) {
|
|
goto exit;
|
|
}
|
|
if (!--noptargs) {
|
|
goto skip_optional_pos;
|
|
}
|
|
}
|
|
timeout_obj = args[1];
|
|
skip_optional_pos:
|
|
Py_BEGIN_CRITICAL_SECTION(self);
|
|
return_value = _queue_SimpleQueue_get_impl(self, cls, block, timeout_obj);
|
|
Py_END_CRITICAL_SECTION();
|
|
|
|
exit:
|
|
return return_value;
|
|
}
|
|
|
|
PyDoc_STRVAR(_queue_SimpleQueue_get_nowait__doc__,
|
|
"get_nowait($self, /)\n"
|
|
"--\n"
|
|
"\n"
|
|
"Remove and return an item from the queue without blocking.\n"
|
|
"\n"
|
|
"Only get an item if one is immediately available. Otherwise\n"
|
|
"raise the Empty exception.");
|
|
|
|
#define _QUEUE_SIMPLEQUEUE_GET_NOWAIT_METHODDEF \
|
|
{"get_nowait", _PyCFunction_CAST(_queue_SimpleQueue_get_nowait), METH_METHOD|METH_FASTCALL|METH_KEYWORDS, _queue_SimpleQueue_get_nowait__doc__},
|
|
|
|
static PyObject *
|
|
_queue_SimpleQueue_get_nowait_impl(simplequeueobject *self,
|
|
PyTypeObject *cls);
|
|
|
|
static PyObject *
|
|
_queue_SimpleQueue_get_nowait(simplequeueobject *self, PyTypeObject *cls, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
|
|
{
|
|
PyObject *return_value = NULL;
|
|
|
|
if (nargs || (kwnames && PyTuple_GET_SIZE(kwnames))) {
|
|
PyErr_SetString(PyExc_TypeError, "get_nowait() takes no arguments");
|
|
goto exit;
|
|
}
|
|
Py_BEGIN_CRITICAL_SECTION(self);
|
|
return_value = _queue_SimpleQueue_get_nowait_impl(self, cls);
|
|
Py_END_CRITICAL_SECTION();
|
|
|
|
exit:
|
|
return return_value;
|
|
}
|
|
|
|
PyDoc_STRVAR(_queue_SimpleQueue_empty__doc__,
|
|
"empty($self, /)\n"
|
|
"--\n"
|
|
"\n"
|
|
"Return True if the queue is empty, False otherwise (not reliable!).");
|
|
|
|
#define _QUEUE_SIMPLEQUEUE_EMPTY_METHODDEF \
|
|
{"empty", (PyCFunction)_queue_SimpleQueue_empty, METH_NOARGS, _queue_SimpleQueue_empty__doc__},
|
|
|
|
static int
|
|
_queue_SimpleQueue_empty_impl(simplequeueobject *self);
|
|
|
|
static PyObject *
|
|
_queue_SimpleQueue_empty(simplequeueobject *self, PyObject *Py_UNUSED(ignored))
|
|
{
|
|
PyObject *return_value = NULL;
|
|
int _return_value;
|
|
|
|
Py_BEGIN_CRITICAL_SECTION(self);
|
|
_return_value = _queue_SimpleQueue_empty_impl(self);
|
|
Py_END_CRITICAL_SECTION();
|
|
if ((_return_value == -1) && PyErr_Occurred()) {
|
|
goto exit;
|
|
}
|
|
return_value = PyBool_FromLong((long)_return_value);
|
|
|
|
exit:
|
|
return return_value;
|
|
}
|
|
|
|
PyDoc_STRVAR(_queue_SimpleQueue_qsize__doc__,
|
|
"qsize($self, /)\n"
|
|
"--\n"
|
|
"\n"
|
|
"Return the approximate size of the queue (not reliable!).");
|
|
|
|
#define _QUEUE_SIMPLEQUEUE_QSIZE_METHODDEF \
|
|
{"qsize", (PyCFunction)_queue_SimpleQueue_qsize, METH_NOARGS, _queue_SimpleQueue_qsize__doc__},
|
|
|
|
static Py_ssize_t
|
|
_queue_SimpleQueue_qsize_impl(simplequeueobject *self);
|
|
|
|
static PyObject *
|
|
_queue_SimpleQueue_qsize(simplequeueobject *self, PyObject *Py_UNUSED(ignored))
|
|
{
|
|
PyObject *return_value = NULL;
|
|
Py_ssize_t _return_value;
|
|
|
|
Py_BEGIN_CRITICAL_SECTION(self);
|
|
_return_value = _queue_SimpleQueue_qsize_impl(self);
|
|
Py_END_CRITICAL_SECTION();
|
|
if ((_return_value == -1) && PyErr_Occurred()) {
|
|
goto exit;
|
|
}
|
|
return_value = PyLong_FromSsize_t(_return_value);
|
|
|
|
exit:
|
|
return return_value;
|
|
}
|
|
/*[clinic end generated code: output=44a718f40072018a input=a9049054013a1b77]*/
|