X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/8f2a8de6e754cbbd6d0d7c216c5b44518fae872e..b622441a8dc47fe33f5677e2baf0253e082bfe4b:/src/generic/datectlg.cpp?ds=sidebyside diff --git a/src/generic/datectlg.cpp b/src/generic/datectlg.cpp index f951b948ea..a862229255 100644 --- a/src/generic/datectlg.cpp +++ b/src/generic/datectlg.cpp @@ -28,14 +28,16 @@ #ifndef WX_PRECOMP #include "wx/dialog.h" #include "wx/dcmemory.h" + #include "wx/intl.h" #include "wx/panel.h" #include "wx/textctrl.h" #include "wx/valtext.h" #endif -#include "wx/datectrl.h" -#include "wx/generic/datectrl.h" +#include "wx/calctrl.h" +#include "wx/combo.h" +#include "wx/datectrl.h" // ---------------------------------------------------------------------------- // constants @@ -110,7 +112,7 @@ public: else // invalid date { wxASSERT_MSG( HasDPFlag(wxDP_ALLOWNONE), - _T("this control must have a valid date") ); + wxT("this control must have a valid date") ); m_combo->SetText(wxEmptyString); } @@ -202,66 +204,15 @@ private: return m_combo->GetParent()->HasFlag(flag); } - // it expands "%x" format and changes %y to %Y if wxDP_SHOWCENTURY flag - // is given. If the locale format can't be easily analyzed (e.g. when - // the month is given as a name, not number), "%x" is returned + // Return the format to be used for the dates shown by the control. This + // functions honours wxDP_SHOWCENTURY flag. wxString GetLocaleDateFormat() const { - wxString x_format(wxT("%x")); - wxString fmt; - int year_cnt = 0, month_cnt = 0, day_cnt = 0; - - wxDateTime dt; - dt.ParseFormat(wxT("2003-10-17"), wxT("%Y-%m-%d")); - wxString str(dt.Format(x_format)); - - const wxChar *p = str.c_str(); - while ( *p ) - { - if (wxIsdigit(*p)) - { - int n=wxAtoi(p); - if (n == dt.GetDay()) - { - fmt.Append(wxT("%d")); - day_cnt++; - p += 2; - } - else if (n == (int)dt.GetMonth()+1) - { - fmt.Append(wxT("%m")); - month_cnt++; - p += 2; - } - else if (n == dt.GetYear()) - { - fmt.Append(wxT("%Y")); - year_cnt++; - p += 4; - } - else if (n == (dt.GetYear() % 100)) - { - if ( HasDPFlag(wxDP_SHOWCENTURY) ) - fmt.Append(wxT("%Y")); - else - fmt.Append(wxT("%y")); - year_cnt++; - p += 2; - } - else - // this shouldn't happen - return x_format; - } - else { - fmt.Append(*p); - p++; - } - } - - if (year_cnt == 1 && month_cnt == 1 && day_cnt == 1) - return fmt; + wxString fmt = wxLocale::GetInfo(wxLOCALE_SHORT_DATE_FMT); + if ( HasDPFlag(wxDP_SHOWCENTURY) ) + fmt.Replace("%y", "%Y"); - return x_format; + return fmt; } bool SetFormat(const wxString& fmt) @@ -271,7 +222,7 @@ private: if ( m_combo ) { wxArrayString allowedChars; - for ( wxChar c = _T('0'); c <= _T('9'); c++ ) + for ( wxChar c = wxT('0'); c <= wxT('9'); c++ ) allowedChars.Add(wxString(c, 1)); const wxChar *p2 = m_format.c_str(); @@ -364,7 +315,7 @@ bool wxDatePickerCtrlGeneric::Create(wxWindow *parent, const wxString& name) { wxASSERT_MSG( !(style & wxDP_SPIN), - _T("wxDP_SPIN style not supported, use wxDP_DEFAULT") ); + wxT("wxDP_SPIN style not supported, use wxDP_DEFAULT") ); if ( !wxControl::Create(parent, id, pos, size, style | wxCLIP_CHILDREN | wxWANTS_CHARS | wxBORDER_NONE,