#if wxUSE_CHECKLISTBOX
-#include "wx/defs.h"
-
#include "wx/checklst.h"
-#include "wx/arrstr.h"
+
+#ifndef WX_PRECOMP
+ #include "wx/arrstr.h"
+#endif
// ============================================================================
// implementation
static inline bool IsChecked(const wxString& s)
{ wxASSERT(s.length() >=4); return s[1] == checkChar; }
-static void CopyStringsAddingPrefix(const wxArrayString& orig,
- wxArrayString& copy)
-{
- copy.Clear();
-
- for(size_t i = 0; i < orig.GetCount(); ++i )
- copy.Add( Prefix(false) + orig[i] );
-}
-
// def ctor: use Create() to really create the control
wxCheckListBox::wxCheckListBox() : wxCheckListBoxBase()
{
void wxCheckListBox::DoToggleItem( int n, int x )
{
- if( x < 23 )
+ if( x > 0 && x < 23 )
{
wxString label = wxListBox::GetString(n);
label[1u] = (!::IsChecked(label)) ? checkChar : uncheckChar;
event.SetEventObject(this);
event.SetString(GetString(n));
- GetEventHandler()->ProcessEvent(event);
+ HandleWindowEvent(event);
}
}
-int wxCheckListBox::DoAppend(const wxString& item)
-{
- return wxListBox::DoAppend( Prefix(false) + item );
-}
-
int wxCheckListBox::FindString(const wxString& s, bool bCase) const
{
int n1 = wxListBox::FindString(Prefix(false) + s, bCase);
return wxListBox::GetString(n).substr(4);
}
-void wxCheckListBox::DoInsertItems(const wxArrayString& items, unsigned int pos)
+int wxCheckListBox::DoInsertItems(const wxArrayStringsAdapter& items,
+ unsigned int pos,
+ void **clientData, wxClientDataType type)
{
wxArrayString copy;
- CopyStringsAddingPrefix(items, copy);
- wxListBox::DoInsertItems(copy, pos);
-}
+ copy.reserve(pos);
+ for ( size_t i = 0; i < items.GetCount(); ++i )
+ copy.push_back( Prefix(false) + items[i] );
-void wxCheckListBox::DoSetItems(const wxArrayString& items, void **clientData)
-{
- wxArrayString copy;
- CopyStringsAddingPrefix(items, copy);
- wxListBox::DoSetItems(copy, clientData);
+ return wxListBox::DoInsertItems(copy, pos, clientData, type);
}
#endif // wxUSE_CHECKLISTBOX