Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-cw
Commits
6cd0eb20
Commit
6cd0eb20
authored
Dec 24, 2014
by
Seán de Búrca
Committed by
Alexandre Julliard
Jan 06, 2015
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
kernel32: Implement Get{Time,Date}FormatEx.
parent
adc091b8
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
377 additions
and
2 deletions
+377
-2
api-ms-win-core-datetime-l1-1-1.spec
...core-datetime-l1-1-1/api-ms-win-core-datetime-l1-1-1.spec
+2
-2
kernel32.spec
dlls/kernel32/kernel32.spec
+2
-0
lcformat.c
dlls/kernel32/lcformat.c
+71
-0
locale.c
dlls/kernel32/tests/locale.c
+300
-0
winnls.h
include/winnls.h
+2
-0
No files found.
dlls/api-ms-win-core-datetime-l1-1-1/api-ms-win-core-datetime-l1-1-1.spec
View file @
6cd0eb20
@ stdcall GetDateFormatA(long long ptr str ptr long) kernel32.GetDateFormatA
@ st
ub
GetDateFormatEx
@ st
dcall GetDateFormatEx(wstr long ptr wstr ptr long wstr) kernel32.
GetDateFormatEx
@ stdcall GetDateFormatW(long long ptr wstr ptr long) kernel32.GetDateFormatW
@ stdcall GetTimeFormatA(long long ptr str ptr long) kernel32.GetTimeFormatA
@ st
ub
GetTimeFormatEx
@ st
dcall GetTimeFormatEx(wstr long ptr wstr ptr long) kernel32.
GetTimeFormatEx
@ stdcall GetTimeFormatW(long long ptr wstr ptr long) kernel32.GetTimeFormatW
dlls/kernel32/kernel32.spec
View file @
6cd0eb20
...
...
@@ -510,6 +510,7 @@
@ stdcall -norelay GetCurrentThread()
@ stdcall -norelay GetCurrentThreadId()
@ stdcall GetDateFormatA(long long ptr str ptr long)
@ stdcall GetDateFormatEx(wstr long ptr wstr ptr long wstr)
@ stdcall GetDateFormatW(long long ptr wstr ptr long)
@ stdcall GetDaylightFlag()
@ stdcall GetDefaultCommConfigA(str ptr long)
...
...
@@ -680,6 +681,7 @@
@ stdcall GetTickCount()
@ stdcall -ret64 GetTickCount64()
@ stdcall GetTimeFormatA(long long ptr str ptr long)
@ stdcall GetTimeFormatEx(wstr long ptr wstr ptr long)
@ stdcall GetTimeFormatW(long long ptr wstr ptr long)
@ stdcall GetTimeZoneInformation(ptr)
@ stdcall GetThreadUILanguage()
...
...
dlls/kernel32/lcformat.c
View file @
6cd0eb20
...
...
@@ -846,6 +846,45 @@ INT WINAPI GetDateFormatA( LCID lcid, DWORD dwFlags, const SYSTEMTIME* lpTime,
lpFormat
,
lpDateStr
,
cchOut
);
}
/******************************************************************************
* GetDateFormatEx [KERNEL32.@]
*
* Format a date for a given locale.
*
* PARAMS
* localename [I] Locale to format for
* flags [I] LOCALE_ and DATE_ flags from "winnls.h"
* date [I] Date to format
* format [I] Format string, or NULL to use the locale defaults
* outbuf [O] Destination for formatted string
* bufsize [I] Size of outbuf, or 0 to calculate the resulting size
* calendar [I] Reserved, must be NULL
*
* See GetDateFormatA for notes.
*
* RETURNS
* Success: The number of characters written to outbuf, or that would have
* been written if bufsize is 0.
* Failure: 0. Use GetLastError() to determine the cause.
*/
INT
WINAPI
GetDateFormatEx
(
LPCWSTR
localename
,
DWORD
flags
,
const
SYSTEMTIME
*
date
,
LPCWSTR
format
,
LPWSTR
outbuf
,
INT
bufsize
,
LPCWSTR
calendar
)
{
TRACE
(
"(%s,0x%08x,%p,%s,%p,%d,%s)
\n
"
,
debugstr_w
(
localename
),
flags
,
date
,
debugstr_w
(
format
),
outbuf
,
bufsize
,
debugstr_w
(
calendar
));
/* Parameter is currently reserved and Windows errors if set */
if
(
calendar
!=
NULL
)
{
SetLastError
(
ERROR_INVALID_PARAMETER
);
return
0
;
}
return
NLS_GetDateTimeFormatW
(
LocaleNameToLCID
(
localename
,
0
),
flags
|
DATE_DATEVARSONLY
,
date
,
format
,
outbuf
,
bufsize
);
}
/******************************************************************************
* GetDateFormatW [KERNEL32.@]
...
...
@@ -914,6 +953,38 @@ INT WINAPI GetTimeFormatA(LCID lcid, DWORD dwFlags, const SYSTEMTIME* lpTime,
}
/******************************************************************************
* GetTimeFormatEx [KERNEL32.@]
*
* Format a date for a given locale.
*
* PARAMS
* localename [I] Locale to format for
* flags [I] LOCALE_ and TIME_ flags from "winnls.h"
* time [I] Time to format
* format [I] Formatting overrides
* outbuf [O] Destination for formatted string
* bufsize [I] Size of outbuf, or 0 to calculate the resulting size
*
* See GetTimeFormatA for notes.
*
* RETURNS
* Success: The number of characters written to outbuf, or that would have
* have been written if bufsize is 0.
* Failure: 0. Use GetLastError() to determine the cause.
*/
INT
WINAPI
GetTimeFormatEx
(
LPCWSTR
localename
,
DWORD
flags
,
const
SYSTEMTIME
*
time
,
LPCWSTR
format
,
LPWSTR
outbuf
,
INT
bufsize
)
{
TRACE
(
"(%s,0x%08x,%p,%s,%p,%d)
\n
"
,
debugstr_w
(
localename
),
flags
,
time
,
debugstr_w
(
format
),
outbuf
,
bufsize
);
return
NLS_GetDateTimeFormatW
(
LocaleNameToLCID
(
localename
,
0
),
flags
|
TIME_TIMEVARSONLY
,
time
,
format
,
outbuf
,
bufsize
);
}
/******************************************************************************
* GetTimeFormatW [KERNEL32.@]
*
* See GetTimeFormatA.
...
...
dlls/kernel32/tests/locale.c
View file @
6cd0eb20
...
...
@@ -39,7 +39,9 @@
static
const
WCHAR
upper_case
[]
=
{
'\t'
,
'J'
,
'U'
,
'S'
,
'T'
,
'!'
,
' '
,
'A'
,
','
,
' '
,
'T'
,
'E'
,
'S'
,
'T'
,
';'
,
' '
,
'S'
,
'T'
,
'R'
,
'I'
,
'N'
,
'G'
,
' '
,
'1'
,
'/'
,
'*'
,
'+'
,
'-'
,
'.'
,
'\r'
,
'\n'
,
0
};
static
const
WCHAR
lower_case
[]
=
{
'\t'
,
'j'
,
'u'
,
's'
,
't'
,
'!'
,
' '
,
'a'
,
','
,
' '
,
't'
,
'e'
,
's'
,
't'
,
';'
,
' '
,
's'
,
't'
,
'r'
,
'i'
,
'n'
,
'g'
,
' '
,
'1'
,
'/'
,
'*'
,
'+'
,
'-'
,
'.'
,
'\r'
,
'\n'
,
0
};
static
const
WCHAR
symbols_stripped
[]
=
{
'j'
,
'u'
,
's'
,
't'
,
'a'
,
't'
,
'e'
,
's'
,
't'
,
's'
,
't'
,
'r'
,
'i'
,
'n'
,
'g'
,
'1'
,
0
};
static
const
WCHAR
localeW
[]
=
{
'e'
,
'n'
,
'-'
,
'U'
,
'S'
,
0
};
static
const
WCHAR
fooW
[]
=
{
'f'
,
'o'
,
'o'
,
0
};
static
const
WCHAR
emptyW
[]
=
{
0
};
static
inline
unsigned
int
strlenW
(
const
WCHAR
*
str
)
{
...
...
@@ -72,6 +74,8 @@ static inline BOOL isdigitW( WCHAR wc )
static
HMODULE
hKernel32
;
static
WORD
enumCount
;
static
INT
(
WINAPI
*
pGetTimeFormatEx
)(
LPCWSTR
,
DWORD
,
const
SYSTEMTIME
*
,
LPCWSTR
,
LPWSTR
,
INT
);
static
INT
(
WINAPI
*
pGetDateFormatEx
)(
LPCWSTR
,
DWORD
,
const
SYSTEMTIME
*
,
LPCWSTR
,
LPWSTR
,
INT
,
LPCWSTR
);
static
BOOL
(
WINAPI
*
pEnumSystemLanguageGroupsA
)(
LANGUAGEGROUP_ENUMPROCA
,
DWORD
,
LONG_PTR
);
static
BOOL
(
WINAPI
*
pEnumLanguageGroupLocalesA
)(
LANGGROUPLOCALE_ENUMPROCA
,
LGRPID
,
DWORD
,
LONG_PTR
);
static
BOOL
(
WINAPI
*
pEnumUILanguagesA
)(
UILANGUAGE_ENUMPROCA
,
DWORD
,
LONG_PTR
);
...
...
@@ -99,6 +103,8 @@ static void InitFunctionPointers(void)
hKernel32
=
GetModuleHandleA
(
"kernel32"
);
#define X(f) p##f = (void*)GetProcAddress(hKernel32, #f)
X
(
GetTimeFormatEx
);
X
(
GetDateFormatEx
);
X
(
EnumSystemLanguageGroupsA
);
X
(
EnumLanguageGroupLocalesA
);
X
(
LocaleNameToLCID
);
...
...
@@ -612,6 +618,202 @@ static void test_GetTimeFormatA(void)
EXPECT_LENA
;
EXPECT_EQA
;
}
static
void
test_GetTimeFormatEx
(
void
)
{
int
ret
;
SYSTEMTIME
curtime
;
WCHAR
buffer
[
BUFFER_SIZE
],
input
[
BUFFER_SIZE
],
Expected
[
BUFFER_SIZE
];
if
(
!
pGetTimeFormatEx
)
{
win_skip
(
"GetTimeFormatEx not supported
\n
"
);
return
;
}
memset
(
&
curtime
,
2
,
sizeof
(
SYSTEMTIME
));
STRINGSW
(
"tt HH':'mm'@'ss"
,
""
);
/* Invalid time */
SetLastError
(
0xdeadbeef
);
ret
=
pGetTimeFormatEx
(
localeW
,
TIME_FORCE24HOURFORMAT
,
&
curtime
,
input
,
buffer
,
COUNTOF
(
buffer
));
ok
(
!
ret
&&
GetLastError
()
==
ERROR_INVALID_PARAMETER
,
"Expected ERROR_INVALID_PARAMETER, got %d
\n
"
,
GetLastError
());
curtime
.
wHour
=
8
;
curtime
.
wMinute
=
56
;
curtime
.
wSecond
=
13
;
curtime
.
wMilliseconds
=
22
;
STRINGSW
(
"tt HH':'mm'@'ss"
,
"AM 08:56@13"
);
/* Valid time */
SetLastError
(
0xdeadbeef
);
ret
=
pGetTimeFormatEx
(
localeW
,
TIME_FORCE24HOURFORMAT
,
&
curtime
,
input
,
buffer
,
COUNTOF
(
buffer
));
ok
(
ret
,
"Expected ret != 0, got %d, error %d
\n
"
,
ret
,
GetLastError
());
EXPECT_LENW
;
EXPECT_EQW
;
/* MSDN: LOCALE_NOUSEROVERRIDE can't be specified with a format string */
SetLastError
(
0xdeadbeef
);
ret
=
pGetTimeFormatEx
(
localeW
,
NUO
|
TIME_FORCE24HOURFORMAT
,
&
curtime
,
input
,
buffer
,
COUNTOF
(
buffer
));
ok
(
!
ret
&&
GetLastError
()
==
ERROR_INVALID_FLAGS
,
"Expected ERROR_INVALID_FLAGS, got %d
\n
"
,
GetLastError
());
STRINGSW
(
"tt HH':'mm'@'ss"
,
"A"
);
/* Insufficient buffer */
SetLastError
(
0xdeadbeef
);
ret
=
pGetTimeFormatEx
(
localeW
,
TIME_FORCE24HOURFORMAT
,
&
curtime
,
input
,
buffer
,
2
);
ok
(
!
ret
&&
GetLastError
()
==
ERROR_INSUFFICIENT_BUFFER
,
"Expected ERROR_INSUFFICIENT_BUFFER, got %d
\n
"
,
GetLastError
());
STRINGSW
(
"tt HH':'mm'@'ss"
,
"AM 08:56@13"
);
/* Calculate length only */
ret
=
pGetTimeFormatEx
(
localeW
,
TIME_FORCE24HOURFORMAT
,
&
curtime
,
input
,
NULL
,
0
);
ok
(
ret
,
"Expected ret != 0, got %d, error %d
\n
"
,
ret
,
GetLastError
());
EXPECT_LENW
;
STRINGSW
(
""
,
"8 AM"
);
/* TIME_NOMINUTESORSECONDS, default format */
ret
=
pGetTimeFormatEx
(
localeW
,
NUO
|
TIME_NOMINUTESORSECONDS
,
&
curtime
,
NULL
,
buffer
,
COUNTOF
(
buffer
));
ok
(
ret
,
"Expected ret != 0, got %d, error %d
\n
"
,
ret
,
GetLastError
());
EXPECT_LENW
;
EXPECT_EQW
;
STRINGSW
(
"m1s2m3s4"
,
""
);
/* TIME_NOMINUTESORSECONDS/complex format */
ret
=
pGetTimeFormatEx
(
localeW
,
TIME_NOMINUTESORSECONDS
,
&
curtime
,
input
,
buffer
,
COUNTOF
(
buffer
));
ok
(
ret
==
strlenW
(
buffer
)
+
1
,
"Expected ret != 0, got %d, error %d
\n
"
,
ret
,
GetLastError
());
EXPECT_LENW
;
EXPECT_EQW
;
STRINGSW
(
""
,
"8:56 AM"
);
/* TIME_NOSECONDS/Default format */
ret
=
pGetTimeFormatEx
(
localeW
,
NUO
|
TIME_NOSECONDS
,
&
curtime
,
NULL
,
buffer
,
COUNTOF
(
buffer
));
ok
(
ret
,
"Expected ret != 0, got %d, error %d
\n
"
,
ret
,
GetLastError
());
EXPECT_LENW
;
EXPECT_EQW
;
STRINGSW
(
"h:m:s tt"
,
"8:56 AM"
);
/* TIME_NOSECONDS */
ret
=
pGetTimeFormatEx
(
localeW
,
TIME_NOSECONDS
,
&
curtime
,
input
,
buffer
,
COUNTOF
(
buffer
));
ok
(
ret
,
"Expected ret != 0, got %d, error %d
\n
"
,
ret
,
GetLastError
());
EXPECT_LENW
;
EXPECT_EQW
;
STRINGSW
(
"h.@:m.@:s.@:tt"
,
"8.@:56AM"
);
/* Multiple delimiters */
ret
=
pGetTimeFormatEx
(
localeW
,
TIME_NOSECONDS
,
&
curtime
,
input
,
buffer
,
COUNTOF
(
buffer
));
ok
(
ret
,
"Expected ret != 0, got %d, error %d
\n
"
,
ret
,
GetLastError
());
EXPECT_LENW
;
EXPECT_EQW
;
STRINGSW
(
"s1s2s3"
,
""
);
/* Duplicate tokens */
ret
=
pGetTimeFormatEx
(
localeW
,
TIME_NOSECONDS
,
&
curtime
,
input
,
buffer
,
COUNTOF
(
buffer
));
ok
(
ret
==
strlenW
(
buffer
)
+
1
,
"Expected ret != 0, got %d, error %d
\n
"
,
ret
,
GetLastError
());
EXPECT_LENW
;
EXPECT_EQW
;
STRINGSW
(
"t/tt"
,
"A/AM"
);
/* AM time marker */
ret
=
pGetTimeFormatEx
(
localeW
,
0
,
&
curtime
,
input
,
buffer
,
COUNTOF
(
buffer
));
ok
(
ret
,
"Expected ret != 0, got %d, error %d
\n
"
,
ret
,
GetLastError
());
EXPECT_LENW
;
EXPECT_EQW
;
curtime
.
wHour
=
13
;
STRINGSW
(
"t/tt"
,
"P/PM"
);
/* PM time marker */
ret
=
pGetTimeFormatEx
(
localeW
,
0
,
&
curtime
,
input
,
buffer
,
COUNTOF
(
buffer
));
ok
(
ret
,
"Expected ret != 0, got %d, error %d
\n
"
,
ret
,
GetLastError
());
EXPECT_LENW
;
EXPECT_EQW
;
STRINGSW
(
"h1t2tt3m"
,
"156"
);
/* TIME_NOTIMEMARKER: removes text around time marker token */
ret
=
pGetTimeFormatEx
(
localeW
,
TIME_NOTIMEMARKER
,
&
curtime
,
input
,
buffer
,
COUNTOF
(
buffer
));
ok
(
ret
,
"Expected ret != 0, got %d, error %d
\n
"
,
ret
,
GetLastError
());
EXPECT_LENW
;
EXPECT_EQW
;
STRINGSW
(
"h:m:s tt"
,
"13:56:13 PM"
);
/* TIME_FORCE24HOURFORMAT */
ret
=
pGetTimeFormatEx
(
localeW
,
TIME_FORCE24HOURFORMAT
,
&
curtime
,
input
,
buffer
,
COUNTOF
(
buffer
));
ok
(
ret
,
"Expected ret != 0, got %d, error %d
\n
"
,
ret
,
GetLastError
());
EXPECT_LENW
;
EXPECT_EQW
;
STRINGSW
(
"h:m:s"
,
"13:56:13"
);
/* TIME_FORCE24HOURFORMAT doesn't add time marker */
ret
=
pGetTimeFormatEx
(
localeW
,
TIME_FORCE24HOURFORMAT
,
&
curtime
,
input
,
buffer
,
COUNTOF
(
buffer
));
ok
(
ret
,
"Expected ret != 0, got %d, error %d
\n
"
,
ret
,
GetLastError
());
EXPECT_LENW
;
EXPECT_EQW
;
curtime
.
wHour
=
14
;
/* change this to 14 or 2pm */
curtime
.
wMinute
=
5
;
curtime
.
wSecond
=
3
;
STRINGSW
(
"h hh H HH m mm s ss t tt"
,
"2 02 14 14 5 05 3 03 P PM"
);
/* 24 hrs, leading 0 */
ret
=
pGetTimeFormatEx
(
localeW
,
0
,
&
curtime
,
input
,
buffer
,
COUNTOF
(
buffer
));
ok
(
ret
,
"Expected ret != 0, got %d, error %d
\n
"
,
ret
,
GetLastError
());
EXPECT_LENW
;
EXPECT_EQW
;
curtime
.
wHour
=
0
;
STRINGSW
(
"h/H/hh/HH"
,
"12/0/12/00"
);
/* "hh" and "HH" */
ret
=
pGetTimeFormatEx
(
localeW
,
0
,
&
curtime
,
input
,
buffer
,
COUNTOF
(
buffer
));
ok
(
ret
,
"Expected ret != 0, got %d, error %d
\n
"
,
ret
,
GetLastError
());
EXPECT_LENW
;
EXPECT_EQW
;
STRINGSW
(
"h:m:s tt"
,
"12:5:3 AM"
);
/* non-zero flags should fail with format, doesn't */
ret
=
pGetTimeFormatEx
(
localeW
,
0
,
&
curtime
,
input
,
buffer
,
COUNTOF
(
buffer
));
ok
(
ret
,
"Expected ret != 0, got %d, error %d
\n
"
,
ret
,
GetLastError
());
EXPECT_LENW
;
EXPECT_EQW
;
/* try to convert formatting strings with more than two letters
* "h:hh:hhh:H:HH:HHH:m:mm:mmm:M:MM:MMM:s:ss:sss:S:SS:SSS"
* NOTE: We expect any letter for which there is an upper case value
* we should see a replacement. For letters that DO NOT have
* upper case values we should see NO REPLACEMENT.
*/
curtime
.
wHour
=
8
;
curtime
.
wMinute
=
56
;
curtime
.
wSecond
=
13
;
curtime
.
wMilliseconds
=
22
;
STRINGSW
(
"h:hh:hhh H:HH:HHH m:mm:mmm M:MM:MMM s:ss:sss S:SS:SSS"
,
"8:08:08 8:08:08 56:56:56 M:MM:MMM 13:13:13 S:SS:SSS"
);
ret
=
pGetTimeFormatEx
(
localeW
,
0
,
&
curtime
,
input
,
buffer
,
COUNTOF
(
buffer
));
ok
(
ret
,
"Expected ret != 0, got %d, error %d
\n
"
,
ret
,
GetLastError
());
EXPECT_LENW
;
EXPECT_EQW
;
STRINGSW
(
"h"
,
"text"
);
/* Don't write to buffer if len is 0 */
lstrcpyW
(
buffer
,
Expected
);
ret
=
pGetTimeFormatEx
(
localeW
,
0
,
&
curtime
,
input
,
buffer
,
0
);
ok
(
ret
==
2
,
"Expected ret == 2, got %d, error %d
\n
"
,
ret
,
GetLastError
());
EXPECT_EQW
;
STRINGSW
(
"h 'h' H 'H' HH 'HH' m 'm' s 's' t 't' tt 'tt'"
,
"8 h 8 H 08 HH 56 m 13 s A t AM tt"
);
/* "'" preserves tokens */
ret
=
pGetTimeFormatEx
(
localeW
,
0
,
&
curtime
,
input
,
buffer
,
COUNTOF
(
buffer
));
ok
(
ret
,
"Expected ret != 0, got %d, error %d
\n
"
,
ret
,
GetLastError
());
EXPECT_LENW
;
EXPECT_EQW
;
STRINGSW
(
"'''"
,
"'"
);
/* invalid quoted string */
ret
=
pGetTimeFormatEx
(
localeW
,
0
,
&
curtime
,
input
,
buffer
,
COUNTOF
(
buffer
));
ok
(
ret
,
"Expected ret != 0, got %d, error %d
\n
"
,
ret
,
GetLastError
());
EXPECT_LENW
;
EXPECT_EQW
;
/* test that msdn suggested single quotation usage works as expected */
STRINGSW
(
"''''"
,
"'"
);
/* single quote mark */
ret
=
pGetTimeFormatEx
(
localeW
,
0
,
&
curtime
,
input
,
buffer
,
COUNTOF
(
buffer
));
ok
(
ret
,
"Expected ret != 0, got %d, error %d
\n
"
,
ret
,
GetLastError
());
EXPECT_LENW
;
EXPECT_EQW
;
STRINGSW
(
"''HHHHHH"
,
"08"
);
/* Normal use */
ret
=
pGetTimeFormatEx
(
localeW
,
0
,
&
curtime
,
input
,
buffer
,
COUNTOF
(
buffer
));
ok
(
ret
,
"Expected ret != 0, got %d, error %d
\n
"
,
ret
,
GetLastError
());
EXPECT_LENW
;
EXPECT_EQW
;
/* and test for normal use of the single quotation mark */
STRINGSW
(
"'''HHHHHH'"
,
"'HHHHHH"
);
/* Normal use */
ret
=
pGetTimeFormatEx
(
localeW
,
0
,
&
curtime
,
input
,
buffer
,
COUNTOF
(
buffer
));
ok
(
ret
,
"Expected ret != 0, got %d, error %d
\n
"
,
ret
,
GetLastError
());
EXPECT_LENW
;
EXPECT_EQW
;
STRINGSW
(
"'''HHHHHH"
,
"'HHHHHH"
);
/* Odd use */
ret
=
pGetTimeFormatEx
(
localeW
,
0
,
&
curtime
,
input
,
buffer
,
COUNTOF
(
buffer
));
ok
(
ret
,
"Expected ret != 0, got %d, error %d
\n
"
,
ret
,
GetLastError
());
EXPECT_LENW
;
EXPECT_EQW
;
STRINGSW
(
"'123'tt"
,
""
);
/* TIME_NOTIMEMARKER drops literals too */
ret
=
pGetTimeFormatEx
(
localeW
,
TIME_NOTIMEMARKER
,
&
curtime
,
input
,
buffer
,
COUNTOF
(
buffer
));
ok
(
ret
,
"Expected ret != 0, got %d, error %d
\n
"
,
ret
,
GetLastError
());
EXPECT_LENW
;
EXPECT_EQW
;
curtime
.
wHour
=
25
;
STRINGSW
(
"'123'tt"
,
""
);
/* Invalid time */
SetLastError
(
0xdeadbeef
);
ret
=
pGetTimeFormatEx
(
localeW
,
0
,
&
curtime
,
input
,
buffer
,
COUNTOF
(
buffer
));
ok
(
!
ret
&&
GetLastError
()
==
ERROR_INVALID_PARAMETER
,
"Expected ERROR_INVALID_PARAMETER, got %d
\n
"
,
GetLastError
());
curtime
.
wHour
=
12
;
curtime
.
wMonth
=
60
;
/* Invalid */
STRINGSW
(
"h:m:s"
,
"12:56:13"
);
/* Invalid date */
ret
=
pGetTimeFormatEx
(
localeW
,
0
,
&
curtime
,
input
,
buffer
,
COUNTOF
(
buffer
));
ok
(
ret
,
"Expected ret != 0, got %d, error %d
\n
"
,
ret
,
GetLastError
());
EXPECT_LENW
;
EXPECT_EQW
;
}
static
void
test_GetDateFormatA
(
void
)
{
int
ret
;
...
...
@@ -779,6 +981,102 @@ static void test_GetDateFormatA(void)
"Expected '%s', got '%s'
\n
"
,
Expected
,
buffer
);
}
static
void
test_GetDateFormatEx
(
void
)
{
int
ret
;
SYSTEMTIME
curtime
;
WCHAR
buffer
[
BUFFER_SIZE
],
input
[
BUFFER_SIZE
],
Expected
[
BUFFER_SIZE
];
if
(
!
pGetDateFormatEx
)
{
win_skip
(
"GetDateFormatEx not supported
\n
"
);
return
;
}
STRINGSW
(
""
,
""
);
/* If flags are set, then format must be NULL */
SetLastError
(
0xdeadbeef
);
ret
=
pGetDateFormatEx
(
localeW
,
DATE_LONGDATE
,
NULL
,
input
,
buffer
,
COUNTOF
(
buffer
),
NULL
);
ok
(
!
ret
&&
GetLastError
()
==
ERROR_INVALID_FLAGS
,
"Expected ERROR_INVALID_FLAGS, got %d
\n
"
,
GetLastError
());
EXPECT_EQW
;
STRINGSW
(
""
,
""
);
/* NULL buffer, len > 0 */
SetLastError
(
0xdeadbeef
);
ret
=
pGetDateFormatEx
(
localeW
,
0
,
NULL
,
input
,
NULL
,
COUNTOF
(
buffer
),
NULL
);
ok
(
!
ret
&&
GetLastError
()
==
ERROR_INVALID_PARAMETER
,
"Expected ERROR_INVALID_PARAMETER, got %d
\n
"
,
GetLastError
());
STRINGSW
(
""
,
""
);
/* NULL buffer, len == 0 */
ret
=
pGetDateFormatEx
(
localeW
,
0
,
NULL
,
input
,
NULL
,
0
,
NULL
);
ok
(
ret
,
"Expected ret != 0, got %d, error %d
\n
"
,
ret
,
GetLastError
());
EXPECT_LENW
;
EXPECT_EQW
;
STRINGSW
(
""
,
""
);
/* Invalid flag combination */
SetLastError
(
0xdeadbeef
);
ret
=
pGetDateFormatEx
(
localeW
,
DATE_LONGDATE
|
DATE_SHORTDATE
,
NULL
,
input
,
NULL
,
0
,
NULL
);
ok
(
!
ret
&&
GetLastError
()
==
ERROR_INVALID_FLAGS
,
"Expected ERROR_INVALID_FLAGS, got %d
\n
"
,
GetLastError
());
EXPECT_EQW
;
curtime
.
wYear
=
2002
;
curtime
.
wMonth
=
10
;
curtime
.
wDay
=
23
;
curtime
.
wDayOfWeek
=
45612
;
/* Should be 3 - Wednesday */
curtime
.
wHour
=
65432
;
/* Invalid */
curtime
.
wMinute
=
34512
;
/* Invalid */
curtime
.
wSecond
=
65535
;
/* Invalid */
curtime
.
wMilliseconds
=
12345
;
STRINGSW
(
"dddd d MMMM yyyy"
,
"Wednesday 23 October 2002"
);
/* Incorrect DOW and time */
ret
=
pGetDateFormatEx
(
localeW
,
0
,
&
curtime
,
input
,
buffer
,
COUNTOF
(
buffer
),
NULL
);
ok
(
ret
,
"Expected ret != 0, got %d, error %d
\n
"
,
ret
,
GetLastError
());
EXPECT_LENW
;
EXPECT_EQW
;
curtime
.
wYear
=
2002
;
curtime
.
wMonth
=
10
;
curtime
.
wDay
=
23
;
curtime
.
wDayOfWeek
=
45612
;
/* Should be 3 - Wednesday */
curtime
.
wHour
=
65432
;
/* Invalid */
curtime
.
wMinute
=
34512
;
/* Invalid */
curtime
.
wSecond
=
65535
;
/* Invalid */
curtime
.
wMilliseconds
=
12345
;
STRINGSW
(
"dddd d MMMM yyyy"
,
"Wednesday 23 October 2002"
);
ret
=
pGetDateFormatEx
(
localeW
,
0
,
&
curtime
,
input
,
buffer
,
COUNTOF
(
buffer
),
emptyW
);
/* Use reserved arg */
ok
(
!
ret
&&
GetLastError
()
==
ERROR_INVALID_PARAMETER
,
"Expected ERROR_INVALID_PARAMETER, got %d
\n
"
,
GetLastError
());
/* Limit tests */
curtime
.
wYear
=
1601
;
curtime
.
wMonth
=
1
;
curtime
.
wDay
=
1
;
curtime
.
wDayOfWeek
=
0
;
/* Irrelevant */
curtime
.
wHour
=
0
;
curtime
.
wMinute
=
0
;
curtime
.
wSecond
=
0
;
curtime
.
wMilliseconds
=
0
;
STRINGSW
(
"dddd d MMMM yyyy"
,
"Monday 1 January 1601"
);
SetLastError
(
0xdeadbeef
);
ret
=
pGetDateFormatEx
(
localeW
,
0
,
&
curtime
,
input
,
buffer
,
COUNTOF
(
buffer
),
NULL
);
ok
(
ret
,
"Expected ret != 0, got %d, error %d
\n
"
,
ret
,
GetLastError
());
EXPECT_LENW
;
EXPECT_EQW
;
curtime
.
wYear
=
1600
;
curtime
.
wMonth
=
12
;
curtime
.
wDay
=
31
;
curtime
.
wDayOfWeek
=
0
;
/* Irrelevant */
curtime
.
wHour
=
23
;
curtime
.
wMinute
=
59
;
curtime
.
wSecond
=
59
;
curtime
.
wMilliseconds
=
999
;
STRINGSW
(
"dddd d MMMM yyyy"
,
"Friday 31 December 1600"
);
SetLastError
(
0xdeadbeef
);
ret
=
pGetDateFormatEx
(
localeW
,
0
,
&
curtime
,
input
,
buffer
,
COUNTOF
(
buffer
),
NULL
);
ok
(
!
ret
&&
GetLastError
()
==
ERROR_INVALID_PARAMETER
,
"Expected ERROR_INVALID_PARAMETER, got %d
\n
"
,
GetLastError
());
}
static
void
test_GetDateFormatW
(
void
)
{
int
ret
;
...
...
@@ -4003,7 +4301,9 @@ START_TEST(locale)
test_GetLocaleInfoW
();
test_GetLocaleInfoEx
();
test_GetTimeFormatA
();
test_GetTimeFormatEx
();
test_GetDateFormatA
();
test_GetDateFormatEx
();
test_GetDateFormatW
();
test_GetCurrencyFormatA
();
/* Also tests the W version */
test_GetNumberFormatA
();
/* Also tests the W version */
...
...
include/winnls.h
View file @
6cd0eb20
...
...
@@ -827,6 +827,7 @@ WINBASEAPI INT WINAPI GetCurrencyFormatA(LCID,DWORD,LPCSTR,const CURRENC
WINBASEAPI
INT
WINAPI
GetCurrencyFormatW
(
LCID
,
DWORD
,
LPCWSTR
,
const
CURRENCYFMTW
*
,
LPWSTR
,
INT
);
#define GetCurrencyFormat WINELIB_NAME_AW(GetCurrencyFormat)
WINBASEAPI
INT
WINAPI
GetDateFormatA
(
LCID
,
DWORD
,
const
SYSTEMTIME
*
,
LPCSTR
,
LPSTR
,
INT
);
WINBASEAPI
INT
WINAPI
GetDateFormatEx
(
LPCWSTR
,
DWORD
,
const
SYSTEMTIME
*
,
LPCWSTR
,
LPWSTR
,
INT
,
LPCWSTR
);
WINBASEAPI
INT
WINAPI
GetDateFormatW
(
LCID
,
DWORD
,
const
SYSTEMTIME
*
,
LPCWSTR
,
LPWSTR
,
INT
);
#define GetDateFormat WINELIB_NAME_AW(GetDateFormat)
WINBASEAPI
INT
WINAPI
GetGeoInfoA
(
GEOID
,
GEOTYPE
,
LPSTR
,
INT
,
LANGID
);
...
...
@@ -850,6 +851,7 @@ WINBASEAPI LCID WINAPI GetSystemDefaultLCID(void);
WINBASEAPI
LANGID
WINAPI
GetSystemDefaultUILanguage
(
void
);
WINBASEAPI
LCID
WINAPI
GetThreadLocale
(
void
);
WINBASEAPI
INT
WINAPI
GetTimeFormatA
(
LCID
,
DWORD
,
const
SYSTEMTIME
*
,
LPCSTR
,
LPSTR
,
INT
);
WINBASEAPI
INT
WINAPI
GetTimeFormatEx
(
LPCWSTR
,
DWORD
,
const
SYSTEMTIME
*
,
LPCWSTR
,
LPWSTR
,
INT
);
WINBASEAPI
INT
WINAPI
GetTimeFormatW
(
LCID
,
DWORD
,
const
SYSTEMTIME
*
,
LPCWSTR
,
LPWSTR
,
INT
);
#define GetTimeFormat WINELIB_NAME_AW(GetTimeFormat)
WINBASEAPI
LANGID
WINAPI
GetUserDefaultLangID
(
void
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment