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;
}
node = node->GetNext() )
{
wxControl *control = node->GetData()->GetControl();
-
+
if (control)
{
if (control->GetId() == id)