X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/154747f5bea610a23748e439230c98d9513252e2..32b70aec1ff90877ae0ce2ce82967f698218fbdc:/wxPython/src/my_typemaps.i diff --git a/wxPython/src/my_typemaps.i b/wxPython/src/my_typemaps.i index 2a2b12e23b..cd202b68fd 100644 --- a/wxPython/src/my_typemaps.i +++ b/wxPython/src/my_typemaps.i @@ -16,7 +16,7 @@ %except(python) { PyThreadState* __tstate = wxPyBeginAllowThreads(); - $function +$function wxPyEndAllowThreads(__tstate); if (PyErr_Occurred()) return NULL; } @@ -151,63 +151,14 @@ //--------------------------------------------------------------------------- -%{ -#if PYTHON_API_VERSION >= 1009 - static char* wxStringErrorMsg = "String or Unicode type required"; -#else - static char* wxStringErrorMsg = "String type required"; -#endif -%} - -// TODO: Which works best??? - -// Implementation #1 -// %typemap(python, in) wxString& (PyObject* temp, int tmpDoDecRef) { -// temp = $source; -// tmpDoDecRef = 0; -// #if PYTHON_API_VERSION >= 1009 -// if (PyUnicode_Check(temp) { -// temp = PyUnicode_AsUTF8String(temp); -// if (! temp) { -// PyErr_SetString(PyExc_TypeError, "Unicode encoding to UTF8 failed."); -// return NULL; -// } -// tmpDoDecRef = 1; -// #endif -// if (!PyString_Check(temp)) { -// PyErr_SetString(PyExc_TypeError, wxStringErrorMsg); -// return NULL; -// } -// $target = new wxString(PyString_AsString(temp), PyString_Size(temp)); -// #if PYTHON_API_VERESION >= 1009 -// if (tmpDoDecRef) Py_DECREF(temp); -// #endif -// } - - -// Implementation #2 + %typemap(python, in) wxString& { -#if PYTHON_API_VERSION >= 1009 - char* tmpPtr; int tmpSize; - if (!PyString_Check($source) && !PyUnicode_Check($source)) { - PyErr_SetString(PyExc_TypeError, wxStringErrorMsg); - return NULL; - } - if (PyString_AsStringAndSize($source, &tmpPtr, &tmpSize) == -1) + $target = wxString_in_helper($source); + if ($target == NULL) return NULL; - $target = new wxString(tmpPtr, tmpSize); -#else - if (!PyString_Check($source)) { - PyErr_SetString(PyExc_TypeError, wxStringErrorMsg); - return NULL; - } - $target = new wxString(PyString_AS_STRING($source), PyString_GET_SIZE($source)); -#endif } - - %typemap(python, freearg) wxString& { if ($target) delete $source; @@ -216,7 +167,11 @@ %typemap(python, out) wxString { +#if wxUSE_UNICODE + $target = PyUnicode_FromUnicode($source->c_str(), $source->Len()); +#else $target = PyString_FromStringAndSize($source->c_str(), $source->Len()); +#endif } %typemap(python, ret) wxString { delete $source; @@ -224,11 +179,41 @@ %typemap(python, out) wxString* { +#if wxUSE_UNICODE + $target = PyUnicode_FromUnicode($source->c_str(), $source->Len()); +#else $target = PyString_FromStringAndSize($source->c_str(), $source->Len()); +#endif +} + + + +//--------------------------------------------------------------------------- + + +%typemap(python, in) wxMemoryBuffer& { + if (!PyString_Check($source)) { + PyErr_SetString(PyExc_TypeError, "String buffer expected"); + return NULL; + } + char* str = PyString_AS_STRING($source); + int len = PyString_GET_SIZE($source); + $target = new wxMemoryBuffer(len); + memcpy($target->GetData(), str, len); } +%typemap(python, freearg) wxMemoryBuffer& { + if ($target) + delete $source; +} +%typemap(python, out) wxMemoryBuffer { + $target = PyString_FromStringAndSize((char*)$source->GetData(), $source->GetDataLen()); +} +%typemap(python, ret) wxMemoryBuffer { + delete $source; +} //--------------------------------------------------------------------------- @@ -281,8 +266,13 @@ int i, len=PySequence_Length($source); for (i=0; iAdd(PyUnicode_AsUnicode(str)); +#else PyObject* str = PyObject_Str(item); $target->Add(PyString_AsString(str)); +#endif Py_DECREF(item); Py_DECREF(str); }