///////////////////////////////////////////////////////////////////////////////
-// Name: checklst.cpp
+// Name: src/motif/checklst.cpp
// Purpose: implementation of wxCheckListBox class
// Author: Julian Smart
// Modified by:
// For compilers that support precompilation, includes "wx.h".
#include "wx/wxprec.h"
-#include "wx/defs.h"
+#if wxUSE_CHECKLISTBOX
#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()
{
bool retVal = wxListBox::Create(parent, id, pos, size, n, choices,
style, validator, name);
return retVal;
-}
+}
bool wxCheckListBox::Create(wxWindow *parent, wxWindowID id,
const wxPoint& pos,
bool retVal = wxListBox::Create(parent, id, pos, size, choices,
style, validator, name);
return retVal;
-}
+}
// check items
// -----------
-bool wxCheckListBox::IsChecked(size_t uiIndex) const
+bool wxCheckListBox::IsChecked(unsigned int uiIndex) const
{
return ::IsChecked(wxListBox::GetString(uiIndex));
}
-void wxCheckListBox::Check(size_t uiIndex, bool bCheck)
+void wxCheckListBox::Check(unsigned int uiIndex, bool bCheck)
{
wxString label = wxListBox::GetString(uiIndex);
if(::IsChecked(label) == bCheck) return;
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.SetInt(n);
event.SetExtraLong(true);
event.SetEventObject(this);
- event.SetString( GetString( n ) );
+ event.SetString(GetString(n));
GetEventHandler()->ProcessEvent(event);
}
}
-int wxCheckListBox::DoAppend(const wxString& item)
+int wxCheckListBox::FindString(const wxString& s, bool bCase) const
{
- return wxListBox::DoAppend( Prefix(false) + item );
-}
-
-int wxCheckListBox::FindString(const wxString& s) const
-{
- int n1 = wxListBox::FindString(Prefix(false) + s);
- int n2 = wxListBox::FindString(Prefix(true) + s);
+ 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:
return min;
}
-void wxCheckListBox::SetString(int n, const wxString& s)
+void wxCheckListBox::SetString(unsigned int n, const wxString& s)
{
- wxListBox::SetString( n, Prefix(IsChecked(n)) + s );
+ wxListBox::SetString(n, Prefix(IsChecked(n)) + s);
}
-wxString wxCheckListBox::GetString(int n) const
+wxString wxCheckListBox::GetString(unsigned int n) const
{
return wxListBox::GetString(n).substr(4);
}
-void wxCheckListBox::DoInsertItems(const wxArrayString& items, 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