From 6fa9e4614d2cd159825b29d23ef31ad91487d83a Mon Sep 17 00:00:00 2001 From: Robin Dunn Date: Sat, 7 Feb 2004 00:47:53 +0000 Subject: [PATCH] Put the wxMemoryBuffer typemaps back git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@25543 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775 --- wxPython/src/my_typemaps.i | 25 ++++++++++++++++++++++++- 1 file changed, 24 insertions(+), 1 deletion(-) diff --git a/wxPython/src/my_typemaps.i b/wxPython/src/my_typemaps.i index 1a7634c1f3..968ff7a26b 100644 --- a/wxPython/src/my_typemaps.i +++ b/wxPython/src/my_typemaps.i @@ -90,7 +90,30 @@ $1 = PyString_Check($input) || PyUnicode_Check($input); } - +//--------------------------------------------------------------------------- +// wxMemoryBuffer (needed for wxSTC) + +%typemap(in) wxMemoryBuffer& (bool temp=False) { + if (!PyString_Check($input)) { + PyErr_SetString(PyExc_TypeError, "String buffer expected"); + SWIG_fail; + } + char* str = PyString_AS_STRING($input); + int len = PyString_GET_SIZE($input); + $1 = new wxMemoryBuffer(len); + temp = True; + memcpy($1->GetData(), str, len); +} + +%typemap(freearg) wxMemoryBuffer& { + if (temp$argnum) delete $1; +} + +%typemap(out) wxMemoryBuffer { + $result = PyString_FromStringAndSize((char*)$1.GetData(), $1.GetDataLen()); +} + + //--------------------------------------------------------------------------- // Typemaps to convert Python sequence objects (tuples, etc.) to