Check for errors after unicode conversions

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@26631 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Robin Dunn
2004-04-06 05:37:20 +00:00
parent af34abed9c
commit 3eb1aad7ec
2 changed files with 41 additions and 61 deletions

View File

@@ -1830,34 +1830,28 @@ long wxPyGetWinHandle(wxWindow* win) {
// Some helper functions for typemaps in my_typemaps.i, so they won't be // Some helper functions for typemaps in my_typemaps.i, so they won't be
// included in every file over and over again... // included in every file over and over again...
#if PYTHON_API_VERSION >= 1009
static char* wxStringErrorMsg = "String or Unicode type required";
#else
static char* wxStringErrorMsg = "String type required";
#endif
wxString* wxString_in_helper(PyObject* source) { wxString* wxString_in_helper(PyObject* source) {
wxString* target; wxString* target = NULL;
#if PYTHON_API_VERSION >= 1009 // Have Python unicode API
if (!PyString_Check(source) && !PyUnicode_Check(source)) { if (!PyString_Check(source) && !PyUnicode_Check(source)) {
PyErr_SetString(PyExc_TypeError, wxStringErrorMsg); PyErr_SetString(PyExc_TypeError, "String or Unicode type required");
return NULL; return NULL;
} }
#if wxUSE_UNICODE #if wxUSE_UNICODE
if (PyUnicode_Check(source)) { PyObject* uni = source;
target = new wxString(); if (PyString_Check(source)) {
size_t len = PyUnicode_GET_SIZE(source); uni = PyUnicode_FromObject(source);
if (len) { if (PyErr_Occurred()) return NULL;
PyUnicode_AsWideChar((PyUnicodeObject*)source, target->GetWriteBuf(len), len);
target->UngetWriteBuf();
}
} else {
// It is a string, get pointers to it and transform to unicode
char* tmpPtr; int tmpSize;
PyString_AsStringAndSize(source, &tmpPtr, &tmpSize);
target = new wxString(tmpPtr, *wxConvCurrent, tmpSize);
} }
target = new wxString();
size_t len = PyUnicode_GET_SIZE(uni);
if (len) {
PyUnicode_AsWideChar((PyUnicodeObject*)uni, target->GetWriteBuf(len), len);
target->UngetWriteBuf();
}
if (PyString_Check(source))
Py_DECREF(uni);
#else #else
char* tmpPtr; int tmpSize; char* tmpPtr; int tmpSize;
if (PyString_AsStringAndSize(source, &tmpPtr, &tmpSize) == -1) { if (PyString_AsStringAndSize(source, &tmpPtr, &tmpSize) == -1) {
@@ -1866,14 +1860,7 @@ wxString* wxString_in_helper(PyObject* source) {
} }
target = new wxString(tmpPtr, tmpSize); target = new wxString(tmpPtr, tmpSize);
#endif // wxUSE_UNICODE #endif // wxUSE_UNICODE
#else // No Python unicode API (1.5.2)
if (!PyString_Check(source)) {
PyErr_SetString(PyExc_TypeError, wxStringErrorMsg);
return NULL;
}
target = new wxString(PyString_AS_STRING(source), PyString_GET_SIZE(source));
#endif
return target; return target;
} }
@@ -1882,45 +1869,37 @@ wxString* wxString_in_helper(PyObject* source) {
wxString Py2wxString(PyObject* source) wxString Py2wxString(PyObject* source)
{ {
wxString target; wxString target;
bool doDecRef = False;
#if PYTHON_API_VERSION >= 1009 // Have Python unicode API
if (!PyString_Check(source) && !PyUnicode_Check(source)) {
// Convert to String if not one already... (TODO: Unicode too?)
source = PyObject_Str(source);
doDecRef = True;
}
#if wxUSE_UNICODE #if wxUSE_UNICODE
if (PyUnicode_Check(source)) { // Convert to a unicode object, if not already, then to a wxString
size_t len = PyUnicode_GET_SIZE(source); PyObject* uni = source;
if (len) { if (!PyUnicode_Check(source)) {
PyUnicode_AsWideChar((PyUnicodeObject*)source, target.GetWriteBuf(len), len); uni = PyUnicode_FromObject(source);
target.UngetWriteBuf(); if (PyErr_Occurred()) return wxEmptyString; // TODO: should we PyErr_Clear?
} }
} else { size_t len = PyUnicode_GET_SIZE(uni);
// It is a string, get pointers to it and transform to unicode if (len) {
char* tmpPtr; int tmpSize; PyUnicode_AsWideChar((PyUnicodeObject*)uni, target.GetWriteBuf(len), len);
PyString_AsStringAndSize(source, &tmpPtr, &tmpSize); target.UngetWriteBuf();
target = wxString(tmpPtr, *wxConvCurrent, tmpSize);
} }
if (!PyUnicode_Check(source))
Py_DECREF(uni);
#else #else
// Convert to a string object if it isn't already, then to wxString
PyObject* str = source;
if (!PyString_Check(source)) {
str = PyObject_Str(source);
if (PyErr_Occurred()) return wxEmptyString; // TODO: should we PyErr_Clear?
}
char* tmpPtr; int tmpSize; char* tmpPtr; int tmpSize;
PyString_AsStringAndSize(source, &tmpPtr, &tmpSize); PyString_AsStringAndSize(str, &tmpPtr, &tmpSize);
target = wxString(tmpPtr, tmpSize); target = wxString(tmpPtr, tmpSize);
if (!PyString_Check(source))
Py_DECREF(str);
#endif // wxUSE_UNICODE #endif // wxUSE_UNICODE
#else // No Python unicode API (1.5.2)
if (!PyString_Check(source)) {
// Convert to String if not one already...
source = PyObject_Str(source);
doDecRef = True;
}
target = wxString(PyString_AS_STRING(source), PyString_GET_SIZE(source));
#endif
if (doDecRef)
Py_DECREF(source);
return target; return target;
} }

View File

@@ -197,6 +197,7 @@
%#else %#else
PyObject* str = PyObject_Str(item); PyObject* str = PyObject_Str(item);
%#endif %#endif
if (PyErr_Occurred()) SWIG_fail;
$1->Add(Py2wxString(str)); $1->Add(Py2wxString(str));
Py_DECREF(item); Py_DECREF(item);
Py_DECREF(str); Py_DECREF(str);