wxHashTable *wxWidgetHashTable = NULL;
-static Window wxGetParentWindow(Window window);
-
IMPLEMENT_DYNAMIC_CLASS(wxApp, wxEvtHandler)
BEGIN_EVENT_TABLE(wxApp, wxEvtHandler)
// Find the first wxWindow that corresponds to this event window
// TODO: may need to translate coordinates from actualWindow
// to window, if the receiving window != wxWindow window
- while (window && !(win = wxGetWindowFromTable(window)))
- window = wxGetParentWindow(window);
+ // while (window && !(win = wxGetWindowFromTable(window)))
+ // window = wxGetWindowParent(window);
+
+ // Because we're receiving events after a window
+ // has been destroyed, assume a 1:1 match between
+ // Window and wxWindow, so if it's not in the table,
+ // it must have been destroyed.
+
+ win = wxGetWindowFromTable(window);
+ if (!win)
+ return;
- // TODO: shouldn't all the ProcessEvents below
- // be win->GetEventHandler()->ProcessEvent?
switch (event->type)
{
case KeyPress:
if (event->xclient.message_type == wm_protocols)
{
- if (event->xclient.data.l[0] == wm_delete_window)
+ if ((Atom) (event->xclient.data.l[0]) == wm_delete_window)
{
if (win)
{
}
return;
}
+ case ConfigureNotify:
+ {
+ if (win)
+ {
+ wxSizeEvent sizeEvent( wxSize(event->xconfigure.width,event->xconfigure.height), win->GetId() );
+ sizeEvent.SetEventObject( win );
+
+ win->GetEventHandler()->ProcessEvent( sizeEvent );
+ }
+ }
case ResizeRequest:
{
/* Terry Gitnick <terryg@scientech.com> - 1/21/98
// Create an application context
bool wxApp::OnInitGui()
{
+ // Eventually this line will be removed, but for
+ // now we don't want to try popping up a dialog
+ // for error messages.
+ delete wxLog::SetActiveTarget(new wxLogStderr);
+ if (!wxAppBase::OnInitGui())
+ return FALSE;
+
// TODO: parse argv and get display to pass to XOpenDisplay
Display* dpy = XOpenDisplay(NULL);
m_initialDisplay = (WXDisplay*) dpy;
return (WXColormap) c;
}
-Window wxGetParentWindow(Window window)
+Window wxGetWindowParent(Window window)
{
Window parent, root = 0;
unsigned int noChildren = 0;
- if (XQueryTree((Display*) wxGetDisplay(), window, & root, & parent,
- NULL, & noChildren))
+ Window* children = NULL;
+ int res = XQueryTree((Display*) wxGetDisplay(), window, & root, & parent,
+ & children, & noChildren);
+ if (children)
+ XFree(children);
+ if (res)
return parent;
else
return (Window) 0;