+void wxVariant::operator=(wxLongLong value)
+{
+ if ( GetType() == wxS("longlong") &&
+ m_refData->GetRefCount() == 1 )
+ {
+ ((wxVariantDataLongLong*)GetData())->SetValue(value);
+ }
+ else
+ {
+ UnRef();
+ m_refData = new wxVariantDataLongLong(value);
+ }
+}
+
+wxLongLong wxVariant::GetLongLong() const
+{
+ wxLongLong value;
+ if ( Convert(&value) )
+ {
+ return value;
+ }
+ else
+ {
+ wxFAIL_MSG(wxT("Could not convert to a long long"));
+ return 0;
+ }
+}
+
+#endif // wxUSE_LONGLONG
+
+// ----------------------------------------------------------------------------
+// wxVariantDataULongLong
+// ----------------------------------------------------------------------------
+
+#if wxUSE_LONGLONG
+
+class WXDLLIMPEXP_BASE wxVariantDataULongLong : public wxVariantData
+{
+public:
+ wxVariantDataULongLong() { m_value = 0; }
+ wxVariantDataULongLong(wxULongLong value) { m_value = value; }
+
+ wxULongLong GetValue() const { return m_value; }
+ void SetValue(wxULongLong value) { m_value = value; }
+
+ virtual bool Eq(wxVariantData& data) const;
+
+ virtual bool Read(wxString& str);
+ virtual bool Write(wxString& str) const;
+#if wxUSE_STD_IOSTREAM
+ virtual bool Read(wxSTD istream& str);
+ virtual bool Write(wxSTD ostream& str) const;
+#endif
+#if wxUSE_STREAMS
+ virtual bool Read(wxInputStream& str);
+ virtual bool Write(wxOutputStream &str) const;
+#endif // wxUSE_STREAMS
+
+ wxVariantData* Clone() const
+ {
+ return new wxVariantDataULongLong(m_value);
+ }
+
+ virtual wxString GetType() const { return wxS("ulonglong"); }
+
+ DECLARE_WXANY_CONVERSION()
+protected:
+ wxULongLong m_value;
+};
+
+//
+// wxULongLong type requires customized wxAny conversion code
+//
+#if wxUSE_ANY
+#ifdef wxLongLong_t
+
+bool wxVariantDataULongLong::GetAsAny(wxAny* any) const
+{
+ *any = m_value.GetValue();
+ return true;
+}
+
+wxVariantData* wxVariantDataULongLong::VariantDataFactory(const wxAny& any)
+{
+ return new wxVariantDataULongLong(wxANY_AS(any, wxULongLong_t));
+}
+
+REGISTER_WXANY_CONVERSION(wxULongLong_t, wxVariantDataULongLong)
+
+#else // if !defined(wxLongLong_t)
+
+bool wxVariantDataULongLong::GetAsAny(wxAny* any) const
+{
+ *any = m_value;
+ return true;
+}
+
+wxVariantData* wxVariantDataULongLong::VariantDataFactory(const wxAny& any)
+{
+ return new wxVariantDataULongLong(wxANY_AS(any, wxULongLong));
+}
+
+REGISTER_WXANY_CONVERSION(wxULongLong, wxVariantDataULongLong)
+
+#endif // defined(wxLongLong_t)/!defined(wxLongLong_t)
+#endif // wxUSE_ANY
+
+
+bool wxVariantDataULongLong::Eq(wxVariantData& data) const
+{
+ wxASSERT_MSG( (data.GetType() == wxS("ulonglong")),
+ "wxVariantDataULongLong::Eq: argument mismatch" );
+
+ wxVariantDataULongLong& otherData = (wxVariantDataULongLong&) data;
+
+ return (otherData.m_value == m_value);
+}
+
+#if wxUSE_STD_IOSTREAM
+bool wxVariantDataULongLong::Write(wxSTD ostream& str) const
+{
+ wxString s;
+ Write(s);
+ str << (const char*) s.mb_str();
+ return true;
+}
+#endif
+
+bool wxVariantDataULongLong::Write(wxString& str) const
+{
+#ifdef wxLongLong_t
+ str.Printf(wxS("%llu"), m_value.GetValue());
+ return true;
+#else
+ return false;
+#endif
+}
+
+#if wxUSE_STD_IOSTREAM
+bool wxVariantDataULongLong::Read(wxSTD istream& WXUNUSED(str))
+{
+ wxFAIL_MSG(wxS("Unimplemented"));
+ return false;
+}
+#endif
+
+#if wxUSE_STREAMS
+bool wxVariantDataULongLong::Write(wxOutputStream& str) const
+{
+ wxTextOutputStream s(str);
+ s.Write32(m_value.GetLo());
+ s.Write32(m_value.GetHi());
+ return true;
+}
+
+bool wxVariantDataULongLong::Read(wxInputStream& str)
+{
+ wxTextInputStream s(str);
+ unsigned long lo = s.Read32();
+ long hi = s.Read32();
+ m_value = wxULongLong(hi, lo);
+ return true;
+}
+#endif // wxUSE_STREAMS
+
+bool wxVariantDataULongLong::Read(wxString& str)
+{
+#ifdef wxLongLong_t
+ wxULongLong_t value_t;
+ if ( !str.ToULongLong(&value_t) )
+ return false;
+ m_value = value_t;
+ return true;
+#else
+ return false;
+#endif
+}
+
+// wxVariant
+
+wxVariant::wxVariant(wxULongLong val, const wxString& name)
+{
+ m_refData = new wxVariantDataULongLong(val);
+ m_name = name;
+}
+
+bool wxVariant::operator==(wxULongLong value) const
+{
+ wxULongLong thisValue;
+ if ( !Convert(&thisValue) )
+ return false;
+ else
+ return (value == thisValue);
+}
+
+bool wxVariant::operator!=(wxULongLong value) const
+{
+ return (!((*this) == value));
+}
+
+void wxVariant::operator=(wxULongLong value)
+{
+ if ( GetType() == wxS("ulonglong") &&
+ m_refData->GetRefCount() == 1 )
+ {
+ ((wxVariantDataULongLong*)GetData())->SetValue(value);
+ }
+ else
+ {
+ UnRef();
+ m_refData = new wxVariantDataULongLong(value);
+ }
+}
+
+wxULongLong wxVariant::GetULongLong() const
+{
+ wxULongLong value;
+ if ( Convert(&value) )
+ {
+ return value;
+ }
+ else
+ {
+ wxFAIL_MSG(wxT("Could not convert to a long long"));
+ return 0;
+ }
+}
+
+#endif // wxUSE_LONGLONG
+
+// ----------------------------------------------------------------------------
+// wxVariantDataList
+// ----------------------------------------------------------------------------
+
+class WXDLLIMPEXP_BASE wxVariantDataList: public wxVariantData
+{
+public:
+ wxVariantDataList() {}
+ wxVariantDataList(const wxVariantList& list);
+ virtual ~wxVariantDataList();
+
+ wxVariantList& GetValue() { return m_value; }
+ void SetValue(const wxVariantList& value) ;
+
+ virtual bool Eq(wxVariantData& data) const;
+#if wxUSE_STD_IOSTREAM
+ virtual bool Write(wxSTD ostream& str) const;
+#endif
+ virtual bool Write(wxString& str) const;
+#if wxUSE_STD_IOSTREAM
+ virtual bool Read(wxSTD istream& str);
+#endif
+ virtual bool Read(wxString& str);
+ virtual wxString GetType() const { return wxT("list"); }
+
+ void Clear();
+
+ wxVariantData* Clone() const { return new wxVariantDataList(m_value); }
+
+ DECLARE_WXANY_CONVERSION()
+protected:
+ wxVariantList m_value;
+};
+
+#if wxUSE_ANY
+
+//
+// Convert to/from list of wxAnys
+//
+
+bool wxVariantDataList::GetAsAny(wxAny* any) const
+{
+ wxAnyList dst;
+ wxVariantList::compatibility_iterator node = m_value.GetFirst();
+ while (node)
+ {
+ wxVariant* pVar = node->GetData();
+ dst.push_back(new wxAny(((const wxVariant&)*pVar)));
+ node = node->GetNext();
+ }
+
+ *any = dst;
+ return true;
+}
+
+wxVariantData* wxVariantDataList::VariantDataFactory(const wxAny& any)
+{
+ wxAnyList src = wxANY_AS(any, wxAnyList);
+ wxVariantList dst;
+ wxAnyList::compatibility_iterator node = src.GetFirst();
+ while (node)
+ {
+ wxAny* pAny = node->GetData();
+ dst.push_back(new wxVariant(*pAny));
+ node = node->GetNext();
+ }
+
+ return new wxVariantDataList(dst);
+}
+
+REGISTER_WXANY_CONVERSION(wxAnyList, wxVariantDataList)
+
+#endif // wxUSE_ANY
+
+wxVariantDataList::wxVariantDataList(const wxVariantList& list)
+{
+ SetValue(list);
+}
+
+wxVariantDataList::~wxVariantDataList()
+{
+ Clear();
+}
+
+void wxVariantDataList::SetValue(const wxVariantList& value)
+{
+ Clear();
+ wxVariantList::compatibility_iterator node = value.GetFirst();
+ while (node)
+ {
+ wxVariant* var = node->GetData();
+ m_value.Append(new wxVariant(*var));
+ node = node->GetNext();
+ }
+}
+
+void wxVariantDataList::Clear()
+{
+ wxVariantList::compatibility_iterator node = m_value.GetFirst();
+ while (node)
+ {
+ wxVariant* var = node->GetData();
+ delete var;
+ node = node->GetNext();
+ }
+ m_value.Clear();
+}
+
+bool wxVariantDataList::Eq(wxVariantData& data) const
+{
+ wxASSERT_MSG( (data.GetType() == wxT("list")), wxT("wxVariantDataList::Eq: argument mismatch") );
+
+ wxVariantDataList& listData = (wxVariantDataList&) data;
+ wxVariantList::compatibility_iterator node1 = m_value.GetFirst();
+ wxVariantList::compatibility_iterator node2 = listData.GetValue().GetFirst();
+ while (node1 && node2)
+ {
+ wxVariant* var1 = node1->GetData();
+ wxVariant* var2 = node2->GetData();
+ if ((*var1) != (*var2))
+ return false;
+ node1 = node1->GetNext();
+ node2 = node2->GetNext();
+ }
+ if (node1 || node2) return false;
+ return true;
+}
+
+#if wxUSE_STD_IOSTREAM
+bool wxVariantDataList::Write(wxSTD ostream& str) const
+{
+ wxString s;
+ Write(s);
+ str << (const char*) s.mb_str();
+ return true;
+}
+#endif
+
+bool wxVariantDataList::Write(wxString& str) const
+{
+ str = wxEmptyString;
+ wxVariantList::compatibility_iterator node = m_value.GetFirst();
+ while (node)
+ {
+ wxVariant* var = node->GetData();
+ if (node != m_value.GetFirst())
+ str += wxT(" ");
+ wxString str1;
+ str += var->MakeString();
+ node = node->GetNext();
+ }
+
+ return true;
+}
+
+#if wxUSE_STD_IOSTREAM
+bool wxVariantDataList::Read(wxSTD istream& WXUNUSED(str))
+{
+ wxFAIL_MSG(wxT("Unimplemented"));
+ // TODO
+ return false;
+}
+#endif
+
+bool wxVariantDataList::Read(wxString& WXUNUSED(str))
+{
+ wxFAIL_MSG(wxT("Unimplemented"));
+ // TODO
+ return false;
+}
+
+// wxVariant
+
+wxVariant::wxVariant(const wxVariantList& val, const wxString& name) // List of variants
+{
+ m_refData = new wxVariantDataList(val);
+ m_name = name;
+}
+
+bool wxVariant::operator== (const wxVariantList& value) const
+{
+ wxASSERT_MSG( (GetType() == wxT("list")), wxT("Invalid type for == operator") );
+
+ wxVariantDataList other(value);
+ return (GetData()->Eq(other));
+}
+
+bool wxVariant::operator!= (const wxVariantList& value) const
+{
+ return (!((*this) == value));
+}
+
+void wxVariant::operator= (const wxVariantList& value)