]> git.saurik.com Git - wxWidgets.git/blame - wxPython/src/_core_api.i
Docstring update
[wxWidgets.git] / wxPython / src / _core_api.i
CommitLineData
d14a1e28
RD
1/////////////////////////////////////////////////////////////////////////////
2// Name: _core_api.i
3// Purpose:
4//
5// Author: Robin Dunn
6//
7// Created: 13-Sept-2003
8// RCS-ID: $Id$
9// Copyright: (c) 2003 by Total Control Software
10// Licence: wxWindows license
11/////////////////////////////////////////////////////////////////////////////
12
13// Not a %module
14
15
16//---------------------------------------------------------------------------
17%{
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.
22
23#include <wx/hashmap.h>
4617be08 24 WX_DECLARE_STRING_HASH_MAP( swig_type_info*, wxPyTypeInfoHashMap );
d14a1e28
RD
25
26
27// Maintains a hashmap of className to swig_type_info pointers. Given the
28// name of a class either looks up the type info in the cache, or scans the
29// SWIG tables for it.
30extern PyObject* wxPyPtrTypeMap;
31static
32swig_type_info* wxPyFindSwigType(const wxChar* className) {
33
34 static wxPyTypeInfoHashMap* typeInfoCache = NULL;
35
36 if (typeInfoCache == NULL)
37 typeInfoCache = new wxPyTypeInfoHashMap;
38
39 wxString name(className);
40 swig_type_info* swigType = (*typeInfoCache)[name];
41
42 if (! swigType) {
43 // it wasn't in the cache, so look it up from SWIG
44 name.Append(wxT(" *"));
1b8c7ba6 45 swigType = SWIG_TypeQuery(name.mb_str());
d14a1e28
RD
46
47 // if it still wasn't found, try looking for a mapped name
48 if (!swigType) {
49 PyObject* item;
50 name = className;
51
52 if ((item = PyDict_GetItemString(wxPyPtrTypeMap,
53 (char*)(const char*)name.mbc_str())) != NULL) {
54 name = wxString(PyString_AsString(item), *wxConvCurrent);
55 name.Append(wxT(" *"));
1b8c7ba6 56 swigType = SWIG_TypeQuery(name.mb_str());
d14a1e28
RD
57 }
58 }
59 if (swigType) {
60 // and add it to the map if found
61 (*typeInfoCache)[className] = swigType;
62 }
63 }
64 return swigType;
65}
66
67
68// Check if a class name is a type known to SWIG
69bool wxPyCheckSwigType(const wxChar* className) {
70
71 swig_type_info* swigType = wxPyFindSwigType(className);
72 return swigType != NULL;
73}
74
75
76// Given a pointer to a C++ object and a class name, construct a Python proxy
77// object for it.
78PyObject* wxPyConstructObject(void* ptr,
79 const wxChar* className,
80 int setThisOwn) {
81
82 swig_type_info* swigType = wxPyFindSwigType(className);
83 wxCHECK_MSG(swigType != NULL, NULL, wxT("Unknown type in wxPyConstructObject"));
84
85 return SWIG_Python_NewPointerObj(ptr, swigType, setThisOwn);
86}
87
88
89// Extract a pointer to the wrapped C++ object from a Python proxy object.
90// Ensures that the proxy object is of the specified (or derived) type. If
91// not able to perform the conversion then a Python exception is set and the
dd9f7fea 92// error should be handled properly in the caller. Returns True on success.
d14a1e28
RD
93bool wxPyConvertSwigPtr(PyObject* obj, void **ptr,
94 const wxChar* className) {
95
96 swig_type_info* swigType = wxPyFindSwigType(className);
a72f4631 97 wxCHECK_MSG(swigType != NULL, false, wxT("Unknown type in wxPyConvertSwigPtr"));
d14a1e28
RD
98
99 return SWIG_Python_ConvertPtr(obj, ptr, swigType, SWIG_POINTER_EXCEPTION) != -1;
100}
101
102
103// Make a SWIGified pointer object suitable for a .this attribute
104PyObject* wxPyMakeSwigPtr(void* ptr, const wxChar* className) {
105
106 PyObject* robj = NULL;
107
108 swig_type_info* swigType = wxPyFindSwigType(className);
214c4fbe 109 wxCHECK_MSG(swigType != NULL, NULL, wxT("Unknown type in wxPyMakeSwigPtr"));
d14a1e28 110
214c4fbe 111#if SWIG_VERSION < 0x010328
d14a1e28 112#ifdef SWIG_COBJECT_TYPES
1b8c7ba6 113 robj = PySwigObject_FromVoidPtrAndDesc((void *) ptr, (char *)swigType->name);
d14a1e28
RD
114#else
115 {
116 char result[1024];
1b8c7ba6
RD
117 robj = SWIG_PackVoidPtr(result, ptr, swigType->name, sizeof(result)) ?
118 PyString_FromString(result) : 0;
119 }
d14a1e28 120#endif
214c4fbe
RD
121#else // SWIG_VERSION >= 1.3.28
122 robj = PySwigObject_New(ptr, swigType, 0);
123#endif
d14a1e28
RD
124 return robj;
125}
126
127
02b800ce
RD
128// Python's PyInstance_Check does not return True for instances of new-style
129// classes. This should get close enough for both new and old classes but I
130// should re-evaluate the need for doing instance checks...
131bool wxPyInstance_Check(PyObject* obj) {
132 return PyObject_HasAttrString(obj, "__class__") != 0;
133}
134
135
136
137// This one checks if the object is an instance of a SWIG proxy class (it has
138// a .this attribute, and the .this attribute is a PySwigObject.)
139bool wxPySwigInstance_Check(PyObject* obj) {
140 static PyObject* this_str = NULL;
141 if (this_str == NULL)
142 this_str = PyString_FromString("this");
143
144 PyObject* this_attr = PyObject_GetAttr(obj, this_str);
145 if (this_attr) {
146 bool retval = (PySwigObject_Check(this_attr) != 0);
147 Py_DECREF(this_attr);
148 return retval;
149 }
150
151 PyErr_Clear();
152 return false;
153}
154
d14a1e28
RD
155
156
157// Export a C API in a struct. Other modules will be able to load this from
54f9ee45
RD
158// the wx._core_ module and will then have safe access to these functions,
159// even if they are located in another shared library.
d14a1e28
RD
160static wxPyCoreAPI API = {
161
d14a1e28
RD
162 wxPyCheckSwigType,
163 wxPyConstructObject,
164 wxPyConvertSwigPtr,
165 wxPyMakeSwigPtr,
166
167 wxPyBeginAllowThreads,
168 wxPyEndAllowThreads,
169 wxPyBeginBlockThreads,
170 wxPyEndBlockThreads,
171
172 wxPy_ConvertList,
173
174 wxString_in_helper,
175 Py2wxString,
176 wx2PyString,
177
178 byte_LIST_helper,
179 int_LIST_helper,
180 long_LIST_helper,
181 string_LIST_helper,
182 wxPoint_LIST_helper,
183 wxBitmap_LIST_helper,
184 wxString_LIST_helper,
185 wxAcceleratorEntry_LIST_helper,
186
187 wxSize_helper,
188 wxPoint_helper,
189 wxRealPoint_helper,
190 wxRect_helper,
191 wxColour_helper,
192 wxPoint2D_helper,
193
194 wxPySimple_typecheck,
195 wxColour_typecheck,
196
197 wxPyCBH_setCallbackInfo,
198 wxPyCBH_findCallback,
199 wxPyCBH_callCallback,
200 wxPyCBH_callCallbackObj,
201 wxPyCBH_delete,
202
203 wxPyMake_wxObject,
204 wxPyMake_wxSizer,
205 wxPyPtrTypeMap_Add,
206 wxPy2int_seq_helper,
207 wxPy4int_seq_helper,
208 wxArrayString2PyList_helper,
209 wxArrayInt2PyList_helper,
210
211 wxPyClientData_dtor,
212 wxPyUserData_dtor,
213 wxPyOORClientData_dtor,
214
215 wxPyCBInputStream_create,
d02ea46c
RD
216 wxPyCBInputStream_copy,
217
d14a1e28 218 wxPyInstance_Check,
ab1f7d2a
RD
219 wxPySwigInstance_Check,
220
221 wxPyCheckForApp
d14a1e28
RD
222
223};
224
225#endif
226%}
227
228
229
230
231%init %{
232#ifndef wxPyUSE_EXPORT
233 // Make our API structure a CObject so other modules can import it
234 // from this module.
235 PyObject* cobj = PyCObject_FromVoidPtr(&API, NULL);
236 PyDict_SetItemString(d,"_wxPyCoreAPI", cobj);
237 Py_XDECREF(cobj);
238#endif
239%}
240
241//---------------------------------------------------------------------------