avoid conflict between wxBookCtrlBase::DoSetSelection() and the derived classes; refactor more common code into the base class

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@41843 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Vadim Zeitlin
2006-10-09 21:29:12 +00:00
parent 6500a868fe
commit deb325e3b2
8 changed files with 60 additions and 41 deletions

View File

@@ -222,22 +222,36 @@ public:
virtual bool HasMultiplePages() const { return true; } virtual bool HasMultiplePages() const { return true; }
protected: protected:
// typically, wxBookCtrl-derived classes will use DoSetSelection() function // flags for DoSetSelection()
// to implement SetSelection() and ChangeSelection() functions.
// these flags make DoSetSelection() more readable
enum enum
{ {
SetSelection_SendEvent = 1 SetSelection_SendEvent = 1
}; };
// if using DoSetSelection() for implementing [Set|Change]Selection, // set the selection to the given page, sending the events (which can
// then override UpdateSelectedPage() and MakeChangedEvent() // possibly prevent the page change from taking place) if SendEvent flag is
virtual int DoSetSelection(size_t nPage, int flags, wxBookCtrlBaseEvent &event); // included
virtual int DoSetSelection(size_t nPage, int flags = 0);
// if the derived class uses DoSetSelection() for implementing
// [Set|Change]Selection, it must override UpdateSelectedPage(),
// CreatePageChangingEvent() and MakeChangedEvent(), but as it might not
// use it, these functions are not pure virtual
// called to notify the control about a new current page
virtual void UpdateSelectedPage(size_t WXUNUSED(newsel)) virtual void UpdateSelectedPage(size_t WXUNUSED(newsel))
{ wxFAIL_MSG(wxT("Override this function!")); } { wxFAIL_MSG(wxT("Override this function!")); }
virtual void MakeChangedEvent(wxBookCtrlBaseEvent &WXUNUSED(event))
// create a new "page changing" event
virtual wxBookCtrlBaseEvent* CreatePageChangingEvent() const
{ wxFAIL_MSG(wxT("Override this function!")); return NULL; }
// modify the event created by CreatePageChangingEvent() to "page changed"
// event, usually by just calling SetEventType() on it
virtual void MakeChangedEvent(wxBookCtrlBaseEvent& WXUNUSED(event))
{ wxFAIL_MSG(wxT("Override this function!")); } { wxFAIL_MSG(wxT("Override this function!")); }
// Should we accept NULL page pointers in Add/InsertPage()? // Should we accept NULL page pointers in Add/InsertPage()?
// //
// Default is no but derived classes may override it if they can treat NULL // Default is no but derived classes may override it if they can treat NULL

View File

@@ -84,18 +84,14 @@ protected:
// get the size which the choice control should have // get the size which the choice control should have
virtual wxSize GetControllerSize() const; virtual wxSize GetControllerSize() const;
int DoSetSelection(size_t nPage, int flags = 0);
void UpdateSelectedPage(size_t newsel) void UpdateSelectedPage(size_t newsel)
{ {
m_selection = newsel; m_selection = newsel;
GetChoiceCtrl()->Select(newsel); GetChoiceCtrl()->Select(newsel);
} }
void MakeChangedEvent(wxBookCtrlBaseEvent &event) wxBookCtrlBaseEvent* CreatePageChangingEvent() const;
{ void MakeChangedEvent(wxBookCtrlBaseEvent &event);
event.SetEventType(wxEVT_COMMAND_CHOICEBOOK_PAGE_CHANGED);
}
// event handlers // event handlers
void OnChoiceSelected(wxCommandEvent& event); void OnChoiceSelected(wxCommandEvent& event);

View File

@@ -85,14 +85,10 @@ protected:
// return the page corresponding to the tab at the specified position // return the page corresponding to the tab at the specified position
virtual int HitTest(const wxPoint& pt, long *flags = NULL) const; virtual int HitTest(const wxPoint& pt, long *flags = NULL) const;
int DoSetSelection(size_t nPage, int flags = 0);
void UpdateSelectedPage(size_t newsel); void UpdateSelectedPage(size_t newsel);
void MakeChangedEvent(wxBookCtrlBaseEvent &event) wxBookCtrlBaseEvent* CreatePageChangingEvent() const;
{ void MakeChangedEvent(wxBookCtrlBaseEvent &event);
event.SetEventType(wxEVT_COMMAND_LISTBOOK_PAGE_CHANGED);
}
// event handlers // event handlers
void OnListSelected(wxListEvent& event); void OnListSelected(wxListEvent& event);

View File

@@ -101,13 +101,10 @@ protected:
void OnSize(wxSizeEvent& event); void OnSize(wxSizeEvent& event);
void OnIdle(wxIdleEvent& event); void OnIdle(wxIdleEvent& event);
int DoSetSelection(size_t nPage, int flags = 0);
void UpdateSelectedPage(size_t newsel); void UpdateSelectedPage(size_t newsel);
void MakeChangedEvent(wxBookCtrlBaseEvent &event) wxBookCtrlBaseEvent* CreatePageChangingEvent() const;
{ void MakeChangedEvent(wxBookCtrlBaseEvent &event);
event.SetEventType(wxEVT_COMMAND_TOOLBOOK_PAGE_CHANGED);
}
// the currently selected page or wxNOT_FOUND if none // the currently selected page or wxNOT_FOUND if none
int m_selection; int m_selection;

View File

@@ -423,7 +423,7 @@ wxSize wxBookCtrlBase::GetControllerSize() const
return size; return size;
} }
int wxBookCtrlBase::DoSetSelection(size_t n, int flags, wxBookCtrlBaseEvent &event) int wxBookCtrlBase::DoSetSelection(size_t n, int flags)
{ {
wxCHECK_MSG( n < GetPageCount(), wxNOT_FOUND, wxCHECK_MSG( n < GetPageCount(), wxNOT_FOUND,
wxT("invalid page index in wxBookCtrlBase::DoSetSelection()") ); wxT("invalid page index in wxBookCtrlBase::DoSetSelection()") );
@@ -432,15 +432,16 @@ int wxBookCtrlBase::DoSetSelection(size_t n, int flags, wxBookCtrlBaseEvent &eve
if ( oldSel != wxNOT_FOUND && n != (size_t)oldSel ) if ( oldSel != wxNOT_FOUND && n != (size_t)oldSel )
{ {
wxBookCtrlBaseEvent *event = CreatePageChangingEvent();
bool allowed = false; bool allowed = false;
if ( flags & SetSelection_SendEvent ) if ( flags & SetSelection_SendEvent )
{ {
event.SetSelection(n); event->SetSelection(n);
event.SetOldSelection(oldSel); event->SetOldSelection(oldSel);
event.SetEventObject(this); event->SetEventObject(this);
allowed = !GetEventHandler()->ProcessEvent(event) || event.IsAllowed(); allowed = !GetEventHandler()->ProcessEvent(*event) || event->IsAllowed();
} }
if ( !(flags & SetSelection_SendEvent) || allowed) if ( !(flags & SetSelection_SendEvent) || allowed)
@@ -458,10 +459,12 @@ int wxBookCtrlBase::DoSetSelection(size_t n, int flags, wxBookCtrlBaseEvent &eve
if ( flags & SetSelection_SendEvent ) if ( flags & SetSelection_SendEvent )
{ {
// program allows the page change // program allows the page change
MakeChangedEvent(event); MakeChangedEvent(*event);
(void)GetEventHandler()->ProcessEvent(event); (void)GetEventHandler()->ProcessEvent(*event);
} }
} }
delete event;
} }
return oldSel; return oldSel;

View File

@@ -209,10 +209,14 @@ int wxChoicebook::GetSelection() const
return m_selection; return m_selection;
} }
int wxChoicebook::DoSetSelection(size_t n, int flags) wxBookCtrlBaseEvent* wxChoicebook::CreatePageChangingEvent() const
{ {
wxChoicebookEvent event(wxEVT_COMMAND_CHOICEBOOK_PAGE_CHANGING, m_windowId); return new wxChoicebookEvent(wxEVT_COMMAND_CHOICEBOOK_PAGE_CHANGING, m_windowId);
return wxBookCtrlBase::DoSetSelection(n, flags, event); }
void wxChoicebook::MakeChangedEvent(wxBookCtrlBaseEvent &event)
{
event.SetEventType(wxEVT_COMMAND_CHOICEBOOK_PAGE_CHANGED);
} }
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------

View File

@@ -274,12 +274,17 @@ int wxListbook::GetSelection() const
return m_selection; return m_selection;
} }
int wxListbook::DoSetSelection(size_t n, int flags) wxBookCtrlBaseEvent* wxListbook::CreatePageChangingEvent() const
{ {
wxListbookEvent event(wxEVT_COMMAND_LISTBOOK_PAGE_CHANGING, m_windowId); return new wxListbookEvent(wxEVT_COMMAND_LISTBOOK_PAGE_CHANGING, m_windowId);
return wxBookCtrlBase::DoSetSelection(n, flags, event);
} }
void wxListbook::MakeChangedEvent(wxBookCtrlBaseEvent &event)
{
event.SetEventType(wxEVT_COMMAND_LISTBOOK_PAGE_CHANGED);
}
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
// adding/removing the pages // adding/removing the pages
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------

View File

@@ -245,10 +245,14 @@ int wxToolbook::GetSelection() const
return m_selection; return m_selection;
} }
int wxToolbook::DoSetSelection(size_t n, int flags) wxBookCtrlBaseEvent* wxToolbook::CreatePageChangingEvent() const
{ {
wxToolbookEvent event(wxEVT_COMMAND_TOOLBOOK_PAGE_CHANGING, m_windowId); return new wxToolbookEvent(wxEVT_COMMAND_TOOLBOOK_PAGE_CHANGING, m_windowId);
return wxBookCtrlBase::DoSetSelection(n, flags, event); }
void wxToolbook::MakeChangedEvent(wxBookCtrlBaseEvent &event)
{
event.SetEventType(wxEVT_COMMAND_TOOLBOOK_PAGE_CHANGED);
} }
void wxToolbook::UpdateSelectedPage(size_t newsel) void wxToolbook::UpdateSelectedPage(size_t newsel)