+void wxCheckListBox::DoToggleItem( int n, int x )
+{
+ if( x < 23 )
+ {
+ wxString label = wxListBox::GetString(n);
+ label[1u] = (!::IsChecked(label)) ? checkChar : uncheckChar;
+ wxListBox::SetString(n, label);
+
+ wxCommandEvent event(wxEVT_COMMAND_CHECKLISTBOX_TOGGLED, GetId());
+ if( HasClientObjectData() )
+ event.SetClientObject( GetClientObject(n) );
+ else if( HasClientUntypedData() )
+ event.SetClientData( GetClientData(n) );
+ event.SetInt(n);
+ event.SetExtraLong(true);
+ event.SetEventObject(this);
+ event.SetString(GetString(n));
+
+ GetEventHandler()->ProcessEvent(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);
+ int n2 = wxListBox::FindString(Prefix(true) + s, bCase);
+ int min = wxMin(n1, n2), max = wxMax(n1, n2);
+
+ // why this works:
+ // n1 == -1, n2 == -1 => return -1 OK
+ // n1 != -1 || n2 != -1 => min == -1 => return the other one
+ // both != -1 => return the first one.
+ if( min == -1 ) return max;
+ return min;
+}
+
+void wxCheckListBox::SetString(unsigned int n, const wxString& s)
+{
+ wxListBox::SetString(n, Prefix(IsChecked(n)) + s);
+}
+
+wxString wxCheckListBox::GetString(unsigned int n) const
+{
+ return wxListBox::GetString(n).substr(4);
+}
+
+void wxCheckListBox::DoInsertItems(const wxArrayString& items, unsigned int pos)
+{
+ wxArrayString copy;
+ CopyStringsAddingPrefix(items, copy);
+ wxListBox::DoInsertItems(copy, pos);
+}
+
+void wxCheckListBox::DoSetItems(const wxArrayString& items, void **clientData)
+{
+ wxArrayString copy;
+ CopyStringsAddingPrefix(items, copy);
+ wxListBox::DoSetItems(copy, clientData);
+}