Commit 92c4bef7 authored by Serhiy Storchaka's avatar Serhiy Storchaka

Issue #28701: _PyUnicode_EqualToASCIIId and _PyUnicode_EqualToASCIIString now

require ASCII right argument and assert this condition in debug build.
parent db1e269f
...@@ -2038,7 +2038,7 @@ PyAPI_FUNC(int) PyUnicode_Compare( ...@@ -2038,7 +2038,7 @@ PyAPI_FUNC(int) PyUnicode_Compare(
#ifndef Py_LIMITED_API #ifndef Py_LIMITED_API
/* Test whether a unicode is equal to ASCII identifier. Return 1 if true, /* Test whether a unicode is equal to ASCII identifier. Return 1 if true,
0 otherwise. Return 0 if any argument contains non-ASCII characters. 0 otherwise. The right argument must be ASCII identifier.
Any error occurs inside will be cleared before return. */ Any error occurs inside will be cleared before return. */
PyAPI_FUNC(int) _PyUnicode_EqualToASCIIId( PyAPI_FUNC(int) _PyUnicode_EqualToASCIIId(
...@@ -2060,7 +2060,7 @@ PyAPI_FUNC(int) PyUnicode_CompareWithASCIIString( ...@@ -2060,7 +2060,7 @@ PyAPI_FUNC(int) PyUnicode_CompareWithASCIIString(
#ifndef Py_LIMITED_API #ifndef Py_LIMITED_API
/* Test whether a unicode is equal to ASCII string. Return 1 if true, /* Test whether a unicode is equal to ASCII string. Return 1 if true,
0 otherwise. Return 0 if any argument contains non-ASCII characters. 0 otherwise. The right argument must be ASCII-encoded string.
Any error occurs inside will be cleared before return. */ Any error occurs inside will be cleared before return. */
PyAPI_FUNC(int) _PyUnicode_EqualToASCIIString( PyAPI_FUNC(int) _PyUnicode_EqualToASCIIString(
......
...@@ -11081,6 +11081,12 @@ _PyUnicode_EqualToASCIIString(PyObject *unicode, const char *str) ...@@ -11081,6 +11081,12 @@ _PyUnicode_EqualToASCIIString(PyObject *unicode, const char *str)
{ {
size_t len; size_t len;
assert(_PyUnicode_CHECK(unicode)); assert(_PyUnicode_CHECK(unicode));
assert(str);
#ifndef NDEBUG
for (const char *p = str; *p; p++) {
assert((unsigned char)*p < 128);
}
#endif
if (PyUnicode_READY(unicode) == -1) { if (PyUnicode_READY(unicode) == -1) {
/* Memory error or bad data */ /* Memory error or bad data */
PyErr_Clear(); PyErr_Clear();
...@@ -11101,6 +11107,11 @@ _PyUnicode_EqualToASCIIId(PyObject *left, _Py_Identifier *right) ...@@ -11101,6 +11107,11 @@ _PyUnicode_EqualToASCIIId(PyObject *left, _Py_Identifier *right)
assert(_PyUnicode_CHECK(left)); assert(_PyUnicode_CHECK(left));
assert(right->string); assert(right->string);
#ifndef NDEBUG
for (const char *p = right->string; *p; p++) {
assert((unsigned char)*p < 128);
}
#endif
if (PyUnicode_READY(left) == -1) { if (PyUnicode_READY(left) == -1) {
/* memory error or bad data */ /* memory error or bad data */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment