mirror of
https://github.com/reactos/reactos.git
synced 2025-06-25 18:39:46 +00:00
[NTDLL_APITEST][LIB_RTL] Add a test for RtlQueryTimeZoneInformation and fix the bug in RtlpQueryRegistryDirect
In working on some problems with Time Zone adjustments in ReactOS I found that the RtlQueryTimeZoneInformation function is partially broken and wrote an apitest to capture the failures. Patch by Doug Lyons. CORE-14658
This commit is contained in:
parent
528e6339c2
commit
0f8e720711
3 changed files with 20 additions and 9 deletions
|
@ -49,6 +49,7 @@ list(APPEND SOURCE
|
|||
RtlMemoryStream.c
|
||||
RtlNtPathNameToDosPathName.c
|
||||
RtlpEnsureBufferSize.c
|
||||
RtlQueryTimeZoneInfo.c
|
||||
RtlReAllocateHeap.c
|
||||
RtlUnicodeStringToAnsiString.c
|
||||
RtlUpcaseUnicodeStringToCountedOemString.c
|
||||
|
|
|
@ -53,6 +53,7 @@ extern void func_RtlIsNameLegalDOS8Dot3(void);
|
|||
extern void func_RtlMemoryStream(void);
|
||||
extern void func_RtlNtPathNameToDosPathName(void);
|
||||
extern void func_RtlpEnsureBufferSize(void);
|
||||
extern void func_RtlQueryTimeZoneInformation(void);
|
||||
extern void func_RtlReAllocateHeap(void);
|
||||
extern void func_RtlUnicodeStringToAnsiString(void);
|
||||
extern void func_RtlUpcaseUnicodeStringToCountedOemString(void);
|
||||
|
@ -111,6 +112,7 @@ const struct test winetest_testlist[] =
|
|||
{ "RtlMemoryStream", func_RtlMemoryStream },
|
||||
{ "RtlNtPathNameToDosPathName", func_RtlNtPathNameToDosPathName },
|
||||
{ "RtlpEnsureBufferSize", func_RtlpEnsureBufferSize },
|
||||
{ "RtlQueryTimeZoneInformation", func_RtlQueryTimeZoneInformation },
|
||||
{ "RtlReAllocateHeap", func_RtlReAllocateHeap },
|
||||
{ "RtlUnicodeStringToAnsiString", func_RtlUnicodeStringToAnsiString },
|
||||
{ "RtlUpcaseUnicodeStringToCountedOemString", func_RtlUpcaseUnicodeStringToCountedOemString },
|
||||
|
|
|
@ -95,6 +95,8 @@ RtlpQueryRegistryDirect(IN ULONG ValueType,
|
|||
RtlCopyMemory(Buffer, ValueData, ValueLength);
|
||||
}
|
||||
else
|
||||
{
|
||||
if (ValueType != REG_BINARY)
|
||||
{
|
||||
/* Check if there's space for the length and type, plus data */
|
||||
if (*Length < (2 * sizeof(ULONG) + ValueLength))
|
||||
|
@ -108,6 +110,12 @@ RtlpQueryRegistryDirect(IN ULONG ValueType,
|
|||
*Length++ = ValueType;
|
||||
RtlCopyMemory(Length, ValueData, ValueLength);
|
||||
}
|
||||
else
|
||||
{
|
||||
/* Return the REG_BINARY data */
|
||||
RtlCopyMemory(Length, ValueData, ValueLength);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/* All done */
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue