1 /////////////////////////////////////////////////////////////////////////////
7 // Created: 13-Sept-2003
9 // Copyright: (c) 2003 by Total Control Software
10 // Licence: wxWindows license
11 /////////////////////////////////////////////////////////////////////////////
16 //---------------------------------------------------------------------------
18 #ifndef wxPyUSE_EXPORT
19 // Helper functions for dealing with SWIG objects and such. These are
20 // located here so they know about the SWIG types and functions declared
21 // in the wrapper code.
24 swig_type_info* wxPyFindSwigType(const wxChar* className);
29 #if SWIG_VERSION < 0x010328
31 // Make a SWIGified pointer object suitable for a .this attribute
32 PyObject* wxPyMakeSwigPtr(void* ptr, const wxChar* className) {
34 PyObject* robj = NULL;
36 swig_type_info* swigType = wxPyFindSwigType(className);
37 wxCHECK_MSG(swigType != NULL, NULL, wxT("Unknown type in wxPyMakeSwigPtr"));
39 #ifdef SWIG_COBJECT_TYPES
40 robj = PySwigObject_FromVoidPtrAndDesc((void *) ptr, (char *)swigType->name);
44 robj = SWIG_PackVoidPtr(result, ptr, swigType->name, sizeof(result)) ?
45 PyString_FromString(result) : 0;
52 #else // SWIG_VERSION >= 1.3.28
54 // Make a SWIGified pointer object suitable for a .this attribute
55 PyObject* wxPyMakeSwigPtr(void* ptr, const wxChar* className) {
57 PyObject* robj = NULL;
59 swig_type_info* swigType = wxPyFindSwigType(className);
60 wxCHECK_MSG(swigType != NULL, NULL, wxT("Unknown type in wxPyMakeSwigPtr"));
62 robj = PySwigObject_New(ptr, swigType, 0);
72 #include <wx/hashmap.h>
73 WX_DECLARE_STRING_HASH_MAP( swig_type_info*, wxPyTypeInfoHashMap );
76 // Maintains a hashmap of className to swig_type_info pointers. Given the
77 // name of a class either looks up the type info in the cache, or scans the
78 // SWIG tables for it.
79 extern PyObject* wxPyPtrTypeMap;
81 swig_type_info* wxPyFindSwigType(const wxChar* className) {
83 static wxPyTypeInfoHashMap* typeInfoCache = NULL;
85 if (typeInfoCache == NULL)
86 typeInfoCache = new wxPyTypeInfoHashMap;
88 wxString name(className);
89 swig_type_info* swigType = (*typeInfoCache)[name];
92 // it wasn't in the cache, so look it up from SWIG
93 name.Append(wxT(" *"));
94 swigType = SWIG_TypeQuery(name.mb_str());
96 // if it still wasn't found, try looking for a mapped name
101 if ((item = PyDict_GetItemString(wxPyPtrTypeMap,
102 (char*)(const char*)name.mbc_str())) != NULL) {
103 name = wxString(PyString_AsString(item), *wxConvCurrent);
104 name.Append(wxT(" *"));
105 swigType = SWIG_TypeQuery(name.mb_str());
109 // and add it to the map if found
110 (*typeInfoCache)[className] = swigType;
117 // Check if a class name is a type known to SWIG
118 bool wxPyCheckSwigType(const wxChar* className) {
120 swig_type_info* swigType = wxPyFindSwigType(className);
121 return swigType != NULL;
125 // Given a pointer to a C++ object and a class name, construct a Python proxy
127 PyObject* wxPyConstructObject(void* ptr,
128 const wxChar* className,
131 swig_type_info* swigType = wxPyFindSwigType(className);
132 wxCHECK_MSG(swigType != NULL, NULL, wxT("Unknown type in wxPyConstructObject"));
134 return SWIG_Python_NewPointerObj(ptr, swigType, setThisOwn);
138 // Extract a pointer to the wrapped C++ object from a Python proxy object.
139 // Ensures that the proxy object is of the specified (or derived) type. If
140 // not able to perform the conversion then a Python exception is set and the
141 // error should be handled properly in the caller. Returns True on success.
142 bool wxPyConvertSwigPtr(PyObject* obj, void **ptr,
143 const wxChar* className) {
145 swig_type_info* swigType = wxPyFindSwigType(className);
146 wxCHECK_MSG(swigType != NULL, false, wxT("Unknown type in wxPyConvertSwigPtr"));
148 return SWIG_Python_ConvertPtr(obj, ptr, swigType, SWIG_POINTER_EXCEPTION) != -1;
154 // Python's PyInstance_Check does not return True for instances of new-style
155 // classes. This should get close enough for both new and old classes but I
156 // should re-evaluate the need for doing instance checks...
157 bool wxPyInstance_Check(PyObject* obj) {
158 return PyObject_HasAttrString(obj, "__class__") != 0;
163 // This one checks if the object is an instance of a SWIG proxy class (it has
164 // a .this attribute, and the .this attribute is a PySwigObject.)
165 bool wxPySwigInstance_Check(PyObject* obj) {
166 static PyObject* this_str = NULL;
167 if (this_str == NULL)
168 this_str = PyString_FromString("this");
170 PyObject* this_attr = PyObject_GetAttr(obj, this_str);
172 bool retval = (PySwigObject_Check(this_attr) != 0);
173 Py_DECREF(this_attr);
183 // Export a C API in a struct. Other modules will be able to load this from
184 // the wx._core_ module and will then have safe access to these functions,
185 // even if they are located in another shared library.
186 static wxPyCoreAPI API = {
193 wxPyBeginAllowThreads,
195 wxPyBeginBlockThreads,
209 wxBitmap_LIST_helper,
210 wxString_LIST_helper,
211 wxAcceleratorEntry_LIST_helper,
220 wxPySimple_typecheck,
223 wxPyCBH_setCallbackInfo,
224 wxPyCBH_findCallback,
225 wxPyCBH_callCallback,
226 wxPyCBH_callCallbackObj,
234 wxArrayString2PyList_helper,
235 wxArrayInt2PyList_helper,
239 wxPyOORClientData_dtor,
241 wxPyCBInputStream_create,
242 wxPyCBInputStream_copy,
245 wxPySwigInstance_Check,
258 #ifndef wxPyUSE_EXPORT
259 // Make our API structure a CObject so other modules can import it
261 PyObject* cobj = PyCObject_FromVoidPtr(&API, NULL);
262 PyDict_SetItemString(d,"_wxPyCoreAPI", cobj);
267 //---------------------------------------------------------------------------