diff options
author | Amaury Forgeot d'Arc <amauryfa@gmail.com> | 2008-01-10 21:59:42 (GMT) |
---|---|---|
committer | Amaury Forgeot d'Arc <amauryfa@gmail.com> | 2008-01-10 21:59:42 (GMT) |
commit | d08a8ebf2a8fe9705a48468c9280445afd1df324 (patch) | |
tree | 48c40584a370567a3426b115c588d1bdaecd507c /Lib/test/test_re.py | |
parent | e850c466c7dd25baac71997d6ca073e3586526b5 (diff) | |
download | cpython-d08a8ebf2a8fe9705a48468c9280445afd1df324.zip cpython-d08a8ebf2a8fe9705a48468c9280445afd1df324.tar.gz cpython-d08a8ebf2a8fe9705a48468c9280445afd1df324.tar.bz2 |
Closing issue1761.
Surprising behaviour of the "$" regexp: it matches the
end of the string, AND just before the newline at the end
of the string::
re.sub('$', '#', 'foo\n') == 'foo#\n#'
Python is consistent with Perl and the pcre library, so
we just document it.
Guido prefers "\Z" to match only the end of the string.
Diffstat (limited to 'Lib/test/test_re.py')
-rw-r--r-- | Lib/test/test_re.py | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/Lib/test/test_re.py b/Lib/test/test_re.py index 3056ef3..a2470cd 100644 --- a/Lib/test/test_re.py +++ b/Lib/test/test_re.py @@ -671,6 +671,18 @@ class ReTests(unittest.TestCase): q = p.match(upper_char) self.assertNotEqual(q, None) + def test_dollar_matches_twice(self): + "$ matches the end of string, and just before the terminating \n" + pattern = re.compile('$') + self.assertEqual(pattern.sub('#', 'a\nb\n'), 'a\nb#\n#') + self.assertEqual(pattern.sub('#', 'a\nb\nc'), 'a\nb\nc#') + self.assertEqual(pattern.sub('#', '\n'), '#\n#') + + pattern = re.compile('$', re.MULTILINE) + self.assertEqual(pattern.sub('#', 'a\nb\n' ), 'a#\nb#\n#' ) + self.assertEqual(pattern.sub('#', 'a\nb\nc'), 'a#\nb#\nc#') + self.assertEqual(pattern.sub('#', '\n'), '#\n#') + def run_re_tests(): from test.re_tests import benchmarks, tests, SUCCEED, FAIL, SYNTAX_ERROR |