summaryrefslogtreecommitdiffstats
path: root/Python
diff options
context:
space:
mode:
authorwmeehan <wmeehan@users.noreply.github.com>2020-08-27 05:45:25 (GMT)
committerGitHub <noreply@github.com>2020-08-27 05:45:25 (GMT)
commit97eaf2b5e5c826b9abe59896a363853bef55c5d9 (patch)
tree6c9743b196087bd35722f08aec8c7aaa12d3aed7 /Python
parent022bc7572f061e1d1132a4db9d085b29707701e7 (diff)
downloadcpython-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.c18
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));
}