Applied patch from SF on menu command not blocked

if they are disabled but still emitted by an
    accelerator
  First attempt at adding wxSizer::Clear(). Further
     testing pending :-)


git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@12403 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Robert Roebling 2001-11-13 16:21:04 +00:00
parent 4494ad58e8
commit 84f7908b99
3 changed files with 43 additions and 5 deletions

View File

@ -47,6 +47,8 @@ public:
wxSizerItem( wxSizer *sizer, int option, int flag, int border, wxObject* userData );
~wxSizerItem();
virtual void DeleteWindows();
virtual wxSize GetSize();
virtual wxSize CalcMin();
@ -143,6 +145,9 @@ public:
virtual bool Remove( wxWindow *window );
virtual bool Remove( wxSizer *sizer );
virtual bool Remove( int pos );
virtual void Clear( bool delete_windows=FALSE );
virtual void DeleteWindows();
void SetMinSize( int width, int height )
{ DoSetMinSize( width, height ); }

View File

@ -182,12 +182,17 @@ bool wxFrameBase::ProcessCommand(int id)
commandEvent.SetEventObject(this);
wxMenuItem *item = bar->FindItem(id);
if ( item && item->IsCheckable() )
if (item)
{
item->Toggle();
// use the new value
commandEvent.SetInt(item->IsChecked());
if (!item->IsEnabled())
return TRUE;
if (item->IsCheckable())
{
item->Toggle();
// use the new value
commandEvent.SetInt(item->IsChecked());
}
}
return GetEventHandler()->ProcessEvent(commandEvent);

View File

@ -232,6 +232,15 @@ void wxSizerItem::SetDimension( wxPoint pos, wxSize size )
m_size = size;
}
void wxSizerItem::DeleteWindows()
{
if (m_window)
m_window->Destroy();
if (m_sizer)
m_sizer->DeleteWindows();
}
bool wxSizerItem::IsWindow()
{
return (m_window != NULL);
@ -355,6 +364,25 @@ bool wxSizer::Remove( int pos )
return TRUE;
}
void wxSizer::Clear( bool delete_windows )
{
if (delete_windows)
DeleteWindows();
m_children.Clear();
}
void wxSizer::DeleteWindows()
{
wxNode *node = m_children.First();
while (node)
{
wxSizerItem *item = (wxSizerItem*)node->Data();
item->DeleteWindows();
node = node->Next();
}
}
void wxSizer::Fit( wxWindow *window )
{
wxSize size;