summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlexis Hildebrandt <afh@surryhill.net>2022-10-01 20:32:41 +0200
committerMartin Michlmayr <tbm@cyrius.com>2022-10-02 10:19:52 +0800
commit401fede79815c3396b9a915622347424ef76ac8d (patch)
treec5e689618beddbed510b9851b4d713fa7e3aaa4b
parent1f79792ec824d1792f76c4ff6d47e32affab7c8a (diff)
downloadfork-ledger-401fede79815c3396b9a915622347424ef76ac8d.tar.gz
fork-ledger-401fede79815c3396b9a915622347424ef76ac8d.tar.bz2
fork-ledger-401fede79815c3396b9a915622347424ef76ac8d.zip
Handle return value of PyUnicode_READY
to ensure access macros are only called on "legacy" unicode string objects that are "ready". See https://docs.python.org/3/c-api/unicode.html#c.PyUnicode_READY
-rw-r--r--src/py_utils.cc3
1 files changed, 2 insertions, 1 deletions
diff --git a/src/py_utils.cc b/src/py_utils.cc
index cd44aa93..8765bb78 100644
--- a/src/py_utils.cc
+++ b/src/py_utils.cc
@@ -134,7 +134,8 @@ struct string_from_python
PyUnicode_GET_SIZE(obj_ptr);
#endif
#if PY_MINOR_VERSION < 12
- PyUnicode_READY(obj_ptr);
+ if (PyUnicode_READY(obj_ptr))
+ return;
#endif
switch (PyUnicode_KIND(obj_ptr)) {
case PyUnicode_1BYTE_KIND: {