wxToolBarToolBase *tool = CreateTool(id, label, bitmap, bmpDisabled, kind,
clientData, shortHelp, longHelp);
- if ( !tool || !DoInsertTool(pos, tool) )
+ if ( !InsertTool(pos, tool) )
{
delete tool;
return NULL;
}
+ return tool;
+}
+
+wxToolBarToolBase *wxToolBarBase::AddTool(wxToolBarToolBase *tool)
+{
+ return InsertTool(GetToolsCount(), tool);
+}
+
+wxToolBarToolBase *
+wxToolBarBase::InsertTool(size_t pos, wxToolBarToolBase *tool)
+{
+ wxCHECK_MSG( pos <= GetToolsCount(), (wxToolBarToolBase *)NULL,
+ _T("invalid position in wxToolBar::InsertTool()") );
+
+ if ( !tool || !DoInsertTool(pos, tool) )
+ {
+ return NULL;
+ }
+
m_tools.Insert(pos, tool);
return tool;
wxToolBarToolBase *tool = CreateTool(control);
- if ( !tool || !DoInsertTool(pos, tool) )
+ if ( !InsertTool(pos, tool) )
{
delete tool;
return NULL;
}
- m_tools.Insert(pos, tool);
-
return tool;
}
+wxControl *wxToolBarBase::FindControl( int id )
+{
+ for ( wxToolBarToolsList::Node* node = m_tools.GetFirst();
+ node;
+ node = node->GetNext() )
+ {
+ wxControl *control = node->GetData()->GetControl();
+
+ if (control)
+ {
+ if (control->GetId() == id)
+ return control;
+ }
+ }
+
+ return NULL;
+}
+
wxToolBarToolBase *wxToolBarBase::AddSeparator()
{
return InsertSeparator(GetToolsCount());
while (parent->GetParent())
parent = parent->GetParent();
-#ifdef __WXMSW__
- wxWindow* focusWin = wxFindFocusDescendant(parent);
-#else
+// This kind of #ifdef is a good way to annoy people. It breaks
+// apps, but only on one platform and due to a hack in officially
+// platform independent code. It took me hours to fix this. RR.
+//
+// #ifdef __WXMSW__
+// wxWindow* focusWin = wxFindFocusDescendant(parent);
+// #else
wxWindow* focusWin = (wxWindow*) NULL;
-#endif
+// #endif
wxEvtHandler* evtHandler = focusWin ? focusWin->GetEventHandler() : GetEventHandler() ;