mirror of
https://foundry.openuru.org/gitblit/r/CWE-ou-minkata.git
synced 2025-07-13 18:17:49 -04:00
More efficient form for PyString_AsStringEx
This commit is contained in:
@ -49,14 +49,18 @@ plString PyString_AsStringEx(PyObject* obj)
|
||||
{
|
||||
if (PyString_Check(obj))
|
||||
return plString::FromUtf8(PyString_AsString(obj));
|
||||
else if (PyUnicode_Check(obj))
|
||||
{
|
||||
PyObject* utf8 = PyUnicode_AsUTF8String(obj);
|
||||
plString str = plString::FromUtf8(PyString_AsString(utf8));
|
||||
Py_DECREF(utf8);
|
||||
return str;
|
||||
} else
|
||||
return plString::Null;
|
||||
|
||||
if (PyUnicode_Check(obj)) {
|
||||
#if (Py_UNICODE_SIZE == 2)
|
||||
return plString::FromUtf16(reinterpret_cast<const uint16_t *>(PyUnicode_AsUnicode(obj)));
|
||||
#elif (Py_UNICODE_SIZE == 4)
|
||||
return plString::FromUtf32(reinterpret_cast<const UniChar *>(PyUnicode_AsUnicode(obj)));
|
||||
#else
|
||||
# error "Py_UNICODE is an unexpected size"
|
||||
#endif
|
||||
}
|
||||
|
||||
return plString::Null;
|
||||
}
|
||||
|
||||
bool PyString_CheckEx(PyObject* obj)
|
||||
|
Reference in New Issue
Block a user