1 ///////////////////////////////////////////////////////////////////////////// 
   2 // Name:        src/os2/window.cpp 
   4 // Author:      David Webster 
   8 // Copyright:   (c) David Webster 
   9 // Licence:     wxWindows licence 
  10 ///////////////////////////////////////////////////////////////////////////// 
  13 // For compilers that support precompilation, includes "wx.h". 
  15 #include "wx/wxprec.h" 
  21     #include "wx/window.h" 
  25     #include "wx/dcclient.h" 
  29     #include "wx/layout.h" 
  30     #include "wx/checkbox.h" 
  31     #include "wx/combobox.h" 
  32     #include "wx/dialog.h" 
  34     #include "wx/listbox.h" 
  35     #include "wx/button.h" 
  36     #include "wx/bmpbuttn.h" 
  37     #include "wx/msgdlg.h" 
  38     #include "wx/scrolwin.h" 
  39     #include "wx/radiobox.h" 
  40     #include "wx/radiobut.h" 
  41     #include "wx/slider.h" 
  42     #include "wx/statbox.h" 
  43     #include "wx/statusbr.h" 
  44     #include "wx/toolbar.h" 
  45     #include "wx/settings.h" 
  50     #include "wx/ownerdrw.h" 
  53 #if     wxUSE_DRAG_AND_DROP 
  57 #include "wx/menuitem.h" 
  60 #include "wx/os2/private.h" 
  63     #include "wx/tooltip.h" 
  67     #include "wx/notebook.h" 
  78 #include "wx/textctrl.h" 
  83 // Place compiler, OS specific includes here 
  87 // Standard macros -- these are for OS/2 PM, but most GUI's have something similar 
  91 //  SHORT1FROMMP -- LOWORD 
  93     #define GET_X_LPARAM(mp) ((unsigned short)(unsigned long)(mp)) 
  95 //  SHORT2FROMMP -- HIWORD 
  97     #define GET_Y_LPARAM(mp) ((unsigned short)(unsigned long)(mp >> 16)) 
  98 #endif // GET_X_LPARAM 
 100 #ifndef CW_USEDEFAULT 
 101 #  define CW_USEDEFAULT    ((int)0x80000000) 
 105     #define VK_OEM_1        0xBA 
 106     #define VK_OEM_PLUS     0xBB 
 107     #define VK_OEM_COMMA    0xBC 
 108     #define VK_OEM_MINUS    0xBD 
 109     #define VK_OEM_PERIOD   0xBE 
 110     #define VK_OEM_2        0xBF 
 111     #define VK_OEM_3        0xC0 
 112     #define VK_OEM_4        0xDB 
 113     #define VK_OEM_5        0xDC 
 114     #define VK_OEM_6        0xDD 
 115     #define VK_OEM_7        0xDE 
 118 // --------------------------------------------------------------------------- 
 120 // --------------------------------------------------------------------------- 
 123 // The last PM message we got (MT-UNSAFE) 
 127 #if wxUSE_MENUS_NATIVE 
 128 wxMenu
*                   wxCurrentPopupMenu 
= NULL
; 
 129 #endif // wxUSE_MENUS_NATIVE 
 131 // --------------------------------------------------------------------------- 
 133 // --------------------------------------------------------------------------- 
 136 // the window proc for all our windows; most gui's have something similar 
 138 MRESULT EXPENTRY 
wxWndProc( HWND hWnd
 
 145     const wxChar 
*wxGetMessageName(int message
); 
 148 wxWindowOS2
* FindWindowForMouseEvent( wxWindow
* pWin
 
 152 void         wxRemoveHandleAssociation(wxWindowOS2
* pWin
); 
 153 void         wxAssociateWinWithHandle( HWND         hWnd
 
 156 wxWindow
* wxFindWinFromHandle(WXHWND hWnd
); 
 159 // get the current state of SHIFT/CTRL keys 
 161 static inline bool IsShiftDown() { return (::WinGetKeyState(HWND_DESKTOP
, VK_SHIFT
) & 0x8000) != 0; } 
 162 static inline bool IsCtrlDown() { return (::WinGetKeyState(HWND_DESKTOP
, VK_CTRL
) & 0x8000) != 0; } 
 164 static wxWindow
*                    gpWinBeingCreated 
= NULL
; 
 166 // --------------------------------------------------------------------------- 
 168 // --------------------------------------------------------------------------- 
 170 // in wxUniv-OS/2 this class is abstract because it doesn't have DoPopupMenu() 
 172 #ifdef __WXUNIVERSAL__ 
 173     IMPLEMENT_ABSTRACT_CLASS(wxWindowOS2
, wxWindowBase
) 
 175     IMPLEMENT_DYNAMIC_CLASS(wxWindow
, wxWindowBase
) 
 176 #endif // __WXUNIVERSAL__/__WXPM__ 
 178 BEGIN_EVENT_TABLE(wxWindowOS2
, wxWindowBase
) 
 179     EVT_ERASE_BACKGROUND(wxWindowOS2::OnEraseBackground
) 
 180     EVT_SYS_COLOUR_CHANGED(wxWindowOS2::OnSysColourChanged
) 
 181     EVT_IDLE(wxWindowOS2::OnIdle
) 
 182     EVT_SET_FOCUS(wxWindowOS2::OnSetFocus
) 
 185 // =========================================================================== 
 187 // =========================================================================== 
 189 // --------------------------------------------------------------------------- 
 190 // wxWindow utility functions 
 191 // --------------------------------------------------------------------------- 
 194 // Find an item given the PM Window id 
 196 wxWindow
* wxWindowOS2::FindItem( 
 201     wxControl
*                      pItem 
= wxDynamicCast(this, wxControl
); 
 206         // I it we or one of our "internal" children? 
 208         if (pItem
->GetId() == lId
 
 209 #ifndef __WXUNIVERSAL__ 
 210             || (pItem
->GetSubcontrols().Index(lId
) != wxNOT_FOUND
) 
 217 #endif // wxUSE_CONTROLS 
 219     wxWindowList::compatibility_iterator  current 
= GetChildren().GetFirst(); 
 223         wxWindow
*                   pChildWin 
= current
->GetData(); 
 224         wxWindow
*                   pWnd 
= pChildWin
->FindItem(lId
); 
 229         current 
= current
->GetNext(); 
 232 } // end of wxWindowOS2::FindItem 
 235 // Find an item given the PM Window handle 
 237 wxWindow
* wxWindowOS2::FindItemByHWND( 
 242     wxWindowList::compatibility_iterator current 
= GetChildren().GetFirst(); 
 246         wxWindow
*                   pParent 
= current
->GetData(); 
 249         // Do a recursive search. 
 251         wxWindow
*                   pWnd 
= pParent
->FindItemByHWND(hWnd
); 
 258             || pParent
->IsKindOf(CLASSINFO(wxControl
)) 
 259 #endif // wxUSE_CONTROLS 
 262             wxWindow
*               pItem 
= current
->GetData(); 
 264             if (pItem
->GetHWND() == hWnd
) 
 268                 if (pItem
->ContainsHWND(hWnd
)) 
 272         current 
= current
->GetNext(); 
 275 } // end of wxWindowOS2::FindItemByHWND 
 278 // Default command handler 
 280 bool wxWindowOS2::OS2Command( WXUINT 
WXUNUSED(uParam
), 
 281                               WXWORD 
WXUNUSED(uId
) ) 
 286 // ---------------------------------------------------------------------------- 
 287 // constructors and such 
 288 // ---------------------------------------------------------------------------- 
 290 void wxWindowOS2::Init() 
 295     m_bWinCaptured 
= false; 
 297     m_fnOldWndProc          
= NULL
; 
 299     m_bMouseInWindow        
= false; 
 300     m_bLastKeydownProcessed 
= false; 
 301     m_pChildrenDisabled     
= NULL
; 
 308     m_hWndScrollBarHorz 
= 0L; 
 309     m_hWndScrollBarVert 
= 0L; 
 311     memset(&m_vWinSwp
, '\0', sizeof (SWP
)); 
 314     // Pass WM_GETDLGCODE to DefWindowProc() 
 320     m_bBackgroundTransparent 
= false; 
 323     // As all windows are created with WS_VISIBLE style... 
 327 #if wxUSE_MOUSEEVENT_HACK 
 330     m_nLastMouseEvent 
= -1; 
 331 #endif // wxUSE_MOUSEEVENT_HACK 
 332 } // wxWindowOS2::Init 
 337 wxWindowOS2::~wxWindowOS2() 
 339     m_isBeingDeleted 
= true; 
 341     for (wxWindow
* pWin 
= GetParent(); pWin
; pWin 
= pWin
->GetParent()) 
 343         wxTopLevelWindow
*           pFrame 
= wxDynamicCast(pWin
, wxTopLevelWindow
); 
 347             if (pFrame
->GetLastFocus() == this) 
 348                 pFrame
->SetLastFocus(NULL
); 
 356         if(!::WinDestroyWindow(GetHWND())) 
 357             wxLogLastError(wxT("DestroyWindow")); 
 359         // remove hWnd <-> wxWindow association 
 361         wxRemoveHandleAssociation(this); 
 363     delete m_pChildrenDisabled
; 
 364 } // end of wxWindowOS2::~wxWindowOS2 
 366 // real construction (Init() must have been called before!) 
 367 bool wxWindowOS2::Create( wxWindow
*       pParent
, 
 372                           const wxString
& rName 
) 
 374     HWND hParent 
= NULLHANDLE
; 
 375     ULONG ulCreateFlags 
= 0; 
 376     WXDWORD dwExStyle 
= 0; 
 378     wxCHECK_MSG(pParent
, false, wxT("can't create wxWindow without parent")); 
 382     // wxGTK doesn't allow to create controls with static box as the parent so 
 383     // this will result in a crash when the program is ported to wxGTK - warn 
 386     // the correct solution is to create the controls as siblings of the 
 389     wxASSERT_MSG( !wxDynamicCast(pParent
, wxStaticBox
), 
 390                   _T("wxStaticBox can't be used as a window parent!") ); 
 391 #endif // wxUSE_STATBOX 
 393      // Ensure groupbox backgrounds are painted 
 394      if (IsKindOf(CLASSINFO(wxPanel
))) 
 395          lStyle 
&= ~wxCLIP_CHILDREN
; 
 397     if ( !CreateBase( pParent
 
 409         pParent
->AddChild(this); 
 410         hParent 
= GetWinHwnd(pParent
); 
 412         if (pParent
->IsKindOf(CLASSINFO(wxScrolledWindow
))) 
 413             ulCreateFlags 
|= WS_CLIPSIBLINGS
; 
 417     // Most wxSTYLES are really PM Class specific styles and will be 
 418     // set in those class create procs.  PM's basic windows styles are 
 421     ulCreateFlags 
|=  OS2GetCreateWindowFlags(&dwExStyle
); 
 424 #ifdef __WXUNIVERSAL__ 
 425     // no 3d effects, we draw them ourselves 
 427 #endif // !wxUniversal 
 428     if (lStyle 
& wxPOPUP_WINDOW
) 
 430         ulCreateFlags 
&= ~WS_VISIBLE
; 
 435         ulCreateFlags 
|= WS_VISIBLE
; 
 439     // Generic OS/2 Windows have no Control Data but other classes 
 440     // that call OS2Create may have some. 
 442     return(OS2Create( (PSZ
)wxCanvasClassName
 
 447                      ,NULL         
// Control Data 
 451 } // end of wxWindowOS2::Create 
 453 // --------------------------------------------------------------------------- 
 455 // --------------------------------------------------------------------------- 
 457 void wxWindowOS2::SetFocus() 
 459     HWND                            hWnd 
= GetHwnd(); 
 460     wxCHECK_RET( hWnd
, _T("can't set focus to invalid window") ); 
 463         ::WinSetFocus(HWND_DESKTOP
, hWnd
); 
 464 } // end of wxWindowOS2::SetFocus 
 466 void wxWindowOS2::SetFocusFromKbd() 
 469     // Nothing else to do under OS/2 
 471     wxWindowBase::SetFocusFromKbd(); 
 472 } // end of wxWindowOS2::SetFocus 
 474 wxWindow
* wxWindowBase::DoFindFocus() 
 476     HWND                            hWnd 
= ::WinQueryFocus(HWND_DESKTOP
); 
 480         return wxFindWinFromHandle((WXHWND
)hWnd
); 
 483 } // wxWindowBase::DoFindFocus 
 485 bool wxWindowOS2::Enable( bool bEnable 
) 
 487     if (!wxWindowBase::Enable(bEnable
)) 
 490     HWND                            hWnd 
= GetHwnd(); 
 493         ::WinEnableWindow(hWnd
, (BOOL
)bEnable
); 
 496     // The logic below doesn't apply to the top level windows -- otherwise 
 497     // showing a modal dialog would result in total greying out (and ungreying 
 498     // out later) of everything which would be really ugly 
 503     wxWindowList::compatibility_iterator     node 
= GetChildren().GetFirst(); 
 507         wxWindow
*                   pChild 
= node
->GetData(); 
 512             // Enable the child back unless it had been disabled before us 
 514             if (!m_pChildrenDisabled 
|| !m_pChildrenDisabled
->Find(pChild
)) 
 517         else // we're being disabled 
 519             if (pChild
->IsEnabled()) 
 522                 // Disable it as children shouldn't stay enabled while the 
 527             else // child already disabled, remember it 
 530                 // Have we created the list of disabled children already? 
 532                 if (!m_pChildrenDisabled
) 
 533                     m_pChildrenDisabled 
= new wxWindowList
; 
 534                 m_pChildrenDisabled
->Append(pChild
); 
 537         node 
= node
->GetNext(); 
 539     if (bEnable 
&& m_pChildrenDisabled
) 
 542         // We don't need this list any more, don't keep unused memory 
 544         delete m_pChildrenDisabled
; 
 545         m_pChildrenDisabled 
= NULL
; 
 548 } // end of wxWindowOS2::Enable 
 550 bool wxWindowOS2::Show( bool bShow 
) 
 552     if (!wxWindowBase::Show(bShow
)) 
 555     HWND                            hWnd 
= GetHwnd(); 
 557     ::WinShowWindow(hWnd
, bShow
); 
 561         ::WinSetWindowPos(hWnd
, HWND_TOP
, 0, 0, 0, 0, SWP_ACTIVATE 
| SWP_ZORDER
); 
 564 } // end of wxWindowOS2::Show 
 566 void wxWindowOS2::Raise() 
 568     ::WinSetWindowPos(GetHwnd(), HWND_TOP
, 0, 0, 0, 0, SWP_ZORDER 
| SWP_ACTIVATE
); 
 569 } // end of wxWindowOS2::Raise 
 571 void wxWindowOS2::Lower() 
 573     ::WinSetWindowPos(GetHwnd(), HWND_BOTTOM
, 0, 0, 0, 0, SWP_ZORDER 
| SWP_DEACTIVATE
); 
 574 } // end of wxWindowOS2::Lower 
 576 void wxWindowOS2::SetLabel( const wxString
& label 
) 
 578     ::WinSetWindowText(GetHwnd(), (PSZ
)label
.c_str()); 
 579 } // end of wxWindowOS2::SetLabel 
 581 wxString 
wxWindowOS2::GetLabel() const 
 583     return wxGetWindowText(GetHWND()); 
 584 } // end of wxWindowOS2::GetLabel 
 586 void wxWindowOS2::DoCaptureMouse() 
 588     HWND hWnd 
= GetHwnd(); 
 590     if (hWnd 
&& !m_bWinCaptured
) 
 592         ::WinSetCapture(HWND_DESKTOP
, hWnd
); 
 593         m_bWinCaptured 
= true; 
 595 } // end of wxWindowOS2::DoCaptureMouse 
 597 void wxWindowOS2::DoReleaseMouse() 
 601         ::WinSetCapture(HWND_DESKTOP
, NULLHANDLE
); 
 602         m_bWinCaptured 
= false; 
 604 } // end of wxWindowOS2::ReleaseMouse 
 606 /* static */ wxWindow
* wxWindowBase::GetCapture() 
 608     HWND hwnd 
= ::WinQueryCapture(HWND_DESKTOP
); 
 609     return hwnd 
? wxFindWinFromHandle((WXHWND
)hwnd
) : (wxWindow 
*)NULL
; 
 610 } // end of wxWindowBase::GetCapture 
 612 bool wxWindowOS2::SetFont( const wxFont
& rFont 
) 
 614     if (!wxWindowBase::SetFont(rFont
)) 
 620     HWND hWnd 
= GetHwnd(); 
 622     wxOS2SetFont( hWnd
, rFont 
); 
 624 } // end of wxWindowOS2::SetFont 
 626 // check if base implementation is OK 
 627 bool wxWindowOS2::SetCursor( const wxCursor
& rCursor
) 
 629     if ( !wxWindowBase::SetCursor(rCursor
)) 
 635     if ( m_cursor
.Ok() ) { 
 636         HWND                            hWnd 
= GetHwnd(); 
 640         ::WinQueryPointerPos(HWND_DESKTOP
, &vPoint
); 
 641         ::WinQueryWindowRect(hWnd
, &vRect
); 
 643         if (::WinPtInRect(vHabmain
, &vRect
, &vPoint
) && !wxIsBusy()) 
 645             ::WinSetPointer(HWND_DESKTOP
, (HPOINTER
)m_cursor
.GetHCURSOR()); 
 649 } // end of wxWindowOS2::SetCursor 
 651 void wxWindowOS2::WarpPointer( 
 660     ::WinQueryWindowRect(GetHwnd(), &vRect
); 
 664     ::WinSetPointerPos(HWND_DESKTOP
, (LONG
)nX
, (LONG
)(nY
)); 
 665 } // end of wxWindowOS2::WarpPointer 
 668 // --------------------------------------------------------------------------- 
 670 // --------------------------------------------------------------------------- 
 672 int  wxWindowOS2::GetScrollPos( 
 676     if (nOrient 
== wxHORIZONTAL
) 
 677         return((int)::WinSendMsg(m_hWndScrollBarHorz
, SBM_QUERYPOS
, (MPARAM
)NULL
, (MPARAM
)NULL
)); 
 679         return((int)::WinSendMsg(m_hWndScrollBarVert
, SBM_QUERYPOS
, (MPARAM
)NULL
, (MPARAM
)NULL
)); 
 680 } // end of wxWindowOS2::GetScrollPos 
 682 int wxWindowOS2::GetScrollRange( 
 688     if (nOrient 
== wxHORIZONTAL
) 
 689         mr 
= ::WinSendMsg(m_hWndScrollBarHorz
, SBM_QUERYRANGE
, (MPARAM
)NULL
, (MPARAM
)NULL
); 
 691         mr 
= ::WinSendMsg(m_hWndScrollBarVert
, SBM_QUERYRANGE
, (MPARAM
)NULL
, (MPARAM
)NULL
); 
 692     return((int)SHORT2FROMMR(mr
)); 
 693 } // end of wxWindowOS2::GetScrollRange 
 695 int wxWindowOS2::GetScrollThumb( 
 699     if (nOrient 
== wxHORIZONTAL 
) 
 700         return m_nXThumbSize
; 
 702         return m_nYThumbSize
; 
 703 } // end of wxWindowOS2::GetScrollThumb 
 705 void wxWindowOS2::SetScrollPos( 
 708 , bool                              WXUNUSED(bRefresh
) 
 711     if (nOrient 
== wxHORIZONTAL 
) 
 712         ::WinSendMsg(m_hWndScrollBarHorz
, SBM_SETPOS
, (MPARAM
)nPos
, (MPARAM
)NULL
); 
 714         ::WinSendMsg(m_hWndScrollBarVert
, SBM_SETPOS
, (MPARAM
)nPos
, (MPARAM
)NULL
); 
 715 } // end of wxWindowOS2::SetScrollPos 
 717 void wxWindowOS2::SetScrollbar( int  nOrient
, 
 721                                 bool WXUNUSED(bRefresh
) ) 
 723     HWND                            hWnd 
= GetHwnd(); 
 724     int                             nOldRange 
= nRange 
- nThumbVisible
; 
 725     int                             nRange1 
= nOldRange
; 
 726     int                             nPageSize 
= nThumbVisible
; 
 727     int         nVSBWidth  
= wxSystemSettingsNative::GetMetric(wxSYS_VSCROLL_X
, 
 729     int         nHSBHeight 
= wxSystemSettingsNative::GetMetric(wxSYS_HSCROLL_Y
, 
 733     ULONG                           ulStyle 
= WS_VISIBLE 
| WS_SYNCPAINT
; 
 738     wxWindow
*                       pParent 
= GetParent(); 
 740     if (pParent 
&& pParent
->IsKindOf(CLASSINFO(wxFrame
))) 
 744         pFrame 
= wxDynamicCast(pParent
, wxFrame
); 
 745         hWndParent 
= pFrame
->GetFrame(); 
 746         hWndClient 
= GetHwndOf(pParent
); 
 751             hWndParent 
= GetHwndOf(pParent
); 
 753             hWndParent 
= GetHwnd(); 
 754         hWndClient 
= hWndParent
; 
 756     ::WinQueryWindowPos(hWndClient
, &vSwp
); 
 757     ::WinQueryWindowPos(hWnd
, &vSwpOwner
); 
 759     if (nPageSize 
> 1 && nRange 
> 0) 
 761         nRange1 
+= (nPageSize 
- 1); 
 764     vInfo
.cb 
= sizeof(SBCDATA
); 
 766     vInfo
.posLast 
= (SHORT
)nRange1
; 
 767     vInfo
.posThumb 
= (SHORT
)nPos
; 
 769     if (nOrient 
== wxHORIZONTAL 
) 
 772         if (m_hWndScrollBarHorz 
== 0L) 
 775             // Since the scrollbars are usually created before the owner is 
 776             // sized either via an OnSize event directly or via sizers or 
 777             // layout constraints, we will initially just use the coords of 
 778             // the parent window (this is usually a frame client window). But 
 779             // the bars themselves, are children of the parent frame (i.e 
 780             // siblings of the frame client.  The owner, however is the actual 
 781             // window being scrolled (or at least the one responsible for 
 782             // handling the scroll events). The owner will be resized later, 
 783             // as it is usually a child of a top level window, and when that 
 784             // is done its scrollbars will be resized and repositioned as well. 
 786             m_hWndScrollBarHorz 
= ::WinCreateWindow( hWndParent
 
 804             // The owner (the scrolled window) is a child of the Frame's 
 805             // client window, usually.  The scrollbars are children of the 
 806             // frame, itself, and thus are positioned relative to the frame's 
 807             // origin, not the frame's client window origin. 
 808             // The starting x position is the same as the starting x position 
 809             // of the owner, but in terms of the parent frame. 
 810             // The starting y position is wxSYS_HSCROLL_Y pels below the 
 811             // origin of the owner in terms of the parent frame. 
 812             // The horz bar is the same width as the owner and wxSYS_HSCROLL_Y 
 815             if (nRange1 
>= nThumbVisible
) 
 817                 ::WinSetWindowPos( m_hWndScrollBarHorz
 
 819                                   ,vSwp
.x 
+ vSwpOwner
.x
 
 820                                   ,(vSwp
.y 
+ vSwpOwner
.y
) - nHSBHeight
 
 823                                   ,SWP_MOVE 
| SWP_SIZE 
| SWP_SHOW 
| SWP_ACTIVATE 
| SWP_ZORDER
 
 825                 ::WinSendMsg( m_hWndScrollBarHorz
 
 828                              ,MPFROM2SHORT(0, (SHORT
)nRange1
) 
 830                 ::WinSendMsg( m_hWndScrollBarHorz
 
 832                              ,MPFROM2SHORT( (SHORT
)nThumbVisible
 
 839                 ::WinShowWindow(m_hWndScrollBarHorz
, FALSE
); 
 845         if (m_hWndScrollBarVert 
== 0L) 
 848             // Since the scrollbars are usually created before the owner is 
 849             // sized either via an OnSize event directly or via sizers or 
 850             // layout constraints, we will initially just use the coords of 
 851             // the parent window (this is usually a frame client window). But 
 852             // the bars themselves, are children of the parent frame (i.e 
 853             // siblings of the frame client.  The owner, however is the actual 
 854             // window being scrolled (or at least the one responsible for 
 855             // handling the scroll events). The owner will be resized later, 
 856             // as it is usually a child of a top level window, and when that 
 857             // is done its scrollbars will be resized and repositioned as well. 
 859             m_hWndScrollBarVert 
= ::WinCreateWindow( hWndParent
 
 863                                                     ,vSwp
.x 
+ vSwp
.cx 
- nVSBWidth
 
 866                                                     ,vSwp
.cy 
- nHSBHeight
 
 877             // The owner (the scrolled window) is a child of the Frame's 
 878             // client window, usually.  The scrollbars are children of the 
 879             // frame, itself and thus are positioned relative to the frame's 
 880             // origin, not the frame's client window's origin. 
 881             // Thus, the x position will be frame client's x (usually a few 
 882             // pels inside the parent frame, plus the width of the owner. 
 883             // Since we may be using sizers or layout constraints for multiple 
 884             // child scrolled windows, the y position will be the frame client's 
 885             // y pos plus the scrolled windows y position, yielding the y 
 886             // position of the scrollbar relative to the parent frame (the vert 
 887             // scrollbar is on the right and starts at the bottom of the 
 889             // It is wxSYS_VSCROLL_X pels wide and the same height as the owner. 
 891             if (nRange1 
>= nThumbVisible
) 
 893                 ::WinSetWindowPos( m_hWndScrollBarVert
 
 895                                   ,vSwp
.x 
+ vSwpOwner
.x 
+ vSwpOwner
.cx
 
 896                                   ,vSwp
.y 
+ vSwpOwner
.y
 
 899                                   ,SWP_ACTIVATE 
| SWP_MOVE 
| SWP_SIZE 
| SWP_SHOW
 
 901                 ::WinSendMsg( m_hWndScrollBarVert
 
 904                              ,MPFROM2SHORT(0, (SHORT
)nRange1
) 
 906                 ::WinSendMsg( m_hWndScrollBarVert
 
 908                              ,MPFROM2SHORT( (SHORT
)nThumbVisible
 
 915                 ::WinShowWindow(m_hWndScrollBarVert
, FALSE
); 
 917         m_nYThumbSize 
= nThumbVisible
; 
 919 } // end of wxWindowOS2::SetScrollbar 
 922 void wxWindowOS2::ScrollWindow( int nDx
, 
 924                                 const wxRect
* pRect 
) 
 928     ::WinQueryWindowRect(GetHwnd(), &vRect
); 
 929     int height 
= vRect
.yTop
; 
 932         vRect
.xLeft   
= pRect
->x
; 
 933         vRect
.yTop    
= height 
- pRect
->y
; 
 934         vRect
.xRight  
= pRect
->x 
+ pRect
->width
; 
 935         vRect
.yBottom 
= vRect
.yTop 
- pRect
->height
; 
 937     nDy 
*= -1; // flip the sign of Dy as OS/2 is opposite Windows. 
 938     ::WinScrollWindow( GetHwnd() 
 945                       ,SW_SCROLLCHILDREN 
| SW_INVALIDATERGN
 
 947 } // end of wxWindowOS2::ScrollWindow 
 949 // --------------------------------------------------------------------------- 
 951 // --------------------------------------------------------------------------- 
 953 void wxWindowOS2::SubclassWin( 
 957     HWND                            hwnd 
= (HWND
)hWnd
; 
 959     wxCHECK_RET(::WinIsWindow(vHabmain
, hwnd
), wxT("invalid HWND in SubclassWin") ); 
 960     wxAssociateWinWithHandle( hWnd
 
 963     if (!wxCheckWindowWndProc( hWnd
 
 964                               ,(WXFARPROC
)wxWndProc
 
 967         m_fnOldWndProc 
= (WXFARPROC
) ::WinSubclassWindow(hwnd
, (PFNWP
)wxWndProc
); 
 971         m_fnOldWndProc 
= (WXFARPROC
)NULL
; 
 973 } // end of wxWindowOS2::SubclassWin 
 975 void wxWindowOS2::UnsubclassWin() 
 978     // Restore old Window proc 
 980     HWND                            hwnd 
= GetHWND(); 
 984         wxCHECK_RET( ::WinIsWindow(vHabmain
, hwnd
), wxT("invalid HWND in UnsubclassWin") ); 
 986         PFNWP                       fnProc 
= (PFNWP
)::WinQueryWindowPtr(hwnd
, QWP_PFNWP
); 
 988         if ( (m_fnOldWndProc 
!= 0) && (fnProc 
!= (PFNWP
) m_fnOldWndProc
)) 
 990             WinSubclassWindow(hwnd
, (PFNWP
)m_fnOldWndProc
); 
 994 } // end of wxWindowOS2::UnsubclassWin 
 996 bool wxCheckWindowWndProc( 
 998 , WXFARPROC                         fnWndProc
 
1001     static char                     zBuffer
[512]; 
1004     ::WinQueryClassName((HWND
)hWnd
, (LONG
)512, (PCH
)zBuffer
); 
1005     ::WinQueryClassInfo(wxGetInstance(), (PSZ
)zBuffer
, &vCls
); 
1006     return(fnWndProc 
== (WXFARPROC
)vCls
.pfnWindowProc
); 
1007 } // end of WinGuiBase_CheckWindowWndProc 
1009 void wxWindowOS2::SetWindowStyleFlag( 
1013     long                            lFlagsOld 
= GetWindowStyleFlag(); 
1015     if (lFlags 
== lFlagsOld
) 
1019     // Update the internal variable 
1021     wxWindowBase::SetWindowStyleFlag(lFlags
); 
1024     // Now update the Windows style as well if needed - and if the window had 
1025     // been already created 
1031     WXDWORD                         dwExstyleOld
; 
1032     long                            lStyle 
= OS2GetStyle( lFlags
 
1035     long                            lStyleOld 
= OS2GetStyle( lFlagsOld
 
1039     if (lStyle 
!= lStyleOld
) 
1042         // Some flags (e.g. WS_VISIBLE or WS_DISABLED) should not be changed by 
1043         // this function so instead of simply setting the style to the new 
1044         // value we clear the bits which were set in styleOld but are set in 
1045         // the new one and set the ones which were not set before 
1047         long                        lStyleReal 
= ::WinQueryWindowULong(GetHwnd(), QWL_STYLE
); 
1049         lStyleReal 
&= ~lStyleOld
; 
1050         lStyleReal 
|= lStyle
; 
1052         ::WinSetWindowULong(GetHwnd(), QWL_STYLE
, lStyleReal
); 
1054 } // end of wxWindowOS2::SetWindowStyleFlag 
1056 WXDWORD 
wxWindowOS2::OS2GetStyle( long     lFlags
, 
1057                                   WXDWORD
* WXUNUSED(pdwExstyle
) ) const 
1059     WXDWORD                         dwStyle 
= 0L; 
1061     if (lFlags 
& wxCLIP_CHILDREN 
) 
1062         dwStyle 
|= WS_CLIPCHILDREN
; 
1064     if (lFlags 
& wxCLIP_SIBLINGS 
) 
1065         dwStyle 
|= WS_CLIPSIBLINGS
; 
1068 } // end of wxWindowOS2::OS2GetStyle 
1071 // Make a Windows extended style from the given wxWidgets window style 
1073 WXDWORD 
wxWindowOS2::MakeExtendedStyle( 
1075 , bool                              bEliminateBorders
 
1079    // Simply fill out with wxWindow extended styles.  We'll conjure 
1080    // something up in OS2Create and all window redrawing pieces later 
1082     WXDWORD                         dwStyle 
= 0; 
1084     if (lStyle 
& wxTRANSPARENT_WINDOW 
) 
1085         dwStyle 
|= wxTRANSPARENT_WINDOW
; 
1087     if (!bEliminateBorders
) 
1089         if (lStyle 
& wxSUNKEN_BORDER
) 
1090             dwStyle 
|= wxSUNKEN_BORDER
; 
1091         if (lStyle 
& wxDOUBLE_BORDER
) 
1092             dwStyle 
|= wxDOUBLE_BORDER
; 
1093         if (lStyle 
& wxRAISED_BORDER 
) 
1094             dwStyle 
|= wxRAISED_BORDER
; 
1095         if (lStyle 
& wxSTATIC_BORDER
) 
1096             dwStyle 
|= wxSTATIC_BORDER
; 
1099 } // end of wxWindowOS2::MakeExtendedStyle 
1102 // Setup background and foreground colours correctly 
1104 void wxWindowOS2::SetupColours() 
1107         SetBackgroundColour(GetParent()->GetBackgroundColour()); 
1108 } // end of wxWindowOS2::SetupColours 
1110 void wxWindowOS2::OnIdle( 
1111   wxIdleEvent
&                      WXUNUSED(rEvent
) 
1115     // Check if we need to send a LEAVE event 
1117     if (m_bMouseInWindow
) 
1121         ::WinQueryPointerPos(HWND_DESKTOP
, &vPoint
); 
1122         if (::WinWindowFromPoint(HWND_DESKTOP
, &vPoint
, FALSE
) != (HWND
)GetHwnd()) 
1125             // Generate a LEAVE event 
1127             m_bMouseInWindow 
= false; 
1130             // Unfortunately the mouse button and keyboard state may have changed 
1131             // by the time the OnIdle function is called, so 'state' may be 
1141             wxMouseEvent            
rEvent(wxEVT_LEAVE_WINDOW
); 
1143             InitMouseEvent( rEvent
 
1148             (void)GetEventHandler()->ProcessEvent(rEvent
); 
1151     if (wxUpdateUIEvent::CanUpdate(this)) 
1152         UpdateWindowUI(wxUPDATE_UI_FROMIDLE
); 
1153 } // end of wxWindowOS2::OnIdle 
1156 // Set this window to be the child of 'parent'. 
1158 bool wxWindowOS2::Reparent( wxWindow
* pParent
) 
1160     if (!wxWindowBase::Reparent(pParent
)) 
1163     HWND hWndChild 
= GetHwnd(); 
1164     HWND hWndParent 
= GetParent() ? GetWinHwnd(GetParent()) : (HWND
)0; 
1166     ::WinSetParent(hWndChild
, hWndParent
, TRUE
); 
1168 } // end of wxWindowOS2::Reparent 
1170 void wxWindowOS2::Update() 
1172     ::WinUpdateWindow(GetHwnd()); 
1173 } // end of wxWindowOS2::Update 
1175 void wxWindowOS2::Freeze() 
1177    ::WinSendMsg(GetHwnd(), WM_VRNDISABLED
, (MPARAM
)0, (MPARAM
)0); 
1178 } // end of wxWindowOS2::Freeze 
1180 void wxWindowOS2::Thaw() 
1182    ::WinSendMsg(GetHwnd(), WM_VRNENABLED
, (MPARAM
)TRUE
, (MPARAM
)0); 
1185     // We need to refresh everything or otherwise he invalidated area is not 
1189 } // end of wxWindowOS2::Thaw 
1191 void wxWindowOS2::Refresh( bool bEraseBack
, 
1192                            const wxRect
* pRect 
) 
1194     HWND hWnd 
= GetHwnd(); 
1203             ::WinQueryWindowRect(GetHwnd(), &vOs2Rect
); 
1204             height 
= vOs2Rect
.yTop
; 
1205             vOs2Rect
.xLeft   
= pRect
->x
; 
1206             vOs2Rect
.yTop    
= height 
- pRect
->y
; 
1207             vOs2Rect
.xRight  
= pRect
->x 
+ pRect
->width
; 
1208             vOs2Rect
.yBottom 
= vOs2Rect
.yTop 
- pRect
->height
; 
1210             ::WinInvalidateRect(hWnd
, &vOs2Rect
, bEraseBack
); 
1213             ::WinInvalidateRect(hWnd
, NULL
, bEraseBack
); 
1214         if (m_hWndScrollBarHorz 
!= NULLHANDLE
) 
1215             ::WinInvalidateRect(m_hWndScrollBarHorz
, NULL
, TRUE
); 
1216         if (m_hWndScrollBarVert 
!= NULLHANDLE
) 
1217             ::WinInvalidateRect(m_hWndScrollBarVert
, NULL
, TRUE
); 
1219 } // end of wxWindowOS2::Refresh 
1221 // --------------------------------------------------------------------------- 
1223 // --------------------------------------------------------------------------- 
1225 #if wxUSE_DRAG_AND_DROP 
1226 void wxWindowOS2::SetDropTarget( 
1227   wxDropTarget
*                     pDropTarget
 
1230     m_dropTarget 
= pDropTarget
; 
1231 } // end of wxWindowOS2::SetDropTarget 
1235 // old style file-manager drag&drop support: we retain the old-style 
1236 // DragAcceptFiles in parallel with SetDropTarget. 
1238 void wxWindowOS2::DragAcceptFiles( 
1242     HWND                            hWnd 
= GetHwnd(); 
1244     if (hWnd 
&& bAccept
) 
1245         ::DrgAcceptDroppedFiles(hWnd
, NULL
, NULL
, DO_COPY
, 0L); 
1246 } // end of wxWindowOS2::DragAcceptFiles 
1248 // ---------------------------------------------------------------------------- 
1250 // ---------------------------------------------------------------------------- 
1254 void wxWindowOS2::DoSetToolTip( 
1258     wxWindowBase::DoSetToolTip(pTooltip
); 
1261         m_tooltip
->SetWindow(this); 
1262 } // end of wxWindowOS2::DoSetToolTip 
1264 #endif // wxUSE_TOOLTIPS 
1266 // --------------------------------------------------------------------------- 
1267 // moving and resizing 
1268 // --------------------------------------------------------------------------- 
1271 void wxWindowOS2::DoGetSize( 
1279     if (IsKindOf(CLASSINFO(wxFrame
))) 
1281         wxFrame
*                    pFrame 
= wxDynamicCast(this, wxFrame
); 
1282         hWnd 
= pFrame
->GetFrame(); 
1287     ::WinQueryWindowRect(hWnd
, &vRect
); 
1290         *pWidth 
= vRect
.xRight 
- vRect
.xLeft
; 
1292         // OS/2 PM is backwards from windows 
1293         *pHeight 
= vRect
.yTop 
- vRect
.yBottom
; 
1294 } // end of wxWindowOS2::DoGetSize 
1296 void wxWindowOS2::DoGetPosition( 
1302     // Return parameters assume wxWidgets coordinate system 
1307     wxWindow
*                       pParent 
= GetParent(); 
1310     // It would seem that WinQueryWindowRect would be the correlary to 
1311     // the WIN32 WinGetRect, but unlike WinGetRect which returns the window 
1312     // origin position in screen coordinates, WinQueryWindowRect returns it 
1313     // relative to itself, i.e. (0,0).  To get the same under PM we must 
1314     // use WinQueryWindowPos.  This call, unlike the WIN32 call, however, 
1315     // returns a position relative to it's parent, so no parent adujstments 
1316     // are needed under OS/2.  Also, windows should be created using 
1317     // wxWindow coordinates, i.e 0,0 is the TOP left. 
1319     if (IsKindOf(CLASSINFO(wxFrame
))) 
1321         wxFrame
*                    pFrame 
= wxDynamicCast(this, wxFrame
); 
1322         hWnd 
= pFrame
->GetFrame(); 
1327     ::WinQueryWindowPos(hWnd
, &vSwp
); 
1332     // We need to convert to wxWidgets coordinates 
1334     DoGetSize(NULL
,&vHeight
); 
1335     wxWindow
* pWindow 
= wxDynamicCast(this,wxWindow
); 
1336     vPoint
.y 
= pWindow
->GetOS2ParentHeight(pParent
) - vPoint
.y 
- vHeight
; 
1339     // We may be faking the client origin. So a window that's really at (0, 
1340     // 30) may appear (to wxWin apps) to be at (0, 0). 
1344         wxPoint                     
vPt(pParent
->GetClientAreaOrigin()); 
1354 } // end of wxWindowOS2::DoGetPosition 
1356 void wxWindowOS2::DoScreenToClient( 
1361     HWND                            hWnd 
= GetHwnd(); 
1364     ::WinQueryWindowPos(hWnd
, &vSwp
); 
1370 } // end of wxWindowOS2::DoScreenToClient 
1372 void wxWindowOS2::DoClientToScreen( 
1377     HWND                            hWnd 
= GetHwnd(); 
1380     ::WinQueryWindowPos(hWnd
, &vSwp
); 
1386 } // end of wxWindowOS2::DoClientToScreen 
1389 // Get size *available for subwindows* i.e. excluding menu bar etc. 
1390 // Must be a frame type window 
1392 void wxWindowOS2::DoGetClientSize( 
1397     HWND                            hWnd 
= GetHwnd(); 
1400    ::WinQueryWindowRect(hWnd
, &vRect
); 
1401     if (IsKindOf(CLASSINFO(wxDialog
))) 
1406         // For a Dialog we have to explicitly request the client portion. 
1407         // For a Frame the hWnd IS the client window 
1409         hWndTitle 
= ::WinWindowFromID(hWnd
, FID_TITLEBAR
); 
1410         if (::WinQueryWindowRect(hWndTitle
, &vTitle
)) 
1412             if (vTitle
.yTop 
- vTitle
.yBottom 
== 0) 
1415                 // Dialog has not been created yet, use a default 
1419             vRect
.yTop 
-= (vTitle
.yTop 
- vTitle
.yBottom
); 
1422         ULONG                       uStyle 
= ::WinQueryWindowULong(hWnd
, QWL_STYLE
); 
1425         // Deal with borders 
1427         if (uStyle 
& FCF_DLGBORDER
) 
1434         else if (uStyle 
& FCF_SIZEBORDER
) 
1441         else if (uStyle 
& FCF_BORDER
) 
1448         else // make some kind of adjustment or top sizers ram into the titlebar! 
1457         *pWidth  
= vRect
.xRight 
- vRect
.xLeft
; 
1459         *pHeight 
= vRect
.yTop 
- vRect
.yBottom
; 
1460 } // end of wxWindowOS2::DoGetClientSize 
1462 void wxWindowOS2::DoMoveWindow( 
1470     // Input parameters assume wxWidgets coordinate system 
1473     wxWindow
*                       pParent 
= GetParent(); 
1474     HWND                            hWnd 
= GetHwnd(); 
1476     if (pParent 
&& !IsKindOf(CLASSINFO(wxDialog
))) 
1478         int                         nOS2Height 
= GetOS2ParentHeight(pParent
); 
1480         nY 
= nOS2Height 
- (nY 
+ nHeight
); 
1486         ::WinQueryWindowRect(HWND_DESKTOP
, &vRect
); 
1487         nY 
= vRect
.yTop 
- (nY 
+ nHeight
); 
1491     // In the case of a frame whose client is sized, the client cannot be 
1492     // large than its parent frame minus its borders! This usually happens 
1493     // when using an autosizer to size a frame to precisely hold client 
1494     // controls as in the notebook sample. 
1496     // In this case, we may need to resize both a frame and its client so we 
1497     // need a quick calc of the frame border size, then if the frame 
1498     // (less its borders) is smaller than the client, size the frame to 
1499     // encompass the client with the appropriate border size. 
1501     if (IsKindOf(CLASSINFO(wxFrame
))) 
1504         int                         nWidthFrameDelta 
= 0; 
1505         int                         nHeightFrameDelta 
= 0; 
1508         pFrame 
= wxDynamicCast(this, wxFrame
); 
1509         hWnd 
= pFrame
->GetFrame(); 
1510         ::WinQueryWindowRect(hWnd
, &vRect
); 
1511         ::WinMapWindowPoints(hWnd
, HWND_DESKTOP
, (PPOINTL
)&vRect
, 2); 
1513         ::WinCalcFrameRect(hWnd
, &vRect
, TRUE
); 
1514         nWidthFrameDelta 
= ((vRect
.xLeft 
- vFRect
.xLeft
) + (vFRect
.xRight 
- vRect
.xRight
)); 
1515         nHeightFrameDelta 
= ((vRect
.yBottom 
- vFRect
.yBottom
) + (vFRect
.yTop 
- vRect
.yTop
)); 
1516         // Input values refer to the window position relative to its parent 
1517         // which may be the Desktop so we need to calculate 
1518         // the new frame values to keep the wxWidgets frame origin constant 
1519         nY 
-= nHeightFrameDelta
; 
1520         nWidth 
+= nWidthFrameDelta
; 
1521         nHeight 
+= nHeightFrameDelta
; 
1523     ::WinSetWindowPos( hWnd
 
1529                       ,SWP_SIZE 
| SWP_MOVE
 
1531     if (m_vWinSwp
.cx 
== 0 && m_vWinSwp
.cy 
== 0 && m_vWinSwp
.fl 
== 0) 
1535         ::WinQueryWindowPos(hWnd
, &m_vWinSwp
); 
1539         // Handle resizing of scrolled windows.  The target or window to 
1540         // be scrolled is the owner (gets the scroll notifications).  The 
1541         // parent is usually the parent frame of the scrolled panel window. 
1542         // In order to show the scrollbars the target window will be shrunk 
1543         // by the size of the scroll bar widths and moved in the X and Y 
1544         // directon.  That value will be computed as part of the diff for 
1545         // moving the children.  Everytime the window is sized the 
1546         // toplevel OnSize is going to resize the panel to fit the client 
1547         // or the whole sizer and will need to me resized. This will send 
1548         // a WM_SIZE out which will be intercepted by the ScrollHelper 
1549         // which will cause the scrollbars to be displayed via the SetScrollbar 
1552         if (IsKindOf(CLASSINFO(wxScrolledWindow
))) 
1554             int                     nAdjustWidth  
= 0; 
1555             int                     nAdjustHeight 
= 0; 
1556             int nHSBHeight 
= wxSystemSettingsNative::GetMetric(wxSYS_HSCROLL_Y
, 
1558             int nVSBWidth  
= wxSystemSettingsNative::GetMetric(wxSYS_VSCROLL_X
, 
1562             if (GetScrollBarHorz() == NULLHANDLE 
|| 
1563                 !WinIsWindowShowing(GetScrollBarHorz())) 
1566                 nAdjustHeight 
= nHSBHeight
; 
1567             if (GetScrollBarVert() == NULLHANDLE 
|| 
1568                 !WinIsWindowShowing(GetScrollBarVert())) 
1571                 nAdjustWidth 
= nVSBWidth
; 
1572             ::WinQueryWindowPos(hWnd
, &vSwpScroll
); 
1573             ::WinSetWindowPos( hWnd
 
1576                               ,vSwpScroll
.y 
+ nAdjustHeight
 
1577                               ,vSwpScroll
.cx 
- nAdjustWidth
 
1578                               ,vSwpScroll
.cy 
- nAdjustHeight
 
1579                               ,SWP_MOVE 
| SWP_SIZE
 
1582         ::WinQueryWindowPos(hWnd
, &m_vWinSwp
); 
1584 } // end of wxWindowOS2::DoMoveWindow 
1587 // Set the size of the window: if the dimensions are positive, just use them, 
1588 // but if any of them is equal to -1, it means that we must find the value for 
1589 // it ourselves (unless sizeFlags contains wxSIZE_ALLOW_MINUS_ONE flag, in 
1590 // which case -1 is a valid value for x and y) 
1592 // If sizeFlags contains wxSIZE_AUTO_WIDTH/HEIGHT flags (default), we calculate 
1593 // the width/height to best suit our contents, otherwise we reuse the current 
1596 void wxWindowOS2::DoSetSize( int nX
, 
1603     // Input & output parameters assume wxWidgets coordinate system 
1607     // Get the current size and position... 
1613     wxSize vSize 
= wxDefaultSize
; 
1615     GetPosition(&nCurrentX
, &nCurrentY
); 
1616     GetSize(&nCurrentWidth
, &nCurrentHeight
); 
1619     // ... and don't do anything (avoiding flicker) if it's already ok 
1621     if (nX 
== nCurrentX 
&& nY 
== nCurrentY 
&& 
1622         nWidth 
== nCurrentWidth 
&& nHeight 
== nCurrentHeight
) 
1627     if (nX 
== wxDefaultCoord 
&& !(nSizeFlags 
& wxSIZE_ALLOW_MINUS_ONE
)) 
1629     if (nY 
== wxDefaultCoord 
&& !(nSizeFlags 
& wxSIZE_ALLOW_MINUS_ONE
)) 
1632     AdjustForParentClientOrigin(nX
, nY
, nSizeFlags
); 
1634     if (nWidth 
== wxDefaultCoord
) 
1636         if (nSizeFlags 
& wxSIZE_AUTO_WIDTH
) 
1638             vSize  
= DoGetBestSize(); 
1644             // Just take the current one 
1646             nWidth 
= nCurrentWidth
; 
1650     if (nHeight 
== wxDefaultCoord
) 
1652         if (nSizeFlags 
& wxSIZE_AUTO_HEIGHT
) 
1654             if (vSize
.x 
== wxDefaultCoord
) 
1656                 vSize 
= DoGetBestSize(); 
1662             // just take the current one 
1663             nHeight 
= nCurrentHeight
; 
1667     DoMoveWindow( nX
, nY
, nWidth
, nHeight 
); 
1668 } // end of wxWindowOS2::DoSetSize 
1670 void wxWindowOS2::DoSetClientSize( int nWidth
, 
1674     // nX & nY assume wxWidgets coordinate system 
1679     GetPosition(&nX
, &nY
); 
1681     DoMoveWindow( nX
, nY
, nWidth
, nHeight 
); 
1683     wxSize 
size( nWidth
, nHeight 
); 
1684     wxSizeEvent 
vEvent( size
, m_windowId 
); 
1685     vEvent
.SetEventObject(this); 
1686     GetEventHandler()->ProcessEvent(vEvent
); 
1687 } // end of wxWindowOS2::DoSetClientSize 
1689 // --------------------------------------------------------------------------- 
1691 // --------------------------------------------------------------------------- 
1693 int wxWindowOS2::GetCharHeight() const 
1696     FONTMETRICS                     vFontMetrics
; 
1698     hPs 
= ::WinGetPS(GetHwnd()); 
1700     if(!GpiQueryFontMetrics(hPs
, sizeof(FONTMETRICS
), &vFontMetrics
)) 
1702         ::WinReleasePS(hPs
); 
1705     ::WinReleasePS(hPs
); 
1706     return(vFontMetrics
.lMaxAscender 
+ vFontMetrics
.lMaxDescender
); 
1707 } // end of wxWindowOS2::GetCharHeight 
1709 int wxWindowOS2::GetCharWidth() const 
1712     FONTMETRICS                     vFontMetrics
; 
1714     hPs 
= ::WinGetPS(GetHwnd()); 
1716     if(!GpiQueryFontMetrics(hPs
, sizeof(FONTMETRICS
), &vFontMetrics
)) 
1718         ::WinReleasePS(hPs
); 
1721     ::WinReleasePS(hPs
); 
1722     return(vFontMetrics
.lAveCharWidth
); 
1723 } // end of wxWindowOS2::GetCharWidth 
1725 void wxWindowOS2::GetTextExtent( const wxString
& rString
, 
1729                                  int* pExternalLeading
, 
1730                                  const wxFont
* WXUNUSED(pTheFont
) ) const 
1732     POINTL      avPoint
[TXTBOX_COUNT
]; 
1737     FONTMETRICS vFM
; // metrics structure 
1742     hPS 
= ::WinGetPS(GetHwnd()); 
1744     l 
= rString
.length(); 
1747         pStr 
= (PCH
)rString
.c_str(); 
1750         // In world coordinates. 
1752         bRc 
= ::GpiQueryTextBox( hPS
, 
1755                                  TXTBOX_COUNT
,// return maximum information 
1756                                  avPoint      
// array of coordinates points 
1760             vPtMin
.x 
= avPoint
[0].x
; 
1761             vPtMax
.x 
= avPoint
[0].x
; 
1762             vPtMin
.y 
= avPoint
[0].y
; 
1763             vPtMax
.y 
= avPoint
[0].y
; 
1764             for (i 
= 1; i 
< 4; i
++) 
1766                 if(vPtMin
.x 
> avPoint
[i
].x
) vPtMin
.x 
= avPoint
[i
].x
; 
1767                 if(vPtMin
.y 
> avPoint
[i
].y
) vPtMin
.y 
= avPoint
[i
].y
; 
1768                 if(vPtMax
.x 
< avPoint
[i
].x
) vPtMax
.x 
= avPoint
[i
].x
; 
1769                 if(vPtMax
.y 
< avPoint
[i
].y
) vPtMax
.y 
= avPoint
[i
].y
; 
1771             bRc 
= ::GpiQueryFontMetrics( hPS
 
1772                                         ,sizeof(FONTMETRICS
) 
1799         *pX 
= (vPtMax
.x 
- vPtMin
.x 
+ 1); 
1801         *pY 
= (vPtMax
.y 
- vPtMin
.y 
+ 1); 
1805             *pDescent 
= vFM
.lMaxDescender
; 
1809     if (pExternalLeading
) 
1812             *pExternalLeading 
= vFM
.lExternalLeading
; 
1814             *pExternalLeading 
= 0; 
1816     ::WinReleasePS(hPS
); 
1817 } // end of wxWindow::GetTextExtent 
1819 bool wxWindowOS2::IsMouseInWindow() const 
1822     // Get the mouse position 
1825     ::WinQueryPointerPos(HWND_DESKTOP
, &vPt
); 
1828     // Find the window which currently has the cursor and go up the window 
1829     // chain until we find this window - or exhaust it 
1831     HWND hWnd 
= ::WinWindowFromPoint(HWND_DESKTOP
, &vPt
, TRUE
); 
1833     while (hWnd 
&& (hWnd 
!= GetHwnd())) 
1834         hWnd 
= ::WinQueryWindow(hWnd
, QW_PARENT
); 
1836     return hWnd 
!= NULL
; 
1837 } // end of wxWindowOS2::IsMouseInWindow 
1840 // --------------------------------------------------------------------------- 
1842 // --------------------------------------------------------------------------- 
1844 #if wxUSE_MENUS_NATIVE 
1845 bool wxWindowOS2::DoPopupMenu( wxMenu
* pMenu
, int nX
, int nY 
) 
1847     HWND hWndOwner 
= GetHwnd(); 
1848     HWND hWndParent 
= GetHwnd(); 
1849     HWND hMenu 
= GetHmenuOf(pMenu
); 
1850     bool bIsWaiting 
= true; 
1853     // Protect against recursion 
1854     if (wxCurrentPopupMenu
) 
1857     pMenu
->SetInvokingWindow(this); 
1860     if ( nX 
== -1 && nY 
== -1 ) 
1862         wxPoint mouse 
= wxGetMousePosition(); 
1863         nX 
= mouse
.x
; nY 
= mouse
.y
; 
1867         DoClientToScreen( &nX
 
1870         DoGetSize(0,&nHeight
); 
1873     wxCurrentPopupMenu 
= pMenu
; 
1875     ::WinPopupMenu( hWndParent
 
1881                    ,PU_HCONSTRAIN 
| PU_VCONSTRAIN 
| PU_MOUSEBUTTON1 
| PU_KEYBOARD
 
1888         ::WinGetMsg(vHabmain
,&vMsg
, (HWND
)0, 0, 0); 
1889         if (vMsg
.msg 
== WM_COMMAND
) 
1891         ::WinDispatchMsg(vHabmain
, (PQMSG
)&vMsg
); 
1894     wxCurrentPopupMenu 
= NULL
; 
1895     pMenu
->SetInvokingWindow(NULL
); 
1897 } // end of wxWindowOS2::DoPopupMenu 
1898 #endif // wxUSE_MENUS_NATIVE 
1900 // =========================================================================== 
1901 // pre/post message processing 
1902 // =========================================================================== 
1904 MRESULT 
wxWindowOS2::OS2DefWindowProc( WXUINT uMsg
, 
1909         return (MRESULT
)m_fnOldWndProc(GetHWND(), uMsg
, (MPARAM
)wParam
, (MPARAM
)lParam
); 
1911         return ::WinDefWindowProc(GetHWND(), uMsg
, (MPARAM
)wParam
, (MPARAM
)lParam
); 
1912 } // end of wxWindowOS2::OS2DefWindowProc 
1914 bool wxWindowOS2::OS2ProcessMessage( WXMSG
* pMsg 
) 
1916 // wxUniversal implements tab traversal itself 
1917 #ifndef __WXUNIVERSAL__ 
1918     QMSG
*                           pQMsg 
= (QMSG
*)pMsg
; 
1920     if (m_hWnd 
!= 0 && (GetWindowStyleFlag() & wxTAB_TRAVERSAL
)) 
1923         // Intercept dialog navigation keys 
1925         bool   bProcess 
= true; 
1926         USHORT uKeyFlags 
= SHORT1FROMMP(pQMsg
->mp1
); 
1928         if (uKeyFlags 
& KC_KEYUP
) 
1931         if (uKeyFlags 
& KC_ALT
) 
1934         if (!(uKeyFlags 
& KC_VIRTUALKEY
)) 
1939             bool                    bCtrlDown 
= IsCtrlDown(); 
1940             bool                    bShiftDown 
= IsShiftDown(); 
1943             // WM_QUERYDLGCODE: ask the control if it wants the key for itself, 
1944             // don't process it if it's the case (except for Ctrl-Tab/Enter 
1945             // combinations which are always processed) 
1947             ULONG                   ulDlgCode 
= 0; 
1951                 ulDlgCode 
= (ULONG
)::WinSendMsg(pQMsg
->hwnd
, WM_QUERYDLGCODE
, pQMsg
, 0); 
1954             bool bForward 
= true; 
1955             bool bWindowChange 
= false; 
1957             switch (SHORT2FROMMP(pQMsg
->mp2
)) 
1960                 // Going to make certain assumptions about specific types of controls 
1961                 // here, so we may have to alter some things later if they prove invalid 
1965                     // Shift tabl will always be a nav-key but tabs may be wanted 
1974                         // Entry Fields want tabs for themselve usually 
1978                             case DLGC_ENTRYFIELD
: 
1988                         // Ctrl-Tab cycles thru notebook pages 
1990                         bWindowChange 
= bCtrlDown
; 
1991                         bForward 
= !bShiftDown
; 
2014                             // ctrl-enter is not processed 
2018                         else if (ulDlgCode 
& DLGC_BUTTON
) 
2021                             // buttons want process Enter themselevs 
2027                             wxButton
*   pBtn 
= wxDynamicCast( GetDefaultItem() 
2031                             if (pBtn 
&& pBtn
->IsEnabled()) 
2034                                 // If we do have a default button, do press it 
2036                                 pBtn
->OS2Command(BN_CLICKED
, 0 /* unused */); 
2039                             else if (!IsTopLevel()) 
2042                                 // if not a top level window, let parent 
2047                             // else: but if it does not it makes sense to make 
2048                             //       it work like a TAB - and that's what we do. 
2049                             //       Note that Ctrl-Enter always works this way. 
2060                 wxNavigationKeyEvent    vEvent
; 
2062                 vEvent
.SetDirection(bForward
); 
2063                 vEvent
.SetWindowChange(bWindowChange
); 
2064                 vEvent
.SetEventObject(this); 
2066                 if (GetEventHandler()->ProcessEvent(vEvent
)) 
2068                     wxButton
*       pBtn 
= wxDynamicCast(FindFocus(), wxButton
); 
2073                         // The button which has focus should be default 
2082         // Let Dialogs process 
2084         if (::WinSendMsg(pQMsg
->hwnd
, WM_QUERYDLGCODE
, pQMsg
, 0)); 
2088     pMsg 
= pMsg
; // just shut up the compiler 
2089 #endif // __WXUNIVERSAL__ 
2092 } // end of wxWindowOS2::OS2ProcessMessage 
2094 bool wxWindowOS2::OS2TranslateMessage( WXMSG
* pMsg 
) 
2096 #if wxUSE_ACCEL && !defined(__WXUNIVERSAL__) 
2097     return m_acceleratorTable
.Translate(m_hWnd
, pMsg
); 
2101 #endif //wxUSE_ACCEL 
2102 } // end of wxWindowOS2::OS2TranslateMessage 
2104 bool wxWindowOS2::OS2ShouldPreProcessMessage( WXMSG
* WXUNUSED(pMsg
) ) 
2106     // preprocess all messages by default 
2108 } // end of wxWindowOS2::OS2ShouldPreProcessMessage 
2110 // --------------------------------------------------------------------------- 
2111 // message params unpackers 
2112 // --------------------------------------------------------------------------- 
2114 void wxWindowOS2::UnpackCommand( 
2122     *pId 
= LOWORD(wParam
); 
2123     *phWnd 
= NULL
;  // or may be GetHWND() ? 
2124     *pCmd 
= LOWORD(lParam
); 
2125 } // end of wxWindowOS2::UnpackCommand 
2127 void wxWindowOS2::UnpackActivate( 
2134     *pState     
= LOWORD(wParam
); 
2135     *phWnd      
= (WXHWND
)lParam
; 
2136 } // end of wxWindowOS2::UnpackActivate 
2138 void wxWindowOS2::UnpackScroll( 
2149     ulId    
= (ULONG
)LONGFROMMP(wParam
); 
2150     hWnd 
= ::WinWindowFromID(GetHwnd(), ulId
); 
2151     if (hWnd 
== m_hWndScrollBarHorz 
|| hWnd 
== m_hWndScrollBarVert
) 
2152         *phWnd 
= NULLHANDLE
; 
2156     *pPos  
= SHORT1FROMMP(lParam
); 
2157     *pCode 
= SHORT2FROMMP(lParam
); 
2158 } // end of wxWindowOS2::UnpackScroll 
2160 void wxWindowOS2::UnpackMenuSelect( 
2168     *pItem 
= (WXWORD
)LOWORD(wParam
); 
2169     *pFlags 
= HIWORD(wParam
); 
2170     *phMenu 
= (WXHMENU
)lParam
; 
2171 } // end of wxWindowOS2::UnpackMenuSelect 
2173 // --------------------------------------------------------------------------- 
2174 // Main wxWidgets window proc and the window proc for wxWindow 
2175 // --------------------------------------------------------------------------- 
2178 // Hook for new window just as it's being created, when the window isn't yet 
2179 // associated with the handle 
2181 wxWindowOS2
*                         wxWndHook 
= NULL
; 
2186 MRESULT EXPENTRY 
wxWndProc( 
2193     wxWindowOS2
*                    pWnd 
= wxFindWinFromHandle((WXHWND
)hWnd
); 
2196     // When we get the first message for the HWND we just created, we associate 
2197     // it with wxWindow stored in wxWndHook 
2199     if (!pWnd 
&& wxWndHook
) 
2201         wxAssociateWinWithHandle(hWnd
, wxWndHook
); 
2204         pWnd
->SetHWND((WXHWND
)hWnd
); 
2207     MRESULT                         rc 
= (MRESULT
)0; 
2211     // Stop right here if we don't have a valid handle in our wxWindow object. 
2213     if (pWnd 
&& !pWnd
->GetHWND()) 
2215         pWnd
->SetHWND((WXHWND
) hWnd
); 
2216         rc 
= pWnd
->OS2DefWindowProc(ulMsg
, wParam
, lParam 
); 
2223             rc 
= pWnd
->OS2WindowProc(ulMsg
, wParam
, lParam
); 
2224             if ( (pWnd
->GetScrollBarHorz() != NULLHANDLE 
|| 
2225                   pWnd
->GetScrollBarVert() != NULLHANDLE
) && 
2228                 if (pWnd
->GetScrollBarHorz() != NULLHANDLE
) 
2229                     ::WinInvalidateRect(pWnd
->GetScrollBarHorz(), NULL
, TRUE
); 
2230                 if (pWnd
->GetScrollBarVert() != NULLHANDLE
) 
2231                     ::WinInvalidateRect(pWnd
->GetScrollBarVert(), NULL
, TRUE
); 
2235             rc 
= ::WinDefWindowProc(hWnd
, ulMsg
, wParam
, lParam
); 
2239 } // end of wxWndProc 
2242 // We will add (or delete) messages we need to handle at this default 
2245 MRESULT 
wxWindowOS2::OS2WindowProc( WXUINT uMsg
, 
2250     // Did we process the uMsg? 
2252     bool bProcessed 
= false; 
2256     // For most messages we should return 0 when we do process the message 
2258     mResult 
= (MRESULT
)0; 
2266                 bProcessed 
= HandleCreate( (WXLPCREATESTRUCT
)lParam
 
2272                     // Return 0 to bAllow window creation 
2274                     mResult 
= (MRESULT
)(bMayCreate 
? 0 : -1); 
2285             bProcessed 
= HandleMove( LOWORD(lParam
) 
2291             bProcessed 
= HandleSize( LOWORD(lParam
) 
2297         case WM_WINDOWPOSCHANGED
: 
2300             // Dialogs under OS/2 do not get WM_SIZE events at all. 
2301             // Instead they get this, which can function much like WM_SIZE 
2302             // PSWP contains the new sizes and positioning, PSWP+1 the old 
2303             // We use this because ADJUSTWINDOWPOS comes BEFORE the new 
2304             // position is added and our auto layout does a WinQueryWindowRect 
2305             // to get the CURRENT client size.  That is the size used to position 
2306             // child controls, so we need to already be sized 
2307             // in order to get the child controls positoned properly. 
2309             if (IsKindOf(CLASSINFO(wxDialog
)) || IsKindOf(CLASSINFO(wxFrame
))) 
2311                 PSWP                pSwp 
= (PSWP
)PVOIDFROMMP(wParam
); 
2312                 PSWP                pSwp2 
= pSwp
++; 
2314                 if (!(pSwp
->cx 
== pSwp2
->cx 
&& 
2315                       pSwp
->cy 
== pSwp2
->cy
)) 
2316                     bProcessed 
= HandleSize( pSwp
->cx
 
2320                 if (IsKindOf(CLASSINFO(wxFrame
))) 
2322                     wxFrame
*            pFrame 
= wxDynamicCast(this, wxFrame
); 
2326                         if (pFrame
->GetStatusBar()) 
2327                             pFrame
->PositionStatusBar(); 
2328                         if (pFrame
->GetToolBar()) 
2329                             pFrame
->PositionToolBar(); 
2340                 UnpackActivate( wParam
 
2346                 bProcessed 
= HandleActivate( wState
 
2354             if (SHORT1FROMMP((MPARAM
)lParam
) == TRUE
) 
2355                 bProcessed 
= HandleSetFocus((WXHWND
)(HWND
)wParam
); 
2357                 bProcessed 
= HandleKillFocus((WXHWND
)(HWND
)wParam
); 
2361             bProcessed 
= HandlePaint(); 
2366             // Don't let the DefWindowProc() destroy our window - we'll do it 
2367             // ourselves in ~wxWindow 
2370             mResult 
= (MRESULT
)TRUE
; 
2374             bProcessed 
= HandleShow(wParam 
!= 0, (int)lParam
); 
2378         // Under OS2 PM Joysticks are treated just like mouse events 
2379         // The "Motion" events will be prevelent in joysticks 
2382         case WM_BUTTON1DOWN
: 
2384         case WM_BUTTON1DBLCLK
: 
2385         case WM_BUTTON1MOTIONEND
: 
2386         case WM_BUTTON1MOTIONSTART
: 
2387         case WM_BUTTON2DOWN
: 
2389         case WM_BUTTON2DBLCLK
: 
2390         case WM_BUTTON2MOTIONEND
: 
2391         case WM_BUTTON2MOTIONSTART
: 
2392         case WM_BUTTON3DOWN
: 
2394         case WM_BUTTON3DBLCLK
: 
2395         case WM_BUTTON3MOTIONEND
: 
2396         case WM_BUTTON3MOTIONSTART
: 
2398                 if (uMsg 
== WM_BUTTON1DOWN 
&& AcceptsFocus()) 
2401                 short               nX 
= LOWORD(wParam
); 
2402                 short               nY 
= HIWORD(wParam
); 
2405                 // Redirect the event to a static control if necessary 
2407                 if (this == GetCapture()) 
2409                     bProcessed 
= HandleMouseEvent( uMsg
 
2412                                                   ,(WXUINT
)SHORT2FROMMP(lParam
) 
2417                     wxWindow
*       pWin 
= FindWindowForMouseEvent( this 
2421                     if (!pWin
->IsOfStandardClass()) 
2423                         if (uMsg 
== WM_BUTTON1DOWN 
&& pWin
->AcceptsFocus() ) 
2426                     bProcessed 
= pWin
->HandleMouseEvent( uMsg
 
2429                                                         ,(WXUINT
)SHORT2FROMMP(lParam
) 
2436             bProcessed 
= HandleSysCommand(wParam
, lParam
); 
2443                 UnpackCommand(wParam
, lParam
, &id
, &hwnd
, &cmd
); 
2445                 bProcessed 
= HandleCommand(id
, cmd
, hwnd
); 
2450             // For these messages we must return TRUE if process the message 
2453         case WM_MEASUREITEM
: 
2455                 int                 nIdCtrl 
= (UINT
)wParam
; 
2457                 if ( uMsg 
== WM_DRAWITEM 
) 
2459                     bProcessed 
= OS2OnDrawItem(nIdCtrl
, 
2460                                               (WXDRAWITEMSTRUCT 
*)lParam
); 
2464                     return MRFROMLONG(OS2OnMeasureItem( nIdCtrl
 
2465                                                        ,(WXMEASUREITEMSTRUCT 
*)lParam
 
2470                     mResult 
= (MRESULT
)TRUE
; 
2474         case WM_QUERYDLGCODE
: 
2475             if (!IsOfStandardClass()) 
2479                     mResult 
= (MRESULT
)m_lDlgCode
; 
2484             //else: get the dlg code from the DefWindowProc() 
2489         // In OS/2 PM all keyboard events are of the WM_CHAR type.  Virtual key and key-up 
2490         // and key-down events are obtained from the WM_CHAR params. 
2494                 USHORT                  uKeyFlags 
= SHORT1FROMMP((MPARAM
)wParam
); 
2496                 if (uKeyFlags 
& KC_KEYUP
) 
2498                     //TODO: check if the cast to WXWORD isn't causing trouble 
2499                     bProcessed 
= HandleKeyUp(wParam
, lParam
); 
2502                 else // keydown event 
2504                     m_bLastKeydownProcessed 
= false; 
2506                     // If this has been processed by an event handler, 
2507                     // return 0 now (we've handled it). DON't RETURN 
2508                     // we still need to process further 
2510                     m_bLastKeydownProcessed 
= HandleKeyDown(wParam
, lParam
); 
2511                     if (uKeyFlags 
& KC_VIRTUALKEY
) 
2513                         USHORT          uVk 
= SHORT2FROMMP((MPARAM
)lParam
); 
2516                         // We consider these message "not interesting" to OnChar 
2529                             // Avoid duplicate messages to OnChar for these ASCII keys: they 
2530                             // will be translated by TranslateMessage() and received in WM_CHAR 
2535                                 // But set processed to false, not true to still pass them to 
2536                                 // the control's default window proc - otherwise built-in 
2537                                 // keyboard handling won't work 
2542                                 bProcessed 
= HandleChar(wParam
, lParam
); 
2546                     else // WM_CHAR -- Always an ASCII character 
2548                         if (m_bLastKeydownProcessed
) 
2551                             // The key was handled in the EVT_KEY_DOWN and handling 
2552                             // a key in an EVT_KEY_DOWN handler is meant, by 
2553                             // design, to prevent EVT_CHARs from happening 
2555                             m_bLastKeydownProcessed 
= false; 
2558                         else // do generate a CHAR event 
2560                             bProcessed 
= HandleChar(wParam
, lParam
, true); 
2573                 UnpackScroll( wParam
 
2580                 bProcessed 
= OS2OnScroll( uMsg 
== WM_HSCROLL 
? wxHORIZONTAL
 
2590             switch(SHORT2FROMMP(wParam
)) 
2594                         HWND                hWnd 
= ::WinWindowFromID((HWND
)GetHwnd(), SHORT1FROMMP(wParam
)); 
2595                         wxWindowOS2
*        pWin 
= wxFindWinFromHandle(hWnd
); 
2602                         if (pWin
->IsKindOf(CLASSINFO(wxBitmapButton
))) 
2604                             wxBitmapButton
*     pBitmapButton 
= wxDynamicCast(pWin
, wxBitmapButton
); 
2606                             pBitmapButton
->OS2OnDraw((WXDRAWITEMSTRUCT 
*)lParam
); 
2612                 case BKN_PAGESELECTEDPENDING
: 
2614                         PPAGESELECTNOTIFY  pPage 
= (PPAGESELECTNOTIFY
)lParam
; 
2616                         if ((pPage
->ulPageIdNew 
!= pPage
->ulPageIdCur
) && 
2617                             (pPage
->ulPageIdNew 
> 0L && pPage
->ulPageIdCur 
> 0L)) 
2619                             wxWindowOS2
*        pWin 
= wxFindWinFromHandle(pPage
->hwndBook
); 
2620                             wxNotebookEvent     
vEvent( wxEVT_COMMAND_NOTEBOOK_PAGE_CHANGED
 
2621                                                        ,(int)SHORT1FROMMP(wParam
) 
2622                                                        ,(int)pPage
->ulPageIdNew
 
2623                                                        ,(int)pPage
->ulPageIdCur
 
2630                             if (pWin
->IsKindOf(CLASSINFO(wxNotebook
))) 
2632                                 wxNotebook
*         pNotebook 
= wxDynamicCast(pWin
, wxNotebook
); 
2634                                 vEvent
.SetEventObject(pWin
); 
2635                                 pNotebook
->OnSelChange(vEvent
); 
2646                 case BN_CLICKED
: // Dups as LN_SELECT and CBN_LBSELECT 
2648                         HWND                hWnd 
= ::WinWindowFromID((HWND
)GetHwnd(), SHORT1FROMMP(wParam
)); 
2649                         wxWindowOS2
*        pWin 
= wxFindWinFromHandle(hWnd
); 
2657                         // Simulate a WM_COMMAND here, as wxWidgets expects all control 
2658                         // button clicks to generate WM_COMMAND msgs, not WM_CONTROL 
2660                         if (pWin
->IsKindOf(CLASSINFO(wxRadioBox
))) 
2662                             wxRadioBox
*         pRadioBox 
= wxDynamicCast(pWin
, wxRadioBox
); 
2664                             pRadioBox
->OS2Command( (WXUINT
)SHORT2FROMMP(wParam
) 
2665                                                   ,(WXWORD
)SHORT1FROMMP(wParam
) 
2668                         if (pWin
->IsKindOf(CLASSINFO(wxRadioButton
))) 
2670                             wxRadioButton
*      pRadioButton 
= wxDynamicCast(pWin
, wxRadioButton
); 
2672                             pRadioButton
->OS2Command( (WXUINT
)SHORT2FROMMP(wParam
) 
2673                                                      ,(WXWORD
)SHORT1FROMMP(wParam
) 
2676                         if (pWin
->IsKindOf(CLASSINFO(wxCheckBox
))) 
2678                             wxCheckBox
*         pCheckBox 
= wxDynamicCast(pWin
, wxCheckBox
); 
2680                             pCheckBox
->OS2Command( (WXUINT
)SHORT2FROMMP(wParam
) 
2681                                                   ,(WXWORD
)SHORT1FROMMP(wParam
) 
2684                         if (pWin
->IsKindOf(CLASSINFO(wxListBox
))) 
2686                             wxListBox
*          pListBox 
= wxDynamicCast(pWin
, wxListBox
); 
2688                             pListBox
->OS2Command( (WXUINT
)SHORT2FROMMP(wParam
) 
2689                                                  ,(WXWORD
)SHORT1FROMMP(wParam
) 
2691                             if (pListBox
->GetWindowStyle() & wxLB_OWNERDRAW
) 
2694                         if (pWin
->IsKindOf(CLASSINFO(wxComboBox
))) 
2696                             wxComboBox
*          pComboBox 
= wxDynamicCast(pWin
, wxComboBox
); 
2698                             pComboBox
->OS2Command( (WXUINT
)SHORT2FROMMP(wParam
) 
2699                                                   ,(WXWORD
)SHORT1FROMMP(wParam
) 
2706                 case LN_ENTER
:   /* dups as CBN_EFCHANGE */ 
2708                         HWND                hWnd 
= HWNDFROMMP(lParam
); 
2709                         wxWindowOS2
*        pWin 
= wxFindWinFromHandle(hWnd
); 
2717                         // Simulate a WM_COMMAND here, as wxWidgets expects all control 
2718                         // button clicks to generate WM_COMMAND msgs, not WM_CONTROL 
2720                         if (pWin
->IsKindOf(CLASSINFO(wxListBox
))) 
2722                             wxListBox
*          pListBox 
= wxDynamicCast(pWin
, wxListBox
); 
2724                             pListBox
->OS2Command( (WXUINT
)SHORT2FROMMP(wParam
) 
2725                                                  ,(WXWORD
)SHORT1FROMMP(wParam
) 
2727                             if (pListBox
->GetWindowStyle() & wxLB_OWNERDRAW
) 
2731                         if (pWin
->IsKindOf(CLASSINFO(wxComboBox
))) 
2733                             wxComboBox
*          pComboBox 
= wxDynamicCast(pWin
, wxComboBox
); 
2735                             pComboBox
->OS2Command( (WXUINT
)SHORT2FROMMP(wParam
) 
2736                                                   ,(WXWORD
)SHORT1FROMMP(wParam
) 
2744                 case SPBN_DOWNARROW
: 
2750                         ::WinSendMsg( HWNDFROMMP(lParam
) 
2753                                      ,MPFROM2SHORT( (USHORT
)10 
2754                                                    ,(USHORT
)SPBQ_UPDATEIFVALID
 
2758                         bProcessed 
= OS2OnScroll( wxVERTICAL
 
2759                                                  ,(WXWORD
)SHORT2FROMMP(wParam
) 
2766                 case SLN_SLIDERTRACK
: 
2768                         HWND         hWnd 
= ::WinWindowFromID(GetHWND(), SHORT1FROMMP(wParam
)); 
2769                         wxWindowOS2
* pChild 
= wxFindWinFromHandle(hWnd
); 
2776                         if (pChild
->IsKindOf(CLASSINFO(wxSlider
))) 
2777                             bProcessed 
= OS2OnScroll( wxVERTICAL
 
2778                                                      ,(WXWORD
)SHORT2FROMMP(wParam
) 
2779                                                      ,(WXWORD
)LONGFROMMP(lParam
) 
2787 #if defined(__VISAGECPP__) && (__IBMCPP__ >= 400) 
2788         case WM_CTLCOLORCHANGE
: 
2790                 bProcessed 
= HandleCtlColor(&hBrush
); 
2794         case WM_ERASEBACKGROUND
: 
2796             // Returning TRUE to requestw PM to paint the window background 
2797             // in SYSCLR_WINDOW. We don't really want that 
2799             bProcessed 
= HandleEraseBkgnd((WXHDC
)(HPS
)wParam
); 
2800             mResult 
= (MRESULT
)(FALSE
); 
2803             // the return value for this message is ignored 
2804         case WM_SYSCOLORCHANGE
: 
2805             bProcessed 
= HandleSysColorChange(); 
2808         case WM_REALIZEPALETTE
: 
2809             bProcessed 
= HandlePaletteChanged(); 
2812         // move all drag and drops to wxDrg 
2814             bProcessed 
= HandleEndDrag(wParam
); 
2818             bProcessed 
= HandleInitDialog((WXHWND
)(HWND
)wParam
); 
2822                 // we never set focus from here 
2823                 mResult 
= (MRESULT
)FALSE
; 
2827         // wxFrame specific message 
2828         case WM_MINMAXFRAME
: 
2829             bProcessed 
= HandleGetMinMaxInfo((PSWP
)wParam
); 
2832         case WM_SYSVALUECHANGED
: 
2833             // TODO: do something 
2834             mResult 
= (MRESULT
)TRUE
; 
2838         // Comparable to WM_SETPOINTER for windows, only for just controls 
2840         case WM_CONTROLPOINTER
: 
2841             bProcessed 
= HandleSetCursor( SHORT1FROMMP(wParam
) // Control ID 
2842                                          ,(HWND
)lParam         
// Cursor Handle 
2847                 // Returning TRUE stops the DefWindowProc() from further 
2848                 // processing this message - exactly what we need because we've 
2849                 // just set the cursor. 
2851                 mResult 
= (MRESULT
)TRUE
; 
2855 #if wxUSE_MENUS_NATIVE 
2857             if (wxCurrentPopupMenu
) 
2859                 if (GetHmenuOf(wxCurrentPopupMenu
) == (HWND
)lParam
) 
2861                     // Break out of msg loop in DoPopupMenu 
2862                     ::WinPostMsg((HWND
)lParam
,WM_COMMAND
,wParam
,0); 
2866 #endif // wxUSE_MENUS_NATIVE 
2872         wxLogTrace(wxTraceMessages
, wxT("Forwarding %s to DefWindowProc."), 
2873                    wxGetMessageName(uMsg
)); 
2874 #endif // __WXDEBUG__ 
2875         if (IsKindOf(CLASSINFO(wxFrame
))) 
2876             mResult 
= ::WinDefWindowProc(m_hWnd
, uMsg
, wParam
, lParam
); 
2877         else if (IsKindOf(CLASSINFO(wxDialog
))) 
2878             mResult 
= ::WinDefDlgProc( m_hWnd
, uMsg
, wParam
, lParam
); 
2880             mResult 
= OS2DefWindowProc(uMsg
, wParam
, lParam
); 
2883 } // end of wxWindowOS2::OS2WindowProc 
2885 // ---------------------------------------------------------------------------- 
2886 // wxWindow <-> HWND map 
2887 // ---------------------------------------------------------------------------- 
2889 wxWinHashTable 
*wxWinHandleHash 
= NULL
; 
2891 wxWindow
* wxFindWinFromHandle( 
2895     return (wxWindow 
*)wxWinHandleHash
->Get((long)hWnd
); 
2896 } // end of wxFindWinFromHandle 
2898 void wxAssociateWinWithHandle( 
2904     // Adding NULL hWnd is (first) surely a result of an error and 
2905     // (secondly) breaks menu command processing 
2907     wxCHECK_RET( hWnd 
!= (HWND
)NULL
, 
2908                  wxT("attempt to add a NULL hWnd to window list ignored") ); 
2910     wxWindow
*                       pOldWin 
= wxFindWinFromHandle((WXHWND
) hWnd
); 
2912     if (pOldWin 
&& (pOldWin 
!= pWin
)) 
2914         wxString  
Newstr(pWin
->GetClassInfo()->GetClassName()); 
2915         wxString 
Oldstr(pOldWin
->GetClassInfo()->GetClassName()); 
2916         wxLogError( _T("Bug! New window of class %s has same HWND %X as old window of class %s"), 
2924         wxWinHandleHash
->Put( (long)hWnd
 
2928 } // end of wxAssociateWinWithHandle 
2930 void wxRemoveHandleAssociation( wxWindowOS2
* pWin 
) 
2932     wxWinHandleHash
->Delete((long)pWin
->GetHWND()); 
2933 } // end of wxRemoveHandleAssociation 
2936 // Default destroyer - override if you destroy it in some other way 
2937 // (e.g. with MDI child windows) 
2939 void wxWindowOS2::OS2DestroyWindow() 
2943 bool wxWindowOS2::OS2GetCreateWindowCoords( const wxPoint
& rPos
, 
2944                                             const wxSize
&  rSize
, 
2948                                             int& rnHeight 
) const 
2950     bool bNonDefault 
= false; 
2951     static const int DEFAULT_Y 
= 200; 
2952     static const int DEFAULT_H 
= 250; 
2954     if (rPos
.x 
== wxDefaultCoord
) 
2956         rnX 
= rnY 
= CW_USEDEFAULT
; 
2961         rnY 
= rPos
.y 
== wxDefaultCoord 
? DEFAULT_Y 
: rPos
.y
; 
2964     if (rSize
.x 
== wxDefaultCoord
) 
2966         rnWidth 
= rnHeight 
= CW_USEDEFAULT
; 
2971         rnHeight 
= rSize
.y 
== wxDefaultCoord 
? DEFAULT_H 
: rSize
.y
; 
2975 } // end of wxWindowOS2::OS2GetCreateWindowCoords 
2977 WXHWND 
wxWindowOS2::OS2GetParent() const 
2979     return m_parent 
? m_parent
->GetHWND() : NULL
; 
2982 bool wxWindowOS2::OS2Create( PSZ            zClass
, 
2983                              const wxChar
*  zTitle
, 
2985                              const wxPoint
& rPos
, 
2986                              const wxSize
&  rSize
, 
2988                              WXDWORD        
WXUNUSED(dwExStyle
), 
2997     long                 lControlId 
= 0L; 
2998     wxWindowCreationHook 
vHook(this); 
2999     wxString             
sClassName((wxChar
*)zClass
); 
3001     OS2GetCreateWindowCoords( rPos
 
3011         lControlId 
= GetId(); 
3012         if (GetWindowStyleFlag() & wxCLIP_SIBLINGS
) 
3014             dwStyle 
|= WS_CLIPSIBLINGS
; 
3018     // For each class "Foo" we have we also have "FooNR" ("no repaint") class 
3019     // which is the same but without CS_[HV]REDRAW class styles so using it 
3020     // ensures that the window is not fully repainted on each resize 
3022     if (!HasFlag(wxFULL_REPAINT_ON_RESIZE
)) 
3024         sClassName 
+= wxT("NR"); 
3026     m_hWnd 
= (WXHWND
)::WinCreateWindow( (HWND
)OS2GetParent() 
3027                                        ,(PSZ
)sClassName
.c_str() 
3028                                        ,(PSZ
)(zTitle 
? zTitle 
: wxEmptyString
) 
3042         vError 
= ::WinGetLastError(wxGetInstance()); 
3043         sError 
= wxPMErrorToStr(vError
); 
3046     SubclassWin(m_hWnd
); 
3047     SetFont(wxSystemSettings::GetFont(wxSYS_DEFAULT_GUI_FONT
)); 
3049     SetBackgroundColour(wxSystemSettings::GetColour(wxSYS_COLOUR_APPWORKSPACE
)); 
3051     LONG lColor 
= (LONG
)m_backgroundColour
.GetPixel(); 
3053     if (!::WinSetPresParam( m_hWnd
 
3059         vError 
= ::WinGetLastError(vHabmain
); 
3060         sError 
= wxPMErrorToStr(vError
); 
3061         wxLogError(_T("Error creating frame. Error: %s\n"), sError
.c_str()); 
3070 } // end of wxWindowOS2::OS2Create 
3072 // =========================================================================== 
3073 // OS2 PM message handlers 
3074 // =========================================================================== 
3076 // --------------------------------------------------------------------------- 
3077 // window creation/destruction 
3078 // --------------------------------------------------------------------------- 
3080 bool wxWindowOS2::HandleCreate( WXLPCREATESTRUCT 
WXUNUSED(vCs
), 
3083     wxWindowCreateEvent             
vEvent((wxWindow
*)this); 
3085     (void)GetEventHandler()->ProcessEvent(vEvent
); 
3086     *pbMayCreate 
= true; 
3088 } // end of wxWindowOS2::HandleCreate 
3090 bool wxWindowOS2::HandleDestroy() 
3092     wxWindowDestroyEvent            
vEvent((wxWindow
*)this); 
3093     vEvent
.SetId(GetId()); 
3094     (void)GetEventHandler()->ProcessEvent(vEvent
); 
3097     // Delete our drop target if we've got one 
3099 #if wxUSE_DRAG_AND_DROP 
3100     if (m_dropTarget 
!= NULL
) 
3102         delete m_dropTarget
; 
3103         m_dropTarget 
= NULL
; 
3105 #endif // wxUSE_DRAG_AND_DROP 
3108     // WM_DESTROY handled 
3111 } // end of wxWindowOS2::HandleDestroy 
3113 // --------------------------------------------------------------------------- 
3115 // --------------------------------------------------------------------------- 
3116 void wxWindowOS2::OnSetFocus( 
3117   wxFocusEvent
&                     rEvent
 
3121 } // end of wxWindowOS2::OnSetFocus 
3123 bool wxWindowOS2::HandleActivate( 
3125 , WXHWND                            
WXUNUSED(hActivate
) 
3128     wxActivateEvent                 
vEvent( wxEVT_ACTIVATE
 
3132     vEvent
.SetEventObject(this); 
3133     return GetEventHandler()->ProcessEvent(vEvent
); 
3134 } // end of wxWindowOS2::HandleActivate 
3136 bool wxWindowOS2::HandleSetFocus( WXHWND 
WXUNUSED(hWnd
) ) 
3139     // Notify the parent keeping track of focus for the kbd navigation 
3140     // purposes that we got it 
3142     wxChildFocusEvent               
vEventFocus((wxWindow 
*)this); 
3143     (void)GetEventHandler()->ProcessEvent(vEventFocus
); 
3151         m_caret
->OnSetFocus(); 
3153 #endif // wxUSE_CARET 
3156     // If it's a wxTextCtrl don't send the event as it will be done 
3157     // after the control gets to process it from EN_FOCUS handler 
3158     if ( wxDynamicCastThis(wxTextCtrl
) ) 
3162 #endif // wxUSE_TEXTCTRL 
3164     wxFocusEvent                    
vEvent(wxEVT_SET_FOCUS
, m_windowId
); 
3166     vEvent
.SetEventObject(this); 
3167     return GetEventHandler()->ProcessEvent(vEvent
); 
3168 } // end of wxWindowOS2::HandleSetFocus 
3170 bool wxWindowOS2::HandleKillFocus( WXHWND hWnd 
) 
3178         m_caret
->OnKillFocus(); 
3180 #endif // wxUSE_CARET 
3184     // If it's a wxTextCtrl don't send the event as it will be done 
3185     // after the control gets to process it. 
3187     wxTextCtrl
*                     pCtrl 
= wxDynamicCastThis(wxTextCtrl
); 
3196     // Don't send the event when in the process of being deleted.  This can 
3197     // only cause problems if the event handler tries to access the object. 
3199     if ( m_isBeingDeleted 
) 
3204     wxFocusEvent                    
vEvent( wxEVT_KILL_FOCUS
 
3208     vEvent
.SetEventObject(this); 
3211     // wxFindWinFromHandle() may return NULL, it is ok 
3213     vEvent
.SetWindow(wxFindWinFromHandle(hWnd
)); 
3214     return GetEventHandler()->ProcessEvent(vEvent
); 
3215 } // end of wxWindowOS2::HandleKillFocus 
3217 // --------------------------------------------------------------------------- 
3219 // --------------------------------------------------------------------------- 
3221 bool wxWindowOS2::HandleShow( 
3223 , int                               WXUNUSED(nStatus
) 
3226     wxShowEvent                     
vEvent(GetId(), bShow
); 
3228     vEvent
.SetEventObject(this); 
3229     return GetEventHandler()->ProcessEvent(vEvent
); 
3230 } // end of wxWindowOS2::HandleShow 
3232 bool wxWindowOS2::HandleInitDialog( WXHWND 
WXUNUSED(hWndFocus
) ) 
3234     wxInitDialogEvent               
vEvent(GetId()); 
3236     vEvent
.SetEventObject(this); 
3237     return GetEventHandler()->ProcessEvent(vEvent
); 
3238 } // end of wxWindowOS2::HandleInitDialog 
3240 bool wxWindowOS2::HandleEndDrag(WXWPARAM 
WXUNUSED(wParam
)) 
3242    // TODO: We'll handle drag and drop later 
3246 bool wxWindowOS2::HandleSetCursor( USHORT 
WXUNUSED(vId
), 
3250     // Under OS/2 PM this allows the pointer to be changed 
3251     // as it passes over a control 
3253     ::WinSetPointer(HWND_DESKTOP
, (HPOINTER
)hPointer
); 
3255 } // end of wxWindowOS2::HandleSetCursor 
3257 // --------------------------------------------------------------------------- 
3258 // owner drawn stuff 
3259 // --------------------------------------------------------------------------- 
3260 bool wxWindowOS2::OS2OnDrawItem( int vId
, 
3261                                  WXDRAWITEMSTRUCT
* pItemStruct 
) 
3263 #if wxUSE_OWNER_DRAWN 
3266 #if wxUSE_MENUS_NATIVE 
3268     // Is it a menu item? 
3274         POWNERITEM                  pMeasureStruct 
= (POWNERITEM
)pItemStruct
; 
3275         wxFrame
*                    pFrame 
= (wxFrame
*)this; 
3276         wxMenuItem
*                 pMenuItem 
= pFrame
->GetMenuBar()->FindItem(pMeasureStruct
->idItem
, pMeasureStruct
->hItem
); 
3277         HDC                         hDC 
= ::GpiQueryDevice(pMeasureStruct
->hps
); 
3278         wxRect                      
vRect( pMeasureStruct
->rclItem
.xLeft
 
3279                                           ,pMeasureStruct
->rclItem
.yBottom
 
3280                                           ,pMeasureStruct
->rclItem
.xRight 
- pMeasureStruct
->rclItem
.xLeft
 
3281                                           ,pMeasureStruct
->rclItem
.yTop 
- pMeasureStruct
->rclItem
.yBottom
 
3283         vDc
.SetHDC( hDC
, false ); 
3284         vDc
.SetHPS( pMeasureStruct
->hps 
); 
3286         // Load the wxWidgets Pallete and set to RGB mode 
3288         if (!::GpiCreateLogColorTable( pMeasureStruct
->hps
 
3292                                       ,(LONG
)wxTheColourDatabase
->m_nSize
 
3293                                       ,(PLONG
)wxTheColourDatabase
->m_palTable
 
3296             vError 
= ::WinGetLastError(vHabmain
); 
3297             sError 
= wxPMErrorToStr(vError
); 
3298             wxLogError(_T("Unable to set current color table. Error: %s\n"), sError
.c_str()); 
3301         // Set the color table to RGB mode 
3303         if (!::GpiCreateLogColorTable( pMeasureStruct
->hps
 
3311             vError 
= ::WinGetLastError(vHabmain
); 
3312             sError 
= wxPMErrorToStr(vError
); 
3313             wxLogError(_T("Unable to set current color table. Error: %s\n"), sError
.c_str()); 
3316         wxCHECK( pMenuItem
->IsKindOf(CLASSINFO(wxMenuItem
)), FALSE 
); 
3321         if (pMeasureStruct
->fsAttribute 
== pMeasureStruct
->fsAttributeOld
) 
3324             // Entire Item needs to be redrawn (either it has reappeared from 
3325             // behind another window or is being displayed for the first time 
3327             eAction 
= wxOwnerDrawn::wxODDrawAll
; 
3329             if (pMeasureStruct
->fsAttribute 
& MIA_HILITED
) 
3332                 // If it is currently selected we let the system handle it 
3334                 eStatus 
|= wxOwnerDrawn::wxODSelected
; 
3336             if (pMeasureStruct
->fsAttribute 
& MIA_CHECKED
) 
3339                 // If it is currently checked we draw our own 
3341                 eStatus 
|= wxOwnerDrawn::wxODChecked
; 
3342                 pMeasureStruct
->fsAttributeOld 
= pMeasureStruct
->fsAttribute 
&= ~MIA_CHECKED
; 
3344             if (pMeasureStruct
->fsAttribute 
& MIA_DISABLED
) 
3347                 // If it is currently disabled we let the system handle it 
3349                 eStatus 
|= wxOwnerDrawn::wxODDisabled
; 
3352             // Don't really care about framed (indicationg focus) or NoDismiss 
3357             if (pMeasureStruct
->fsAttribute 
& MIA_HILITED
) 
3359                 eAction 
= wxOwnerDrawn::wxODDrawAll
; 
3360                 eStatus 
|= wxOwnerDrawn::wxODSelected
; 
3362                 // Keep the system from trying to highlight with its bogus colors 
3364                 pMeasureStruct
->fsAttributeOld 
= pMeasureStruct
->fsAttribute 
&= ~MIA_HILITED
; 
3366             else if (!(pMeasureStruct
->fsAttribute 
& MIA_HILITED
)) 
3368                 eAction 
= wxOwnerDrawn::wxODDrawAll
; 
3371                 // Keep the system from trying to highlight with its bogus colors 
3373                 pMeasureStruct
->fsAttribute 
= pMeasureStruct
->fsAttributeOld 
&= ~MIA_HILITED
; 
3378                 // For now we don't care about anything else 
3379                 // just ignore the entire message! 
3385         // Now redraw the item 
3387         return(pMenuItem
->OnDrawItem( vDc
 
3389                                      ,(wxOwnerDrawn::wxODAction
)eAction
 
3390                                      ,(wxOwnerDrawn::wxODStatus
)eStatus
 
3393         // leave the fsAttribute and fsOldAttribute unchanged.  If different, 
3394         // the system will do the highlight or fraeming or disabling for us, 
3395         // otherwise, we'd have to do it ourselves. 
3398 #endif // wxUSE_MENUS_NATIVE 
3400     wxWindow
*                       pItem 
= FindItem(vId
); 
3402     if (pItem 
&& pItem
->IsKindOf(CLASSINFO(wxControl
))) 
3404         return ((wxControl 
*)pItem
)->OS2OnDraw(pItemStruct
); 
3408     pItemStruct 
= pItemStruct
; 
3411 } // end of wxWindowOS2::OS2OnDrawItem 
3413 long wxWindowOS2::OS2OnMeasureItem( int lId
, 
3414                                     WXMEASUREITEMSTRUCT
* pItemStruct 
) 
3416 #if wxUSE_OWNER_DRAWN 
3418     // Is it a menu item? 
3420     if (lId 
== 65536) // I really don't like this...has to be a better indicator 
3422         if (IsKindOf(CLASSINFO(wxFrame
))) // we'll assume if Frame then a menu 
3426             POWNERITEM              pMeasureStruct 
= (POWNERITEM
)pItemStruct
; 
3427             wxFrame
*                pFrame 
= (wxFrame
*)this; 
3428             wxMenuItem
*             pMenuItem 
= pFrame
->GetMenuBar()->FindItem(pMeasureStruct
->idItem
, pMeasureStruct
->hItem
); 
3430             wxCHECK( pMenuItem
->IsKindOf(CLASSINFO(wxMenuItem
)), FALSE 
); 
3433             if (pMenuItem
->OnMeasureItem( &nWidth
 
3439                 pMeasureStruct
->rclItem
.xRight  
= nWidth
; 
3440                 pMeasureStruct
->rclItem
.xLeft   
= 0L; 
3441                 pMeasureStruct
->rclItem
.yTop    
= nHeight
; 
3442                 pMeasureStruct
->rclItem
.yBottom 
= 0L; 
3443                 mRc 
= MRFROM2SHORT(nHeight
, nWidth
); 
3444                 return LONGFROMMR(mRc
); 
3449     wxWindow
*                      pItem 
= FindItem(lId
); 
3451     if (pItem 
&& pItem
->IsKindOf(CLASSINFO(wxControl
))) 
3455         vItem
.idItem 
= (LONG
)pItemStruct
; 
3456         return ((wxControl 
*)pItem
)->OS2OnMeasure((WXMEASUREITEMSTRUCT
*)&vItem
); 
3460     pItemStruct 
= pItemStruct
; 
3461 #endif // wxUSE_OWNER_DRAWN 
3465 // --------------------------------------------------------------------------- 
3466 // colours and palettes 
3467 // --------------------------------------------------------------------------- 
3469 bool wxWindowOS2::HandleSysColorChange() 
3471     wxSysColourChangedEvent         vEvent
; 
3473     vEvent
.SetEventObject(this); 
3474     return GetEventHandler()->ProcessEvent(vEvent
); 
3475 } // end of wxWindowOS2::HandleSysColorChange 
3477 bool wxWindowOS2::HandleCtlColor( WXHBRUSH
* WXUNUSED(phBrush
) ) 
3480     // Not much provided with message. So not sure I can do anything with it 
3483 } // end of wxWindowOS2::HandleCtlColor 
3486 // Define for each class of dialog and control 
3487 WXHBRUSH 
wxWindowOS2::OnCtlColor(WXHDC 
WXUNUSED(hDC
), 
3488                                  WXHWND 
WXUNUSED(hWnd
), 
3489                                  WXUINT 
WXUNUSED(nCtlColor
), 
3490                                  WXUINT 
WXUNUSED(message
), 
3491                                  WXWPARAM 
WXUNUSED(wParam
), 
3492                                  WXLPARAM 
WXUNUSED(lParam
)) 
3497 bool wxWindowOS2::HandlePaletteChanged() 
3499     // need to set this to something first 
3500     WXHWND                          hWndPalChange 
= NULLHANDLE
; 
3502     wxPaletteChangedEvent           
vEvent(GetId()); 
3504     vEvent
.SetEventObject(this); 
3505     vEvent
.SetChangedWindow(wxFindWinFromHandle(hWndPalChange
)); 
3507     return GetEventHandler()->ProcessEvent(vEvent
); 
3508 } // end of wxWindowOS2::HandlePaletteChanged 
3511 // Responds to colour changes: passes event on to children. 
3513 void wxWindowOS2::OnSysColourChanged( 
3514   wxSysColourChangedEvent
&          rEvent
 
3517     wxWindowList::compatibility_iterator node 
= GetChildren().GetFirst(); 
3522         // Only propagate to non-top-level windows 
3524         wxWindow
*                   pWin 
= (wxWindow 
*)node
->GetData(); 
3526         if (pWin
->GetParent()) 
3528             wxSysColourChangedEvent vEvent
; 
3530             rEvent
.SetEventObject(pWin
); 
3531             pWin
->GetEventHandler()->ProcessEvent(vEvent
); 
3533         node 
= node
->GetNext(); 
3535 } // end of wxWindowOS2::OnSysColourChanged 
3537 // --------------------------------------------------------------------------- 
3539 // --------------------------------------------------------------------------- 
3541 void wxWindow::OnPaint ( 
3542   wxPaintEvent
&                     rEvent
 
3545     HDC                             hDC 
= (HDC
)wxPaintDC::FindDCInCache((wxWindow
*) rEvent
.GetEventObject()); 
3549         OS2DefWindowProc( (WXUINT
)WM_PAINT
 
3554 } // end of wxWindow::OnPaint 
3556 bool wxWindowOS2::HandlePaint() 
3559     wxPaintEvent                    
vEvent(m_windowId
); 
3563     // Create empty region 
3564     // TODO: get HPS somewhere else if possible 
3565     hPS  
= ::WinGetPS(GetHwnd()); 
3566     hRgn 
= ::GpiCreateRegion(hPS
, 0, NULL
); 
3568     if (::WinQueryUpdateRegion(GetHwnd(), hRgn
) == RGN_ERROR
) 
3570          wxLogLastError(wxT("CreateRectRgn")); 
3574     // Get all the rectangles from the region, convert the individual 
3575     // rectangles to "the other" coordinate system and reassemble a 
3576     // region from the rectangles, to be feed into m_updateRegion. 
3578     // FIXME: This is a bad hack since OS/2 API specifies that rectangles 
3579     //        passed into GpiSetRegion must not have Bottom > Top, 
3580     //        however, at first sight, it _seems_ to work nonetheless. 
3583     PRECTL                      pUpdateRects 
= NULL
; 
3584     vRgnData
.ulDirection 
= RECTDIR_LFRT_TOPBOT
; 
3585     if (::GpiQueryRegionRects( hPS          
// Pres space 
3586                               ,hRgn         
// Handle of region to query 
3587                               ,NULL         
// Return all RECTs 
3588                               ,&vRgnData    
// Will contain number or RECTs in region 
3589                               ,NULL         
// NULL to return number of RECTs 
3592         pUpdateRects 
= new RECTL
[vRgnData
.crcReturned
]; 
3593         vRgnData
.crc 
= vRgnData
.crcReturned
; 
3594         vRgnData
.ircStart 
= 1; 
3595         if (::GpiQueryRegionRects( hPS      
// Pres space of source 
3596                                   ,hRgn     
// Handle of source region 
3597                                   ,NULL     
// Return all RECTs 
3598                                   ,&vRgnData 
// Operations set to return rects 
3599                                   ,pUpdateRects 
// Will contain the actual RECTS 
3604             ::WinQueryWindowRect(GetHwnd(), &vRect
); 
3605             height 
= vRect
.yTop
; 
3607             for(size_t i 
= 0; i 
< vRgnData
.crc
; i
++) 
3610                 rectHeight 
= pUpdateRects
[i
].yTop 
- pUpdateRects
[i
].yBottom
; 
3611                 pUpdateRects
[i
].yTop 
= height 
- pUpdateRects
[i
].yTop
; 
3612                 pUpdateRects
[i
].yBottom 
= pUpdateRects
[i
].yTop 
+ rectHeight
; 
3614             ::GpiSetRegion(hPS
, hRgn
, vRgnData
.crc
, pUpdateRects
); 
3615             delete [] pUpdateRects
; 
3619     m_updateRegion 
= wxRegion(hRgn
, hPS
); 
3621     vEvent
.SetEventObject(this); 
3622     bProcessed 
= GetEventHandler()->ProcessEvent(vEvent
); 
3625          IsKindOf(CLASSINFO(wxPanel
)) && 
3626          GetChildren().GetCount() == 0 
3630         // OS/2 needs to process this right here, not by the default proc 
3631         // Window's default proc correctly paints everything, OS/2 does not. 
3632         // For decorative panels that typically have no children, we draw 
3638         hPS 
= ::WinBeginPaint( GetHwnd() 
3644             ::GpiCreateLogColorTable( hPS
 
3648                                      ,(LONG
)wxTheColourDatabase
->m_nSize
 
3649                                      ,(PLONG
)wxTheColourDatabase
->m_palTable
 
3651             ::GpiCreateLogColorTable( hPS
 
3658             if (::WinIsWindowVisible(GetHWND())) 
3659                 ::WinFillRect(hPS
, &vRect
,  GetBackgroundColour().GetPixel()); 
3662                 LINEBUNDLE      vLineBundle
; 
3664                 vLineBundle
.lColor     
= 0x00000000; // Black 
3665                 vLineBundle
.usMixMode  
= FM_OVERPAINT
; 
3666                 vLineBundle
.fxWidth    
= 1; 
3667                 vLineBundle
.lGeomWidth 
= 1; 
3668                 vLineBundle
.usType     
= LINETYPE_SOLID
; 
3669                 vLineBundle
.usEnd      
= 0; 
3670                 vLineBundle
.usJoin     
= 0; 
3673                               ,LBB_COLOR 
| LBB_MIX_MODE 
| LBB_WIDTH 
| LBB_GEOM_WIDTH 
| LBB_TYPE
 
3677                 ::WinQueryWindowRect(GetHwnd(), &vRect
); 
3687     else if (!bProcessed 
&& 
3688              IsKindOf(CLASSINFO(wxPanel
)) 
3692         // Panel with children, usually fills a frame client so no borders. 
3697         hPS 
= ::WinBeginPaint( GetHwnd() 
3703             ::GpiCreateLogColorTable( hPS
 
3707                                      ,(LONG
)wxTheColourDatabase
->m_nSize
 
3708                                      ,(PLONG
)wxTheColourDatabase
->m_palTable
 
3710             ::GpiCreateLogColorTable( hPS
 
3718             if (::WinIsWindowVisible(GetHWND())) 
3719                 ::WinFillRect(hPS
, &vRect
,  GetBackgroundColour().GetPixel()); 
3725 } // end of wxWindowOS2::HandlePaint 
3727 bool wxWindowOS2::HandleEraseBkgnd( WXHDC hDC 
) 
3732     ::WinQueryWindowPos(GetHwnd(), &vSwp
); 
3733     if (vSwp
.fl 
& SWP_MINIMIZE
) 
3738     vDC
.m_hPS 
= (HPS
)hDC
; // this is really a PS 
3739     vDC
.SetWindow((wxWindow
*)this); 
3741     wxEraseEvent 
vEvent(m_windowId
, &vDC
); 
3743     vEvent
.SetEventObject(this); 
3745     rc 
= GetEventHandler()->ProcessEvent(vEvent
); 
3747     vDC
.m_hPS 
= NULLHANDLE
; 
3749 } // end of wxWindowOS2::HandleEraseBkgnd 
3751 void wxWindowOS2::OnEraseBackground(wxEraseEvent
& rEvent
) 
3754     HPS     hPS 
= rEvent
.GetDC()->GetHPS(); 
3756     LONG    lColor 
= m_backgroundColour
.GetPixel(); 
3758     rc 
= ::WinQueryWindowRect(GetHwnd(), &vRect
); 
3759     rc 
= ::WinFillRect(hPS
, &vRect
, lColor
); 
3760 }  // end of wxWindowOS2::OnEraseBackground 
3762 // --------------------------------------------------------------------------- 
3763 // moving and resizing 
3764 // --------------------------------------------------------------------------- 
3766 bool wxWindowOS2::HandleMinimize() 
3768     wxIconizeEvent                  
vEvent(m_windowId
); 
3770     vEvent
.SetEventObject(this); 
3771     return GetEventHandler()->ProcessEvent(vEvent
); 
3772 } // end of wxWindowOS2::HandleMinimize 
3774 bool wxWindowOS2::HandleMaximize() 
3776     wxMaximizeEvent                 
vEvent(m_windowId
); 
3778     vEvent
.SetEventObject(this); 
3779     return GetEventHandler()->ProcessEvent(vEvent
); 
3780 } // end of wxWindowOS2::HandleMaximize 
3782 bool wxWindowOS2::HandleMove( int nX
, int nY 
) 
3785     wxMoveEvent 
vEvent(pt
, m_windowId
); 
3787     vEvent
.SetEventObject(this); 
3788     return GetEventHandler()->ProcessEvent(vEvent
); 
3789 }  // end of wxWindowOS2::HandleMove 
3791 bool wxWindowOS2::HandleSize( int    nWidth
, 
3793                               WXUINT 
WXUNUSED(nFlag
) ) 
3795     wxSize 
sz(nWidth
, nHeight
); 
3796     wxSizeEvent 
vEvent(sz
, m_windowId
); 
3798     vEvent
.SetEventObject(this); 
3799     return GetEventHandler()->ProcessEvent(vEvent
); 
3800 } // end of wxWindowOS2::HandleSize 
3802 bool wxWindowOS2::HandleGetMinMaxInfo( PSWP pSwp 
) 
3809             ::WinGetMaxPosition(GetHwnd(), pSwp
); 
3810             m_maxWidth 
= pSwp
->cx
; 
3811             m_maxHeight 
= pSwp
->cy
; 
3815             ::WinGetMinPosition(GetHwnd(), pSwp
, &vPoint
); 
3816             m_minWidth 
= pSwp
->cx
; 
3817             m_minHeight 
= pSwp
->cy
; 
3824 } // end of wxWindowOS2::HandleGetMinMaxInfo 
3826 // --------------------------------------------------------------------------- 
3828 // --------------------------------------------------------------------------- 
3829 bool wxWindowOS2::HandleCommand( WXWORD wId
, 
3833 #if wxUSE_MENUS_NATIVE 
3834     if (wxCurrentPopupMenu
) 
3836         wxMenu
*                     pPopupMenu 
= wxCurrentPopupMenu
; 
3838         wxCurrentPopupMenu 
= NULL
; 
3839         return pPopupMenu
->OS2Command(wCmd
, wId
); 
3841 #endif // wxUSE_MENUS_NATIVE 
3843     wxWindow
*                       pWin 
= FindItem(wId
); 
3847         pWin 
= wxFindWinFromHandle(hControl
); 
3851         return pWin
->OS2Command(wCmd
, wId
); 
3854 } // end of wxWindowOS2::HandleCommand 
3856 bool wxWindowOS2::HandleSysCommand( WXWPARAM wParam
, 
3857                                     WXLPARAM 
WXUNUSED(lParam
) ) 
3860     // 4 bits are reserved 
3862     switch (SHORT1FROMMP(wParam
)) 
3865             return HandleMaximize(); 
3868             return HandleMinimize(); 
3871 } // end of wxWindowOS2::HandleSysCommand 
3873 // --------------------------------------------------------------------------- 
3875 // --------------------------------------------------------------------------- 
3876 //TODO: check against MSW 
3877 void wxWindowOS2::InitMouseEvent( 
3878   wxMouseEvent
&                     rEvent
 
3885     DoGetSize(0, &nHeight
); 
3887     // Convert to wxWidgets standard coordinate system! 
3888     rEvent
.m_y           
= nHeight 
- nY
; 
3889     rEvent
.m_shiftDown   
= ((uFlags 
& KC_SHIFT
) != 0); 
3890     rEvent
.m_controlDown 
= ((uFlags 
& KC_CTRL
) != 0); 
3891     rEvent
.m_altDown     
= ((uFlags 
& KC_ALT
) != 0); 
3892     rEvent
.m_leftDown    
= (::WinGetKeyState(HWND_DESKTOP
, VK_BUTTON1
) & 
3894     rEvent
.m_middleDown  
= (::WinGetKeyState(HWND_DESKTOP
, VK_BUTTON3
) & 
3896     rEvent
.m_rightDown   
= (::WinGetKeyState(HWND_DESKTOP
, VK_BUTTON2
) & 
3898     rEvent
.SetTimestamp(s_currentMsg
.time
); 
3899     rEvent
.SetEventObject(this); 
3900     rEvent
.SetId(GetId()); 
3902 #if wxUSE_MOUSEEVENT_HACK 
3905     m_lastMouseEvent 
= rEvent
.GetEventType(); 
3906 #endif // wxUSE_MOUSEEVENT_HACK 
3907 } // end of wxWindowOS2::InitMouseEvent 
3909 bool wxWindowOS2::HandleMouseEvent( WXUINT uMsg
, 
3914     bool bProcessed 
= false; 
3917     // The mouse events take consecutive IDs from WM_MOUSEFIRST to 
3918     // WM_MOUSELAST, so it's enough to subtract WM_MOUSEMOVE == WM_MOUSEFIRST 
3919     // from the message id and take the value in the table to get wxWin event 
3922     static const wxEventType eventsMouse
[] = 
3937     if ((uMsg 
>= WM_MOUSEMOVE
) && (uMsg 
<= WM_BUTTON3DBLCLK
)) 
3939         wxMouseEvent 
vEvent(eventsMouse
[uMsg 
- WM_MOUSEMOVE
]); 
3941         InitMouseEvent( vEvent
 
3947         bProcessed 
= GetEventHandler()->ProcessEvent(vEvent
); 
3950             HPOINTER hCursor 
= (HPOINTER
)GetCursor().GetHCURSOR(); 
3952             if (hCursor 
!= NULLHANDLE
) 
3954                 ::WinSetPointer(HWND_DESKTOP
, hCursor
); 
3960 } // end of wxWindowOS2::HandleMouseEvent 
3962 bool wxWindowOS2::HandleMouseMove( int nX
, 
3966     if (!m_bMouseInWindow
) 
3969         // Generate an ENTER event 
3971         m_bMouseInWindow 
= true; 
3973         wxMouseEvent 
vEvent(wxEVT_ENTER_WINDOW
); 
3975         InitMouseEvent( vEvent
 
3981         (void)GetEventHandler()->ProcessEvent(vEvent
); 
3983     return HandleMouseEvent( WM_MOUSEMOVE
 
3988 } // end of wxWindowOS2::HandleMouseMove 
3990 // --------------------------------------------------------------------------- 
3991 // keyboard handling 
3992 // --------------------------------------------------------------------------- 
3995 // Create the key event of the given type for the given key - used by 
3996 // HandleChar and HandleKeyDown/Up 
3998 wxKeyEvent 
wxWindowOS2::CreateKeyEvent( 
4005     wxKeyEvent                      
vEvent(eType
); 
4007     vEvent
.SetId(GetId()); 
4008     vEvent
.m_shiftDown   
= IsShiftDown(); 
4009     vEvent
.m_controlDown 
= IsCtrlDown(); 
4010     vEvent
.m_altDown     
= (HIWORD(lParam
) & KC_ALT
) == KC_ALT
; 
4012     vEvent
.SetEventObject((wxWindow 
*)this); // const_cast 
4013     vEvent
.m_keyCode     
= nId
; 
4014     vEvent
.m_rawCode 
= (wxUint32
)wParam
; 
4015     vEvent
.m_rawFlags 
= (wxUint32
)lParam
; 
4016     vEvent
.SetTimestamp(s_currentMsg
.time
); 
4019     // Translate the position to client coords 
4024     ::WinQueryPointerPos(HWND_DESKTOP
, &vPoint
); 
4025     ::WinQueryWindowRect( GetHwnd() 
4029     vPoint
.x 
-= vRect
.xLeft
; 
4030     vPoint
.y 
-= vRect
.yBottom
; 
4032     vEvent
.m_x 
= vPoint
.x
; 
4033     vEvent
.m_y 
= vPoint
.y
; 
4036 } // end of wxWindowOS2::CreateKeyEvent 
4039 // isASCII is true only when we're called from WM_CHAR handler and not from 
4042 bool wxWindowOS2::HandleChar( WXWPARAM 
WXUNUSED(wParam
), 
4046     bool bCtrlDown 
= false; 
4049     if (m_bLastKeydownProcessed
) 
4052         // The key was handled in the EVT_KEY_DOWN.  Handling a key in an 
4053         // EVT_KEY_DOWN handler is meant, by design, to prevent EVT_CHARs 
4054         // from happening, so just bail out at this point. 
4056         m_bLastKeydownProcessed 
= false; 
4062         // If 1 -> 26, translate to either special keycode or just set 
4063         // ctrlDown.  IOW, Ctrl-C should result in keycode == 3 and 
4064         // ControlDown() == true. 
4066         vId 
= SHORT1FROMMP(lParam
); 
4067         if ((vId 
> 0) && (vId 
< 27)) 
4089     else  // we're called from WM_KEYDOWN 
4091         vId 
= wxCharCodeOS2ToWX((int)SHORT2FROMMP(lParam
)); 
4096     wxKeyEvent 
vEvent(CreateKeyEvent( wxEVT_CHAR
, vId
, lParam 
)); 
4100         vEvent
.m_controlDown 
= true; 
4103     return (GetEventHandler()->ProcessEvent(vEvent
)); 
4106 bool wxWindowOS2::HandleKeyDown( WXWPARAM wParam
, 
4109     int nId 
= wxCharCodeOS2ToWX((int)SHORT2FROMMP(lParam
)); 
4114         // Normal ASCII char 
4116         nId 
= SHORT1FROMMP(lParam
); 
4121         wxKeyEvent  
vEvent(CreateKeyEvent( wxEVT_KEY_DOWN
 
4127         if (GetEventHandler()->ProcessEvent(vEvent
)) 
4133 } // end of wxWindowOS2::HandleKeyDown 
4135 bool wxWindowOS2::HandleKeyUp( WXWPARAM wParam
, 
4138     int nId 
= wxCharCodeOS2ToWX((int)SHORT2FROMMP(lParam
)); 
4143         // Normal ASCII char 
4145         nId 
= CHAR1FROMMP(lParam
); 
4150         wxKeyEvent 
vEvent(CreateKeyEvent( wxEVT_KEY_UP
 
4156         if (GetEventHandler()->ProcessEvent(vEvent
)) 
4160 } // end of wxWindowOS2::HandleKeyUp 
4162 // --------------------------------------------------------------------------- 
4164 // --------------------------------------------------------------------------- 
4166 // --------------------------------------------------------------------------- 
4168 // --------------------------------------------------------------------------- 
4170 bool wxWindowOS2::OS2OnScroll( int nOrientation
, 
4177         wxWindow
*                   pChild 
= wxFindWinFromHandle(hControl
); 
4180             return pChild
->OS2OnScroll( nOrientation
 
4187     wxScrollWinEvent                vEvent
; 
4189     vEvent
.SetPosition(wPos
); 
4190     vEvent
.SetOrientation(nOrientation
); 
4191     vEvent
.SetEventObject(this); 
4196             vEvent
.SetEventType(wxEVT_SCROLLWIN_LINEUP
); 
4200             vEvent
.SetEventType(wxEVT_SCROLLWIN_LINEDOWN
); 
4204             vEvent
.SetEventType(wxEVT_SCROLLWIN_PAGEUP
); 
4208             vEvent
.SetEventType(wxEVT_SCROLLWIN_PAGEDOWN
); 
4211         case SB_SLIDERPOSITION
: 
4212             vEvent
.SetEventType(wxEVT_SCROLLWIN_THUMBRELEASE
); 
4215         case SB_SLIDERTRACK
: 
4216             vEvent
.SetEventType(wxEVT_SCROLLWIN_THUMBTRACK
); 
4222     return GetEventHandler()->ProcessEvent(vEvent
); 
4223 } // end of wxWindowOS2::OS2OnScroll 
4226 //  Getting the Y position for a window, like a control, is a real 
4227 //  pain.  There are three situations we must deal with in determining 
4228 //  the OS2 to wxWidgets Y coordinate. 
4230 //  1)  The controls are created in a dialog. 
4231 //      This is the easiest since a dialog is created with its original 
4232 //      size so the standard: Y = ParentHeight - (Y + ControlHeight); 
4234 //  2)  The controls are direct children of a frame 
4235 //      In this instance the controls are actually children of the Frame's 
4236 //      client.  During creation the frame's client resizes several times 
4237 //      during creation of the status bar and toolbars.  The CFrame class 
4238 //      will take care of this using its AlterChildPos proc. 
4240 //  3)  The controls are children of a panel, which in turn is a child of 
4242 //      The panel may be one of many, in which case the same treatment 
4243 //      as 1 applies. It may be the only child, though. 
4244 //      This is the nastiest case.  A panel is created as the only child of 
4245 //      the frame and as such, when a frame has only one child, the child is 
4246 //      expanded to fit the entire client area of the frame.  Because the 
4247 //      controls are created BEFORE this occurs their positions are totally 
4248 //      whacked and any call to WinQueryWindowPos will return invalid 
4249 //      coordinates.  So for this situation we have to compare the size of 
4250 //      the panel at control creation time with that of the frame client.  If 
4251 //      they are the same we can use the standard Y position equation.  If 
4252 //      not, then we must use the Frame Client's dimensions to position them 
4253 //      as that will be the eventual size of the panel after the frame resizes 
4256 int wxWindowOS2::GetOS2ParentHeight( wxWindowOS2
* pParent 
) 
4263         if (pParent
->IsKindOf(CLASSINFO(wxDialog
))) 
4264             return(pParent
->GetClientSize().y
); 
4267     // Case 2 -- if we are one of the separately built standard Frame 
4268     //           children, like a statusbar, menubar, or toolbar we want to 
4269     //           use the frame, itself, for positioning.  Otherwise we are 
4270     //           child window and want to use the Frame's client. 
4272         else if (pParent
->IsKindOf(CLASSINFO(wxFrame
))) 
4274             if (IsKindOf(CLASSINFO(wxStatusBar
)) || 
4275                 IsKindOf(CLASSINFO(wxMenuBar
))   || 
4276                 IsKindOf(CLASSINFO(wxToolBar
)) 
4279                 if (IsKindOf(CLASSINFO(wxToolBar
))) 
4281                     wxFrame
*        pFrame 
= wxDynamicCast(GetParent(), wxFrame
); 
4283                     if (pFrame
->GetToolBar() == this) 
4284                         return(pParent
->GetSize().y
); 
4286                         return(pParent
->GetClientSize().y
); 
4289                     return(pParent
->GetSize().y
); 
4292                 return(pParent
->GetClientSize().y
); 
4295         // Case -- this is for any window that is the sole child of a Frame. 
4296         //         The grandparent must exist and it must be of type CFrame 
4297         //         and it's height must be different. Otherwise the standard 
4301             return(pParent
->GetClientSize().y
); 
4303     else // We must be a child of the screen 
4306         wxDisplaySize(NULL
,&nHeight
); 
4309 } // end of wxWindowOS2::GetOS2ParentHeight 
4312 // OS/2 needs a lot extra manipulation to deal with layouts 
4313 // for canvas windows, particularly scrolled ones. 
4315 wxWindowCreationHook::wxWindowCreationHook( 
4316   wxWindow
*                         pWinBeingCreated
 
4319     gpWinBeingCreated 
= pWinBeingCreated
; 
4320 } // end of wxWindowCreationHook::wxWindowCreationHook 
4322 wxWindowCreationHook::~wxWindowCreationHook() 
4324     gpWinBeingCreated 
= NULL
; 
4325 } // end of wxWindowCreationHook::~wxWindowCreationHook 
4327 // =========================================================================== 
4329 // =========================================================================== 
4335 ,wxFont
*                            WXUNUSED(pTheFont
) 
4342     hPS 
=::WinGetPS(hWnd
); 
4344     rc 
= ::GpiQueryFontMetrics(hPS
, sizeof(FONTMETRICS
), &vFM
); 
4348             *pX 
= vFM
.lAveCharWidth
; 
4350             *pY 
= vFM
.lEmHeight 
+ vFM
.lExternalLeading
; 
4359     ::WinReleasePS(hPS
); 
4360 } // end of wxGetCharSize 
4363 // Returns 0 if was a normal ASCII value, not a special key. This indicates that 
4364 // the key should be ignored by WM_KEYDOWN and processed by WM_CHAR instead. 
4366 int wxCharCodeOS2ToWX( 
4374         case VK_BACKTAB
:    nId 
= WXK_BACK
; break; 
4375         case VK_TAB
:        nId 
= WXK_TAB
; break; 
4376         case VK_CLEAR
:      nId 
= WXK_CLEAR
; break; 
4377         case VK_ENTER
:      nId 
= WXK_RETURN
; break; 
4378         case VK_SHIFT
:      nId 
= WXK_SHIFT
; break; 
4379         case VK_CTRL
:       nId 
= WXK_CONTROL
; break; 
4380         case VK_PAUSE
:      nId 
= WXK_PAUSE
; break; 
4381         case VK_SPACE
:      nId 
= WXK_SPACE
; break; 
4382         case VK_PAGEUP
:     nId 
= WXK_PAGEUP
; break; 
4383         case VK_PAGEDOWN
:   nId 
= WXK_PAGEDOWN
; break; 
4384         case VK_ESC
:        nId 
= WXK_ESCAPE
; break; 
4385         case VK_END
:        nId 
= WXK_END
; break; 
4386         case VK_HOME 
:      nId 
= WXK_HOME
; break; 
4387         case VK_LEFT 
:      nId 
= WXK_LEFT
; break; 
4388         case VK_UP
:         nId 
= WXK_UP
; break; 
4389         case VK_RIGHT
:      nId 
= WXK_RIGHT
; break; 
4390         case VK_DOWN 
:      nId 
= WXK_DOWN
; break; 
4391         case VK_PRINTSCRN
:  nId 
= WXK_PRINT
; break; 
4392         case VK_INSERT
:     nId 
= WXK_INSERT
; break; 
4393         case VK_DELETE
:     nId 
= WXK_DELETE
; break; 
4394         case VK_CAPSLOCK
:   nId 
= WXK_CAPITAL
; break; 
4395         case VK_F1
:         nId 
= WXK_F1
; break; 
4396         case VK_F2
:         nId 
= WXK_F2
; break; 
4397         case VK_F3
:         nId 
= WXK_F3
; break; 
4398         case VK_F4
:         nId 
= WXK_F4
; break; 
4399         case VK_F5
:         nId 
= WXK_F5
; break; 
4400         case VK_F6
:         nId 
= WXK_F6
; break; 
4401         case VK_F7
:         nId 
= WXK_F7
; break; 
4402         case VK_F8
:         nId 
= WXK_F8
; break; 
4403         case VK_F9
:         nId 
= WXK_F9
; break; 
4404         case VK_F10
:        nId 
= WXK_F10
; break; 
4405         case VK_F11
:        nId 
= WXK_F11
; break; 
4406         case VK_F12
:        nId 
= WXK_F12
; break; 
4407         case VK_F13
:        nId 
= WXK_F13
; break; 
4408         case VK_F14
:        nId 
= WXK_F14
; break; 
4409         case VK_F15
:        nId 
= WXK_F15
; break; 
4410         case VK_F16
:        nId 
= WXK_F16
; break; 
4411         case VK_F17
:        nId 
= WXK_F17
; break; 
4412         case VK_F18
:        nId 
= WXK_F18
; break; 
4413         case VK_F19
:        nId 
= WXK_F19
; break; 
4414         case VK_F20
:        nId 
= WXK_F20
; break; 
4415         case VK_F21
:        nId 
= WXK_F21
; break; 
4416         case VK_F22
:        nId 
= WXK_F22
; break; 
4417         case VK_F23
:        nId 
= WXK_F23
; break; 
4418         case VK_F24
:        nId 
= WXK_F24
; break; 
4419         case VK_OEM_1
:      nId 
= ';'; break; 
4420         case VK_OEM_PLUS
:   nId 
= '+'; break; 
4421         case VK_OEM_COMMA
:  nId 
= ','; break; 
4422         case VK_OEM_MINUS
:  nId 
= '-'; break; 
4423         case VK_OEM_PERIOD
: nId 
= '.'; break; 
4424         case VK_OEM_2
:      nId 
= '/'; break; 
4425         case VK_OEM_3
:      nId 
= '~'; break; 
4426         case VK_OEM_4
:      nId 
= '['; break; 
4427         case VK_OEM_5
:      nId 
= '\\'; break; 
4428         case VK_OEM_6
:      nId 
= ']'; break; 
4429         case VK_OEM_7
:      nId 
= '\''; break; 
4430         case VK_NUMLOCK
:    nId 
= WXK_NUMLOCK
; break; 
4431         case VK_SCRLLOCK
:   nId 
= WXK_SCROLL
; break; 
4438 } // end of wxCharCodeOS2ToWX 
4440 int wxCharCodeWXToOS2( int nId
, 
4448         case WXK_CLEAR
:     nKeySym 
= VK_CLEAR
; break; 
4449         case WXK_SHIFT
:     nKeySym 
= VK_SHIFT
; break; 
4450         case WXK_CONTROL
:   nKeySym 
= VK_CTRL
; break; 
4451         case WXK_PAUSE
:     nKeySym 
= VK_PAUSE
; break; 
4452         case WXK_PAGEUP
:    nKeySym 
= VK_PAGEUP
; break; 
4453         case WXK_PAGEDOWN
:  nKeySym 
= VK_PAGEDOWN
; break; 
4454         case WXK_END
:       nKeySym 
= VK_END
; break; 
4455         case WXK_HOME 
:     nKeySym 
= VK_HOME
; break; 
4456         case WXK_LEFT 
:     nKeySym 
= VK_LEFT
; break; 
4457         case WXK_UP
:        nKeySym 
= VK_UP
; break; 
4458         case WXK_RIGHT
:     nKeySym 
= VK_RIGHT
; break; 
4459         case WXK_DOWN 
:     nKeySym 
= VK_DOWN
; break; 
4460         case WXK_PRINT
:     nKeySym 
= VK_PRINTSCRN
; break; 
4461         case WXK_INSERT
:    nKeySym 
= VK_INSERT
; break; 
4462         case WXK_DELETE
:    nKeySym 
= VK_DELETE
; break; 
4463         case WXK_F1
:        nKeySym 
= VK_F1
; break; 
4464         case WXK_F2
:        nKeySym 
= VK_F2
; break; 
4465         case WXK_F3
:        nKeySym 
= VK_F3
; break; 
4466         case WXK_F4
:        nKeySym 
= VK_F4
; break; 
4467         case WXK_F5
:        nKeySym 
= VK_F5
; break; 
4468         case WXK_F6
:        nKeySym 
= VK_F6
; break; 
4469         case WXK_F7
:        nKeySym 
= VK_F7
; break; 
4470         case WXK_F8
:        nKeySym 
= VK_F8
; break; 
4471         case WXK_F9
:        nKeySym 
= VK_F9
; break; 
4472         case WXK_F10
:       nKeySym 
= VK_F10
; break; 
4473         case WXK_F11
:       nKeySym 
= VK_F11
; break; 
4474         case WXK_F12
:       nKeySym 
= VK_F12
; break; 
4475         case WXK_F13
:       nKeySym 
= VK_F13
; break; 
4476         case WXK_F14
:       nKeySym 
= VK_F14
; break; 
4477         case WXK_F15
:       nKeySym 
= VK_F15
; break; 
4478         case WXK_F16
:       nKeySym 
= VK_F16
; break; 
4479         case WXK_F17
:       nKeySym 
= VK_F17
; break; 
4480         case WXK_F18
:       nKeySym 
= VK_F18
; break; 
4481         case WXK_F19
:       nKeySym 
= VK_F19
; break; 
4482         case WXK_F20
:       nKeySym 
= VK_F20
; break; 
4483         case WXK_F21
:       nKeySym 
= VK_F21
; break; 
4484         case WXK_F22
:       nKeySym 
= VK_F22
; break; 
4485         case WXK_F23
:       nKeySym 
= VK_F23
; break; 
4486         case WXK_F24
:       nKeySym 
= VK_F24
; break; 
4487         case WXK_NUMLOCK
:   nKeySym 
= VK_NUMLOCK
; break; 
4488         case WXK_SCROLL
:    nKeySym 
= VK_SCRLLOCK
; break; 
4491             *bIsVirtual 
= false; 
4497 } // end of wxCharCodeWXToOS2 
4499 wxWindow
* wxGetActiveWindow() 
4501     HWND                            hWnd 
= ::WinQueryActiveWindow(HWND_DESKTOP
); 
4505         return wxFindWinFromHandle((WXHWND
)hWnd
); 
4508 } // end of wxGetActiveWindow 
4511 const wxChar
* wxGetMessageName( int nMessage 
) 
4515         case 0x0000: return wxT("WM_NULL"); 
4516         case 0x0001: return wxT("WM_CREATE"); 
4517         case 0x0002: return wxT("WM_DESTROY"); 
4518         case 0x0004: return wxT("WM_ENABLE"); 
4519         case 0x0005: return wxT("WM_SHOW"); 
4520         case 0x0006: return wxT("WM_MOVE"); 
4521         case 0x0007: return wxT("WM_SIZE"); 
4522         case 0x0008: return wxT("WM_ADJUSTWINDOWPOS"); 
4523         case 0x0009: return wxT("WM_CALCVALIDRECTS"); 
4524         case 0x000A: return wxT("WM_SETWINDOWPARAMS"); 
4525         case 0x000B: return wxT("WM_QUERYWINDOWPARAMS"); 
4526         case 0x000C: return wxT("WM_HITTEST"); 
4527         case 0x000D: return wxT("WM_ACTIVATE"); 
4528         case 0x000F: return wxT("WM_SETFOCUS"); 
4529         case 0x0010: return wxT("WM_SETSELECTION"); 
4530         case 0x0011: return wxT("WM_PPAINT"); 
4531         case 0x0012: return wxT("WM_PSETFOCUS"); 
4532         case 0x0013: return wxT("WM_PSYSCOLORCHANGE"); 
4533         case 0x0014: return wxT("WM_PSIZE"); 
4534         case 0x0015: return wxT("WM_PACTIVATE"); 
4535         case 0x0016: return wxT("WM_PCONTROL"); 
4536         case 0x0020: return wxT("WM_COMMAND"); 
4537         case 0x0021: return wxT("WM_SYSCOMMAND"); 
4538         case 0x0022: return wxT("WM_HELP"); 
4539         case 0x0023: return wxT("WM_PAINT"); 
4540         case 0x0024: return wxT("WM_TIMER"); 
4541         case 0x0025: return wxT("WM_SEM1"); 
4542         case 0x0026: return wxT("WM_SEM2"); 
4543         case 0x0027: return wxT("WM_SEM3"); 
4544         case 0x0028: return wxT("WM_SEM4"); 
4545         case 0x0029: return wxT("WM_CLOSE"); 
4546         case 0x002A: return wxT("WM_QUIT"); 
4547         case 0x002B: return wxT("WM_SYSCOLORCHANGE"); 
4548         case 0x002D: return wxT("WM_SYSVALUECHANGE"); 
4549         case 0x002E: return wxT("WM_APPTERMINATENOTIFY"); 
4550         case 0x002F: return wxT("WM_PRESPARAMCHANGED"); 
4551         // Control notification messages 
4552         case 0x0030: return wxT("WM_CONTROL"); 
4553         case 0x0031: return wxT("WM_VSCROLL"); 
4554         case 0x0032: return wxT("WM_HSCROLL"); 
4555         case 0x0033: return wxT("WM_INITMENU"); 
4556         case 0x0034: return wxT("WM_MENUSELECT"); 
4557         case 0x0035: return wxT("WM_MENUSEND"); 
4558         case 0x0036: return wxT("WM_DRAWITEM"); 
4559         case 0x0037: return wxT("WM_MEASUREITEM"); 
4560         case 0x0038: return wxT("WM_CONTROLPOINTER"); 
4561         case 0x003A: return wxT("WM_QUERYDLGCODE"); 
4562         case 0x003B: return wxT("WM_INITDLG"); 
4563         case 0x003C: return wxT("WM_SUBSTITUTESTRING"); 
4564         case 0x003D: return wxT("WM_MATCHMNEMONIC"); 
4565         case 0x003E: return wxT("WM_SAVEAPPLICATION"); 
4566         case 0x0129: return wxT("WM_CTLCOLORCHANGE"); 
4567         case 0x0130: return wxT("WM_QUERYCTLTYPE"); 
4569         case 0x0040: return wxT("WM_FLASHWINDOW"); 
4570         case 0x0041: return wxT("WM_FORMATFRAME"); 
4571         case 0x0042: return wxT("WM_UPDATEFRAME"); 
4572         case 0x0043: return wxT("WM_FOCUSCHANGE"); 
4573         case 0x0044: return wxT("WM_SETBORDERSIZE"); 
4574         case 0x0045: return wxT("WM_TRACKFRAME"); 
4575         case 0x0046: return wxT("WM_MINMAXFRAME"); 
4576         case 0x0047: return wxT("WM_SETICON"); 
4577         case 0x0048: return wxT("WM_QUERYICON"); 
4578         case 0x0049: return wxT("WM_SETACCELTABLE"); 
4579         case 0x004A: return wxT("WM_QUERYACCELTABLE"); 
4580         case 0x004B: return wxT("WM_TRANSLATEACCEL"); 
4581         case 0x004C: return wxT("WM_QUERYTRACKINFO"); 
4582         case 0x004D: return wxT("WM_QUERYBORDERSIZE"); 
4583         case 0x004E: return wxT("WM_NEXTMENU"); 
4584         case 0x004F: return wxT("WM_ERASEBACKGROUND"); 
4585         case 0x0050: return wxT("WM_QUERYFRAMEINFO"); 
4586         case 0x0051: return wxT("WM_QUERYFOCUSCHAIN"); 
4587         case 0x0052: return wxT("WM_OWNERPOSCHANGE"); 
4588         case 0x0053: return wxT("WM_CACLFRAMERECT"); 
4589         case 0x0055: return wxT("WM_WINDOWPOSCHANGED"); 
4590         case 0x0056: return wxT("WM_ADJUSTFRAMEPOS"); 
4591         case 0x0059: return wxT("WM_QUERYFRAMECTLCOUNT"); 
4592         case 0x005B: return wxT("WM_QUERYHELPINFO"); 
4593         case 0x005C: return wxT("WM_SETHELPINFO"); 
4594         case 0x005D: return wxT("WM_ERROR"); 
4595         case 0x005E: return wxT("WM_REALIZEPALETTE"); 
4596         // Clipboard messages 
4597         case 0x0060: return wxT("WM_RENDERFMT"); 
4598         case 0x0061: return wxT("WM_RENDERALLFMTS"); 
4599         case 0x0062: return wxT("WM_DESTROYCLIPBOARD"); 
4600         case 0x0063: return wxT("WM_PAINTCLIPBOARD"); 
4601         case 0x0064: return wxT("WM_SIZECLIPBOARD"); 
4602         case 0x0065: return wxT("WM_HSCROLLCLIPBOARD"); 
4603         case 0x0066: return wxT("WM_VSCROLLCLIPBOARD"); 
4604         case 0x0067: return wxT("WM_DRAWCLIPBOARD"); 
4606         case 0x0070: return wxT("WM_MOUSEMOVE"); 
4607         case 0x0071: return wxT("WM_BUTTON1DOWN"); 
4608         case 0x0072: return wxT("WM_BUTTON1UP"); 
4609         case 0x0073: return wxT("WM_BUTTON1DBLCLK"); 
4610         case 0x0074: return wxT("WM_BUTTON2DOWN"); 
4611         case 0x0075: return wxT("WM_BUTTON2UP"); 
4612         case 0x0076: return wxT("WM_BUTTON2DBLCLK"); 
4613         case 0x0077: return wxT("WM_BUTTON3DOWN"); 
4614         case 0x0078: return wxT("WM_BUTTON3UP"); 
4615         case 0x0079: return wxT("WM_BUTTON3DBLCLK"); 
4616         case 0x007D: return wxT("WM_MOUSEMAP"); 
4617         case 0x007E: return wxT("WM_VRNDISABLED"); 
4618         case 0x007F: return wxT("WM_VRNENABLED"); 
4619         case 0x0410: return wxT("WM_CHORD"); 
4620         case 0x0411: return wxT("WM_BUTTON1MOTIONSTART"); 
4621         case 0x0412: return wxT("WM_BUTTON1MOTIONEND"); 
4622         case 0x0413: return wxT("WM_BUTTON1CLICK"); 
4623         case 0x0414: return wxT("WM_BUTTON2MOTIONSTART"); 
4624         case 0x0415: return wxT("WM_BUTTON2MOTIONEND"); 
4625         case 0x0416: return wxT("WM_BUTTON2CLICK"); 
4626         case 0x0417: return wxT("WM_BUTTON3MOTIONSTART"); 
4627         case 0x0418: return wxT("WM_BUTTON3MOTIONEND"); 
4628         case 0x0419: return wxT("WM_BUTTON3CLICK"); 
4629         case 0x0420: return wxT("WM_BEGINDRAG"); 
4630         case 0x0421: return wxT("WM_ENDDRAG"); 
4631         case 0x0422: return wxT("WM_SINGLESELECT"); 
4632         case 0x0423: return wxT("WM_OPEN"); 
4633         case 0x0424: return wxT("WM_CONTEXTMENU"); 
4634         case 0x0425: return wxT("WM_CONTEXTHELP"); 
4635         case 0x0426: return wxT("WM_TEXTEDIT"); 
4636         case 0x0427: return wxT("WM_BEGINSELECT"); 
4637         case 0x0228: return wxT("WM_ENDSELECT"); 
4638         case 0x0429: return wxT("WM_PICKUP"); 
4639         case 0x04C0: return wxT("WM_PENFIRST"); 
4640         case 0x04FF: return wxT("WM_PENLAST"); 
4641         case 0x0500: return wxT("WM_MMPMFIRST"); 
4642         case 0x05FF: return wxT("WM_MMPMLAST"); 
4643         case 0x0600: return wxT("WM_STDDLGFIRST"); 
4644         case 0x06FF: return wxT("WM_STDDLGLAST"); 
4645         case 0x0BD0: return wxT("WM_BIDI_FIRST"); 
4646         case 0x0BFF: return wxT("WM_BIDI_LAST"); 
4648         case 0x007A: return wxT("WM_CHAR"); 
4649         case 0x007B: return wxT("WM_VIOCHAR"); 
4651         case 0x00A0: return wxT("WM_DDE_INITIATE"); 
4652         case 0x00A1: return wxT("WM_DDE_REQUEST"); 
4653         case 0x00A2: return wxT("WM_DDE_ACK"); 
4654         case 0x00A3: return wxT("WM_DDE_DATA"); 
4655         case 0x00A4: return wxT("WM_DDE_ADVISE"); 
4656         case 0x00A5: return wxT("WM_DDE_UNADVISE"); 
4657         case 0x00A6: return wxT("WM_DDE_POKE"); 
4658         case 0x00A7: return wxT("WM_DDE_EXECUTE"); 
4659         case 0x00A8: return wxT("WM_DDE_TERMINATE"); 
4660         case 0x00A9: return wxT("WM_DDE_INITIATEACK"); 
4661         case 0x00AF: return wxT("WM_DDE_LAST"); 
4663         case 0x0120: return wxT("BM_CLICK"); 
4664         case 0x0121: return wxT("BM_QUERYCHECKINDEX"); 
4665         case 0x0122: return wxT("BM_QUERYHILITE"); 
4666         case 0x0123: return wxT("BM_SETHILITE"); 
4667         case 0x0124: return wxT("BM_QUERYCHECK"); 
4668         case 0x0125: return wxT("BM_SETCHECK"); 
4669         case 0x0126: return wxT("BM_SETDEFAULT"); 
4670         case 0x0128: return wxT("BM_AUTOSIZE"); 
4672         case 0x029A: return wxT("CBID_LIST"); 
4673         case 0x029B: return wxT("CBID_EDIT"); 
4674         case 0x0170: return wxT("CBM_SHOWLIST"); 
4675         case 0x0171: return wxT("CBM_HILITE"); 
4676         case 0x0172: return wxT("CBM_ISLISTSHOWING"); 
4678         case 0x0140: return wxT("EM_QUERYCHANGED"); 
4679         case 0x0141: return wxT("EM_QUERYSEL"); 
4680         case 0x0142: return wxT("EM_SETSEL"); 
4681         case 0x0143: return wxT("EM_SETTEXTLIMIT"); 
4682         case 0x0144: return wxT("EM_CUT"); 
4683         case 0x0145: return wxT("EM_COPY"); 
4684         case 0x0146: return wxT("EM_CLEAR"); 
4685         case 0x0147: return wxT("EM_PASTE"); 
4686         case 0x0148: return wxT("EM_QUERYFIRSTCHAR"); 
4687         case 0x0149: return wxT("EM_SETFIRSTCHAR"); 
4688         case 0x014A: return wxT("EM_QUERYREADONLY"); 
4689         case 0x014B: return wxT("EM_SETREADONLY"); 
4690         case 0x014C: return wxT("EM_SETINSERTMODE"); 
4692         case 0x0160: return wxT("LM_QUERYITEMCOUNT"); 
4693         case 0x0161: return wxT("LM_INSERTITEM"); 
4694         case 0x0162: return wxT("LM_SETOPENINDEX"); 
4695         case 0x0163: return wxT("LM_DELETEITEM"); 
4696         case 0x0164: return wxT("LM_SELECTITEM"); 
4697         case 0x0165: return wxT("LM_QUERYSELECTION"); 
4698         case 0x0166: return wxT("LM_SETITEMTEXT"); 
4699         case 0x0167: return wxT("LM_QUERYITEMTEXTLENGTH"); 
4700         case 0x0168: return wxT("LM_QUERYITEMTEXT"); 
4701         case 0x0169: return wxT("LM_SETITEMHANDLE"); 
4702         case 0x016A: return wxT("LM_QUERYITEMHANDLE"); 
4703         case 0x016B: return wxT("LM_SEARCHSTRING"); 
4704         case 0x016C: return wxT("LM_SETITEMHEIGHT"); 
4705         case 0x016D: return wxT("LM_QUERYTOPINDEX"); 
4706         case 0x016E: return wxT("LM_DELETEALL"); 
4707         case 0x016F: return wxT("LM_INSERTMULITEMS"); 
4708         case 0x0660: return wxT("LM_SETITEMWIDTH"); 
4710         case 0x0180: return wxT("MM_INSERTITEM"); 
4711         case 0x0181: return wxT("MM_DELETEITEM"); 
4712         case 0x0182: return wxT("MM_QUERYITEM"); 
4713         case 0x0183: return wxT("MM_SETITEM"); 
4714         case 0x0184: return wxT("MM_QUERYITEMCOUNT"); 
4715         case 0x0185: return wxT("MM_STARTMENUMODE"); 
4716         case 0x0186: return wxT("MM_ENDMENUMODE"); 
4717         case 0x0188: return wxT("MM_REMOVEITEM"); 
4718         case 0x0189: return wxT("MM_SELECTITEM"); 
4719         case 0x018A: return wxT("MM_QUERYSELITEMID"); 
4720         case 0x018B: return wxT("MM_QUERYITEMTEXT"); 
4721         case 0x018C: return wxT("MM_QUERYITEMTEXTLENGTH"); 
4722         case 0x018D: return wxT("MM_SETITEMHANDLE"); 
4723         case 0x018E: return wxT("MM_SETITEMTEXT"); 
4724         case 0x018F: return wxT("MM_ITEMPOSITIONFROMID"); 
4725         case 0x0190: return wxT("MM_ITEMIDFROMPOSITION"); 
4726         case 0x0191: return wxT("MM_QUERYITEMATTR"); 
4727         case 0x0192: return wxT("MM_SETITEMATTR"); 
4728         case 0x0193: return wxT("MM_ISITEMVALID"); 
4729         case 0x0194: return wxT("MM_QUERYITEMRECT"); 
4730         case 0x0431: return wxT("MM_QUERYDEFAULTITEMID"); 
4731         case 0x0432: return wxT("MM_SETDEFAULTITEMID"); 
4733         case 0x01A0: return wxT("SBM_SETSCROLLBAR"); 
4734         case 0x01A1: return wxT("SBM_SETPOS"); 
4735         case 0x01A2: return wxT("SBM_QUERYPOS"); 
4736         case 0x01A3: return wxT("SBM_QUERYRANGE"); 
4737         case 0x01A6: return wxT("SBM_SETTHUMBSIZE"); 
4740         case 0x0F00: return wxT("WM_HELPBASE"); 
4741         case 0x0FFF: return wxT("WM_HELPTOP"); 
4742         // Beginning of user defined messages 
4743         case 0x1000: return wxT("WM_USER"); 
4745         // wxWidgets user defined types 
4748         // case 0x1000 + 0: return wxT("LVM_GETBKCOLOR"); 
4749         case 0x1000 + 1: return wxT("LVM_SETBKCOLOR"); 
4750         case 0x1000 + 2: return wxT("LVM_GETIMAGELIST"); 
4751         case 0x1000 + 3: return wxT("LVM_SETIMAGELIST"); 
4752         case 0x1000 + 4: return wxT("LVM_GETITEMCOUNT"); 
4753         case 0x1000 + 5: return wxT("LVM_GETITEMA"); 
4754         case 0x1000 + 75: return wxT("LVM_GETITEMW"); 
4755         case 0x1000 + 6: return wxT("LVM_SETITEMA"); 
4756         case 0x1000 + 76: return wxT("LVM_SETITEMW"); 
4757         case 0x1000 + 7: return wxT("LVM_INSERTITEMA"); 
4758         case 0x1000 + 77: return wxT("LVM_INSERTITEMW"); 
4759         case 0x1000 + 8: return wxT("LVM_DELETEITEM"); 
4760         case 0x1000 + 9: return wxT("LVM_DELETEALLITEMS"); 
4761         case 0x1000 + 10: return wxT("LVM_GETCALLBACKMASK"); 
4762         case 0x1000 + 11: return wxT("LVM_SETCALLBACKMASK"); 
4763         case 0x1000 + 12: return wxT("LVM_GETNEXTITEM"); 
4764         case 0x1000 + 13: return wxT("LVM_FINDITEMA"); 
4765         case 0x1000 + 83: return wxT("LVM_FINDITEMW"); 
4766         case 0x1000 + 14: return wxT("LVM_GETITEMRECT"); 
4767         case 0x1000 + 15: return wxT("LVM_SETITEMPOSITION"); 
4768         case 0x1000 + 16: return wxT("LVM_GETITEMPOSITION"); 
4769         case 0x1000 + 17: return wxT("LVM_GETSTRINGWIDTHA"); 
4770         case 0x1000 + 87: return wxT("LVM_GETSTRINGWIDTHW"); 
4771         case 0x1000 + 18: return wxT("LVM_HITTEST"); 
4772         case 0x1000 + 19: return wxT("LVM_ENSUREVISIBLE"); 
4773         case 0x1000 + 20: return wxT("LVM_SCROLL"); 
4774         case 0x1000 + 21: return wxT("LVM_REDRAWITEMS"); 
4775         case 0x1000 + 22: return wxT("LVM_ARRANGE"); 
4776         case 0x1000 + 23: return wxT("LVM_EDITLABELA"); 
4777         case 0x1000 + 118: return wxT("LVM_EDITLABELW"); 
4778         case 0x1000 + 24: return wxT("LVM_GETEDITCONTROL"); 
4779         case 0x1000 + 25: return wxT("LVM_GETCOLUMNA"); 
4780         case 0x1000 + 95: return wxT("LVM_GETCOLUMNW"); 
4781         case 0x1000 + 26: return wxT("LVM_SETCOLUMNA"); 
4782         case 0x1000 + 96: return wxT("LVM_SETCOLUMNW"); 
4783         case 0x1000 + 27: return wxT("LVM_INSERTCOLUMNA"); 
4784         case 0x1000 + 97: return wxT("LVM_INSERTCOLUMNW"); 
4785         case 0x1000 + 28: return wxT("LVM_DELETECOLUMN"); 
4786         case 0x1000 + 29: return wxT("LVM_GETCOLUMNWIDTH"); 
4787         case 0x1000 + 30: return wxT("LVM_SETCOLUMNWIDTH"); 
4788         case 0x1000 + 31: return wxT("LVM_GETHEADER"); 
4789         case 0x1000 + 33: return wxT("LVM_CREATEDRAGIMAGE"); 
4790         case 0x1000 + 34: return wxT("LVM_GETVIEWRECT"); 
4791         case 0x1000 + 35: return wxT("LVM_GETTEXTCOLOR"); 
4792         case 0x1000 + 36: return wxT("LVM_SETTEXTCOLOR"); 
4793         case 0x1000 + 37: return wxT("LVM_GETTEXTBKCOLOR"); 
4794         case 0x1000 + 38: return wxT("LVM_SETTEXTBKCOLOR"); 
4795         case 0x1000 + 39: return wxT("LVM_GETTOPINDEX"); 
4796         case 0x1000 + 40: return wxT("LVM_GETCOUNTPERPAGE"); 
4797         case 0x1000 + 41: return wxT("LVM_GETORIGIN"); 
4798         case 0x1000 + 42: return wxT("LVM_UPDATE"); 
4799         case 0x1000 + 43: return wxT("LVM_SETITEMSTATE"); 
4800         case 0x1000 + 44: return wxT("LVM_GETITEMSTATE"); 
4801         case 0x1000 + 45: return wxT("LVM_GETITEMTEXTA"); 
4802         case 0x1000 + 115: return wxT("LVM_GETITEMTEXTW"); 
4803         case 0x1000 + 46: return wxT("LVM_SETITEMTEXTA"); 
4804         case 0x1000 + 116: return wxT("LVM_SETITEMTEXTW"); 
4805         case 0x1000 + 47: return wxT("LVM_SETITEMCOUNT"); 
4806         case 0x1000 + 48: return wxT("LVM_SORTITEMS"); 
4807         case 0x1000 + 49: return wxT("LVM_SETITEMPOSITION32"); 
4808         case 0x1000 + 50: return wxT("LVM_GETSELECTEDCOUNT"); 
4809         case 0x1000 + 51: return wxT("LVM_GETITEMSPACING"); 
4810         case 0x1000 + 52: return wxT("LVM_GETISEARCHSTRINGA"); 
4811         case 0x1000 + 117: return wxT("LVM_GETISEARCHSTRINGW"); 
4812         case 0x1000 + 53: return wxT("LVM_SETICONSPACING"); 
4813         case 0x1000 + 54: return wxT("LVM_SETEXTENDEDLISTVIEWSTYLE"); 
4814         case 0x1000 + 55: return wxT("LVM_GETEXTENDEDLISTVIEWSTYLE"); 
4815         case 0x1000 + 56: return wxT("LVM_GETSUBITEMRECT"); 
4816         case 0x1000 + 57: return wxT("LVM_SUBITEMHITTEST"); 
4817         case 0x1000 + 58: return wxT("LVM_SETCOLUMNORDERARRAY"); 
4818         case 0x1000 + 59: return wxT("LVM_GETCOLUMNORDERARRAY"); 
4819         case 0x1000 + 60: return wxT("LVM_SETHOTITEM"); 
4820         case 0x1000 + 61: return wxT("LVM_GETHOTITEM"); 
4821         case 0x1000 + 62: return wxT("LVM_SETHOTCURSOR"); 
4822         case 0x1000 + 63: return wxT("LVM_GETHOTCURSOR"); 
4823         case 0x1000 + 64: return wxT("LVM_APPROXIMATEVIEWRECT"); 
4824         case 0x1000 + 65: return wxT("LVM_SETWORKAREA"); 
4827         case 0x1100 + 0: return wxT("TVM_INSERTITEMA"); 
4828         case 0x1100 + 50: return wxT("TVM_INSERTITEMW"); 
4829         case 0x1100 + 1: return wxT("TVM_DELETEITEM"); 
4830         case 0x1100 + 2: return wxT("TVM_EXPAND"); 
4831         case 0x1100 + 4: return wxT("TVM_GETITEMRECT"); 
4832         case 0x1100 + 5: return wxT("TVM_GETCOUNT"); 
4833         case 0x1100 + 6: return wxT("TVM_GETINDENT"); 
4834         case 0x1100 + 7: return wxT("TVM_SETINDENT"); 
4835         case 0x1100 + 8: return wxT("TVM_GETIMAGELIST"); 
4836         case 0x1100 + 9: return wxT("TVM_SETIMAGELIST"); 
4837         case 0x1100 + 10: return wxT("TVM_GETNEXTITEM"); 
4838         case 0x1100 + 11: return wxT("TVM_SELECTITEM"); 
4839         case 0x1100 + 12: return wxT("TVM_GETITEMA"); 
4840         case 0x1100 + 62: return wxT("TVM_GETITEMW"); 
4841         case 0x1100 + 13: return wxT("TVM_SETITEMA"); 
4842         case 0x1100 + 63: return wxT("TVM_SETITEMW"); 
4843         case 0x1100 + 14: return wxT("TVM_EDITLABELA"); 
4844         case 0x1100 + 65: return wxT("TVM_EDITLABELW"); 
4845         case 0x1100 + 15: return wxT("TVM_GETEDITCONTROL"); 
4846         case 0x1100 + 16: return wxT("TVM_GETVISIBLECOUNT"); 
4847         case 0x1100 + 17: return wxT("TVM_HITTEST"); 
4848         case 0x1100 + 18: return wxT("TVM_CREATEDRAGIMAGE"); 
4849         case 0x1100 + 19: return wxT("TVM_SORTCHILDREN"); 
4850         case 0x1100 + 20: return wxT("TVM_ENSUREVISIBLE"); 
4851         case 0x1100 + 21: return wxT("TVM_SORTCHILDRENCB"); 
4852         case 0x1100 + 22: return wxT("TVM_ENDEDITLABELNOW"); 
4853         case 0x1100 + 23: return wxT("TVM_GETISEARCHSTRINGA"); 
4854         case 0x1100 + 64: return wxT("TVM_GETISEARCHSTRINGW"); 
4855         case 0x1100 + 24: return wxT("TVM_SETTOOLTIPS"); 
4856         case 0x1100 + 25: return wxT("TVM_GETTOOLTIPS"); 
4859         case 0x1200 + 0: return wxT("HDM_GETITEMCOUNT"); 
4860         case 0x1200 + 1: return wxT("HDM_INSERTITEMA"); 
4861         case 0x1200 + 10: return wxT("HDM_INSERTITEMW"); 
4862         case 0x1200 + 2: return wxT("HDM_DELETEITEM"); 
4863         case 0x1200 + 3: return wxT("HDM_GETITEMA"); 
4864         case 0x1200 + 11: return wxT("HDM_GETITEMW"); 
4865         case 0x1200 + 4: return wxT("HDM_SETITEMA"); 
4866         case 0x1200 + 12: return wxT("HDM_SETITEMW"); 
4867         case 0x1200 + 5: return wxT("HDM_LAYOUT"); 
4868         case 0x1200 + 6: return wxT("HDM_HITTEST"); 
4869         case 0x1200 + 7: return wxT("HDM_GETITEMRECT"); 
4870         case 0x1200 + 8: return wxT("HDM_SETIMAGELIST"); 
4871         case 0x1200 + 9: return wxT("HDM_GETIMAGELIST"); 
4872         case 0x1200 + 15: return wxT("HDM_ORDERTOINDEX"); 
4873         case 0x1200 + 16: return wxT("HDM_CREATEDRAGIMAGE"); 
4874         case 0x1200 + 17: return wxT("HDM_GETORDERARRAY"); 
4875         case 0x1200 + 18: return wxT("HDM_SETORDERARRAY"); 
4876         case 0x1200 + 19: return wxT("HDM_SETHOTDIVIDER"); 
4879         case 0x1300 + 2: return wxT("TCM_GETIMAGELIST"); 
4880         case 0x1300 + 3: return wxT("TCM_SETIMAGELIST"); 
4881         case 0x1300 + 4: return wxT("TCM_GETITEMCOUNT"); 
4882         case 0x1300 + 5: return wxT("TCM_GETITEMA"); 
4883         case 0x1300 + 60: return wxT("TCM_GETITEMW"); 
4884         case 0x1300 + 6: return wxT("TCM_SETITEMA"); 
4885         case 0x1300 + 61: return wxT("TCM_SETITEMW"); 
4886         case 0x1300 + 7: return wxT("TCM_INSERTITEMA"); 
4887         case 0x1300 + 62: return wxT("TCM_INSERTITEMW"); 
4888         case 0x1300 + 8: return wxT("TCM_DELETEITEM"); 
4889         case 0x1300 + 9: return wxT("TCM_DELETEALLITEMS"); 
4890         case 0x1300 + 10: return wxT("TCM_GETITEMRECT"); 
4891         case 0x1300 + 11: return wxT("TCM_GETCURSEL"); 
4892         case 0x1300 + 12: return wxT("TCM_SETCURSEL"); 
4893         case 0x1300 + 13: return wxT("TCM_HITTEST"); 
4894         case 0x1300 + 14: return wxT("TCM_SETITEMEXTRA"); 
4895         case 0x1300 + 40: return wxT("TCM_ADJUSTRECT"); 
4896         case 0x1300 + 41: return wxT("TCM_SETITEMSIZE"); 
4897         case 0x1300 + 42: return wxT("TCM_REMOVEIMAGE"); 
4898         case 0x1300 + 43: return wxT("TCM_SETPADDING"); 
4899         case 0x1300 + 44: return wxT("TCM_GETROWCOUNT"); 
4900         case 0x1300 + 45: return wxT("TCM_GETTOOLTIPS"); 
4901         case 0x1300 + 46: return wxT("TCM_SETTOOLTIPS"); 
4902         case 0x1300 + 47: return wxT("TCM_GETCURFOCUS"); 
4903         case 0x1300 + 48: return wxT("TCM_SETCURFOCUS"); 
4904         case 0x1300 + 49: return wxT("TCM_SETMINTABWIDTH"); 
4905         case 0x1300 + 50: return wxT("TCM_DESELECTALL"); 
4908         case WM_USER
+1000+1: return wxT("TB_ENABLEBUTTON"); 
4909         case WM_USER
+1000+2: return wxT("TB_CHECKBUTTON"); 
4910         case WM_USER
+1000+3: return wxT("TB_PRESSBUTTON"); 
4911         case WM_USER
+1000+4: return wxT("TB_HIDEBUTTON"); 
4912         case WM_USER
+1000+5: return wxT("TB_INDETERMINATE"); 
4913         case WM_USER
+1000+9: return wxT("TB_ISBUTTONENABLED"); 
4914         case WM_USER
+1000+10: return wxT("TB_ISBUTTONCHECKED"); 
4915         case WM_USER
+1000+11: return wxT("TB_ISBUTTONPRESSED"); 
4916         case WM_USER
+1000+12: return wxT("TB_ISBUTTONHIDDEN"); 
4917         case WM_USER
+1000+13: return wxT("TB_ISBUTTONINDETERMINATE"); 
4918         case WM_USER
+1000+17: return wxT("TB_SETSTATE"); 
4919         case WM_USER
+1000+18: return wxT("TB_GETSTATE"); 
4920         case WM_USER
+1000+19: return wxT("TB_ADDBITMAP"); 
4921         case WM_USER
+1000+20: return wxT("TB_ADDBUTTONS"); 
4922         case WM_USER
+1000+21: return wxT("TB_INSERTBUTTON"); 
4923         case WM_USER
+1000+22: return wxT("TB_DELETEBUTTON"); 
4924         case WM_USER
+1000+23: return wxT("TB_GETBUTTON"); 
4925         case WM_USER
+1000+24: return wxT("TB_BUTTONCOUNT"); 
4926         case WM_USER
+1000+25: return wxT("TB_COMMANDTOINDEX"); 
4927         case WM_USER
+1000+26: return wxT("TB_SAVERESTOREA"); 
4928         case WM_USER
+1000+76: return wxT("TB_SAVERESTOREW"); 
4929         case WM_USER
+1000+27: return wxT("TB_CUSTOMIZE"); 
4930         case WM_USER
+1000+28: return wxT("TB_ADDSTRINGA"); 
4931         case WM_USER
+1000+77: return wxT("TB_ADDSTRINGW"); 
4932         case WM_USER
+1000+29: return wxT("TB_GETITEMRECT"); 
4933         case WM_USER
+1000+30: return wxT("TB_BUTTONSTRUCTSIZE"); 
4934         case WM_USER
+1000+31: return wxT("TB_SETBUTTONSIZE"); 
4935         case WM_USER
+1000+32: return wxT("TB_SETBITMAPSIZE"); 
4936         case WM_USER
+1000+33: return wxT("TB_AUTOSIZE"); 
4937         case WM_USER
+1000+35: return wxT("TB_GETTOOLTIPS"); 
4938         case WM_USER
+1000+36: return wxT("TB_SETTOOLTIPS"); 
4939         case WM_USER
+1000+37: return wxT("TB_SETPARENT"); 
4940         case WM_USER
+1000+39: return wxT("TB_SETROWS"); 
4941         case WM_USER
+1000+40: return wxT("TB_GETROWS"); 
4942         case WM_USER
+1000+42: return wxT("TB_SETCMDID"); 
4943         case WM_USER
+1000+43: return wxT("TB_CHANGEBITMAP"); 
4944         case WM_USER
+1000+44: return wxT("TB_GETBITMAP"); 
4945         case WM_USER
+1000+45: return wxT("TB_GETBUTTONTEXTA"); 
4946         case WM_USER
+1000+75: return wxT("TB_GETBUTTONTEXTW"); 
4947         case WM_USER
+1000+46: return wxT("TB_REPLACEBITMAP"); 
4948         case WM_USER
+1000+47: return wxT("TB_SETINDENT"); 
4949         case WM_USER
+1000+48: return wxT("TB_SETIMAGELIST"); 
4950         case WM_USER
+1000+49: return wxT("TB_GETIMAGELIST"); 
4951         case WM_USER
+1000+50: return wxT("TB_LOADIMAGES"); 
4952         case WM_USER
+1000+51: return wxT("TB_GETRECT"); 
4953         case WM_USER
+1000+52: return wxT("TB_SETHOTIMAGELIST"); 
4954         case WM_USER
+1000+53: return wxT("TB_GETHOTIMAGELIST"); 
4955         case WM_USER
+1000+54: return wxT("TB_SETDISABLEDIMAGELIST"); 
4956         case WM_USER
+1000+55: return wxT("TB_GETDISABLEDIMAGELIST"); 
4957         case WM_USER
+1000+56: return wxT("TB_SETSTYLE"); 
4958         case WM_USER
+1000+57: return wxT("TB_GETSTYLE"); 
4959         case WM_USER
+1000+58: return wxT("TB_GETBUTTONSIZE"); 
4960         case WM_USER
+1000+59: return wxT("TB_SETBUTTONWIDTH"); 
4961         case WM_USER
+1000+60: return wxT("TB_SETMAXTEXTROWS"); 
4962         case WM_USER
+1000+61: return wxT("TB_GETTEXTROWS"); 
4963         case WM_USER
+1000+41: return wxT("TB_GETBITMAPFLAGS"); 
4966     static wxString s_szBuf
; 
4967     s_szBuf
.Printf(wxT("<unknown message = %d>"), nMessage
); 
4968     return s_szBuf
.c_str(); 
4970 } // end of wxGetMessageName 
4972 #endif // __WXDEBUG__ 
4976 static void TranslateKbdEventToMouse( 
4984     // Construct the key mask 
4985     ULONG
&                          fwKeys 
= *pFlags
; 
4987     fwKeys 
= VK_BUTTON2
; 
4988     if ((::WinGetKeyState(HWND_DESKTOP
, VK_CTRL
) & 0x100) != 0) 
4990     if ((::WinGetKeyState(HWND_DESKTOP
, VK_SHIFT
) & 0x100) != 0) 
4994     // Simulate right mouse button click 
4998     ::WinQueryMsgPos(vHabmain
, &vPoint
); 
5002     pWin
->ScreenToClient(pX
, pY
); 
5003 } // end of TranslateKbdEventToMouse 
5006 // Find the wxWindow at the current mouse position, returning the mouse 
5008 wxWindow
* wxFindWindowAtPointer(wxPoint
& WXUNUSED(rPt
)) 
5010     return wxFindWindowAtPoint(wxGetMousePosition()); 
5013 wxWindow
* wxFindWindowAtPoint(const wxPoint
& rPt
) 
5020     HWND      hWndHit 
= ::WinWindowFromPoint(HWND_DESKTOP
, &vPt2
, FALSE
); 
5021     wxWindow
* pWin 
= wxFindWinFromHandle((WXHWND
)hWndHit
) ; 
5022     HWND      hWnd 
= hWndHit
; 
5025     // Try to find a window with a wxWindow associated with it 
5027     while (!pWin 
&& (hWnd 
!= 0)) 
5029         hWnd 
= ::WinQueryWindow(hWnd
, QW_PARENT
); 
5030         pWin 
= wxFindWinFromHandle((WXHWND
)hWnd
) ; 
5035 // Get the current mouse position. 
5036 wxPoint 
wxGetMousePosition() 
5040     ::WinQueryPointerPos(HWND_DESKTOP
, &vPt
); 
5041     return wxPoint(vPt
.x
, vPt
.y
); 
5044 wxWindowOS2
* FindWindowForMouseEvent( wxWindow
* pWin
, 
5045                                       short*    WXUNUSED(pnX
), 
5046                                       short*    WXUNUSED(pnY
) ) 
5048     HWND   hWnd 
= GetHwndOf(pWin
); 
5049     HWND   hWndUnderMouse
; 
5051     BOOL   rcEnabled 
= FALSE
; 
5052     BOOL   rcVisible 
= FALSE
; 
5054     ::WinQueryPointerPos(HWND_DESKTOP
, &vPoint
); 
5055     hWndUnderMouse 
= ::WinWindowFromPoint(HWND_DESKTOP
, &vPoint
, TRUE
); 
5056     if (hWndUnderMouse 
!= HWND_DESKTOP
) 
5058         wxWindow
*                   pWinUnderMouse 
= wxFindWinFromHandle((WXHWND
)hWndUnderMouse
); 
5062             wxWindowList::compatibility_iterator current 
= pWinUnderMouse
->GetChildren().GetFirst(); 
5063             wxWindow
*               pGrandChild 
= NULL
; 
5067             ::WinMapWindowPoints(HWND_DESKTOP
, hWndUnderMouse
, &vPoint
, 1); 
5069             // Find a child window mouse might be under 
5073                 wxWindow
*                   pChild 
= current
->GetData(); 
5075                 vPoint2
.x 
= vPoint
.x
; 
5076                 vPoint2
.y 
= vPoint
.y
; 
5077                 ::WinMapWindowPoints(hWndUnderMouse
, pChild
->GetHWND(), &vPoint2
, 1); 
5078                 ::WinQueryWindowRect(pChild
->GetHWND(), &vRect
); 
5079                 if (::WinPtInRect(vHabmain
, &vRect
, &vPoint2
)) 
5081                     if (pChild
->IsTopLevel()) 
5084                         wxWindowList::compatibility_iterator current2 
=pChild
->GetChildren().GetFirst(); 
5088                             wxWindow
*           pGrandChild 
= current2
->GetData(); 
5090                             vPoint3
.x 
= vPoint2
.x
; 
5091                             vPoint3
.y 
= vPoint2
.y
; 
5092                             ::WinMapWindowPoints( pChild
->GetHWND() 
5093                                                  ,pGrandChild
->GetHWND() 
5097                             ::WinQueryWindowRect(pGrandChild
->GetHWND(), &vRect
); 
5098                             if (::WinPtInRect(vHabmain
, &vRect
, &vPoint3
)) 
5100                                 hWndUnderMouse 
= GetHwndOf(pGrandChild
); 
5101                                 pWinUnderMouse 
= pGrandChild
; 
5104                             current2 
= current2
->GetNext(); 
5109                     hWndUnderMouse 
= GetHwndOf(pChild
); 
5110                     pWinUnderMouse 
= pChild
; 
5111                     rcVisible 
= ::WinIsWindowVisible(hWndUnderMouse
); 
5112                     rcEnabled 
= ::WinIsWindowEnabled(hWndUnderMouse
); 
5113                     if (rcVisible 
&& rcEnabled
) 
5116                 current 
= current
->GetNext(); 
5120     rcVisible 
= ::WinIsWindowVisible(hWndUnderMouse
); 
5121     rcEnabled 
= ::WinIsWindowEnabled(hWndUnderMouse
); 
5125     // Check that we have a child window which is susceptible to receive mouse 
5126     // events: for this it must be shown and enabled 
5128     if ( hWndUnderMouse 
&& 
5129          hWndUnderMouse 
!= hWnd 
&& 
5130          rcVisible 
&& rcEnabled
) 
5132         wxWindow
*                       pWinUnderMouse 
= wxFindWinFromHandle((WXHWND
)hWndUnderMouse
); 
5137             // Translate the mouse coords to the other window coords 
5139             pWin 
= pWinUnderMouse
; 
5143 } // end of FindWindowForMouseEvent