X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/d4d8988c72e26ea5ef68b87a53691da7c3751a95..e0954e729dabaad5603d9970d123d6b96ed73463:/src/common/list.cpp diff --git a/src/common/list.cpp b/src/common/list.cpp index 9cd9c1b90d..7d069da0ff 100644 --- a/src/common/list.cpp +++ b/src/common/list.cpp @@ -29,7 +29,6 @@ #include #ifndef WX_PRECOMP - #include "wx/defs.h" #include "wx/list.h" #endif @@ -54,7 +53,7 @@ bool wxListKey::operator==(wxListKeyValue value) const // by not putting return here... case wxKEY_STRING: - return wxStrcmp(m_key.string, value.string) == 0; + return *m_key.string == *value.string; case wxKEY_INTEGER: return m_key.integer == value.integer; @@ -85,7 +84,7 @@ wxNodeBase::wxNodeBase(wxListBase *list, case wxKEY_STRING: // to be free()d later - m_key.string = wxStrdup(key.GetString()); + m_key.string = new wxString(key.GetString()); break; default: @@ -108,7 +107,7 @@ wxNodeBase::~wxNodeBase() { if ( m_list->m_keyType == wxKEY_STRING ) { - free(m_key.string); + delete m_key.string; } m_list->DetachNode(this); @@ -258,7 +257,7 @@ wxNodeBase *wxListBase::Append(long key, void *object) return AppendCommon(node); } -wxNodeBase *wxListBase::Append (const wxChar *key, void *object) +wxNodeBase *wxListBase::Append (const wxString& key, void *object) { wxCHECK_MSG( (m_keyType == wxKEY_STRING) || (m_keyType == wxKEY_NONE && m_count == 0), @@ -760,8 +759,10 @@ wxNode *wxStringList::Prepend(const wxChar *s) WX_DEFINE_LIST(wxObjectList) // with wxUSE_STL wxStringList contains wxString objects, not pointers -void wxStringListBase::DeleteFunction( wxString WXUNUSED(X) ) +void _WX_LIST_HELPER_wxStringListBase::DeleteFunction( wxString WXUNUSED(X) ) { } +wxStringListBase::BaseListType wxStringListBase::EmptyList; + #endif // !wxUSE_STL