diff options
author | Marc-André Lemburg <mal@egenix.com> | 2001-01-29 11:14:16 (GMT) |
---|---|---|
committer | Marc-André Lemburg <mal@egenix.com> | 2001-01-29 11:14:16 (GMT) |
commit | fde66e1bcc4431a59f36bad0ca0dd7a848ce794b (patch) | |
tree | 6f8050abb89c2c8ad8cec8c24b06b31ee037221d | |
parent | 30be8708c544f1b6a0ebacf856915830c6b36d39 (diff) | |
download | cpython-fde66e1bcc4431a59f36bad0ca0dd7a848ce794b.zip cpython-fde66e1bcc4431a59f36bad0ca0dd7a848ce794b.tar.gz cpython-fde66e1bcc4431a59f36bad0ca0dd7a848ce794b.tar.bz2 |
Fixed .capitalize() method of Unicode objects to work like the
corresponding string method. Added tests for this too.
Patch written by Marc-Andre Lemburg. Copyright assigned to Guido van Rossum.
-rw-r--r-- | Lib/test/string_tests.py | 2 | ||||
-rw-r--r-- | Lib/test/test_unicode.py | 2 | ||||
-rw-r--r-- | Objects/unicodeobject.c | 22 |
3 files changed, 22 insertions, 4 deletions
diff --git a/Lib/test/string_tests.py b/Lib/test/string_tests.py index c3010d6..2e912c8 100644 --- a/Lib/test/string_tests.py +++ b/Lib/test/string_tests.py @@ -53,6 +53,8 @@ def run_method_tests(test): test('capitalize', ' hello ', ' hello ') test('capitalize', 'hello ', 'Hello ') + test('capitalize', 'aaaa', 'Aaaa') + test('capitalize', 'AaAa', 'Aaaa') test('count', 'aaa', 3, 'a') test('count', 'aaa', 0, 'b') diff --git a/Lib/test/test_unicode.py b/Lib/test/test_unicode.py index 855b0a2..2a24255 100644 --- a/Lib/test/test_unicode.py +++ b/Lib/test/test_unicode.py @@ -31,6 +31,8 @@ def test(method, input, output, *args): test('capitalize', u' hello ', u' hello ') test('capitalize', u'hello ', u'Hello ') +test('capitalize', u'aaaa', u'Aaaa') +test('capitalize', u'AaAa', u'Aaaa') test('count', u'aaa', 3, u'a') test('count', u'aaa', 0, u'b') diff --git a/Objects/unicodeobject.c b/Objects/unicodeobject.c index 5c193dd..7b12594 100644 --- a/Objects/unicodeobject.c +++ b/Objects/unicodeobject.c @@ -2631,11 +2631,25 @@ int fixswapcase(PyUnicodeObject *self) static int fixcapitalize(PyUnicodeObject *self) { - if (self->length > 0 && Py_UNICODE_ISLOWER(self->str[0])) { - self->str[0] = Py_UNICODE_TOUPPER(self->str[0]); - return 1; + int len = self->length; + Py_UNICODE *s = self->str; + int status = 0; + + if (len == 0) + return 0; + if (Py_UNICODE_ISLOWER(*s)) { + *s = Py_UNICODE_TOUPPER(*s); + status = 1; } - return 0; + s++; + while (--len > 0) { + if (Py_UNICODE_ISUPPER(*s)) { + *s = Py_UNICODE_TOLOWER(*s); + status = 1; + } + s++; + } + return status; } static |