fix push/pop mechanism after r58786; add a few notes about the stack mechanism both in the docs and in the public header (see #10733)

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@60321 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Francesco Montorsi 2009-04-24 21:14:59 +00:00
parent 48e8f217bc
commit 30800ba5e4
3 changed files with 21 additions and 9 deletions

View File

@ -105,6 +105,8 @@ public:
// field text // field text
// ---------- // ----------
// NOTE: even if it is not pure virtual, SetStatusText() must be overloaded by
// the derived classes to update the given text in the native control
virtual void SetStatusText(const wxString& text, int number = 0) virtual void SetStatusText(const wxString& text, int number = 0)
{ m_panes[number].GetStack().Last() = text; } { m_panes[number].GetStack().Last() = text; }
virtual wxString GetStatusText(int number = 0) const virtual wxString GetStatusText(int number = 0) const

View File

@ -53,6 +53,9 @@ public:
to give small amounts of status information. It can contain one or more fields, to give small amounts of status information. It can contain one or more fields,
one or more of which can be variable length according to the size of the window. one or more of which can be variable length according to the size of the window.
wxStatusBar also maintains an independent stack of status texts for each field
(see PushStatusText() and PopStatusText()).
Note that in wxStatusBar context, the terms @e pane and @e field are synonyms. Note that in wxStatusBar context, the terms @e pane and @e field are synonyms.
@beginStyleTable @beginStyleTable
@ -195,7 +198,7 @@ public:
void PopStatusText(int field = 0); void PopStatusText(int field = 0);
/** /**
Saves the current field text in a per field stack, and sets the field text Saves the current field text in a per-field stack, and sets the field text
to the string passed as argument. to the string passed as argument.
@see PopStatusText() @see PopStatusText()
@ -239,7 +242,11 @@ public:
virtual void SetStatusStyles(int n, const int* styles); virtual void SetStatusStyles(int n, const int* styles);
/** /**
Sets the text for one field. Sets the status text for the @a i-th field.
The given text will replace the current text. Note that unlike PushStatusText()
this function won't save the current text (and calling PopStatusText() won't
restore it!).
@param text @param text
The text to be set. Use an empty string ("") to clear the field. The text to be set. Use an empty string ("") to clear the field.

View File

@ -191,22 +191,25 @@ wxArrayInt wxStatusBarBase::CalculateAbsWidths(wxCoord widthTotal) const
void wxStatusBarBase::PushStatusText(const wxString& text, int number) void wxStatusBarBase::PushStatusText(const wxString& text, int number)
{ {
// save current status text in the stack // save the new text (in non-ellipsized form) in the stack
m_panes[number].m_arrStack.push_back(GetStatusText(number)); m_panes[number].m_arrStack.push_back(text);
SetStatusText(text, number); SetStatusText(text, number);
// update current status text (eventually also in the native control) // update current status text (which will possibly be ellipsized)
// also in the native control
} }
void wxStatusBarBase::PopStatusText(int number) void wxStatusBarBase::PopStatusText(int number)
{ {
wxASSERT_MSG(m_panes[number].m_arrStack.GetCount() == 1, wxASSERT_MSG(m_panes[number].m_arrStack.GetCount() >= 1,
"can't pop any further string"); "can't pop any further string");
wxString text = m_panes[number].m_arrStack.back(); // the top of the stack is the status text currently shown in the native control;
m_panes[number].m_arrStack.pop_back(); // also remove it from the stack // remove it
m_panes[number].m_arrStack.pop_back();
// restore the popped status text in the pane // restore the previous status text in the native control
const wxString& text = m_panes[number].m_arrStack.back();
SetStatusText(text, number); SetStatusText(text, number);
} }