diff options
author | wmeehan <wmeehan@users.noreply.github.com> | 2020-08-27 05:45:25 (GMT) |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-08-27 05:45:25 (GMT) |
commit | 97eaf2b5e5c826b9abe59896a363853bef55c5d9 (patch) | |
tree | 6c9743b196087bd35722f08aec8c7aaa12d3aed7 /Python | |
parent | 022bc7572f061e1d1132a4db9d085b29707701e7 (diff) | |
download | cpython-97eaf2b5e5c826b9abe59896a363853bef55c5d9.zip cpython-97eaf2b5e5c826b9abe59896a363853bef55c5d9.tar.gz cpython-97eaf2b5e5c826b9abe59896a363853bef55c5d9.tar.bz2 |
bpo-41524: fix pointer bug in PyOS_mystr{n}icmp (GH-21845)
* bpo-41524: fix pointer bug in PyOS_mystr{n}icmp
The existing implementations of PyOS_mystrnicmp and PyOS_mystricmp
can increment pointers beyond the end of a string.
This commit fixes those cases by moving the mutation out of the condition.
* 📜🤖 Added by blurb_it.
* Address comments
Co-authored-by: blurb-it[bot] <43283697+blurb-it[bot]@users.noreply.github.com>
Diffstat (limited to 'Python')
-rw-r--r-- | Python/pystrcmp.c | 18 |
1 files changed, 11 insertions, 7 deletions
diff --git a/Python/pystrcmp.c b/Python/pystrcmp.c index f9c2277..9224ce4 100644 --- a/Python/pystrcmp.c +++ b/Python/pystrcmp.c @@ -6,21 +6,25 @@ int PyOS_mystrnicmp(const char *s1, const char *s2, Py_ssize_t size) { + const unsigned char *p1, *p2; if (size == 0) return 0; - while ((--size > 0) && - (tolower((unsigned)*s1) == tolower((unsigned)*s2))) { - if (!*s1++ || !*s2++) - break; + p1 = (const unsigned char *)s1; + p2 = (const unsigned char *)s2; + for (; (--size > 0) && *p1 && *p2 && (tolower(*p1) == tolower(*p2)); + p1++, p2++) { + ; } - return tolower((unsigned)*s1) - tolower((unsigned)*s2); + return tolower(*p1) - tolower(*p2); } int PyOS_mystricmp(const char *s1, const char *s2) { - while (*s1 && (tolower((unsigned)*s1++) == tolower((unsigned)*s2++))) { + const unsigned char *p1 = (const unsigned char *)s1; + const unsigned char *p2 = (const unsigned char *)s2; + for (; *p1 && *p2 && (tolower(*p1) == tolower(*p2)); p1++, p2++) { ; } - return (tolower((unsigned)*s1) - tolower((unsigned)*s2)); + return (tolower(*p1) - tolower(*p2)); } |