diff options
author | Victor Stinner <victor.stinner@gmail.com> | 2016-11-22 14:30:53 (GMT) |
---|---|---|
committer | Victor Stinner <victor.stinner@gmail.com> | 2016-11-22 14:30:53 (GMT) |
commit | 0b87b69a6e5db7b3ddd4590439af6142dbc7bd7f (patch) | |
tree | 890f2b17e9b160c9877d8e7a02d4a877e50161aa | |
parent | 9ad8a639f37ded33154da1b12cddd46ab764495b (diff) | |
parent | bcf4dccfa77df6fd75181e2a7cbfbf2d4b2c6255 (diff) | |
download | cpython-0b87b69a6e5db7b3ddd4590439af6142dbc7bd7f.zip cpython-0b87b69a6e5db7b3ddd4590439af6142dbc7bd7f.tar.gz cpython-0b87b69a6e5db7b3ddd4590439af6142dbc7bd7f.tar.bz2 |
Merge 3.6
-rw-r--r-- | Lib/test/test_re.py | 4 | ||||
-rw-r--r-- | Modules/_sre.c | 8 |
2 files changed, 11 insertions, 1 deletions
diff --git a/Lib/test/test_re.py b/Lib/test/test_re.py index 4fcd2d4..84131d2 100644 --- a/Lib/test/test_re.py +++ b/Lib/test/test_re.py @@ -1781,6 +1781,10 @@ SUBPATTERN None 0 0 def test_pattern_compare(self): pattern1 = re.compile('abc', re.IGNORECASE) + # equal to itself + self.assertEqual(pattern1, pattern1) + self.assertFalse(pattern1 != pattern1) + # equal re.purge() pattern2 = re.compile('abc', re.IGNORECASE) diff --git a/Modules/_sre.c b/Modules/_sre.c index c1e9fa6..979e61f 100644 --- a/Modules/_sre.c +++ b/Modules/_sre.c @@ -2683,12 +2683,18 @@ pattern_richcompare(PyObject *lefto, PyObject *righto, int op) if (Py_TYPE(lefto) != &Pattern_Type || Py_TYPE(righto) != &Pattern_Type) { Py_RETURN_NOTIMPLEMENTED; } + + if (lefto == righto) { + /* a pattern is equal to itself */ + return PyBool_FromLong(op == Py_EQ); + } + left = (PatternObject *)lefto; right = (PatternObject *)righto; cmp = (left->flags == right->flags && left->isbytes == right->isbytes - && left->codesize && right->codesize); + && left->codesize == right->codesize); if (cmp) { /* Compare the code and the pattern because the same pattern can produce different codes depending on the locale used to compile the |