diff options
author | Victor Stinner <vstinner@wyplay.com> | 2011-10-07 08:01:28 (GMT) |
---|---|---|
committer | Victor Stinner <vstinner@wyplay.com> | 2011-10-07 08:01:28 (GMT) |
commit | 59de0ee9e087a819a0a63b31c1391c6eee55b8ef (patch) | |
tree | a460b0d2c099e04b6dbc661c90227fe3daa30d3d | |
parent | 72ca65dce4529906b64710e94a3c004f9cc2712f (diff) | |
download | cpython-59de0ee9e087a819a0a63b31c1391c6eee55b8ef.zip cpython-59de0ee9e087a819a0a63b31c1391c6eee55b8ef.tar.gz cpython-59de0ee9e087a819a0a63b31c1391c6eee55b8ef.tar.bz2 |
str.replace(a, a) is now returning str unchanged if a is a
-rw-r--r-- | Lib/test/test_unicode.py | 6 | ||||
-rw-r--r-- | Objects/unicodeobject.c | 2 |
2 files changed, 8 insertions, 0 deletions
diff --git a/Lib/test/test_unicode.py b/Lib/test/test_unicode.py index 870853e..14d3fa6 100644 --- a/Lib/test/test_unicode.py +++ b/Lib/test/test_unicode.py @@ -275,6 +275,12 @@ class UnicodeTest(string_tests.CommonTest, self.checkequalnofix('one@two!three!', 'one!two!three!', 'replace', '!', '@', 1) self.assertRaises(TypeError, 'replace'.replace, "r", 42) + @support.cpython_only + def test_replace_id(self): + a = 'a' # single ascii letters are singletons + text = 'abc' + self.assertIs(text.replace('a', 'a'), text) + def test_bytes_comparison(self): with support.check_warnings(): warnings.simplefilter('ignore', BytesWarning) diff --git a/Objects/unicodeobject.c b/Objects/unicodeobject.c index caad326..8608776 100644 --- a/Objects/unicodeobject.c +++ b/Objects/unicodeobject.c @@ -9604,6 +9604,8 @@ replace(PyObject *self, PyObject *str1, else if (maxcount == 0 || slen == 0) goto nothing; + if (str1 == str2) + goto nothing; if (skind < kind1) /* substring too wide to be present */ goto nothing; |