diff options
author | Marc-André Lemburg <mal@egenix.com> | 2000-06-18 22:25:22 (GMT) |
---|---|---|
committer | Marc-André Lemburg <mal@egenix.com> | 2000-06-18 22:25:22 (GMT) |
commit | 49ef6dc1f44c6d831fdd5c127b424cb5ecef2b78 (patch) | |
tree | 5702c4ebea5d4f5cafe663f460469bb5f5f48a77 /Objects/unicodeobject.c | |
parent | 2f4d0e9bb6a1988b59274bd6db980b214fb17d23 (diff) | |
download | cpython-49ef6dc1f44c6d831fdd5c127b424cb5ecef2b78.zip cpython-49ef6dc1f44c6d831fdd5c127b424cb5ecef2b78.tar.gz cpython-49ef6dc1f44c6d831fdd5c127b424cb5ecef2b78.tar.bz2 |
Marc-Andre Lemburg <mal@lemburg.com>:
Fixed a bug in PyUnicode_Count() which would have caused a
core dump in case of substring coercion failure.
Synchronized .count() with the string method of the same name
to return len(s)+1 for s.count('').
Diffstat (limited to 'Objects/unicodeobject.c')
-rw-r--r-- | Objects/unicodeobject.c | 10 |
1 files changed, 4 insertions, 6 deletions
diff --git a/Objects/unicodeobject.c b/Objects/unicodeobject.c index e6d2a1a..3157cd8 100644 --- a/Objects/unicodeobject.c +++ b/Objects/unicodeobject.c @@ -2106,6 +2106,9 @@ int count(PyUnicodeObject *self, { int count = 0; + if (substring->length == 0) + return (end - start + 1); + end -= substring->length; while (start <= end) @@ -2130,7 +2133,7 @@ int PyUnicode_Count(PyObject *str, return -1; substr = PyUnicode_FromObject(substr); if (substr == NULL) { - Py_DECREF(substr); + Py_DECREF(str); return -1; } @@ -3086,11 +3089,6 @@ unicode_count(PyUnicodeObject *self, PyObject *args) if (substring == NULL) return NULL; - if (substring->length == 0) { - Py_DECREF(substring); - return PyInt_FromLong((long) 0); - } - if (start < 0) start += self->length; if (start < 0) |