- more tweaks
- have discovered some problems but not yet discovered solutions... git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@634 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -33,8 +33,9 @@
|
|||||||
* and things like that.
|
* and things like that.
|
||||||
*
|
*
|
||||||
* $Log$
|
* $Log$
|
||||||
* Revision 1.2 1998/08/22 19:50:56 RD
|
* Revision 1.3 1998/08/27 00:00:54 RD
|
||||||
* some tweaks for wxGTK
|
* - more tweaks
|
||||||
|
* - have discovered some problems but not yet discovered solutions...
|
||||||
*
|
*
|
||||||
************************************************************************/
|
************************************************************************/
|
||||||
|
|
||||||
@@ -556,15 +557,6 @@ char *SWIG_GetPtr(char *_c, void **ptr, char *_t)
|
|||||||
|
|
||||||
#define SWIG_name "wxpc"
|
#define SWIG_name "wxpc"
|
||||||
|
|
||||||
|
|
||||||
#ifdef __WXMSW__
|
|
||||||
#include <windows.h>
|
|
||||||
#undef FindWindow
|
|
||||||
#undef GetCharWidth
|
|
||||||
#undef LoadAccelerators
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
#include "helpers.h"
|
#include "helpers.h"
|
||||||
|
|
||||||
static PyObject* l_output_helper(PyObject* target, PyObject* o) {
|
static PyObject* l_output_helper(PyObject* target, PyObject* o) {
|
||||||
@@ -628,21 +620,6 @@ extern wxAcceleratorEntry* wxAcceleratorEntry_LIST_helper(PyObject* source);
|
|||||||
|
|
||||||
static char* wxStringErrorMsg = "string type is required for parameter";
|
static char* wxStringErrorMsg = "string type is required for parameter";
|
||||||
|
|
||||||
#ifdef __WXMSW__ // If building for win32...
|
|
||||||
extern HINSTANCE wxhInstance;
|
|
||||||
|
|
||||||
BOOL WINAPI DllMain(
|
|
||||||
HINSTANCE hinstDLL, // handle to DLL module
|
|
||||||
DWORD fdwReason, // reason for calling function
|
|
||||||
LPVOID lpvReserved // reserved
|
|
||||||
)
|
|
||||||
{
|
|
||||||
wxhInstance = hinstDLL;
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
extern "C" SWIGEXPORT(void,initwindowsc)();
|
extern "C" SWIGEXPORT(void,initwindowsc)();
|
||||||
extern "C" SWIGEXPORT(void,initwindows2c)();
|
extern "C" SWIGEXPORT(void,initwindows2c)();
|
||||||
extern "C" SWIGEXPORT(void,initeventsc)();
|
extern "C" SWIGEXPORT(void,initeventsc)();
|
||||||
@@ -1695,12 +1672,6 @@ SWIGEXPORT(void,initwxpc)() {
|
|||||||
SWIG_addvarlink(SWIG_globals,"wxPyDefaultPosition",_wrap_wxPyDefaultPosition_get, _wrap_wxPyDefaultPosition_set);
|
SWIG_addvarlink(SWIG_globals,"wxPyDefaultPosition",_wrap_wxPyDefaultPosition_get, _wrap_wxPyDefaultPosition_set);
|
||||||
SWIG_addvarlink(SWIG_globals,"wxPyDefaultSize",_wrap_wxPyDefaultSize_get, _wrap_wxPyDefaultSize_set);
|
SWIG_addvarlink(SWIG_globals,"wxPyDefaultSize",_wrap_wxPyDefaultSize_get, _wrap_wxPyDefaultSize_set);
|
||||||
|
|
||||||
// We don't want to run the wxEntry or OnInit yet, so we just do the
|
|
||||||
// beginings of what it would have done... See __wxStart() for the
|
|
||||||
// rest.
|
|
||||||
#ifdef __WXMSW__
|
|
||||||
wxApp::Initialize((WXHINSTANCE)wxhInstance);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
// wxPyWindows = new wxHashTable(wxKEY_INTEGER, 100);
|
// wxPyWindows = new wxHashTable(wxKEY_INTEGER, 100);
|
||||||
|
@@ -1372,8 +1372,9 @@ class wxApp(wxPyApp):
|
|||||||
#----------------------------------------------------------------------------
|
#----------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
# $Log$
|
# $Log$
|
||||||
# Revision 1.2 1998/08/22 19:50:58 RD
|
# Revision 1.3 1998/08/27 00:00:56 RD
|
||||||
# some tweaks for wxGTK
|
# - more tweaks
|
||||||
|
# - have discovered some problems but not yet discovered solutions...
|
||||||
#
|
#
|
||||||
# Revision 1.2 1998/08/18 19:48:12 RD
|
# Revision 1.2 1998/08/18 19:48:12 RD
|
||||||
# more wxGTK compatibility things.
|
# more wxGTK compatibility things.
|
||||||
|
@@ -10,6 +10,13 @@
|
|||||||
// Licence: wxWindows license
|
// Licence: wxWindows license
|
||||||
/////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
#ifdef __WXMSW__
|
||||||
|
#include <windows.h>
|
||||||
|
#undef FindWindow
|
||||||
|
#undef GetCharWidth
|
||||||
|
#undef LoadAccelerators
|
||||||
|
#endif
|
||||||
|
|
||||||
#undef DEBUG
|
#undef DEBUG
|
||||||
#include <Python.h>
|
#include <Python.h>
|
||||||
#include "helpers.h"
|
#include "helpers.h"
|
||||||
@@ -31,6 +38,23 @@ wxString wxPyEmptyStr("");
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __WXMSW__ // If building for win32...
|
||||||
|
extern HINSTANCE wxhInstance;
|
||||||
|
|
||||||
|
//----------------------------------------------------------------------
|
||||||
|
// This gets run when the DLL is loaded. We just need to save a handle.
|
||||||
|
//----------------------------------------------------------------------
|
||||||
|
BOOL WINAPI DllMain(
|
||||||
|
HINSTANCE hinstDLL, // handle to DLL module
|
||||||
|
DWORD fdwReason, // reason for calling function
|
||||||
|
LPVOID lpvReserved // reserved
|
||||||
|
)
|
||||||
|
{
|
||||||
|
wxhInstance = hinstDLL;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
//----------------------------------------------------------------------
|
//----------------------------------------------------------------------
|
||||||
// Class for implementing the wxp main application shell.
|
// Class for implementing the wxp main application shell.
|
||||||
//----------------------------------------------------------------------
|
//----------------------------------------------------------------------
|
||||||
@@ -81,6 +105,7 @@ void wxPyApp::AfterMainLoop(void) {
|
|||||||
//----------------------------------------------------------------------
|
//----------------------------------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Start the user application, user App's OnInit method is a parameter here
|
// Start the user application, user App's OnInit method is a parameter here
|
||||||
PyObject* __wxStart(PyObject* /* self */, PyObject* args)
|
PyObject* __wxStart(PyObject* /* self */, PyObject* args)
|
||||||
{
|
{
|
||||||
@@ -92,15 +117,18 @@ PyObject* __wxStart(PyObject* /* self */, PyObject* args)
|
|||||||
if (!PyArg_ParseTuple(args, "O", &onInitFunc))
|
if (!PyArg_ParseTuple(args, "O", &onInitFunc))
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
// This is where we pick up one part of the wxEntry functionality...
|
// This is where we pick up one part of the wxEntry functionality...
|
||||||
// the rest is in AfterMainLoop.
|
// the rest is in AfterMainLoop.
|
||||||
#ifdef __WXMSW__
|
#ifdef __WXMSW__
|
||||||
|
wxApp::Initialize((WXHINSTANCE)wxhInstance);
|
||||||
|
|
||||||
wxPythonApp->argc = 0;
|
wxPythonApp->argc = 0;
|
||||||
wxPythonApp->argv = NULL;
|
wxPythonApp->argv = NULL;
|
||||||
wxPythonApp->OnInitGui();
|
wxPythonApp->OnInitGui();
|
||||||
#endif
|
#endif
|
||||||
#ifdef __WXGTK__
|
#ifdef __WXGTK__
|
||||||
wxClassInfo::InitializeClasses();
|
wxClassInfo::InitializeClasses();
|
||||||
|
|
||||||
PyObject* sysargv = PySys_GetObject("argv");
|
PyObject* sysargv = PySys_GetObject("argv");
|
||||||
int argc = PyList_Size(sysargv);
|
int argc = PyList_Size(sysargv);
|
||||||
char** argv = new char*[argc+1];
|
char** argv = new char*[argc+1];
|
||||||
@@ -110,23 +138,18 @@ PyObject* __wxStart(PyObject* /* self */, PyObject* args)
|
|||||||
argv[argc] = NULL;
|
argv[argc] = NULL;
|
||||||
|
|
||||||
|
|
||||||
wxTheApp->argc = argc;
|
wxPythonApp->argc = argc;
|
||||||
wxTheApp->argv = argv;
|
wxPythonApp->argv = argv;
|
||||||
|
|
||||||
gtk_init( &wxTheApp->argc, &wxTheApp->argv );
|
gtk_init( &wxPythonApp->argc, &wxPythonApp->argv );
|
||||||
|
|
||||||
#ifdef USE_GDK_IMLIB
|
#ifdef USE_GDK_IMLIB
|
||||||
|
|
||||||
gdk_imlib_init();
|
gdk_imlib_init();
|
||||||
|
|
||||||
gtk_widget_push_visual(gdk_imlib_get_visual());
|
gtk_widget_push_visual(gdk_imlib_get_visual());
|
||||||
|
|
||||||
gtk_widget_push_colormap(gdk_imlib_get_colormap());
|
gtk_widget_push_colormap(gdk_imlib_get_colormap());
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
wxApp::CommonInit();
|
wxApp::CommonInit();
|
||||||
|
|
||||||
wxTheApp->OnInitGui();
|
wxTheApp->OnInitGui();
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
@@ -167,106 +190,6 @@ PyObject* __wxStart(PyObject* /* self */, PyObject* args)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//PyObject* __wxMainLoop(PyObject* /* self */, PyObject* /* args */)
|
|
||||||
//{
|
|
||||||
// wxPythonApp->MainLoop();
|
|
||||||
// if (wxPythonApp->wx_frame) {
|
|
||||||
// wxPythonApp->wx_frame->GetEventHandler()->OnClose();
|
|
||||||
// delete wxPythonApp->wx_frame;
|
|
||||||
// }
|
|
||||||
// wxCleanUp();
|
|
||||||
|
|
||||||
// Py_INCREF(Py_None);
|
|
||||||
// return Py_None;
|
|
||||||
//}
|
|
||||||
|
|
||||||
|
|
||||||
//PyObject* __wxExitMainLoop(PyObject* /* self */, PyObject* /* args */)
|
|
||||||
//{
|
|
||||||
// wxPythonApp->ExitMainLoop();
|
|
||||||
// Py_INCREF(Py_None);
|
|
||||||
// return Py_None;
|
|
||||||
//}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//PyObject* __wxAddCallback(PyObject* /* self */, PyObject* args)
|
|
||||||
//{
|
|
||||||
// char* swigPtr;
|
|
||||||
// char* name;
|
|
||||||
// PyObject* callback;
|
|
||||||
// wxWindow* win;
|
|
||||||
// wxPyEvtHandlers* evtHdlr;
|
|
||||||
|
|
||||||
// if (!PyArg_ParseTuple(args, "ssO", &swigPtr, &name, &callback))
|
|
||||||
// return NULL;
|
|
||||||
|
|
||||||
// if (!PyCallable_Check(callback)) {
|
|
||||||
// PyErr_SetString(PyExc_TypeError, "Expected a callable object.");
|
|
||||||
// return NULL;
|
|
||||||
// }
|
|
||||||
|
|
||||||
// if (SWIG_GetPtr(swigPtr, (void **)&win, "_wxWindow_p")) {
|
|
||||||
// PyErr_SetString(PyExc_TypeError, "Expected class derived from wxWindow.");
|
|
||||||
// return NULL;
|
|
||||||
// }
|
|
||||||
|
|
||||||
// evtHdlr = (wxPyEvtHandlers*)win->GetClientData();
|
|
||||||
// if (! evtHdlr->addCallback(name, callback)) {
|
|
||||||
// PyErr_SetString(PyExc_TypeError, "Unknown callback name.");
|
|
||||||
// return NULL;
|
|
||||||
// }
|
|
||||||
|
|
||||||
// Py_INCREF(Py_None);
|
|
||||||
// return Py_None;
|
|
||||||
//}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//PyObject* __wxSetWinEvtHdlr(PyObject* /* self */, PyObject* args)
|
|
||||||
//{
|
|
||||||
// char* swigPtr;
|
|
||||||
// wxWindow* win;
|
|
||||||
// wxPyEvtHandlers* evtHdlr;
|
|
||||||
|
|
||||||
// if (!PyArg_ParseTuple(args, "s", &swigPtr))
|
|
||||||
// return NULL;
|
|
||||||
|
|
||||||
// if (SWIG_GetPtr(swigPtr, (void **)&win, "_wxWindow_p")) {
|
|
||||||
// PyErr_SetString(PyExc_TypeError, "Expected class derived from wxWindow.");
|
|
||||||
// return NULL;
|
|
||||||
// }
|
|
||||||
|
|
||||||
// evtHdlr = new wxPyEvtHandlers;
|
|
||||||
// win->SetClientData((char*)evtHdlr);
|
|
||||||
|
|
||||||
// Py_INCREF(Py_None);
|
|
||||||
// return Py_None;
|
|
||||||
//}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//PyObject* __wxDelWinEvtHdlr(PyObject* /* self */, PyObject* args)
|
|
||||||
//{
|
|
||||||
// char* swigPtr;
|
|
||||||
// wxWindow* win;
|
|
||||||
// wxPyEvtHandlers* evtHdlr;
|
|
||||||
|
|
||||||
// if (!PyArg_ParseTuple(args, "s", &swigPtr))
|
|
||||||
// return NULL;
|
|
||||||
|
|
||||||
// if (SWIG_GetPtr(swigPtr, (void **)&win, "_wxWindow_p")) {
|
|
||||||
// PyErr_SetString(PyExc_TypeError, "Expected class derived from wxWindow.");
|
|
||||||
// return NULL;
|
|
||||||
// }
|
|
||||||
|
|
||||||
// evtHdlr = (wxPyEvtHandlers*)win->GetClientData();
|
|
||||||
// printf("__wxDelWinEvtHdlr: %p\n", evtHdlr);
|
|
||||||
// delete evtHdlr;
|
|
||||||
|
|
||||||
// Py_INCREF(Py_None);
|
|
||||||
// return Py_None;
|
|
||||||
//}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -282,16 +205,19 @@ PyObject* __wxSetDictionary(PyObject* /* self */, PyObject* args)
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
#ifdef __WXMOTIF__
|
#ifdef __WXMOTIF__
|
||||||
#define wxPlatform "__MOTIF__"
|
#define wxPlatform "__WXMOTIF__"
|
||||||
|
#endif
|
||||||
|
#ifdef __WXQT__
|
||||||
|
#define wxPlatform "__WXQT__"
|
||||||
#endif
|
#endif
|
||||||
#ifdef __WXGTK__
|
#ifdef __WXGTK__
|
||||||
#define wxPlatform "__GTK__"
|
#define wxPlatform "__WXGTK__"
|
||||||
#endif
|
#endif
|
||||||
#if defined(__WIN32__) || defined(__WXMSW__)
|
#if defined(__WIN32__) || defined(__WXMSW__)
|
||||||
#define wxPlatform "__WXMSW__"
|
#define wxPlatform "__WXMSW__"
|
||||||
#endif
|
#endif
|
||||||
#ifdef __WXMAC__
|
#ifdef __WXMAC__
|
||||||
#define wxPlatform "__MAC__"
|
#define wxPlatform "__WXMAC__"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
PyDict_SetItemString(wxPython_dict, "wxPlatform", PyString_FromString(wxPlatform));
|
PyDict_SetItemString(wxPython_dict, "wxPlatform", PyString_FromString(wxPlatform));
|
||||||
@@ -415,377 +341,6 @@ void wxPyTimer::Notify() {
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
//----------------------------------------------------------------------
|
|
||||||
// wxPyEvtHandlers class
|
|
||||||
//----------------------------------------------------------------------
|
|
||||||
|
|
||||||
//wxPyEvtHandlers::wxPyEvtHandlers()
|
|
||||||
// : pyOnActivate(0),
|
|
||||||
// pyOnChar(0),
|
|
||||||
// pyOnCharHook(0),
|
|
||||||
// pyOnClose(0),
|
|
||||||
// pyOnCommand(0),
|
|
||||||
// pyOnDropFiles(0),
|
|
||||||
// pyOnDefaultAction(0),
|
|
||||||
// pyOnEvent(0),
|
|
||||||
// pyOnInitMenuPopup(0),
|
|
||||||
// pyOnKillFocus(0),
|
|
||||||
// pyOnMenuCommand(0),
|
|
||||||
// pyOnMenuSelect(0),
|
|
||||||
// pyOnMove(0),
|
|
||||||
// pyOnPaint(0),
|
|
||||||
// pyOnScroll(0),
|
|
||||||
// pyOnSetFocus(0),
|
|
||||||
// pyOnSize(0),
|
|
||||||
// pyOnSysColourChange(0),
|
|
||||||
// pyOnLeftClick(0),
|
|
||||||
// pyOnMouseEnter(0),
|
|
||||||
// pyOnRightClick(0),
|
|
||||||
// pyOnDoubleClickSash(0),
|
|
||||||
// pyOnUnsplit(0)
|
|
||||||
//{
|
|
||||||
//}
|
|
||||||
|
|
||||||
|
|
||||||
//wxPyEvtHandlers::~wxPyEvtHandlers()
|
|
||||||
//{
|
|
||||||
// Py_XDECREF(pyOnActivate);
|
|
||||||
// Py_XDECREF(pyOnChar);
|
|
||||||
// Py_XDECREF(pyOnCharHook);
|
|
||||||
// Py_XDECREF(pyOnClose);
|
|
||||||
// Py_XDECREF(pyOnCommand);
|
|
||||||
// Py_XDECREF(pyOnDropFiles);
|
|
||||||
// Py_XDECREF(pyOnDefaultAction);
|
|
||||||
// Py_XDECREF(pyOnEvent);
|
|
||||||
// Py_XDECREF(pyOnInitMenuPopup);
|
|
||||||
// Py_XDECREF(pyOnKillFocus);
|
|
||||||
// Py_XDECREF(pyOnMenuCommand);
|
|
||||||
// Py_XDECREF(pyOnMenuSelect);
|
|
||||||
// Py_XDECREF(pyOnMove);
|
|
||||||
// Py_XDECREF(pyOnPaint);
|
|
||||||
// Py_XDECREF(pyOnScroll);
|
|
||||||
// Py_XDECREF(pyOnSetFocus);
|
|
||||||
// Py_XDECREF(pyOnSize);
|
|
||||||
// Py_XDECREF(pyOnSysColourChange);
|
|
||||||
// Py_XDECREF(pyOnLeftClick);
|
|
||||||
// Py_XDECREF(pyOnMouseEnter);
|
|
||||||
// Py_XDECREF(pyOnRightClick);
|
|
||||||
// Py_XDECREF(pyOnDoubleClickSash);
|
|
||||||
// Py_XDECREF(pyOnUnsplit);
|
|
||||||
|
|
||||||
// wxNode* node = cleanupList.First();
|
|
||||||
// while (node) {
|
|
||||||
// delete (wxPyEvtHandlers*)node->Data();
|
|
||||||
// delete node;
|
|
||||||
// node = cleanupList.First();
|
|
||||||
// }
|
|
||||||
|
|
||||||
// node = decrefList.First();
|
|
||||||
// while (node) {
|
|
||||||
// PyObject* obj = (PyObject*)node->Data();
|
|
||||||
// Py_DECREF(obj);
|
|
||||||
// delete node;
|
|
||||||
// node = decrefList.First();
|
|
||||||
// }
|
|
||||||
//// printf("~wxPyEvtHandlers: %p\n", this);
|
|
||||||
//}
|
|
||||||
|
|
||||||
////----------------------------------------------------------------------
|
|
||||||
|
|
||||||
//Bool wxPyEvtHandlers::addCallback(char* name, PyObject* callback)
|
|
||||||
//{
|
|
||||||
// Py_INCREF(callback);
|
|
||||||
|
|
||||||
// if (strcmp(name, "OnActivate") == 0) {
|
|
||||||
// pyOnActivate = callback;
|
|
||||||
// return TRUE;
|
|
||||||
// }
|
|
||||||
// if (strcmp(name, "OnChar") == 0) {
|
|
||||||
// pyOnChar = callback;
|
|
||||||
// return TRUE;
|
|
||||||
// }
|
|
||||||
// if (strcmp(name, "OnCharHook") == 0) {
|
|
||||||
// pyOnCharHook = callback;
|
|
||||||
// return TRUE;
|
|
||||||
// }
|
|
||||||
// if (strcmp(name, "OnClose") == 0) {
|
|
||||||
// pyOnClose = callback;
|
|
||||||
// return TRUE;
|
|
||||||
// }
|
|
||||||
// if (strcmp(name, "OnCommand") == 0) {
|
|
||||||
// pyOnCommand = callback;
|
|
||||||
// return TRUE;
|
|
||||||
// }
|
|
||||||
// if (strcmp(name, "OnDropFiles") == 0) {
|
|
||||||
// pyOnDropFiles = callback;
|
|
||||||
// return TRUE;
|
|
||||||
// }
|
|
||||||
// if (strcmp(name, "OnDefaultAction") == 0) {
|
|
||||||
// pyOnDefaultAction = callback;
|
|
||||||
// return TRUE;
|
|
||||||
// }
|
|
||||||
// if (strcmp(name, "OnEvent") == 0) {
|
|
||||||
// pyOnEvent = callback;
|
|
||||||
// return TRUE;
|
|
||||||
// }
|
|
||||||
// if (strcmp(name, "OnInitMenuPopup") == 0) {
|
|
||||||
// pyOnInitMenuPopup = callback;
|
|
||||||
// return TRUE;
|
|
||||||
// }
|
|
||||||
// if (strcmp(name, "OnKillFocus") == 0) {
|
|
||||||
// pyOnKillFocus = callback;
|
|
||||||
// return TRUE;
|
|
||||||
// }
|
|
||||||
// if (strcmp(name, "OnMenuCommand") == 0) {
|
|
||||||
// pyOnMenuCommand = callback;
|
|
||||||
// return TRUE;
|
|
||||||
// }
|
|
||||||
// if (strcmp(name, "OnMenuSelect") == 0) {
|
|
||||||
// pyOnMenuSelect = callback;
|
|
||||||
// return TRUE;
|
|
||||||
// }
|
|
||||||
// if (strcmp(name, "OnMove") == 0) {
|
|
||||||
// pyOnMove = callback;
|
|
||||||
// return TRUE;
|
|
||||||
// }
|
|
||||||
// if (strcmp(name, "OnPaint") == 0) {
|
|
||||||
// pyOnPaint = callback;
|
|
||||||
// return TRUE;
|
|
||||||
// }
|
|
||||||
// if (strcmp(name, "OnScroll") == 0) {
|
|
||||||
// pyOnScroll = callback;
|
|
||||||
// return TRUE;
|
|
||||||
// }
|
|
||||||
// if (strcmp(name, "OnSetFocus") == 0) {
|
|
||||||
// pyOnSetFocus = callback;
|
|
||||||
// return TRUE;
|
|
||||||
// }
|
|
||||||
// if (strcmp(name, "OnSize") == 0) {
|
|
||||||
// pyOnSize = callback;
|
|
||||||
// return TRUE;
|
|
||||||
// }
|
|
||||||
// if (strcmp(name, "OnSysColourChange") == 0) {
|
|
||||||
// pyOnSysColourChange = callback;
|
|
||||||
// return TRUE;
|
|
||||||
// }
|
|
||||||
// if (strcmp(name, "OnLeftClick") == 0) {
|
|
||||||
// pyOnLeftClick = callback;
|
|
||||||
// return TRUE;
|
|
||||||
// }
|
|
||||||
// if (strcmp(name, "OnMouseEnter") == 0) {
|
|
||||||
// pyOnMouseEnter = callback;
|
|
||||||
// return TRUE;
|
|
||||||
// }
|
|
||||||
// if (strcmp(name, "OnRightClick") == 0) {
|
|
||||||
// pyOnRightClick = callback;
|
|
||||||
// return TRUE;
|
|
||||||
// }
|
|
||||||
// if (strcmp(name, "OnDoubleClickSash") == 0) {
|
|
||||||
// pyOnDoubleClickSash = callback;
|
|
||||||
// return TRUE;
|
|
||||||
// }
|
|
||||||
// if (strcmp(name, "OnUnsplit") == 0) {
|
|
||||||
// pyOnUnsplit = callback;
|
|
||||||
// return TRUE;
|
|
||||||
// }
|
|
||||||
|
|
||||||
// // If we get here, there was no match.
|
|
||||||
// Py_DECREF(callback);
|
|
||||||
// return FALSE;
|
|
||||||
//}
|
|
||||||
|
|
||||||
|
|
||||||
////----------------------------------------------------------------------
|
|
||||||
//// Helpers to assist in calling the python callable objects
|
|
||||||
////----------------------------------------------------------------------
|
|
||||||
|
|
||||||
//PyObject* wxPyEvtHandlers::constructObject(void* ptr, char* className)
|
|
||||||
//{
|
|
||||||
// char buff[64]; // should be big enough...
|
|
||||||
// char swigptr[64];
|
|
||||||
|
|
||||||
// sprintf(buff, "_%s_p", className);
|
|
||||||
// SWIG_MakePtr(swigptr, ptr, buff);
|
|
||||||
|
|
||||||
// sprintf(buff, "%sPtr", className);
|
|
||||||
// PyObject* classobj = PyDict_GetItemString(wxPython_dict, buff);
|
|
||||||
// PyObject* arg = Py_BuildValue("(s)", swigptr);
|
|
||||||
// PyObject* obj = PyInstance_New(classobj, arg, NULL);
|
|
||||||
// Py_DECREF(arg);
|
|
||||||
|
|
||||||
// return obj;
|
|
||||||
//}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//int wxPyEvtHandlers::callFunc(PyObject* func, PyObject* arglist)
|
|
||||||
//{
|
|
||||||
// PyObject* result;
|
|
||||||
// int retval = FALSE;
|
|
||||||
|
|
||||||
// result = PyEval_CallObject(func, arglist);
|
|
||||||
// Py_DECREF(arglist);
|
|
||||||
// if (result) { // Assumes an integer return type...
|
|
||||||
// retval = PyInt_AsLong(result);
|
|
||||||
// Py_DECREF(result);
|
|
||||||
// PyErr_Clear(); // forget about it if it's not...
|
|
||||||
// } else {
|
|
||||||
// PyErr_Print();
|
|
||||||
// }
|
|
||||||
// return retval;
|
|
||||||
//}
|
|
||||||
|
|
||||||
////---------------------------------------------------------------------------
|
|
||||||
//// Methods and helpers of the wxPy* classes
|
|
||||||
////---------------------------------------------------------------------------
|
|
||||||
|
|
||||||
//IMP_OnActivate(wxFrame, wxPyFrame);
|
|
||||||
//IMP_OnCharHook(wxFrame, wxPyFrame);
|
|
||||||
//IMP_OnClose(wxFrame, wxPyFrame);
|
|
||||||
//IMP_OnMenuCommand(wxFrame, wxPyFrame);
|
|
||||||
//IMP_OnMenuSelect(wxFrame, wxPyFrame);
|
|
||||||
//IMP_OnSize(wxFrame, wxPyFrame);
|
|
||||||
//IMP_OnDropFiles(wxFrame, wxPyFrame);
|
|
||||||
|
|
||||||
//IMP_OnChar(wxCanvas, wxPyCanvas);
|
|
||||||
//IMP_OnEvent(wxCanvas, wxPyCanvas);
|
|
||||||
//IMP_OnPaint(wxCanvas, wxPyCanvas);
|
|
||||||
//IMP_OnScroll(wxCanvas, wxPyCanvas);
|
|
||||||
//IMP_OnDropFiles(wxCanvas, wxPyCanvas);
|
|
||||||
|
|
||||||
//IMP_OnChar(wxPanel, wxPyPanel);
|
|
||||||
//IMP_OnEvent(wxPanel, wxPyPanel);
|
|
||||||
//IMP_OnPaint(wxPanel, wxPyPanel);
|
|
||||||
//IMP_OnScroll(wxPanel, wxPyPanel);
|
|
||||||
//IMP_OnCommand(wxPanel, wxPyPanel);
|
|
||||||
//IMP_OnDefaultAction(wxPanel, wxPyPanel);
|
|
||||||
//IMP_OnDropFiles(wxPanel, wxPyPanel);
|
|
||||||
|
|
||||||
//IMP_OnChar(wxTextWindow, wxPyTextWindow);
|
|
||||||
//IMP_OnDropFiles(wxTextWindow, wxPyTextWindow);
|
|
||||||
|
|
||||||
//IMP_OnCharHook(wxDialogBox, wxPyDialogBox);
|
|
||||||
//IMP_OnClose(wxDialogBox, wxPyDialogBox);
|
|
||||||
//IMP_OnSize(wxDialogBox, wxPyDialogBox);
|
|
||||||
//IMP_OnDropFiles(wxDialogBox, wxPyDialogBox);
|
|
||||||
//IMP_OnChar(wxDialogBox, wxPyDialogBox);
|
|
||||||
//IMP_OnEvent(wxDialogBox, wxPyDialogBox);
|
|
||||||
//IMP_OnPaint(wxDialogBox, wxPyDialogBox);
|
|
||||||
//IMP_OnScroll(wxDialogBox, wxPyDialogBox);
|
|
||||||
//IMP_OnCommand(wxDialogBox, wxPyDialogBox);
|
|
||||||
//IMP_OnDefaultAction(wxDialogBox, wxPyDialogBox);
|
|
||||||
|
|
||||||
//IMP_OnChar(wxToolBar, wxPyToolBar);
|
|
||||||
//IMP_OnEvent(wxToolBar, wxPyToolBar);
|
|
||||||
//IMP_OnPaint(wxToolBar, wxPyToolBar);
|
|
||||||
//IMP_OnScroll(wxToolBar, wxPyToolBar);
|
|
||||||
//IMP_OnCommand(wxToolBar, wxPyToolBar);
|
|
||||||
//IMP_OnDefaultAction(wxToolBar, wxPyToolBar);
|
|
||||||
//IMP_OnDropFiles(wxToolBar, wxPyToolBar);
|
|
||||||
//IMP_OnMouseEnter(wxToolBar, wxPyToolBar);
|
|
||||||
//IMP_OnRightClick(wxToolBar, wxPyToolBar);
|
|
||||||
|
|
||||||
//IMP_OnChar(wxButtonBar, wxPyButtonBar);
|
|
||||||
//IMP_OnEvent(wxButtonBar, wxPyButtonBar);
|
|
||||||
//IMP_OnPaint(wxButtonBar, wxPyButtonBar);
|
|
||||||
//IMP_OnScroll(wxButtonBar, wxPyButtonBar);
|
|
||||||
//IMP_OnCommand(wxButtonBar, wxPyButtonBar);
|
|
||||||
//IMP_OnDefaultAction(wxButtonBar, wxPyButtonBar);
|
|
||||||
//IMP_OnDropFiles(wxButtonBar, wxPyButtonBar);
|
|
||||||
//IMP_OnMouseEnter(wxButtonBar, wxPyButtonBar);
|
|
||||||
//IMP_OnRightClick(wxButtonBar, wxPyButtonBar);
|
|
||||||
|
|
||||||
//IMP_OnDoubleClickSash(wxSplitterWindow, wxPySplitterWindow);
|
|
||||||
//IMP_OnUnsplit(wxSplitterWindow, wxPySplitterWindow);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//Bool wxPyToolBar::OnLeftClick(int a, int b) {
|
|
||||||
// wxPyEvtHandlers* peh=(wxPyEvtHandlers*)GetClientData();
|
|
||||||
// if (peh->pyOnLeftClick)
|
|
||||||
// return peh->callFunc(peh->pyOnLeftClick, Py_BuildValue("(ii)",a,b));
|
|
||||||
// else {
|
|
||||||
// // If there is no Python callback, redirect the request to
|
|
||||||
// // the OnMenuCommand of the parent frame.
|
|
||||||
// wxFrame* frame = (wxFrame*)GetParent();
|
|
||||||
// frame->OnMenuCommand(a);
|
|
||||||
// return TRUE;
|
|
||||||
// }
|
|
||||||
//// else
|
|
||||||
//// return wxToolBar::OnLeftClick(a,b);
|
|
||||||
//}
|
|
||||||
//Bool wxPyToolBar::baseclass_OnLeftClick(int a, int b) {
|
|
||||||
// return wxToolBar::OnLeftClick(a,b);
|
|
||||||
//}
|
|
||||||
|
|
||||||
|
|
||||||
//Bool wxPyButtonBar::OnLeftClick(int a, int b) {
|
|
||||||
// wxPyEvtHandlers* peh=(wxPyEvtHandlers*)GetClientData();
|
|
||||||
// if (peh->pyOnLeftClick)
|
|
||||||
// return peh->callFunc(peh->pyOnLeftClick, Py_BuildValue("(ii)",a,b));
|
|
||||||
// else {
|
|
||||||
// // If there is no Python callback, redirect the request to
|
|
||||||
// // the OnMenuCommand of the parent frame.
|
|
||||||
// wxFrame* frame = (wxFrame*)GetParent();
|
|
||||||
// frame->OnMenuCommand(a);
|
|
||||||
// return TRUE;
|
|
||||||
// }
|
|
||||||
//}
|
|
||||||
//Bool wxPyButtonBar::baseclass_OnLeftClick(int a, int b) {
|
|
||||||
// return wxButtonBar::OnLeftClick(a,b);
|
|
||||||
//}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//wxPyMenu::wxPyMenu(PyObject* _func)
|
|
||||||
// : wxMenu(NULL, (wxFunction)(func ? MenuCallback : NULL)), func(0) {
|
|
||||||
|
|
||||||
// if (_func) {
|
|
||||||
// func = _func;
|
|
||||||
// Py_INCREF(func);
|
|
||||||
// }
|
|
||||||
//}
|
|
||||||
|
|
||||||
//wxPyMenu::~wxPyMenu() {
|
|
||||||
// if (func)
|
|
||||||
// Py_DECREF(func);
|
|
||||||
//}
|
|
||||||
|
|
||||||
|
|
||||||
//void wxPyMenu::MenuCallback(wxWindow& win, wxCommandEvent& evt) {
|
|
||||||
// wxPyEvtHandlers* peh= new wxPyEvtHandlers; // Used for the helper methods
|
|
||||||
// PyObject* evtobj = peh->constructObject((void*)&evt, "wxCommandEvent");
|
|
||||||
// PyObject* winobj = peh->constructObject((void*)&win, "wxWindow");
|
|
||||||
// if (PyErr_Occurred()) {
|
|
||||||
// // bail out if a problem
|
|
||||||
// PyErr_Print();
|
|
||||||
// delete peh;
|
|
||||||
// return;
|
|
||||||
// }
|
|
||||||
// // Now call the callback...
|
|
||||||
// PyObject* func = ((wxPyMenu*)&win)->func;
|
|
||||||
// peh->callFunc(func, Py_BuildValue("(OO)", winobj, evtobj));
|
|
||||||
// Py_DECREF(evtobj);
|
|
||||||
// Py_DECREF(winobj);
|
|
||||||
// delete peh;
|
|
||||||
//}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//wxPyTimer::wxPyTimer(PyObject* callback) {
|
|
||||||
// func = callback;
|
|
||||||
// Py_INCREF(func);
|
|
||||||
//}
|
|
||||||
|
|
||||||
//wxPyTimer::~wxPyTimer() {
|
|
||||||
// Py_DECREF(func);
|
|
||||||
//}
|
|
||||||
|
|
||||||
//void wxPyTimer::Notify() {
|
|
||||||
// wxPyEvtHandlers* peh= new wxPyEvtHandlers; // just for the helper methods
|
|
||||||
// peh->callFunc(func, Py_BuildValue("()"));
|
|
||||||
// delete peh;
|
|
||||||
//}
|
|
||||||
|
|
||||||
//----------------------------------------------------------------------
|
//----------------------------------------------------------------------
|
||||||
//----------------------------------------------------------------------
|
//----------------------------------------------------------------------
|
||||||
@@ -1073,7 +628,12 @@ wxAcceleratorEntry* wxAcceleratorEntry_LIST_helper(PyObject* source) {
|
|||||||
/////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// $Log$
|
// $Log$
|
||||||
|
// Revision 1.7 1998/08/27 00:00:26 RD
|
||||||
|
// - more tweaks
|
||||||
|
// - have discovered some problems but not yet discovered solutions...
|
||||||
|
//
|
||||||
// Revision 1.6 1998/08/18 21:54:12 RD
|
// Revision 1.6 1998/08/18 21:54:12 RD
|
||||||
|
//
|
||||||
// ifdef out some wxGTK specific code
|
// ifdef out some wxGTK specific code
|
||||||
//
|
//
|
||||||
// Revision 1.5 1998/08/18 19:48:17 RD
|
// Revision 1.5 1998/08/18 19:48:17 RD
|
||||||
|
@@ -14,15 +14,6 @@
|
|||||||
|
|
||||||
|
|
||||||
%{
|
%{
|
||||||
|
|
||||||
#ifdef __WXMSW__
|
|
||||||
#include <windows.h>
|
|
||||||
#undef FindWindow
|
|
||||||
#undef GetCharWidth
|
|
||||||
#undef LoadAccelerators
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
#include "helpers.h"
|
#include "helpers.h"
|
||||||
%}
|
%}
|
||||||
|
|
||||||
@@ -101,29 +92,6 @@ public:
|
|||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
//---------------------------------------------------------------------------
|
|
||||||
//---------------------------------------------------------------------------
|
|
||||||
|
|
||||||
|
|
||||||
%{
|
|
||||||
#ifdef __WXMSW__ // If building for win32...
|
|
||||||
extern HINSTANCE wxhInstance;
|
|
||||||
|
|
||||||
BOOL WINAPI DllMain(
|
|
||||||
HINSTANCE hinstDLL, // handle to DLL module
|
|
||||||
DWORD fdwReason, // reason for calling function
|
|
||||||
LPVOID lpvReserved // reserved
|
|
||||||
)
|
|
||||||
{
|
|
||||||
wxhInstance = hinstDLL;
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
%}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//----------------------------------------------------------------------
|
//----------------------------------------------------------------------
|
||||||
// This code gets added to the module initialization function
|
// This code gets added to the module initialization function
|
||||||
@@ -143,12 +111,6 @@ extern "C" SWIGEXPORT(void,initcmndlgsc)();
|
|||||||
%}
|
%}
|
||||||
|
|
||||||
%init %{
|
%init %{
|
||||||
// We don't want to run the wxEntry or OnInit yet, so we just do the
|
|
||||||
// beginings of what it would have done... See __wxStart() for the
|
|
||||||
// rest.
|
|
||||||
#ifdef __WXMSW__
|
|
||||||
wxApp::Initialize((WXHINSTANCE)wxhInstance);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
// wxPyWindows = new wxHashTable(wxKEY_INTEGER, 100);
|
// wxPyWindows = new wxHashTable(wxKEY_INTEGER, 100);
|
||||||
@@ -177,6 +139,10 @@ extern "C" SWIGEXPORT(void,initcmndlgsc)();
|
|||||||
/////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// $Log$
|
// $Log$
|
||||||
|
// Revision 1.5 1998/08/27 00:00:28 RD
|
||||||
|
// - more tweaks
|
||||||
|
// - have discovered some problems but not yet discovered solutions...
|
||||||
|
//
|
||||||
// Revision 1.4 1998/08/18 19:48:20 RD
|
// Revision 1.4 1998/08/18 19:48:20 RD
|
||||||
// more wxGTK compatibility things.
|
// more wxGTK compatibility things.
|
||||||
//
|
//
|
||||||
|
@@ -369,10 +369,11 @@ class AppFrame(wxFrame):
|
|||||||
|
|
||||||
def WriteText(self, str):
|
def WriteText(self, str):
|
||||||
self.log.WriteText(str)
|
self.log.WriteText(str)
|
||||||
w, h = self.log.GetClientSize()
|
if wxPlatform == '__WXMSW__':
|
||||||
numLines = h/self.charHeight
|
w, h = self.log.GetClientSize()
|
||||||
x, y = self.log.PositionToXY(self.log.GetLastPosition())
|
numLines = h/self.charHeight
|
||||||
self.log.ShowPosition(self.log.XYToPosition(x, y-numLines+1))
|
x, y = self.log.PositionToXY(self.log.GetLastPosition())
|
||||||
|
self.log.ShowPosition(self.log.XYToPosition(x, y-numLines+1))
|
||||||
|
|
||||||
def OnFileExit(self, event):
|
def OnFileExit(self, event):
|
||||||
self.Close()
|
self.Close()
|
||||||
@@ -506,6 +507,11 @@ class MyApp(wxApp):
|
|||||||
|
|
||||||
def main():
|
def main():
|
||||||
app = MyApp(0)
|
app = MyApp(0)
|
||||||
|
import wxPython.gdi
|
||||||
|
reload(wxPython.gdi)
|
||||||
|
print wxPython.gdi.wxBLUE
|
||||||
|
print wxPython.gdi.wxBLUE.this
|
||||||
|
|
||||||
app.MainLoop()
|
app.MainLoop()
|
||||||
|
|
||||||
|
|
||||||
@@ -513,6 +519,20 @@ def t():
|
|||||||
import pdb
|
import pdb
|
||||||
pdb.run('main()')
|
pdb.run('main()')
|
||||||
|
|
||||||
|
|
||||||
|
# for focused testing...
|
||||||
|
def t2():
|
||||||
|
class T2App(wxApp):
|
||||||
|
def OnInit(self):
|
||||||
|
frame = TestLayoutConstraints(NULL)
|
||||||
|
frame.Show(true)
|
||||||
|
self.SetTopWindow(frame)
|
||||||
|
|
||||||
|
app = T2App(0)
|
||||||
|
app.MainLoop()
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
main()
|
main()
|
||||||
|
|
||||||
@@ -520,6 +540,10 @@ if __name__ == '__main__':
|
|||||||
#----------------------------------------------------------------------------
|
#----------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
# $Log$
|
# $Log$
|
||||||
|
# Revision 1.3 1998/08/27 00:01:17 RD
|
||||||
|
# - more tweaks
|
||||||
|
# - have discovered some problems but not yet discovered solutions...
|
||||||
|
#
|
||||||
# Revision 1.2 1998/08/22 19:51:18 RD
|
# Revision 1.2 1998/08/22 19:51:18 RD
|
||||||
# some tweaks for wxGTK
|
# some tweaks for wxGTK
|
||||||
#
|
#
|
||||||
|
Reference in New Issue
Block a user