Second try for GetCalendarInfo
Vincent Béron
vberon at mecano.gme.usherb.ca
Sat May 11 22:35:47 CDT 2002
There's still a couple of things unimplemented, as I don't have access
to a compiler able to produce working code on Windows for me to get the
missing data. (VC98 bails out on _GetCalendarInfoA, and it's the only
one I have easy access to).
Where should I put (when I get them) new strings identifying the
requested calendar? There's one for each pair of CALID (12 in total) and
LOCALE (many many). dlls/kernel/nls/*.nls, with something like a clone
of GetLocaleInfo?
Changelog:
- Better implementation of GetCalendarInfo{A,W}, not perfect.
Vincent
-------------- next part --------------
diff -urN wine/dlls/kernel/time.c-orig wine/dlls/kernel/time.c
--- wine/dlls/kernel/time.c-orig Mon Mar 11 00:08:38 2002
+++ wine/dlls/kernel/time.c Sat May 11 23:12:54 2002
@@ -585,75 +585,23 @@
int WINAPI GetCalendarInfoA(LCID Locale, CALID Calendar, CALTYPE CalType,
LPSTR lpCalData, int cchData, LPDWORD lpValue)
{
- FIXME("(%08lx,%08lx,%08lx,%p,%d,%p): stub\n",
+ int ret;
+ LPWSTR lpCalDataW = NULL;
+
+ FIXME("(%08lx,%08lx,%08lx,%p,%d,%p): quarter-stub\n",
Locale, Calendar, CalType, lpCalData, cchData, lpValue);
- /* dont have the #define values for those */
+ /* FIXME: Should verify if Locale is allowable in ANSI, as per MSDN */
- FIXME("\t");
- /*
- if (CalType & CAL_NOUSEROVERRIDE)
- MESSAGE("CAL_NOUSEROVERRIDE|");
- if (CalType & CAL_RETURN_NUMBER)
- MESSAGE("CAL_RETURN_NUMBER|");
- if (CalType & CAL_USE_CP_ACP)
- MESSAGE("CAL_USE_CP_ACP|");
- */
+ if(cchData)
+ if(!(lpCalDataW = HeapAlloc(GetProcessHeap(), 0, cchData*sizeof(WCHAR)))) return 0;
- /*switch (CalType & ~(CAL_NOUSEROVERRIDE|CAL_RETURN_NUMBER|CAL_USE_CP_ACP)) {*/
- switch (CalType & 0xffff) {
-#define X(x) case x: MESSAGE(#x"\n");break;
- X(CAL_ICALINTVALUE)
- X(CAL_SCALNAME)
- X(CAL_IYEAROFFSETRANGE)
- X(CAL_SERASTRING)
- X(CAL_SSHORTDATE)
- X(CAL_SLONGDATE)
- X(CAL_SDAYNAME1)
- X(CAL_SDAYNAME2)
- X(CAL_SDAYNAME3)
- X(CAL_SDAYNAME4)
- X(CAL_SDAYNAME5)
- X(CAL_SDAYNAME6)
- X(CAL_SDAYNAME7)
- X(CAL_SABBREVDAYNAME1)
- X(CAL_SABBREVDAYNAME2)
- X(CAL_SABBREVDAYNAME3)
- X(CAL_SABBREVDAYNAME4)
- X(CAL_SABBREVDAYNAME5)
- X(CAL_SABBREVDAYNAME6)
- X(CAL_SABBREVDAYNAME7)
- X(CAL_SMONTHNAME1)
- X(CAL_SMONTHNAME2)
- X(CAL_SMONTHNAME3)
- X(CAL_SMONTHNAME4)
- X(CAL_SMONTHNAME5)
- X(CAL_SMONTHNAME6)
- X(CAL_SMONTHNAME7)
- X(CAL_SMONTHNAME8)
- X(CAL_SMONTHNAME9)
- X(CAL_SMONTHNAME10)
- X(CAL_SMONTHNAME11)
- X(CAL_SMONTHNAME12)
- X(CAL_SMONTHNAME13)
- X(CAL_SABBREVMONTHNAME1)
- X(CAL_SABBREVMONTHNAME2)
- X(CAL_SABBREVMONTHNAME3)
- X(CAL_SABBREVMONTHNAME4)
- X(CAL_SABBREVMONTHNAME5)
- X(CAL_SABBREVMONTHNAME6)
- X(CAL_SABBREVMONTHNAME7)
- X(CAL_SABBREVMONTHNAME8)
- X(CAL_SABBREVMONTHNAME9)
- X(CAL_SABBREVMONTHNAME10)
- X(CAL_SABBREVMONTHNAME11)
- X(CAL_SABBREVMONTHNAME12)
- X(CAL_SABBREVMONTHNAME13)
- X(CAL_SYEARMONTH)
-#undef X
- default: MESSAGE("Unknown caltype %ld\n",CalType & 0xffff);
- return E_FAIL;
- }
- return 0;
+ ret = GetCalendarInfoW(Locale, Calendar, CalType, lpCalDataW, cchData, lpValue);
+ if(ret && lpCalDataW && lpCalData)
+ WideCharToMultiByte(CP_ACP, 0, lpCalDataW, cchData, lpCalData, cchData, NULL, NULL);
+ if(lpCalDataW)
+ HeapFree(GetProcessHeap(), 0, lpCalDataW);
+
+ return ret;
}
/*********************************************************************
@@ -663,8 +611,131 @@
int WINAPI GetCalendarInfoW(LCID Locale, CALID Calendar, CALTYPE CalType,
LPWSTR lpCalData, int cchData, LPDWORD lpValue)
{
- FIXME("(%08lx,%08lx,%08lx,%p,%d,%p): stub\n",
+ FIXME("(%08lx,%08lx,%08lx,%p,%d,%p): quarter-stub\n",
Locale, Calendar, CalType, lpCalData, cchData, lpValue);
+
+ if (CalType & CAL_NOUSEROVERRIDE)
+ FIXME("flag CAL_NOUSEROVERRIDE used, not fully implemented\n");
+ if (CalType & CAL_USE_CP_ACP)
+ FIXME("flag CAL_USE_CP_ACP used, not fully implemented\n");
+
+ if (CalType & CAL_RETURN_NUMBER) {
+ if (lpCalData != NULL)
+ WARN("lpCalData not NULL (%p) when it should!\n", lpCalData);
+ if (cchData != 0)
+ WARN("cchData not 0 (%d) when it should!\n", cchData);
+ } else {
+ if (lpValue != NULL)
+ WARN("lpValue not NULL (%p) when it should!\n", lpValue);
+ }
+
+ /* FIXME: No verification is made yet wrt Locale
+ * for the CALTYPES not requiring GetLocaleInfoA */
+ switch (CalType & ~(CAL_NOUSEROVERRIDE|CAL_RETURN_NUMBER|CAL_USE_CP_ACP)) {
+ case CAL_ICALINTVALUE:
+ FIXME("Unimplemented caltype %ld\n", CalType & 0xffff);
+ return E_FAIL;
+ case CAL_SCALNAME:
+ FIXME("Unimplemented caltype %ld\n", CalType & 0xffff);
+ return E_FAIL;
+ case CAL_IYEAROFFSETRANGE:
+ FIXME("Unimplemented caltype %ld\n", CalType & 0xffff);
+ return E_FAIL;
+ case CAL_SERASTRING:
+ FIXME("Unimplemented caltype %ld\n", CalType & 0xffff);
+ return E_FAIL;
+ case CAL_SSHORTDATE:
+ return GetLocaleInfoW(Locale, LOCALE_SSHORTDATE, lpCalData, cchData);
+ case CAL_SLONGDATE:
+ return GetLocaleInfoW(Locale, LOCALE_SLONGDATE, lpCalData, cchData);
+ case CAL_SDAYNAME1:
+ return GetLocaleInfoW(Locale, LOCALE_SDAYNAME1, lpCalData, cchData);
+ case CAL_SDAYNAME2:
+ return GetLocaleInfoW(Locale, LOCALE_SDAYNAME2, lpCalData, cchData);
+ case CAL_SDAYNAME3:
+ return GetLocaleInfoW(Locale, LOCALE_SDAYNAME3, lpCalData, cchData);
+ case CAL_SDAYNAME4:
+ return GetLocaleInfoW(Locale, LOCALE_SDAYNAME4, lpCalData, cchData);
+ case CAL_SDAYNAME5:
+ return GetLocaleInfoW(Locale, LOCALE_SDAYNAME5, lpCalData, cchData);
+ case CAL_SDAYNAME6:
+ return GetLocaleInfoW(Locale, LOCALE_SDAYNAME6, lpCalData, cchData);
+ case CAL_SDAYNAME7:
+ return GetLocaleInfoW(Locale, LOCALE_SDAYNAME7, lpCalData, cchData);
+ case CAL_SABBREVDAYNAME1:
+ return GetLocaleInfoW(Locale, LOCALE_SABBREVDAYNAME1, lpCalData, cchData);
+ case CAL_SABBREVDAYNAME2:
+ return GetLocaleInfoW(Locale, LOCALE_SABBREVDAYNAME2, lpCalData, cchData);
+ case CAL_SABBREVDAYNAME3:
+ return GetLocaleInfoW(Locale, LOCALE_SABBREVDAYNAME3, lpCalData, cchData);
+ case CAL_SABBREVDAYNAME4:
+ return GetLocaleInfoW(Locale, LOCALE_SABBREVDAYNAME4, lpCalData, cchData);
+ case CAL_SABBREVDAYNAME5:
+ return GetLocaleInfoW(Locale, LOCALE_SABBREVDAYNAME5, lpCalData, cchData);
+ case CAL_SABBREVDAYNAME6:
+ return GetLocaleInfoW(Locale, LOCALE_SABBREVDAYNAME6, lpCalData, cchData);
+ case CAL_SABBREVDAYNAME7:
+ return GetLocaleInfoW(Locale, LOCALE_SABBREVDAYNAME7, lpCalData, cchData);
+ case CAL_SMONTHNAME1:
+ return GetLocaleInfoW(Locale, LOCALE_SMONTHNAME1, lpCalData, cchData);
+ case CAL_SMONTHNAME2:
+ return GetLocaleInfoW(Locale, LOCALE_SMONTHNAME2, lpCalData, cchData);
+ case CAL_SMONTHNAME3:
+ return GetLocaleInfoW(Locale, LOCALE_SMONTHNAME3, lpCalData, cchData);
+ case CAL_SMONTHNAME4:
+ return GetLocaleInfoW(Locale, LOCALE_SMONTHNAME4, lpCalData, cchData);
+ case CAL_SMONTHNAME5:
+ return GetLocaleInfoW(Locale, LOCALE_SMONTHNAME5, lpCalData, cchData);
+ case CAL_SMONTHNAME6:
+ return GetLocaleInfoW(Locale, LOCALE_SMONTHNAME6, lpCalData, cchData);
+ case CAL_SMONTHNAME7:
+ return GetLocaleInfoW(Locale, LOCALE_SMONTHNAME7, lpCalData, cchData);
+ case CAL_SMONTHNAME8:
+ return GetLocaleInfoW(Locale, LOCALE_SMONTHNAME8, lpCalData, cchData);
+ case CAL_SMONTHNAME9:
+ return GetLocaleInfoW(Locale, LOCALE_SMONTHNAME9, lpCalData, cchData);
+ case CAL_SMONTHNAME10:
+ return GetLocaleInfoW(Locale, LOCALE_SMONTHNAME10, lpCalData, cchData);
+ case CAL_SMONTHNAME11:
+ return GetLocaleInfoW(Locale, LOCALE_SMONTHNAME11, lpCalData, cchData);
+ case CAL_SMONTHNAME12:
+ return GetLocaleInfoW(Locale, LOCALE_SMONTHNAME12, lpCalData, cchData);
+ case CAL_SMONTHNAME13:
+ return GetLocaleInfoW(Locale, LOCALE_SMONTHNAME13, lpCalData, cchData);
+ case CAL_SABBREVMONTHNAME1:
+ return GetLocaleInfoW(Locale, LOCALE_SABBREVMONTHNAME1, lpCalData, cchData);
+ case CAL_SABBREVMONTHNAME2:
+ return GetLocaleInfoW(Locale, LOCALE_SABBREVMONTHNAME2, lpCalData, cchData);
+ case CAL_SABBREVMONTHNAME3:
+ return GetLocaleInfoW(Locale, LOCALE_SABBREVMONTHNAME3, lpCalData, cchData);
+ case CAL_SABBREVMONTHNAME4:
+ return GetLocaleInfoW(Locale, LOCALE_SABBREVMONTHNAME4, lpCalData, cchData);
+ case CAL_SABBREVMONTHNAME5:
+ return GetLocaleInfoW(Locale, LOCALE_SABBREVMONTHNAME5, lpCalData, cchData);
+ case CAL_SABBREVMONTHNAME6:
+ return GetLocaleInfoW(Locale, LOCALE_SABBREVMONTHNAME6, lpCalData, cchData);
+ case CAL_SABBREVMONTHNAME7:
+ return GetLocaleInfoW(Locale, LOCALE_SABBREVMONTHNAME7, lpCalData, cchData);
+ case CAL_SABBREVMONTHNAME8:
+ return GetLocaleInfoW(Locale, LOCALE_SABBREVMONTHNAME8, lpCalData, cchData);
+ case CAL_SABBREVMONTHNAME9:
+ return GetLocaleInfoW(Locale, LOCALE_SABBREVMONTHNAME9, lpCalData, cchData);
+ case CAL_SABBREVMONTHNAME10:
+ return GetLocaleInfoW(Locale, LOCALE_SABBREVMONTHNAME10, lpCalData, cchData);
+ case CAL_SABBREVMONTHNAME11:
+ return GetLocaleInfoW(Locale, LOCALE_SABBREVMONTHNAME11, lpCalData, cchData);
+ case CAL_SABBREVMONTHNAME12:
+ return GetLocaleInfoW(Locale, LOCALE_SABBREVMONTHNAME12, lpCalData, cchData);
+ case CAL_SABBREVMONTHNAME13:
+ return GetLocaleInfoW(Locale, LOCALE_SABBREVMONTHNAME13, lpCalData, cchData);
+ case CAL_SYEARMONTH:
+ return GetLocaleInfoW(Locale, LOCALE_SYEARMONTH, lpCalData, cchData);
+ case CAL_ITWODIGITYEARMAX:
+ FIXME("Unimplemented caltype %ld\n", CalType & 0xffff);
+ return E_FAIL;
+ default: MESSAGE("Unknown caltype %ld\n",CalType & 0xffff);
+ return E_FAIL;
+ }
return 0;
}
diff -urN wine/include/winnls.h-orig wine/include/winnls.h
--- wine/include/winnls.h-orig Sat Mar 9 19:02:34 2002
+++ wine/include/winnls.h Sat May 11 15:26:59 2002
@@ -37,11 +37,12 @@
/* flags to GetLocaleInfo */
#define LOCALE_NOUSEROVERRIDE 0x80000000
#define LOCALE_USE_CP_ACP 0x40000000
+#define LOCALE_RETURN_NUMBER 0x20000000
#define LOCALE_LOCALEINFOFLAGSMASK 0xC0000000
/* When adding new defines, don't forget to add an entry to the
- * locale2id map in misc/ole2nls.c
+ * locale_name2id map in ole/ole2nls.c
*/
#define LOCALE_ILANGUAGE 0x00000001
#define LOCALE_SLANGUAGE 0x00000002
@@ -265,6 +266,9 @@
#define MAX_DEFAULTCHAR 2
/* Defines for calendar handling */
+#define CAL_NOUSEROVERRIDE LOCALE_NOUSEROVERRIDE
+#define CAL_USE_CP_ACP LOCALE_USE_CP_ACP
+#define CAL_RETURN_NUMBER LOCALE_RETURN_NUMBER
#define CAL_ICALINTVALUE 0x00000001
#define CAL_SCALNAME 0x00000002
#define CAL_IYEAROFFSETRANGE 0x00000003
@@ -312,6 +316,7 @@
#define CAL_SABBREVMONTHNAME12 0x0000002d
#define CAL_SABBREVMONTHNAME13 0x0000002e
#define CAL_SYEARMONTH 0x0000002f
+#define CAL_ITWODIGITYEARMAX 0x00000030
#define CAL_GREGORIAN 1
#define CAL_GREGORIAN_US 2
#define CAL_JAPAN 3
@@ -490,6 +495,9 @@
BOOL WINAPI GetCPInfoExA(UINT,DWORD,LPCPINFOEXA);
BOOL WINAPI GetCPInfoExW(UINT,DWORD,LPCPINFOEXW);
#define GetCPInfoEx WINELIB_NAME_AW(GetCPInfoEx)
+int WINAPI GetCalendarInfoA(LCID,DWORD,DWORD,LPSTR,INT,LPDWORD);
+int WINAPI GetCalendarInfoW(LCID,DWORD,DWORD,LPWSTR,INT,LPDWORD);
+#define GetCalendarInfo WINELIB_NAME_AW(GetCalendarInfo)
INT WINAPI GetCurrencyFormatA(LCID,DWORD,LPCSTR,const CURRENCYFMTA*,LPSTR,int);
INT WINAPI GetCurrencyFormatW(LCID,DWORD,LPCWSTR,const CURRENCYFMTW*,LPWSTR,int);
#define GetCurrencyFormat WINELIB_NAME_AW(GetCurrencyFormat)
More information about the wine-patches
mailing list