summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorNeil Schemenauer <nascheme@enme.ucalgary.ca>2002-11-18 16:10:18 (GMT)
committerNeil Schemenauer <nascheme@enme.ucalgary.ca>2002-11-18 16:10:18 (GMT)
commitce30bc9f49dd77a9e6707eabaa1f3ceb8e6e458e (patch)
tree0928b8dd8215d4768baba0d4f3d671252f0a4cf9
parenta6cd4e65d7faef4928f86ad728c32dcf24b80fb5 (diff)
downloadcpython-ce30bc9f49dd77a9e6707eabaa1f3ceb8e6e458e.zip
cpython-ce30bc9f49dd77a9e6707eabaa1f3ceb8e6e458e.tar.gz
cpython-ce30bc9f49dd77a9e6707eabaa1f3ceb8e6e458e.tar.bz2
Add nb_remainder (i.e. __mod__) slot to unicode type. Fixes SF bug #615506.
-rw-r--r--Objects/unicodeobject.c23
1 files changed, 21 insertions, 2 deletions
diff --git a/Objects/unicodeobject.c b/Objects/unicodeobject.c
index 12846bf..8565fb1 100644
--- a/Objects/unicodeobject.c
+++ b/Objects/unicodeobject.c
@@ -5799,6 +5799,24 @@ static PyMethodDef unicode_methods[] = {
{NULL, NULL}
};
+static PyObject *
+unicode_mod(PyObject *v, PyObject *w)
+{
+ if (!PyUnicode_Check(v)) {
+ Py_INCREF(Py_NotImplemented);
+ return Py_NotImplemented;
+ }
+ return PyUnicode_Format(v, w);
+}
+
+static PyNumberMethods unicode_as_number = {
+ 0, /*nb_add*/
+ 0, /*nb_subtract*/
+ 0, /*nb_multiply*/
+ 0, /*nb_divide*/
+ unicode_mod, /*nb_remainder*/
+};
+
static PySequenceMethods unicode_as_sequence = {
(inquiry) unicode_length, /* sq_length */
(binaryfunc) PyUnicode_Concat, /* sq_concat */
@@ -6647,7 +6665,7 @@ PyTypeObject PyUnicode_Type = {
0, /* tp_setattr */
(cmpfunc) unicode_compare, /* tp_compare */
(reprfunc) unicode_repr, /* tp_repr */
- 0, /* tp_as_number */
+ &unicode_as_number, /* tp_as_number */
&unicode_as_sequence, /* tp_as_sequence */
&unicode_as_mapping, /* tp_as_mapping */
(hashfunc) unicode_hash, /* tp_hash*/
@@ -6656,7 +6674,8 @@ PyTypeObject PyUnicode_Type = {
PyObject_GenericGetAttr, /* tp_getattro */
0, /* tp_setattro */
&unicode_as_buffer, /* tp_as_buffer */
- Py_TPFLAGS_DEFAULT | Py_TPFLAGS_BASETYPE, /* tp_flags */
+ Py_TPFLAGS_DEFAULT | Py_TPFLAGS_CHECKTYPES |
+ Py_TPFLAGS_BASETYPE, /* tp_flags */
unicode_doc, /* tp_doc */
0, /* tp_traverse */
0, /* tp_clear */