wxDbGrid additions - Added support for ODBC date types

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@10499 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
George Tasker 2001-06-10 17:04:00 +00:00
parent ffd98768ba
commit edca7a8205
2 changed files with 234 additions and 2 deletions

View File

@ -26,6 +26,12 @@
#include "wx/date.h" #include "wx/date.h"
#endif // time/date #endif // time/date
#include "wx/datetime.h"
#if wxUSE_ODBC
#include "wx/db.h" // will #include sqltypes.h
#endif //ODBC
#include "wx/ioswrap.h" #include "wx/ioswrap.h"
/* /*
@ -98,6 +104,15 @@ public:
#endif #endif
wxVariant(void* ptr, const wxString& name = wxEmptyString); // void* (general purpose) wxVariant(void* ptr, const wxString& name = wxEmptyString); // void* (general purpose)
wxVariant(wxVariantData* data, const wxString& name = wxEmptyString); // User-defined data wxVariant(wxVariantData* data, const wxString& name = wxEmptyString); // User-defined data
//TODO: Need to document
wxVariant(const wxDateTime& val, const wxString& name = wxEmptyString); // Date
#if wxUSE_ODBC
wxVariant(const DATE_STRUCT* valptr, const wxString& name = wxEmptyString); // DateTime
wxVariant(const TIME_STRUCT* valptr, const wxString& name = wxEmptyString); // DateTime
wxVariant(const TIMESTAMP_STRUCT* valptr, const wxString& name = wxEmptyString); // DateTime
#endif
//TODO: End of Need to document
wxVariant(const wxVariant& variant); wxVariant(const wxVariant& variant);
~wxVariant(); ~wxVariant();
@ -105,6 +120,17 @@ public:
// Assignment // Assignment
void operator= (const wxVariant& variant); void operator= (const wxVariant& variant);
//TODO: Need to document
bool operator== (const wxDateTime& value) const;
bool operator!= (const wxDateTime& value) const;
void operator= (const wxDateTime& value) ;
#if wxUSE_ODBC
void operator= (const DATE_STRUCT* value) ;
void operator= (const TIME_STRUCT* value) ;
void operator= (const TIMESTAMP_STRUCT* value) ;
#endif
//TODO: End of Need to document
// Assignment using data, e.g. // Assignment using data, e.g.
// myVariant = new wxStringVariantData("hello"); // myVariant = new wxStringVariantData("hello");
void operator= (wxVariantData* variantData); void operator= (wxVariantData* variantData);
@ -168,6 +194,9 @@ public:
inline operator wxDate () const { return GetDate(); } inline operator wxDate () const { return GetDate(); }
#endif #endif
inline operator void* () const { return GetVoidPtr(); } inline operator void* () const { return GetVoidPtr(); }
//TODO: Need to document
inline operator wxDateTime () const { return GetDateTime(); }
//TODO: End of Need to document
// Accessors // Accessors
// Sets/gets name // Sets/gets name
@ -206,6 +235,9 @@ public:
wxDate GetDate() const ; wxDate GetDate() const ;
#endif #endif
void* GetVoidPtr() const ; void* GetVoidPtr() const ;
//TODO: Need to document
wxDateTime GetDateTime() const ;
//TODO: End of Need to document
// Operations // Operations
// Make NULL (i.e. delete the data) // Make NULL (i.e. delete the data)
@ -242,6 +274,9 @@ protected:
bool Convert(wxTime* value) const; bool Convert(wxTime* value) const;
bool Convert(wxDate* value) const; bool Convert(wxDate* value) const;
#endif #endif
//TODO: Need to document
bool Convert(wxDateTime* value) const;
//TODO: End of Need to document
// Attributes // Attributes
protected: protected:

View File

@ -1076,6 +1076,102 @@ bool wxVariantDataVoidPtr::Read(wxString& WXUNUSED(str))
return FALSE; return FALSE;
} }
/*
* wxVariantDataDateTime
*/
class wxVariantDataDateTime: public wxVariantData
{
DECLARE_DYNAMIC_CLASS(wxVariantDataDateTime)
public:
wxVariantDataDateTime() { }
wxVariantDataDateTime(const wxDateTime& value) { m_value = value; }
#if wxUSE_ODBC
wxVariantDataDateTime(const TIME_STRUCT* valptr)
{ m_value = wxDateTime(valptr->hour, valptr->minute, valptr->second); }
wxVariantDataDateTime(const DATE_STRUCT* valptr)
{ m_value = wxDateTime(valptr->day, (wxDateTime::Month) (valptr->month - 1),valptr->year); }
wxVariantDataDateTime(const TIMESTAMP_STRUCT* valptr)
{ m_value = wxDateTime(valptr->day, (wxDateTime::Month) (valptr->month - 1), valptr->year,
valptr->hour, valptr->minute, valptr->second, valptr->fraction ); }
#endif //ODBC
inline wxDateTime GetValue() const { return m_value; }
inline void SetValue(const wxDateTime& value) { m_value = value; }
virtual void Copy(wxVariantData& data);
virtual bool Eq(wxVariantData& data) const;
#if wxUSE_STD_IOSTREAM
virtual bool Write(ostream& str) const;
#endif
virtual bool Write(wxString& str) const;
#if wxUSE_STD_IOSTREAM
virtual bool Read(istream& str);
#endif
virtual bool Read(wxString& str);
virtual wxString GetType() const { return wxT("datetime"); };
virtual wxVariantData* Clone() { return new wxVariantDataDateTime; }
protected:
wxDateTime m_value;
};
IMPLEMENT_DYNAMIC_CLASS(wxVariantDataDateTime, wxVariantData)
void wxVariantDataDateTime::Copy(wxVariantData& data)
{
wxASSERT_MSG( (data.GetType() == wxT("datetime")), wxT("wxVariantDataDateTime::Copy: Can't copy to this type of data") );
wxVariantDataDateTime& otherData = (wxVariantDataDateTime&) data;
otherData.m_value = m_value;
}
bool wxVariantDataDateTime::Eq(wxVariantData& data) const
{
wxASSERT_MSG( (data.GetType() == wxT("datetime")), wxT("wxVariantDataDateTime::Eq: argument mismatch") );
wxVariantDataDateTime& otherData = (wxVariantDataDateTime&) data;
return (otherData.m_value == m_value);
}
#if wxUSE_STD_IOSTREAM
bool wxVariantDataDateTime::Write(ostream& str) const
{
// Not implemented
return FALSE;
}
#endif
bool wxVariantDataDateTime::Write(wxString& str) const
{
str = m_value.Format();
return TRUE;
}
#if wxUSE_STD_IOSTREAM
bool wxVariantDataDateTime::Read(istream& WXUNUSED(str))
{
// Not implemented
return FALSE;
}
#endif
bool wxVariantDataDateTime::Read(wxString& str)
{
if(! m_value.ParseDateTime(str))
return FALSE;
return TRUE;
}
/* /*
* wxVariant * wxVariant
@ -1160,6 +1256,32 @@ wxVariant::wxVariant(void* val, const wxString& name) // Void ptr
m_name = name; m_name = name;
} }
wxVariant::wxVariant(const wxDateTime& val, const wxString& name) // Date
{
m_data = new wxVariantDataDateTime(val);
m_name = name;
}
#if wxUSE_ODBC
wxVariant::wxVariant(const TIME_STRUCT* valptr, const wxString& name) // Date
{
m_data = new wxVariantDataDateTime(valptr);
m_name = name;
}
wxVariant::wxVariant(const TIMESTAMP_STRUCT* valptr, const wxString& name) // Date
{
m_data = new wxVariantDataDateTime(valptr);
m_name = name;
}
wxVariant::wxVariant(const DATE_STRUCT* valptr, const wxString& name) // Date
{
m_data = new wxVariantDataDateTime(valptr);
m_name = name;
}
#endif
wxVariant::wxVariant(const wxVariant& variant) wxVariant::wxVariant(const wxVariant& variant)
{ {
if (!variant.IsNull()) if (!variant.IsNull())
@ -1527,6 +1649,61 @@ void wxVariant::operator= (void* value)
} }
} }
bool wxVariant::operator== (const wxDateTime& value) const
{
wxDateTime thisValue;
if (!Convert(&thisValue))
return FALSE;
return value.IsEqualTo(thisValue);
}
bool wxVariant::operator!= (const wxDateTime& value) const
{
return (!((*this) == value));
}
void wxVariant::operator= (const wxDateTime& value)
{
if (GetType() == wxT("datetime"))
{
((wxVariantDataDateTime*)GetData())->SetValue(value);
}
else
{
if (m_data)
delete m_data;
m_data = new wxVariantDataDateTime(value);
}
}
#if wxUSE_ODBC
void wxVariant::operator= (const DATE_STRUCT* value)
{
if (m_data)
delete m_data;
m_data = new wxVariantDataDateTime(value);
}
void wxVariant::operator= (const TIME_STRUCT* value)
{
if (m_data)
delete m_data;
m_data = new wxVariantDataDateTime(value);
}
void wxVariant::operator= (const TIMESTAMP_STRUCT* value)
{
if (m_data)
delete m_data;
m_data = new wxVariantDataDateTime(value);
}
#endif
// Treat a list variant as an array // Treat a list variant as an array
wxVariant wxVariant::operator[] (size_t idx) const wxVariant wxVariant::operator[] (size_t idx) const
{ {
@ -1709,6 +1886,17 @@ void* wxVariant::GetVoidPtr() const
return (void*) ((wxVariantDataVoidPtr*) m_data)->GetValue(); return (void*) ((wxVariantDataVoidPtr*) m_data)->GetValue();
} }
wxDateTime wxVariant::GetDateTime() const
{
wxDateTime value;
if (!Convert(& value))
{
wxFAIL_MSG(wxT("Could not convert to a datetime"));
}
return value;
}
wxList& wxVariant::GetList() const wxList& wxVariant::GetList() const
{ {
wxASSERT( (GetType() == wxT("list")) ); wxASSERT( (GetType() == wxT("list")) );
@ -1901,6 +2089,15 @@ bool wxVariant::Convert(wxDate* value) const
return TRUE; return TRUE;
} }
#endif #endif // wxUSE_TIMEDATE
// wxUSE_TIMEDATE
bool wxVariant::Convert(wxDateTime* value) const
{
wxString type(GetType());
if (type == wxT("datetime"))
*value = ((wxVariantDataDateTime*)GetData())->GetValue();
else
return FALSE;
return TRUE;
}