#include "wx/brush.h"
#include "wx/cursor.h"
#include "wx/icon.h"
-#include "wx/palette.h"
-#include "wx/dc.h"
#include "wx/dialog.h"
#include "wx/msgdlg.h"
#include "wx/log.h"
XErrorHandlerFunc gs_pfnXErrorHandler = 0;
-static Window XGetParent(Window window);
-
static int wxXErrorHandler(Display *dpy, XErrorEvent *xevent)
{
// just forward to the default handler for now
// TODO: may need to translate coordinates from actualWindow
// to window, if the receiving window != wxWindow window
while (window && !(win = wxGetWindowFromTable(window)))
- window = XGetParent(window);
+ window = wxGetParentWindow(window);
// TODO: shouldn't all the ProcessEvents below
// be win->GetEventHandler()->ProcessEvent?
{
case KeyPress:
{
+ if (win && !win->IsEnabled())
+ return;
+
if (CheckForAccelerator(_event))
{
// Do nothing! We intercepted and processed the event as an
// We didn't process wxEVT_KEY_DOWN, so send
// wxEVT_CHAR
- if (!win->ProcessEvent( keyEvent ))
+ if (!win->GetEventHandler()->ProcessEvent( keyEvent ))
{
keyEvent.SetEventType(wxEVT_CHAR);
- win->ProcessEvent( keyEvent );
+ win->GetEventHandler()->ProcessEvent( keyEvent );
}
// We intercepted and processed the key down event
}
case KeyRelease:
{
+ if (win && !win->IsEnabled())
+ return;
+
if (win)
{
wxKeyEvent keyEvent(wxEVT_KEY_UP);
wxTranslateKeyEvent(keyEvent, win, window, event);
- win->ProcessEvent( keyEvent );
+ win->GetEventHandler()->ProcessEvent( keyEvent );
}
return;
}
HandlePropertyChange(_event);
return;
}
+ case ClientMessage:
+ {
+ Atom wm_delete_window = XInternAtom(wxGlobalDisplay(), "WM_DELETE_WINDOW", True);;
+ Atom wm_protocols = XInternAtom(wxGlobalDisplay(), "WM_PROTOCOLS", True);;
+
+ if (event->xclient.message_type == wm_protocols)
+ {
+ if (event->xclient.data.l[0] == wm_delete_window)
+ {
+ if (win)
+ {
+ win->Close(FALSE);
+ }
+ }
+ }
+ return;
+ }
case ResizeRequest:
{
/* Terry Gitnick <terryg@scientech.com> - 1/21/98
wxSizeEvent sizeEvent(sz, win->GetId());
sizeEvent.SetEventObject(win);
- win->ProcessEvent( sizeEvent );
+ win->GetEventHandler()->ProcessEvent( sizeEvent );
}
return;
case ButtonRelease:
case MotionNotify:
{
+ if (win && !win->IsEnabled())
+ return;
+
if (win)
{
wxMouseEvent wxevent;
wxTranslateMouseEvent(wxevent, win, window, event);
- win->ProcessEvent( wxevent );
+ win->GetEventHandler()->ProcessEvent( wxevent );
}
return;
}
{
wxFocusEvent focusEvent(wxEVT_SET_FOCUS, win->GetId());
focusEvent.SetEventObject(win);
- win->ProcessEvent(focusEvent);
+ win->GetEventHandler()->ProcessEvent(focusEvent);
}
break;
}
{
wxFocusEvent focusEvent(wxEVT_KILL_FOCUS, win->GetId());
focusEvent.SetEventObject(win);
- win->ProcessEvent(focusEvent);
+ win->GetEventHandler()->ProcessEvent(focusEvent);
}
break;
}
+ case DestroyNotify:
+ {
+ // Do we want to process this (for top-level windows)?
+ // But we want to be able to veto closes, anyway
+ break;
+ }
default:
{
break;
return (WXColormap) c;
}
-static Window XGetParent(Window window)
+Window wxGetWindowParent(Window window)
{
Window parent, root = 0;
unsigned int noChildren = 0;
// Find the first wxWindow that corresponds to this event window
while (window && !(win = wxGetWindowFromTable(window)))
- window = XGetParent(window);
+ window = wxGetWindowParent(window);
if (!window || !win)
return FALSE;