X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/2a227e8c9f968b8a8d25961457ce709a06aead1f..74b965198ce3a4257deac901b6f7517e6447ca0f:/src/common/variant.cpp diff --git a/src/common/variant.cpp b/src/common/variant.cpp index f297b3c4d6..1820f4b8d5 100644 --- a/src/common/variant.cpp +++ b/src/common/variant.cpp @@ -225,11 +225,10 @@ wxVariant::wxVariant(const wxAny& any) wxAny wxVariant::GetAny() const { - wxAny any; - if ( IsNull() ) - return any; + return wxAny(); + wxAny any; wxVariantData* data = GetData(); if ( data->GetAsAny(&any) ) @@ -880,6 +879,26 @@ protected: IMPLEMENT_TRIVIAL_WXANY_CONVERSION(wxString, wxVariantDataString) +#if wxUSE_ANY +// This allows converting string literal wxAnys to string variants +wxVariantData* wxVariantDataFromConstCharPAny(const wxAny& any) +{ + return new wxVariantDataString(wxANY_AS(any, const char*)); +} + +wxVariantData* wxVariantDataFromConstWchar_tPAny(const wxAny& any) +{ + return new wxVariantDataString(wxANY_AS(any, const wchar_t*)); +} + +_REGISTER_WXANY_CONVERSION(const char*, + ConstCharP, + wxVariantDataFromConstCharPAny) +_REGISTER_WXANY_CONVERSION(const wchar_t*, + ConstWchar_tP, + wxVariantDataFromConstWchar_tPAny) +#endif + bool wxVariantDataString::Eq(wxVariantData& data) const { wxASSERT_MSG( (data.GetType() == wxT("string")), wxT("wxVariantDataString::Eq: argument mismatch") );