These were just an artifact of the old unicode concatenation hack and likely
just penalized other kinds of adding. Also, this fixes __(i)add__ on string
subclasses.
self.assertEqual(size, nchar)
self.assertEqual(wchar, nonbmp + '\0')
+ def test_subclass_add(self):
+ class S(str):
+ def __add__(self, o):
+ return "3"
+ self.assertEqual(S("4") + S("5"), "3")
+ class S(str):
+ def __iadd__(self, o):
+ return "3"
+ s = S("1")
+ s += "4"
+ self.assertEqual(s, "3")
+
class StringModuleTest(unittest.TestCase):
def test_formatter_parser(self):
TARGET(BINARY_ADD)
w = POP();
v = TOP();
- if (PyUnicode_Check(v) && PyUnicode_Check(w))
- x = PyUnicode_Concat(v, w);
- else
- x = PyNumber_Add(v, w);
+ x = PyNumber_Add(v, w);
Py_DECREF(v);
Py_DECREF(w);
SET_TOP(x);
TARGET(INPLACE_ADD)
w = POP();
v = TOP();
- if (PyUnicode_Check(v) && PyUnicode_Check(w))
- x = PyUnicode_Concat(v, w);
- else
- x = PyNumber_InPlaceAdd(v, w);
+ x = PyNumber_InPlaceAdd(v, w);
Py_DECREF(v);
Py_DECREF(w);
SET_TOP(x);