blob: 0e5092cf7a9168a25dfc815cd982f13280988791 [file] [log] [blame]
Victor Stinnerb05cbac2017-01-17 03:46:13 +01001/*[clinic input]
2preserve
3[clinic start generated code]*/
4
5PyDoc_STRVAR(OrderedDict_fromkeys__doc__,
6"fromkeys($type, /, iterable, value=None)\n"
7"--\n"
8"\n"
Serhiy Storchaka78d9e582017-01-25 00:30:04 +02009"Create a new ordered dictionary with keys from iterable and values set to value.");
Victor Stinnerb05cbac2017-01-17 03:46:13 +010010
11#define ORDEREDDICT_FROMKEYS_METHODDEF \
12 {"fromkeys", (PyCFunction)OrderedDict_fromkeys, METH_FASTCALL|METH_CLASS, OrderedDict_fromkeys__doc__},
13
14static PyObject *
15OrderedDict_fromkeys_impl(PyTypeObject *type, PyObject *seq, PyObject *value);
16
17static PyObject *
18OrderedDict_fromkeys(PyTypeObject *type, PyObject **args, Py_ssize_t nargs, PyObject *kwnames)
19{
20 PyObject *return_value = NULL;
21 static const char * const _keywords[] = {"iterable", "value", NULL};
22 static _PyArg_Parser _parser = {"O|O:fromkeys", _keywords, 0};
23 PyObject *seq;
24 PyObject *value = Py_None;
25
26 if (!_PyArg_ParseStackAndKeywords(args, nargs, kwnames, &_parser,
27 &seq, &value)) {
28 goto exit;
29 }
30 return_value = OrderedDict_fromkeys_impl(type, seq, value);
31
32exit:
33 return return_value;
34}
35
36PyDoc_STRVAR(OrderedDict_setdefault__doc__,
37"setdefault($self, /, key, default=None)\n"
38"--\n"
39"\n"
Serhiy Storchaka78d9e582017-01-25 00:30:04 +020040"Insert key with a value of default if key is not in the dictionary.\n"
41"\n"
42"Return the value for key if key is in the dictionary, else default.");
Victor Stinnerb05cbac2017-01-17 03:46:13 +010043
44#define ORDEREDDICT_SETDEFAULT_METHODDEF \
45 {"setdefault", (PyCFunction)OrderedDict_setdefault, METH_FASTCALL, OrderedDict_setdefault__doc__},
46
47static PyObject *
48OrderedDict_setdefault_impl(PyODictObject *self, PyObject *key,
Serhiy Storchakaa70eaf22017-01-19 19:38:13 +020049 PyObject *default_value);
Victor Stinnerb05cbac2017-01-17 03:46:13 +010050
51static PyObject *
52OrderedDict_setdefault(PyODictObject *self, PyObject **args, Py_ssize_t nargs, PyObject *kwnames)
53{
54 PyObject *return_value = NULL;
55 static const char * const _keywords[] = {"key", "default", NULL};
56 static _PyArg_Parser _parser = {"O|O:setdefault", _keywords, 0};
57 PyObject *key;
Serhiy Storchakaa70eaf22017-01-19 19:38:13 +020058 PyObject *default_value = Py_None;
Victor Stinnerb05cbac2017-01-17 03:46:13 +010059
60 if (!_PyArg_ParseStackAndKeywords(args, nargs, kwnames, &_parser,
Serhiy Storchakaa70eaf22017-01-19 19:38:13 +020061 &key, &default_value)) {
Victor Stinnerb05cbac2017-01-17 03:46:13 +010062 goto exit;
63 }
Serhiy Storchakaa70eaf22017-01-19 19:38:13 +020064 return_value = OrderedDict_setdefault_impl(self, key, default_value);
Victor Stinnerb05cbac2017-01-17 03:46:13 +010065
66exit:
67 return return_value;
68}
69
70PyDoc_STRVAR(OrderedDict_popitem__doc__,
71"popitem($self, /, last=True)\n"
72"--\n"
73"\n"
Serhiy Storchaka78d9e582017-01-25 00:30:04 +020074"Remove and return a (key, value) pair from the dictionary.\n"
Victor Stinnerb05cbac2017-01-17 03:46:13 +010075"\n"
76"Pairs are returned in LIFO order if last is true or FIFO order if false.");
77
78#define ORDEREDDICT_POPITEM_METHODDEF \
79 {"popitem", (PyCFunction)OrderedDict_popitem, METH_FASTCALL, OrderedDict_popitem__doc__},
80
81static PyObject *
82OrderedDict_popitem_impl(PyODictObject *self, int last);
83
84static PyObject *
85OrderedDict_popitem(PyODictObject *self, PyObject **args, Py_ssize_t nargs, PyObject *kwnames)
86{
87 PyObject *return_value = NULL;
88 static const char * const _keywords[] = {"last", NULL};
89 static _PyArg_Parser _parser = {"|p:popitem", _keywords, 0};
90 int last = 1;
91
92 if (!_PyArg_ParseStackAndKeywords(args, nargs, kwnames, &_parser,
93 &last)) {
94 goto exit;
95 }
96 return_value = OrderedDict_popitem_impl(self, last);
97
98exit:
99 return return_value;
100}
101
102PyDoc_STRVAR(OrderedDict_move_to_end__doc__,
103"move_to_end($self, /, key, last=True)\n"
104"--\n"
105"\n"
Serhiy Storchaka78d9e582017-01-25 00:30:04 +0200106"Move an existing element to the end (or beginning if last is false).\n"
Victor Stinnerb05cbac2017-01-17 03:46:13 +0100107"\n"
Serhiy Storchaka78d9e582017-01-25 00:30:04 +0200108"Raise KeyError if the element does not exist.");
Victor Stinnerb05cbac2017-01-17 03:46:13 +0100109
110#define ORDEREDDICT_MOVE_TO_END_METHODDEF \
111 {"move_to_end", (PyCFunction)OrderedDict_move_to_end, METH_FASTCALL, OrderedDict_move_to_end__doc__},
112
113static PyObject *
114OrderedDict_move_to_end_impl(PyODictObject *self, PyObject *key, int last);
115
116static PyObject *
117OrderedDict_move_to_end(PyODictObject *self, PyObject **args, Py_ssize_t nargs, PyObject *kwnames)
118{
119 PyObject *return_value = NULL;
120 static const char * const _keywords[] = {"key", "last", NULL};
121 static _PyArg_Parser _parser = {"O|p:move_to_end", _keywords, 0};
122 PyObject *key;
123 int last = 1;
124
125 if (!_PyArg_ParseStackAndKeywords(args, nargs, kwnames, &_parser,
126 &key, &last)) {
127 goto exit;
128 }
129 return_value = OrderedDict_move_to_end_impl(self, key, last);
130
131exit:
132 return return_value;
133}
Serhiy Storchaka78d9e582017-01-25 00:30:04 +0200134/*[clinic end generated code: output=a19a24ac37b42e5e input=a9049054013a1b77]*/