[Python-checkins] bpo-41524: fix pointer bug in PyOS_mystr{n}icmp (GH-21845) (GH-22016)
Miss Islington (bot)
webhook-mailer at python.org
Sun Aug 30 03:20:44 EDT 2020
https://github.com/python/cpython/commit/85ca9c049c5a490d143d28933bbb02ab80394ed8
commit: 85ca9c049c5a490d143d28933bbb02ab80394ed8
branch: 3.8
author: Miss Islington (bot) <31488909+miss-islington at users.noreply.github.com>
committer: GitHub <noreply at github.com>
date: 2020-08-30T16:20:40+09:00
summary:
bpo-41524: fix pointer bug in PyOS_mystr{n}icmp (GH-21845) (GH-22016)
files:
A Misc/NEWS.d/next/C API/2020-08-12-17-09-06.bpo-41524.u6Xfr2.rst
M Python/pystrcmp.c
diff --git a/Misc/NEWS.d/next/C API/2020-08-12-17-09-06.bpo-41524.u6Xfr2.rst b/Misc/NEWS.d/next/C API/2020-08-12-17-09-06.bpo-41524.u6Xfr2.rst
new file mode 100644
index 0000000000000..4704e29be29bb
--- /dev/null
+++ b/Misc/NEWS.d/next/C API/2020-08-12-17-09-06.bpo-41524.u6Xfr2.rst
@@ -0,0 +1,2 @@
+Fix bug in PyOS_mystrnicmp and PyOS_mystricmp that incremented
+pointers beyond the end of a string.
\ No newline at end of file
diff --git a/Python/pystrcmp.c b/Python/pystrcmp.c
index f9c2277cb56dc..9224ce4c70605 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));
}
More information about the Python-checkins
mailing list