fixed wxDateTime::ParseFormat to correctly handle '%x' on Windows

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@32310 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Václav Slavík
2005-02-22 16:48:34 +00:00
parent 8795498cd9
commit 64f9c10094

View File

@@ -77,6 +77,12 @@
#include <ctype.h>
#ifdef __WINDOWS__
#include "wx/msw/wrapwin.h"
#include <winnls.h>
#include <locale.h>
#endif
#include "wx/datetime.h"
#include "wx/stopwatch.h" // for wxGetLocalTimeMillis()
@@ -2824,6 +2830,60 @@ const wxChar *wxDateTime::ParseRfc822Date(const wxChar* date)
return p;
}
#ifdef __WINDOWS__
// Get's current locale's date formatting string and stores it in fmt if
// the locale is set; otherwise or in case of failure, leaves fmt unchanged
void GetLocaleDateFormat(wxString *fmt)
{
if ( strcmp(setlocale(LC_ALL, NULL), "C") != 0 )
{
// The locale was programatically set to non-C. We assume that this was
// done using wxLocale, in which case thread's current locale is also
// set to correct LCID value and we can use GetLocaleInfo to determine
// the correct formatting string:
LCID lcid = GetThreadLocale();
wxChar delim[5]; // fields deliminer, 4 chars max
if ( GetLocaleInfo(lcid, LOCALE_SDATE, delim, 5) )
{
wxChar centurybuf[2]; // use %y or %Y, 1 char max
wxChar century = 'y';
if ( GetLocaleInfo(lcid, LOCALE_ICENTURY, centurybuf, 2) )
{
if ( centurybuf[0] == _T('1') )
century = 'Y';
// else 'y' as above
}
wxChar order[2]; // order code, 1 char max
if ( GetLocaleInfo(lcid, LOCALE_IDATE, order, 2) )
{
if ( order[0] == _T('0') ) // M-D-Y
{
*fmt = wxString::Format(_T("%%m%s%%d%s%%%c"),
delim, delim, century);
}
else if ( order[0] == _T('1') ) // D-M-Y
{
*fmt = wxString::Format(_T("%%d%s%%m%s%%%c"),
delim, delim, century);
}
else if ( order[0] == _T('2') ) // Y-M-D
{
*fmt = wxString::Format(_T("%%%c%s%%m%s%%d"),
century, delim, delim);
}
else
{
wxFAIL_MSG(_T("unexpected GetLocaleInfo return value"));
}
}
}
// if we failed, leave fmtDate value unchanged and
// try our luck with the default set above
}
}
#endif // __WINDOWS__
const wxChar *wxDateTime::ParseFormat(const wxChar *date,
const wxChar *format,
const wxDateTime& dateDef)
@@ -3183,11 +3243,11 @@ const wxChar *wxDateTime::ParseFormat(const wxChar *date,
}
#endif // HAVE_STRPTIME
// TODO query the LOCALE_IDATE setting under Win32
{
wxDateTime dt;
wxString fmtDate, fmtDateAlt;
if ( IsWestEuropeanCountry(GetCountry()) ||
GetCountry() == Russia )
{
@@ -3200,6 +3260,12 @@ const wxChar *wxDateTime::ParseFormat(const wxChar *date,
fmtDateAlt = _T("%d/%m/%y");
}
#ifdef __WINDOWS__
// The above doesn't work for all locales, try to query
// Windows for the right way of formatting the date:
GetLocaleDateFormat(&fmtDate);
#endif
const wxChar *result = dt.ParseFormat(input, fmtDate);
if ( !result )