]> git.saurik.com Git - wxWidgets.git/blobdiff - include/wx/mousemanager.h
Don't define __STRICT_ANSI__, we should build both with and without it.
[wxWidgets.git] / include / wx / mousemanager.h
index 75c8920df9d8b64cf357bca220832e3b21c01e0d..caa2abeaec0ec604590b2b31ca5aa4a68f47f3f1 100644 (file)
@@ -3,7 +3,6 @@
 // Purpose:     wxMouseEventsManager class declaration
 // Author:      Vadim Zeitlin
 // Created:     2009-04-20
 // Purpose:     wxMouseEventsManager class declaration
 // Author:      Vadim Zeitlin
 // Created:     2009-04-20
-// RCS-ID:      $Id$
 // Copyright:   (c) 2009 Vadim Zeitlin <vadim@wxwidgets.org>
 // Licence:     wxWindows licence
 ///////////////////////////////////////////////////////////////////////////////
 // Copyright:   (c) 2009 Vadim Zeitlin <vadim@wxwidgets.org>
 // Licence:     wxWindows licence
 ///////////////////////////////////////////////////////////////////////////////
@@ -34,8 +33,11 @@ class WXDLLIMPEXP_CORE wxMouseEventsManager : public wxEvtHandler
 {
 public:
     // a mouse event manager is always associated with a window and must be
 {
 public:
     // a mouse event manager is always associated with a window and must be
-    // deleted by the window when it is destroyed
-    wxMouseEventsManager(wxWindow *win);
+    // deleted by the window when it is destroyed so if it is created using the
+    // default ctor Create() must be called later
+    wxMouseEventsManager() { Init(); }
+    wxMouseEventsManager(wxWindow *win) { Init(); Create(win); }
+    bool Create(wxWindow *win);
 
     virtual ~wxMouseEventsManager();
 
 
     virtual ~wxMouseEventsManager();
 
@@ -113,6 +115,8 @@ private:
         State_Dragging  // the item is being dragged
     };
 
         State_Dragging  // the item is being dragged
     };
 
+    // common part of both ctors
+    void Init();
 
     // various event handlers
     void OnCaptureLost(wxMouseCaptureLostEvent& event);
 
     // various event handlers
     void OnCaptureLost(wxMouseCaptureLostEvent& event);
@@ -121,8 +125,9 @@ private:
     void OnMove(wxMouseEvent& event);
 
 
     void OnMove(wxMouseEvent& event);
 
 
-    // the associated window, never NULL
-    wxWindow * const m_win;
+    // the associated window, never NULL except between the calls to the
+    // default ctor and Create()
+    wxWindow *m_win;
 
     // the current state
     State m_state;
 
     // the current state
     State m_state;