mirror of
https://github.com/python/cpython.git
synced 2025-08-05 01:18:26 +00:00

* [3.9] gh-133767: Fix use-after-free in the unicode-escape decoder with an error handler (GH-129648) (GH-133944) If the error handler is used, a new bytes object is created to set as the object attribute of UnicodeDecodeError, and that bytes object then replaces the original data. A pointer to the decoded data will became invalid after destroying that temporary bytes object. So we need other way to return the first invalid escape from _PyUnicode_DecodeUnicodeEscapeInternal(). _PyBytes_DecodeEscape() does not have such issue, because it does not use the error handlers registry, but it should be changed for compatibility with _PyUnicode_DecodeUnicodeEscapeInternal(). (cherry picked from commit9f69a58623
) (cherry picked from commit6279eb8c07
) (cherry picked from commita75953b347
) (cherry picked from commit0c33e5baed
) (cherry picked from commit8b528cacbb
) Co-authored-by: Serhiy Storchaka <storchaka@gmail.com>
2 lines
86 B
ReStructuredText
2 lines
86 B
ReStructuredText
Fix use-after-free in the "unicode-escape" decoder with a non-"strict" error
|
|
handler.
|