+ // Use the 'real' MSW position
+ GetToolBar()->SetSize(0, 0, rect.xRight, th, wxSIZE_NO_ADJUSTMENTS);
+ }
+ }
+}
+#endif // wxUSE_TOOLBAR
+
+// propagate our state change to all child frames: this allows us to emulate X
+// Windows behaviour where child frames float independently of the parent one
+// on the desktop, but are iconized/restored with it
+void wxFrame::IconizeChildFrames(bool bIconize)
+{
+ for ( wxWindowList::Node *node = GetChildren().GetFirst();
+ node;
+ node = node->GetNext() )
+ {
+ wxWindow *win = node->GetData();
+
+ if ( win->IsKindOf(CLASSINFO(wxFrame)) )
+ {
+ ((wxFrame *)win)->Iconize(bIconize);
+ }
+ }
+}
+
+
+// make the window modal (all other windows unresponsive)
+void wxFrame::MakeModal(bool modal)
+{
+ if (modal) {
+ wxEnableTopLevelWindows(FALSE);
+ Enable(TRUE); // keep this window enabled
+ }
+ else {
+ wxEnableTopLevelWindows(TRUE);
+ }
+}
+
+
+// ===========================================================================
+// message processing
+// ===========================================================================
+
+// ---------------------------------------------------------------------------
+// preprocessing
+// ---------------------------------------------------------------------------
+
+bool wxFrame::OS2TranslateMessage(WXMSG* pMsg)
+{
+// TODO: if ( wxWindow::OS2TranslateMessage(pMsg) )
+// return TRUE;
+
+ // try the menu bar accels
+ wxMenuBar *menuBar = GetMenuBar();
+ if ( !menuBar )
+ return FALSE;
+
+// TODO: const wxAcceleratorTable& acceleratorTable = menuBar->GetAccelTable();
+// return acceleratorTable.Translate(this, pMsg);
+ return TRUE;
+}
+
+// ---------------------------------------------------------------------------
+// our private (non virtual) message handlers
+// ---------------------------------------------------------------------------
+
+bool wxFrame::HandlePaint()
+{
+ RECT rect;
+// TODO:
+// if ( GetUpdateRect(GetHwnd(), &rect, FALSE) )
+// {
+// if ( m_iconized )
+// {
+// HICON hIcon = m_icon.Ok() ? GetHiconOf(m_icon)
+// : (HICON)m_defaultIcon;
+//
+ // Hold a pointer to the dc so long as the OnPaint() message
+ // is being processed
+//
+// PAINTSTRUCT ps;
+// HDC hdc = ::BeginPaint(GetHwnd(), &ps);
+// // Erase background before painting or we get white background
+// OS2DefWindowProc(WM_ICONERASEBKGND, (WORD)(LONG)ps.hdc, 0L);
+//
+// if ( hIcon )
+// {
+// RECT rect;
+// TODO: ::GetClientRect(GetHwnd(), &rect);
+
+ // FIXME: why hardcoded?
+// static const int icon_width = 32;
+// static const int icon_height = 32;
+//
+// int icon_x = (int)((rect.right - icon_width)/2);
+// int icon_y = (int)((rect.bottom - icon_height)/2);
+//
+// TODO: ::DrawIcon(hdc, icon_x, icon_y, hIcon);
+// }
+//
+// TODO: ::EndPaint(GetHwnd(), &ps);
+//
+// return TRUE;
+// }
+// else
+// {
+// return wxWindow::HandlePaint();
+// }
+// }
+// else
+// {
+// // nothing to paint - processed
+// return TRUE;
+// }
+ return TRUE;
+}
+
+bool wxFrame::HandleSize(int x, int y, WXUINT id)
+{
+ bool processed = FALSE;
+
+/* switch ( id )
+ {
+ case SIZENORMAL:
+ // only do it it if we were iconized before, otherwise resizing the
+ // parent frame has a curious side effect of bringing it under it's
+ // children
+ if ( !m_iconized )
+ break;
+
+ // restore all child frames too
+ IconizeChildFrames(FALSE);
+
+ // fall through
+
+ case SIZEFULLSCREEN:
+ m_iconized = FALSE;
+ break;
+
+ case SIZEICONIC:
+ // iconize all child frames too
+ IconizeChildFrames(TRUE);
+
+ m_iconized = TRUE;
+ break;
+ }
+*/
+ if ( !m_iconized )
+ {
+ PositionStatusBar();
+ PositionToolBar();
+
+ wxSizeEvent event(wxSize(x, y), m_windowId);
+ event.SetEventObject( this );
+ processed = GetEventHandler()->ProcessEvent(event);
+ }
+
+ return processed;
+}
+
+bool wxFrame::HandleCommand(WXWORD id, WXWORD cmd, WXHWND control)
+{
+ if ( control )
+ {
+ // In case it's e.g. a toolbar.
+ wxWindow *win = wxFindWinFromHandle(control);
+ if ( win )
+// TODO: return win->OS2Command(cmd, id);
+ return TRUE;
+ }
+
+ // handle here commands from menus and accelerators
+ if ( cmd == 0 || cmd == 1 )
+ {
+ if ( wxCurrentPopupMenu )
+ {
+ wxMenu *popupMenu = wxCurrentPopupMenu;
+ wxCurrentPopupMenu = NULL;
+
+// return popupMenu->OS2Command(cmd, id);
+ return TRUE;