Author: mjansen
Date: Sat May 28 17:55:56 2016
New Revision: 71442
URL:
http://svn.reactos.org/svn/reactos?rev=71442&view=rev
Log:
[APPHELP][APPHELP_APITEST] Implement various VersionLie shims. CORE-11299 #resolve
- Implement VersionLie shims
- Add tests for the VersionLie shims
- update get_host_winver prototype (thanks to Thomas for pointing out my err)
We cannot apply this shim yet, since a required part of the infrastructure is missing.
Added:
trunk/reactos/dll/appcompat/shims/layer/
trunk/reactos/dll/appcompat/shims/layer/CMakeLists.txt (with props)
trunk/reactos/dll/appcompat/shims/layer/layer.spec (with props)
trunk/reactos/dll/appcompat/shims/layer/main.c (with props)
trunk/reactos/dll/appcompat/shims/layer/versionlie.c (with props)
trunk/reactos/dll/appcompat/shims/layer/versionlie.inl (with props)
trunk/rostests/apitests/apphelp/versionlie.c (with props)
Modified:
trunk/reactos/dll/appcompat/shims/CMakeLists.txt
trunk/rostests/apitests/apphelp/CMakeLists.txt
trunk/rostests/apitests/apphelp/apphelp.c
trunk/rostests/apitests/apphelp/data.c
trunk/rostests/apitests/apphelp/layerapi.c
trunk/rostests/apitests/apphelp/testlist.c
Modified: trunk/reactos/dll/appcompat/shims/CMakeLists.txt
URL:
http://svn.reactos.org/svn/reactos/trunk/reactos/dll/appcompat/shims/CMakeL…
==============================================================================
--- trunk/reactos/dll/appcompat/shims/CMakeLists.txt [iso-8859-1] (original)
+++ trunk/reactos/dll/appcompat/shims/CMakeLists.txt [iso-8859-1] Sat May 28 17:55:56
2016
@@ -1,3 +1,4 @@
add_subdirectory(shimlib)
+add_subdirectory(layer)
Added: trunk/reactos/dll/appcompat/shims/layer/CMakeLists.txt
URL:
http://svn.reactos.org/svn/reactos/trunk/reactos/dll/appcompat/shims/layer/…
==============================================================================
--- trunk/reactos/dll/appcompat/shims/layer/CMakeLists.txt (added)
+++ trunk/reactos/dll/appcompat/shims/layer/CMakeLists.txt [iso-8859-1] Sat May 28
17:55:56 2016
@@ -0,0 +1,18 @@
+
+include_directories(${SHIMLIB_DIR})
+
+spec2def(aclayers.dll layer.spec)
+
+list(APPEND SOURCE
+ versionlie.c
+ main.c
+ layer.spec)
+
+add_library(aclayers SHARED
+ ${SOURCE}
+ ${CMAKE_CURRENT_BINARY_DIR}/aclayers.def)
+
+set_module_type(aclayers win32dll)
+target_link_libraries(aclayers shimlib)
+add_importlibs(aclayers msvcrt kernel32 ntdll)
+add_cd_file(TARGET aclayers DESTINATION reactos/AppPatch FOR all)
Propchange: trunk/reactos/dll/appcompat/shims/layer/CMakeLists.txt
------------------------------------------------------------------------------
svn:eol-style = native
Added: trunk/reactos/dll/appcompat/shims/layer/layer.spec
URL:
http://svn.reactos.org/svn/reactos/trunk/reactos/dll/appcompat/shims/layer/…
==============================================================================
--- trunk/reactos/dll/appcompat/shims/layer/layer.spec (added)
+++ trunk/reactos/dll/appcompat/shims/layer/layer.spec [iso-8859-1] Sat May 28 17:55:56
2016
@@ -0,0 +1,3 @@
+
+@ stdcall GetHookAPIs(str wstr ptr)
+@ stdcall NotifyShims(long ptr)
Propchange: trunk/reactos/dll/appcompat/shims/layer/layer.spec
------------------------------------------------------------------------------
svn:eol-style = native
Added: trunk/reactos/dll/appcompat/shims/layer/main.c
URL:
http://svn.reactos.org/svn/reactos/trunk/reactos/dll/appcompat/shims/layer/…
==============================================================================
--- trunk/reactos/dll/appcompat/shims/layer/main.c (added)
+++ trunk/reactos/dll/appcompat/shims/layer/main.c [iso-8859-1] Sat May 28 17:55:56 2016
@@ -0,0 +1,37 @@
+/*
+ * COPYRIGHT: See COPYING in the top level directory
+ * PROJECT: ReactOS Shim library
+ * FILE: dll/appcompat/shims/layer/main.c
+ * PURPOSE: Shim entrypoint
+ * PROGRAMMER: Mark Jansen
+ */
+
+#include <windows.h>
+#include <strsafe.h>
+#include <shimlib.h>
+
+/* Forward to the generic implementation */
+PHOOKAPI WINAPI GetHookAPIs(IN LPCSTR szCommandLine, IN LPCWSTR wszShimName, OUT PDWORD
pdwHookCount)
+{
+ return ShimLib_GetHookAPIs(szCommandLine, wszShimName, pdwHookCount);
+}
+
+/* PLDR_DATA_TABLE_ENTRY */
+BOOL WINAPI NotifyShims(DWORD fdwReason, PVOID P)
+{
+ return TRUE;
+}
+
+BOOL WINAPI DllMain(HINSTANCE hInstance, DWORD dwReason, LPVOID lpReserved)
+{
+ switch(dwReason)
+ {
+ case DLL_PROCESS_ATTACH:
+ ShimLib_Init(hInstance);
+ break;
+ case DLL_PROCESS_DETACH:
+ ShimLib_Deinit();
+ break;
+ }
+ return TRUE;
+}
Propchange: trunk/reactos/dll/appcompat/shims/layer/main.c
------------------------------------------------------------------------------
svn:eol-style = native
Added: trunk/reactos/dll/appcompat/shims/layer/versionlie.c
URL:
http://svn.reactos.org/svn/reactos/trunk/reactos/dll/appcompat/shims/layer/…
==============================================================================
--- trunk/reactos/dll/appcompat/shims/layer/versionlie.c (added)
+++ trunk/reactos/dll/appcompat/shims/layer/versionlie.c [iso-8859-1] Sat May 28 17:55:56
2016
@@ -0,0 +1,232 @@
+/*
+ * COPYRIGHT: See COPYING in the top level directory
+ * PROJECT: ReactOS Shim library
+ * FILE: dll/appcompat/shims/layer/versionlie.c
+ * PURPOSE: Version lie shims
+ * PROGRAMMER: Mark Jansen
+ */
+
+#include <windows.h>
+#include <shimlib.h>
+#include <strsafe.h>
+
+/* Generic version info to use with the shims */
+typedef struct VersionLieInfo
+{
+ DWORD FullVersion;
+ WORD dwMajorVersion;
+ WORD dwMinorVersion;
+ DWORD dwBuildNumber;
+ WORD dwPlatformId;
+ WORD wServicePackMajor;
+ WORD wServicePackMinor;
+ char szCSDVersionA[20];
+ WCHAR szCSDVersionW[20];
+} VersionLieInfo;
+
+VersionLieInfo g_Win95 = { 0xC3B60004, 4, 0, 950, VER_PLATFORM_WIN32_WINDOWS, 0, 0 };
+VersionLieInfo g_WinNT4SP5 = { 0x05650004, 4, 0, 1381, VER_PLATFORM_WIN32_NT, 5, 0 };
+VersionLieInfo g_Win98 = { 0xC0000A04, 4, 10, 0x040A08AE, VER_PLATFORM_WIN32_WINDOWS, 0,
0 };
+
+VersionLieInfo g_Win2000 = { 0x08930005, 5, 0, 2195, VER_PLATFORM_WIN32_NT, 0, 0 };
+VersionLieInfo g_Win2000SP1 = { 0x08930005, 5, 0, 2195, VER_PLATFORM_WIN32_NT, 1, 0 };
+VersionLieInfo g_Win2000SP2 = { 0x08930005, 5, 0, 2195, VER_PLATFORM_WIN32_NT, 2, 0 };
+VersionLieInfo g_Win2000SP3 = { 0x08930005, 5, 0, 2195, VER_PLATFORM_WIN32_NT, 3, 0 };
+
+VersionLieInfo g_WinXP = { 0x0a280105, 5, 1, 2600, VER_PLATFORM_WIN32_NT, 0, 0 };
+VersionLieInfo g_WinXPSP1 = { 0x0a280105, 5, 1, 2600, VER_PLATFORM_WIN32_NT, 1, 0 };
+VersionLieInfo g_WinXPSP2 = { 0x0a280105, 5, 1, 2600, VER_PLATFORM_WIN32_NT, 2, 0 };
+VersionLieInfo g_WinXPSP3 = { 0x0a280105, 5, 1, 2600, VER_PLATFORM_WIN32_NT, 3, 0 };
+
+VersionLieInfo g_Win2k3RTM = { 0x0ece0205, 5, 2, 3790, VER_PLATFORM_WIN32_NT, 0, 0 };
+VersionLieInfo g_Win2k3SP1 = { 0x0ece0205, 5, 2, 3790, VER_PLATFORM_WIN32_NT, 1, 0 };
+
+VersionLieInfo g_WinVistaRTM = { 0x17700006, 6, 0, 6000, VER_PLATFORM_WIN32_NT, 0, 0 };
+VersionLieInfo g_WinVistaSP1 = { 0x17710006, 6, 0, 6001, VER_PLATFORM_WIN32_NT, 1, 0 };
+VersionLieInfo g_WinVistaSP2 = { 0x17720006, 6, 0, 6002, VER_PLATFORM_WIN32_NT, 2, 0 };
+
+VersionLieInfo g_Win7RTM = { 0x1db00106, 6, 1, 7600, VER_PLATFORM_WIN32_NT, 0, 0 };
+
+
+/* Fill the OSVERSIONINFO[EX][W|A] struct with the info from the generic VersionLieInfo
*/
+
+BOOL FakeVersion(LPOSVERSIONINFOEXA pResult, VersionLieInfo* pFake)
+{
+ if (pResult->dwOSVersionInfoSize == sizeof(OSVERSIONINFOEXA) ||
pResult->dwOSVersionInfoSize == sizeof(OSVERSIONINFOA) ||
+ pResult->dwOSVersionInfoSize == sizeof(OSVERSIONINFOEXW) ||
pResult->dwOSVersionInfoSize == sizeof(OSVERSIONINFOW))
+ {
+ pResult->dwMajorVersion = pFake->dwMajorVersion;
+ pResult->dwMinorVersion = pFake->dwMinorVersion;
+ pResult->dwBuildNumber = pFake->dwBuildNumber;
+ pResult->dwPlatformId = pFake->dwPlatformId;
+ if (pResult->dwOSVersionInfoSize == sizeof(OSVERSIONINFOEXA) ||
pResult->dwOSVersionInfoSize == sizeof(OSVERSIONINFOA))
+ {
+ if (FAILED(StringCbCopyA(pResult->szCSDVersion,
sizeof(pResult->szCSDVersion), pFake->szCSDVersionA)))
+ return FALSE;
+ if (pResult->dwOSVersionInfoSize == sizeof(OSVERSIONINFOEXA) &&
pFake->dwPlatformId != VER_PLATFORM_WIN32_WINDOWS)
+ {
+ pResult->wServicePackMajor = pFake->wServicePackMajor;
+ pResult->wServicePackMinor = pFake->wServicePackMinor;
+ }
+ }
+ else
+ {
+ LPOSVERSIONINFOEXW pResultW = (LPOSVERSIONINFOEXW)pResult;
+ if (FAILED(StringCbCopyW(pResultW->szCSDVersion,
sizeof(pResultW->szCSDVersion), pFake->szCSDVersionW)))
+ return FALSE;
+ if (pResultW->dwOSVersionInfoSize == sizeof(OSVERSIONINFOEXW) &&
pFake->dwPlatformId != VER_PLATFORM_WIN32_WINDOWS)
+ {
+ pResultW->wServicePackMajor = pFake->wServicePackMajor;
+ pResultW->wServicePackMinor = pFake->wServicePackMinor;
+ }
+ }
+ return TRUE;
+ }
+ return FALSE;
+}
+
+typedef BOOL(WINAPI* GETVERSIONEXAPROC)(LPOSVERSIONINFOEXA);
+
+
+#define SHIM_NS Win95VersionLie
+
+#include <setup_shim.inl>
+
+DWORD WINAPI SHIM_OBJ_NAME(APIHook_GetVersion)()
+{
+ return g_Win95.FullVersion;
+}
+
+BOOL WINAPI SHIM_OBJ_NAME(APIHook_GetVersionExA)(LPOSVERSIONINFOEXA lpOsVersionInfo)
+{
+ if (CALL_SHIM(1, GETVERSIONEXAPROC)(lpOsVersionInfo))
+ {
+ return FakeVersion(lpOsVersionInfo, &g_Win95);
+ }
+ return FALSE;
+}
+
+/* We do not call about the actual type, FakeVersion will correctly handle it either way
*/
+BOOL WINAPI SHIM_OBJ_NAME(APIHook_GetVersionExW)(LPOSVERSIONINFOEXA lpOsVersionInfo)
+{
+ if (CALL_SHIM(2, GETVERSIONEXAPROC)(lpOsVersionInfo))
+ {
+ return FakeVersion(lpOsVersionInfo, &g_Win95);
+ }
+ return FALSE;
+}
+
+#define SHIM_NUM_HOOKS 3
+#define SHIM_SETUP_HOOKS \
+ SHIM_HOOK(0, "KERNEL32.DLL", "GetVersion",
SHIM_OBJ_NAME(APIHook_GetVersion)) \
+ SHIM_HOOK(1, "KERNEL32.DLL", "GetVersionExA",
SHIM_OBJ_NAME(APIHook_GetVersionExA)) \
+ SHIM_HOOK(2, "KERNEL32.DLL", "GetVersionExW",
SHIM_OBJ_NAME(APIHook_GetVersionExW))
+
+#include <implement_shim.inl>
+
+
+
+
+#define SHIM_NS Win98VersionLie
+
+#include <setup_shim.inl>
+
+DWORD WINAPI SHIM_OBJ_NAME(APIHook_GetVersion)()
+{
+ return g_Win98.FullVersion;
+}
+
+BOOL WINAPI SHIM_OBJ_NAME(APIHook_GetVersionExA)(LPOSVERSIONINFOEXA lpOsVersionInfo)
+{
+ if (CALL_SHIM(0, GETVERSIONEXAPROC)(lpOsVersionInfo))
+ {
+ return FakeVersion(lpOsVersionInfo, &g_Win98);
+ }
+ return FALSE;
+}
+
+/* We do not call about the actual type, FakeVersion will correctly handle it either way
*/
+BOOL WINAPI SHIM_OBJ_NAME(APIHook_GetVersionExW)(LPOSVERSIONINFOEXA lpOsVersionInfo)
+{
+ if (CALL_SHIM(1, GETVERSIONEXAPROC)(lpOsVersionInfo))
+ {
+ return FakeVersion(lpOsVersionInfo, &g_Win98);
+ }
+ return FALSE;
+}
+
+#define SHIM_NUM_HOOKS 3
+#define SHIM_SETUP_HOOKS \
+ SHIM_HOOK(2, "KERNEL32.DLL", "GetVersion",
SHIM_OBJ_NAME(APIHook_GetVersion)) \
+ SHIM_HOOK(0, "KERNEL32.DLL", "GetVersionExA",
SHIM_OBJ_NAME(APIHook_GetVersionExA)) \
+ SHIM_HOOK(1, "KERNEL32.DLL", "GetVersionExW",
SHIM_OBJ_NAME(APIHook_GetVersionExW))
+
+#include <implement_shim.inl>
+
+
+
+#define SHIM_NS WinNT4SP5VersionLie
+#define VERSION_INFO g_WinNT4SP5
+#include "versionlie.inl"
+
+#define SHIM_NS Win2000VersionLie
+#define VERSION_INFO g_Win2000
+#include "versionlie.inl"
+
+#define SHIM_NS Win2000SP1VersionLie
+#define VERSION_INFO g_Win2000SP1
+#include "versionlie.inl"
+
+#define SHIM_NS Win2000SP2VersionLie
+#define VERSION_INFO g_Win2000SP2
+#include "versionlie.inl"
+
+#define SHIM_NS Win2000SP3VersionLie
+#define VERSION_INFO g_Win2000SP3
+#include "versionlie.inl"
+
+
+#define SHIM_NS WinXPVersionLie
+#define VERSION_INFO g_WinXP
+#include "versionlie.inl"
+
+#define SHIM_NS WinXPSP1VersionLie
+#define VERSION_INFO g_WinXPSP1
+#include "versionlie.inl"
+
+#define SHIM_NS WinXPSP2VersionLie
+#define VERSION_INFO g_WinXPSP2
+#include "versionlie.inl"
+
+#define SHIM_NS WinXPSP3VersionLie
+#define VERSION_INFO g_WinXPSP3
+#include "versionlie.inl"
+
+
+#define SHIM_NS Win2k3RTMVersionLie
+#define VERSION_INFO g_Win2k3RTM
+#include "versionlie.inl"
+
+#define SHIM_NS Win2k3SP1VersionLie
+#define VERSION_INFO g_Win2k3SP1
+#include "versionlie.inl"
+
+
+#define SHIM_NS VistaRTMVersionLie
+#define VERSION_INFO g_WinVistaRTM
+#include "versionlie.inl"
+
+#define SHIM_NS VistaSP1VersionLie
+#define VERSION_INFO g_WinVistaSP1
+#include "versionlie.inl"
+
+#define SHIM_NS VistaSP2VersionLie
+#define VERSION_INFO g_WinVistaSP2
+#include "versionlie.inl"
+
+
+#define SHIM_NS Win7RTMVersionLie
+#define VERSION_INFO g_Win7RTM
+#include "versionlie.inl"
+
+
Propchange: trunk/reactos/dll/appcompat/shims/layer/versionlie.c
------------------------------------------------------------------------------
svn:eol-style = native
Added: trunk/reactos/dll/appcompat/shims/layer/versionlie.inl
URL:
http://svn.reactos.org/svn/reactos/trunk/reactos/dll/appcompat/shims/layer/…
==============================================================================
--- trunk/reactos/dll/appcompat/shims/layer/versionlie.inl (added)
+++ trunk/reactos/dll/appcompat/shims/layer/versionlie.inl [iso-8859-1] Sat May 28
17:55:56 2016
@@ -0,0 +1,73 @@
+/*
+ * COPYRIGHT: See COPYING in the top level directory
+ * PROJECT: ReactOS Shim library
+ * FILE: dll/appcompat/shims/layer/versionlie.inl
+ * PURPOSE: Version lie implementation helper
+ * PROGRAMMER: Mark Jansen
+ */
+
+
+#include <setup_shim.inl>
+
+DWORD WINAPI SHIM_OBJ_NAME(APIHook_GetVersion)()
+{
+ return VERSION_INFO.FullVersion;
+}
+
+BOOL WINAPI SHIM_OBJ_NAME(APIHook_GetVersionExA)(LPOSVERSIONINFOEXA lpOsVersionInfo)
+{
+ if (CALL_SHIM(0, GETVERSIONEXAPROC)(lpOsVersionInfo))
+ {
+ return FakeVersion(lpOsVersionInfo, &VERSION_INFO);
+ }
+ return FALSE;
+}
+
+/* We do not care about the actual type, FakeVersion will correctly handle it either way
*/
+BOOL WINAPI SHIM_OBJ_NAME(APIHook_GetVersionExW)(LPOSVERSIONINFOEXA lpOsVersionInfo)
+{
+ if (CALL_SHIM(1, GETVERSIONEXAPROC)(lpOsVersionInfo))
+ {
+ return FakeVersion(lpOsVersionInfo, &VERSION_INFO);
+ }
+ return FALSE;
+}
+
+/* We do not care about the actual type, FakeVersion will correctly handle it either way
*/
+BOOL WINAPI SHIM_OBJ_NAME(APIHook_RtlGetVersion)(LPOSVERSIONINFOEXA lpOsVersionInfo)
+{
+ if (CALL_SHIM(3, GETVERSIONEXAPROC)(lpOsVersionInfo))
+ {
+ return FakeVersion(lpOsVersionInfo, &VERSION_INFO);
+ }
+ return FALSE;
+}
+
+BOOL WINAPI SHIM_OBJ_NAME(Notify)(DWORD fdwReason)
+{
+ if (fdwReason == SHIM_REASON_ATTACH && VERSION_INFO.wServicePackMajor)
+ {
+ HRESULT hr = StringCbPrintfA(VERSION_INFO.szCSDVersionA,
sizeof(VERSION_INFO.szCSDVersionA),
+ "Service Pack %u", VERSION_INFO.wServicePackMajor);
+ if (FAILED(hr))
+ return FALSE;
+ StringCbPrintfW(VERSION_INFO.szCSDVersionW, sizeof(VERSION_INFO.szCSDVersionW),
+ (CONST
WCHAR[]){'S','e','r','v','i','c','e','
','P','a','c','k','
','%','u',0}, VERSION_INFO.wServicePackMajor);
+ if (FAILED(hr))
+ return FALSE;
+ }
+ return TRUE;
+}
+
+
+#define SHIM_NUM_HOOKS 4
+#define SHIM_SETUP_HOOKS \
+ SHIM_HOOK(0, "KERNEL32.DLL", "GetVersionExA",
SHIM_OBJ_NAME(APIHook_GetVersionExA)) \
+ SHIM_HOOK(1, "KERNEL32.DLL", "GetVersionExW",
SHIM_OBJ_NAME(APIHook_GetVersionExW)) \
+ SHIM_HOOK(2, "KERNEL32.DLL", "GetVersion",
SHIM_OBJ_NAME(APIHook_GetVersion)) \
+ SHIM_HOOK(3, "NTDLL.DLL", "RtlGetVersion",
SHIM_OBJ_NAME(APIHook_RtlGetVersion))
+#define SHIM_NOTIFY_FN SHIM_OBJ_NAME(Notify)
+
+#include <implement_shim.inl>
+
+#undef VERSION_INFO
Propchange: trunk/reactos/dll/appcompat/shims/layer/versionlie.inl
------------------------------------------------------------------------------
svn:eol-style = native
Modified: trunk/rostests/apitests/apphelp/CMakeLists.txt
URL:
http://svn.reactos.org/svn/reactos/trunk/rostests/apitests/apphelp/CMakeLis…
==============================================================================
--- trunk/rostests/apitests/apphelp/CMakeLists.txt [iso-8859-1] (original)
+++ trunk/rostests/apitests/apphelp/CMakeLists.txt [iso-8859-1] Sat May 28 17:55:56 2016
@@ -1,4 +1,4 @@
-
+project(appcompat)
add_definitions(-D__ROS_LONG64__)
list(APPEND SOURCE
@@ -6,6 +6,7 @@
data.c
db.c
layerapi.c
+ versionlie.c
testlist.c)
add_executable(apphelp_apitest ${SOURCE})
Modified: trunk/rostests/apitests/apphelp/apphelp.c
URL:
http://svn.reactos.org/svn/reactos/trunk/rostests/apitests/apphelp/apphelp.…
==============================================================================
--- trunk/rostests/apitests/apphelp/apphelp.c [iso-8859-1] (original)
+++ trunk/rostests/apitests/apphelp/apphelp.c [iso-8859-1] Sat May 28 17:55:56 2016
@@ -40,7 +40,7 @@
void test_create_exe_imp(const char* name, int skip_rsrc_exports);
void test_create_file_imp(const char* name, const char* contents, size_t len);
void test_create_ne_imp(const char* name, int skip_names);
-DWORD get_host_winver();
+DWORD get_host_winver(void);
#define test_create_exe (winetest_set_location(__FILE__, __LINE__), 0) ? (void)0 :
test_create_exe_imp
#define test_create_file (winetest_set_location(__FILE__, __LINE__), 0) ? (void)0 :
test_create_file_imp
Modified: trunk/rostests/apitests/apphelp/data.c
URL:
http://svn.reactos.org/svn/reactos/trunk/rostests/apitests/apphelp/data.c?r…
==============================================================================
--- trunk/rostests/apitests/apphelp/data.c [iso-8859-1] (original)
+++ trunk/rostests/apitests/apphelp/data.c [iso-8859-1] Sat May 28 17:55:56 2016
@@ -784,7 +784,7 @@
}
static DWORD g_WinVersion;
-DWORD get_host_winver()
+DWORD get_host_winver(void)
{
if (!g_WinVersion)
{
Modified: trunk/rostests/apitests/apphelp/layerapi.c
URL:
http://svn.reactos.org/svn/reactos/trunk/rostests/apitests/apphelp/layerapi…
==============================================================================
--- trunk/rostests/apitests/apphelp/layerapi.c [iso-8859-1] (original)
+++ trunk/rostests/apitests/apphelp/layerapi.c [iso-8859-1] Sat May 28 17:55:56 2016
@@ -32,7 +32,7 @@
#include "wine/test.h"
/* data.c */
-DWORD get_host_winver();
+DWORD get_host_winver(void);
#define GPLK_USER 1
#define GPLK_MACHINE 2
Modified: trunk/rostests/apitests/apphelp/testlist.c
URL:
http://svn.reactos.org/svn/reactos/trunk/rostests/apitests/apphelp/testlist…
==============================================================================
--- trunk/rostests/apitests/apphelp/testlist.c [iso-8859-1] (original)
+++ trunk/rostests/apitests/apphelp/testlist.c [iso-8859-1] Sat May 28 17:55:56 2016
@@ -6,11 +6,13 @@
extern void func_apphelp(void);
extern void func_db(void);
extern void func_layerapi(void);
+extern void func_versionlie(void);
const struct test winetest_testlist[] =
{
{ "apphelp", func_apphelp },
{ "db", func_db },
{ "layerapi", func_layerapi },
+ { "versionlie", func_versionlie },
{ 0, 0 }
};
Added: trunk/rostests/apitests/apphelp/versionlie.c
URL:
http://svn.reactos.org/svn/reactos/trunk/rostests/apitests/apphelp/versionl…
==============================================================================
--- trunk/rostests/apitests/apphelp/versionlie.c (added)
+++ trunk/rostests/apitests/apphelp/versionlie.c [iso-8859-1] Sat May 28 17:55:56 2016
@@ -0,0 +1,350 @@
+/*
+ * Copyright 2015 Mark Jansen
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
+ */
+
+#include <ntstatus.h>
+#define WIN32_NO_STATUS
+#include <windows.h>
+#ifdef __REACTOS__
+#include <ntndk.h>
+#else
+#include <winternl.h>
+#endif
+#include <stdio.h>
+#include "wine/test.h"
+
+/* data.c */
+DWORD get_host_winver(void);
+
+typedef struct tagHOOKAPI {
+ PCSTR LibraryName;
+ PCSTR FunctionName;
+ PVOID ReplacementFunction;
+ PVOID OriginalFunction;
+ PVOID Unk1;
+ PVOID Unk2;
+} HOOKAPI, *PHOOKAPI;
+
+static BOOL (WINAPI* pSdbGetAppPatchDir)(PVOID,LPWSTR,DWORD);
+static PHOOKAPI (WINAPI* pGetHookAPIs)(LPCSTR,LPCWSTR,PDWORD);
+
+
+static DWORD g_WinVersion;
+#define WINVER_WINXP 0x0501
+
+
+typedef struct VersionLieInfo
+{
+ DWORD FullVersion;
+ DWORD dwMajorVersion;
+ DWORD dwMinorVersion;
+ DWORD dwBuildNumber;
+ DWORD dwPlatformId;
+ WORD wServicePackMajor;
+ WORD wServicePackMinor;
+} VersionLieInfo;
+
+typedef BOOL(WINAPI* GETVERSIONEXAPROC)(LPOSVERSIONINFOEXA);
+typedef BOOL(WINAPI* GETVERSIONEXWPROC)(LPOSVERSIONINFOEXW);
+typedef DWORD(WINAPI* GETVERSIONPROC)(void);
+
+static void expect_shim_imp(PHOOKAPI hook, PCSTR library, PCSTR function, PCSTR shim,
int* same)
+{
+ int lib = lstrcmpA(library, hook->LibraryName);
+ int fn = lstrcmpA(function, hook->FunctionName);
+ winetest_ok(lib == 0, "Expected LibrarayName to be %s, was: %s for %s\n",
library, hook->LibraryName, shim);
+ winetest_ok(fn == 0, "Expected FunctionName to be %s, was: %s for %s\n",
function, hook->FunctionName, shim);
+ *same = (lib == 0 && fn == 0);
+}
+
+static void verify_shima_imp(PHOOKAPI hook, const VersionLieInfo* info, PCSTR shim, int
same)
+{
+ OSVERSIONINFOEXA v1 = { sizeof(v1), 0 }, v2 = { sizeof(v2), 0 };
+ BOOL ok1, ok2;
+
+ if (!same)
+ {
+ skip("Skipping implementation tests for %s\n", shim);
+ return;
+ }
+
+ while (v1.dwOSVersionInfoSize)
+ {
+ ok1 = GetVersionExA((LPOSVERSIONINFOA)&v1), ok2;
+ hook->OriginalFunction = GetVersionExA;
+
+ ok2 = ((GETVERSIONEXAPROC)hook->ReplacementFunction)(&v2);
+
+ winetest_ok(ok1 == ok2, "Expected ok1 to equal ok2, was: %i, %i for
%s\n", ok1, ok2, shim);
+ if (ok1 && ok2)
+ {
+ char szCSDVersion[128] = "";
+ winetest_ok(v1.dwOSVersionInfoSize == v2.dwOSVersionInfoSize, "Expected
dwOSVersionInfoSize to be equal, was: %u, %u for %s\n", v1.dwOSVersionInfoSize,
v2.dwOSVersionInfoSize, shim);
+ winetest_ok(info->dwMajorVersion == v2.dwMajorVersion, "Expected
dwMajorVersion to be equal, was: %u, %u for %s\n", info->dwMajorVersion,
v2.dwMajorVersion, shim);
+ winetest_ok(info->dwMinorVersion == v2.dwMinorVersion, "Expected
dwMinorVersion to be equal, was: %u, %u for %s\n", info->dwMinorVersion,
v2.dwMinorVersion, shim);
+ winetest_ok(info->dwBuildNumber == v2.dwBuildNumber, "Expected
dwBuildNumber to be equal, was: %u, %u for %s\n", info->dwBuildNumber,
v2.dwBuildNumber, shim);
+ winetest_ok(info->dwPlatformId == v2.dwPlatformId, "Expected
dwPlatformId to be equal, was: %u, %u for %s\n", info->dwPlatformId,
v2.dwPlatformId, shim);
+
+ if (info->wServicePackMajor)
+ sprintf(szCSDVersion, "Service Pack %u",
info->wServicePackMajor);
+ winetest_ok(lstrcmpA(szCSDVersion, v2.szCSDVersion) == 0, "Expected
szCSDVersion to be equal, was: %s, %s for %s\n", szCSDVersion, v2.szCSDVersion,
shim);
+
+ if (v1.dwOSVersionInfoSize == sizeof(OSVERSIONINFOEXA))
+ {
+ if (info->dwPlatformId != VER_PLATFORM_WIN32_WINDOWS)
+ {
+ winetest_ok(info->wServicePackMajor == v2.wServicePackMajor,
"Expected wServicePackMajor to be equal, was: %i, %i for %s\n",
info->wServicePackMajor, v2.wServicePackMajor, shim);
+ winetest_ok(info->wServicePackMinor == v2.wServicePackMinor,
"Expected wServicePackMinor to be equal, was: %i, %i for %s\n",
info->wServicePackMinor, v2.wServicePackMinor, shim);
+ }
+ else
+ {
+ winetest_ok(v1.wServicePackMajor == v2.wServicePackMajor,
"Expected wServicePackMajor to be equal, was: %i, %i for %s\n",
v1.wServicePackMajor, v2.wServicePackMajor, shim);
+ winetest_ok(v1.wServicePackMinor == v2.wServicePackMinor,
"Expected wServicePackMinor to be equal, was: %i, %i for %s\n",
v1.wServicePackMinor, v2.wServicePackMinor, shim);
+ }
+ winetest_ok(v1.wSuiteMask == v2.wSuiteMask, "Expected wSuiteMask to
be equal, was: %i, %i for %s\n", v1.wSuiteMask, v2.wSuiteMask, shim);
+ winetest_ok(v1.wProductType == v2.wProductType, "Expected
wProductType to be equal, was: %i, %i for %s\n", v1.wProductType, v2.wProductType,
shim);
+ winetest_ok(v1.wReserved == v2.wReserved, "Expected wReserved to be
equal, was: %i, %i for %s\n", v1.wReserved, v2.wReserved, shim);
+ }
+ else
+ {
+ winetest_ok(v1.wServicePackMajor == 0 && v2.wServicePackMajor ==
0, "Expected wServicePackMajor to be 0, was: %i, %i for %s\n",
v1.wServicePackMajor, v2.wServicePackMajor, shim);
+ winetest_ok(v1.wServicePackMinor == 0 && v2.wServicePackMinor ==
0, "Expected wServicePackMinor to be 0, was: %i, %i for %s\n",
v1.wServicePackMinor, v2.wServicePackMinor, shim);
+ winetest_ok(v1.wSuiteMask == 0 && v2.wSuiteMask == 0,
"Expected wSuiteMask to be 0, was: %i, %i for %s\n", v1.wSuiteMask,
v2.wSuiteMask, shim);
+ winetest_ok(v1.wProductType == 0 && v2.wProductType == 0,
"Expected wProductType to be 0, was: %i, %i for %s\n", v1.wProductType,
v2.wProductType, shim);
+ winetest_ok(v1.wReserved == 0 && v2.wReserved == 0,
"Expected wReserved to be 0, was: %i, %i for %s\n", v1.wReserved, v2.wReserved,
shim);
+ }
+ }
+
+ ZeroMemory(&v1, sizeof(v1));
+ ZeroMemory(&v2, sizeof(v2));
+ if (v1.dwOSVersionInfoSize == sizeof(OSVERSIONINFOEXA))
+ v1.dwOSVersionInfoSize = v2.dwOSVersionInfoSize = sizeof(OSVERSIONINFOA);
+ }
+}
+
+static void verify_shimw_imp(PHOOKAPI hook, const VersionLieInfo* info, PCSTR shim, int
same, int first_might_be_broken)
+{
+ OSVERSIONINFOEXW v1 = { sizeof(v1), 0 }, v2 = { sizeof(v2), 0 };
+ BOOL ok1, ok2, first = TRUE;
+
+ if (!same)
+ {
+ skip("Skipping implementation tests for %s\n", shim);
+ return;
+ }
+
+ while (v1.dwOSVersionInfoSize)
+ {
+ ok1 = GetVersionExW((LPOSVERSIONINFOW)&v1), ok2;
+ hook->OriginalFunction = GetVersionExW;
+
+ ok2 = ((GETVERSIONEXWPROC)hook->ReplacementFunction)(&v2);
+
+ if (first_might_be_broken && first && ok1 == TRUE && ok2
== FALSE)
+ {
+ skip("Skipping first check because 0x%x is (falsely) not accepted by the
shim %s\n", sizeof(v1), shim);
+ }
+ else
+ {
+ winetest_ok(ok1 == ok2, "Expected ok1 to equal ok2, was: %i, %i for
%s(first:%d)\n", ok1, ok2, shim, first);
+ }
+ if (ok1 && ok2)
+ {
+ WCHAR szCSDVersion[128] = { 0 };
+ winetest_ok(v1.dwOSVersionInfoSize == v2.dwOSVersionInfoSize, "Expected
dwOSVersionInfoSize to be equal, was: %u, %u for %s\n", v1.dwOSVersionInfoSize,
v2.dwOSVersionInfoSize, shim);
+ winetest_ok(info->dwMajorVersion == v2.dwMajorVersion, "Expected
dwMajorVersion to be equal, was: %u, %u for %s\n", info->dwMajorVersion,
v2.dwMajorVersion, shim);
+ winetest_ok(info->dwMinorVersion == v2.dwMinorVersion, "Expected
dwMinorVersion to be equal, was: %u, %u for %s\n", info->dwMinorVersion,
v2.dwMinorVersion, shim);
+ winetest_ok(info->dwBuildNumber == v2.dwBuildNumber, "Expected
dwBuildNumber to be equal, was: %u, %u for %s\n", info->dwBuildNumber,
v2.dwBuildNumber, shim);
+ winetest_ok(info->dwPlatformId == v2.dwPlatformId, "Expected
dwPlatformId to be equal, was: %u, %u for %s\n", info->dwPlatformId,
v2.dwPlatformId, shim);
+
+ if (info->wServicePackMajor)
+ swprintf(szCSDVersion, (const
WCHAR[]){'S','e','r','v','i','c','e','
','P','a','c','k','
','%','u',0}, info->wServicePackMajor);
+ winetest_ok(lstrcmpW(szCSDVersion, v2.szCSDVersion) == 0, "Expected
szCSDVersion to be equal, was: %s, %s for %s\n", wine_dbgstr_w(szCSDVersion),
wine_dbgstr_w(v2.szCSDVersion), shim);
+
+ if (v1.dwOSVersionInfoSize == sizeof(OSVERSIONINFOEXW))
+ {
+ if (info->dwPlatformId != VER_PLATFORM_WIN32_WINDOWS)
+ {
+ winetest_ok(info->wServicePackMajor == v2.wServicePackMajor,
"Expected wServicePackMajor to be equal, was: %i, %i for %s\n",
info->wServicePackMajor, v2.wServicePackMajor, shim);
+ winetest_ok(info->wServicePackMinor == v2.wServicePackMinor,
"Expected wServicePackMinor to be equal, was: %i, %i for %s\n",
info->wServicePackMinor, v2.wServicePackMinor, shim);
+ }
+ else
+ {
+ winetest_ok(v1.wServicePackMajor == v2.wServicePackMajor,
"Expected wServicePackMajor to be equal, was: %i, %i for %s\n",
v1.wServicePackMajor, v2.wServicePackMajor, shim);
+ winetest_ok(v1.wServicePackMinor == v2.wServicePackMinor,
"Expected wServicePackMinor to be equal, was: %i, %i for %s\n",
v1.wServicePackMinor, v2.wServicePackMinor, shim);
+ }
+ winetest_ok(v1.wSuiteMask == v2.wSuiteMask, "Expected wSuiteMask to
be equal, was: %i, %i for %s\n", v1.wSuiteMask, v2.wSuiteMask, shim);
+ winetest_ok(v1.wProductType == v2.wProductType, "Expected
wProductType to be equal, was: %i, %i for %s\n", v1.wProductType, v2.wProductType,
shim);
+ winetest_ok(v1.wReserved == v2.wReserved, "Expected wReserved to be
equal, was: %i, %i for %s\n", v1.wReserved, v2.wReserved, shim);
+ }
+ else
+ {
+ winetest_ok(v1.wServicePackMajor == 0 && v2.wServicePackMajor ==
0, "Expected wServicePackMajor to be 0, was: %i, %i for %s\n",
v1.wServicePackMajor, v2.wServicePackMajor, shim);
+ winetest_ok(v1.wServicePackMinor == 0 && v2.wServicePackMinor ==
0, "Expected wServicePackMinor to be 0, was: %i, %i for %s\n",
v1.wServicePackMinor, v2.wServicePackMinor, shim);
+ winetest_ok(v1.wSuiteMask == 0 && v2.wSuiteMask == 0,
"Expected wSuiteMask to be 0, was: %i, %i for %s\n", v1.wSuiteMask,
v2.wSuiteMask, shim);
+ winetest_ok(v1.wProductType == 0 && v2.wProductType == 0,
"Expected wProductType to be 0, was: %i, %i for %s\n", v1.wProductType,
v2.wProductType, shim);
+ winetest_ok(v1.wReserved == 0 && v2.wReserved == 0,
"Expected wReserved to be 0, was: %i, %i for %s\n", v1.wReserved, v2.wReserved,
shim);
+ }
+ }
+
+ ZeroMemory(&v1, sizeof(v1));
+ ZeroMemory(&v2, sizeof(v2));
+ if (v1.dwOSVersionInfoSize == sizeof(OSVERSIONINFOEXW))
+ v1.dwOSVersionInfoSize = v2.dwOSVersionInfoSize = sizeof(OSVERSIONINFOW);
+ first = FALSE;
+ }
+}
+
+static void verify_shim_imp(PHOOKAPI hook, const VersionLieInfo* info, PCSTR shim, int
same)
+{
+ DWORD ver;
+ if (!same)
+ {
+ skip("Skipping implementation tests for %s\n", shim);
+ return;
+ }
+ ver = ((GETVERSIONPROC)hook->ReplacementFunction)();
+ winetest_ok(info->FullVersion == ver, "Expected GetVersion to return %u, was:
%u for %s\n", info->FullVersion, ver, shim);
+}
+
+
+#define expect_shim (winetest_set_location(__FILE__, __LINE__), 0) ? (void)0 :
expect_shim_imp
+#define verify_shima (winetest_set_location(__FILE__, __LINE__), 0) ? (void)0 :
verify_shima_imp
+#define verify_shimw (winetest_set_location(__FILE__, __LINE__), 0) ? (void)0 :
verify_shimw_imp
+#define verify_shim (winetest_set_location(__FILE__, __LINE__), 0) ? (void)0 :
verify_shim_imp
+
+
+
+
+static void run_test(LPCSTR shim, const VersionLieInfo* info)
+{
+ DWORD num_shims = 0;
+ WCHAR wide_shim[50] = { 0 };
+ PHOOKAPI hook;
+ DWORD ver;
+ MultiByteToWideChar(CP_ACP, 0, shim, -1, wide_shim, 50);
+ hook = pGetHookAPIs("", wide_shim, &num_shims);
+ ver = (info->dwMajorVersion << 8) | info->dwMinorVersion;
+ if (hook == NULL)
+ {
+ skip("Skipping tests for layers (%s) not present in this os (0x%x)\n",
shim, g_WinVersion);
+ return;
+ }
+ ok(hook != NULL, "Expected hook to be a valid pointer for %s\n", shim);
+ if (info->dwPlatformId == VER_PLATFORM_WIN32_WINDOWS)
+ {
+ ok(num_shims == 3, "Expected num_shims to be 3, was: %u for %s\n",
num_shims, shim);
+ if (hook && num_shims == 3)
+ {
+ int off = info->dwBuildNumber == 0x040A08AE ? 0 : 1, same = 0;
+ expect_shim(hook + ((0+off)%3), "KERNEL32.DLL",
"GetVersionExA", shim, &same);
+ verify_shima(hook + ((0+off)%3), info, shim, same);
+ expect_shim(hook + ((1+off)%3), "KERNEL32.DLL",
"GetVersionExW", shim, &same);
+ verify_shimw(hook + ((1+off)%3), info, shim, same, 0);
+ expect_shim(hook + ((2+off)%3), "KERNEL32.DLL",
"GetVersion", shim, &same);
+ verify_shim(hook + ((2+off)%3), info, shim, same);
+ }
+ }
+ else
+ {
+ int shimnum_ok = num_shims == 4 || ((ver < WINVER_WINXP) && (num_shims
== 3));
+ ok(shimnum_ok, "Expected num_shims to be 4%s, was: %u for %s\n", ((ver
< WINVER_WINXP) ? " or 3":""), num_shims, shim);
+ if (hook && shimnum_ok)
+ {
+ int same = 0;
+ expect_shim(hook + 0, "KERNEL32.DLL", "GetVersionExA",
shim, &same);
+ verify_shima(hook + 0, info, shim, same);
+ expect_shim(hook + 1, "KERNEL32.DLL", "GetVersionExW",
shim, &same);
+ verify_shimw(hook + 1, info, shim, same, 0);
+ expect_shim(hook + 2, "KERNEL32.DLL", "GetVersion", shim,
&same);
+ verify_shim(hook + 2, info, shim, same);
+ if (num_shims == 4)
+ {
+ expect_shim(hook + 3, "NTDLL.DLL", "RtlGetVersion",
shim, &same);
+ verify_shimw(hook + 3, info, shim, same, 1);
+ }
+ }
+ }
+}
+
+
+VersionLieInfo g_Win95 = { 0xC3B60004, 4, 0, 950, VER_PLATFORM_WIN32_WINDOWS, 0, 0 };
+VersionLieInfo g_WinNT4SP5 = { 0x05650004, 4, 0, 1381, VER_PLATFORM_WIN32_NT, 5, 0 };
+VersionLieInfo g_Win98 = { 0xC0000A04, 4, 10, 0x040A08AE, VER_PLATFORM_WIN32_WINDOWS, 0,
0 };
+
+VersionLieInfo g_Win2000 = { 0x08930005, 5, 0, 2195, VER_PLATFORM_WIN32_NT, 0, 0 };
+VersionLieInfo g_Win2000SP1 = { 0x08930005, 5, 0, 2195, VER_PLATFORM_WIN32_NT, 1, 0 };
+VersionLieInfo g_Win2000SP2 = { 0x08930005, 5, 0, 2195, VER_PLATFORM_WIN32_NT, 2, 0 };
+VersionLieInfo g_Win2000SP3 = { 0x08930005, 5, 0, 2195, VER_PLATFORM_WIN32_NT, 3, 0 };
+
+VersionLieInfo g_WinXP = { 0x0a280105, 5, 1, 2600, VER_PLATFORM_WIN32_NT, 0, 0 };
+VersionLieInfo g_WinXPSP1 = { 0x0a280105, 5, 1, 2600, VER_PLATFORM_WIN32_NT, 1, 0 };
+VersionLieInfo g_WinXPSP2 = { 0x0a280105, 5, 1, 2600, VER_PLATFORM_WIN32_NT, 2, 0 };
+VersionLieInfo g_WinXPSP3 = { 0x0a280105, 5, 1, 2600, VER_PLATFORM_WIN32_NT, 3, 0 };
+
+VersionLieInfo g_Win2k3RTM = { 0x0ece0205, 5, 2, 3790, VER_PLATFORM_WIN32_NT, 0, 0 };
+VersionLieInfo g_Win2k3SP1 = { 0x0ece0205, 5, 2, 3790, VER_PLATFORM_WIN32_NT, 1, 0 };
+
+VersionLieInfo g_WinVistaRTM = { 0x17700006, 6, 0, 6000, VER_PLATFORM_WIN32_NT, 0, 0 };
+VersionLieInfo g_WinVistaSP1 = { 0x17710006, 6, 0, 6001, VER_PLATFORM_WIN32_NT, 1, 0 };
+VersionLieInfo g_WinVistaSP2 = { 0x17720006, 6, 0, 6002, VER_PLATFORM_WIN32_NT, 2, 0 };
+
+VersionLieInfo g_Win7RTM = { 0x1db00106, 6, 1, 7600, VER_PLATFORM_WIN32_NT, 0, 0 };
+
+
+START_TEST(versionlie)
+{
+ HMODULE dll = LoadLibraryA("apphelp.dll");
+ WCHAR buf[MAX_PATH];
+ WCHAR aclayers[] =
{'\\','a','c','l','a','y','e','r','s','.','d','l','l',0};
+ pSdbGetAppPatchDir = (void*)GetProcAddress(dll, "SdbGetAppPatchDir");
+ if (!pSdbGetAppPatchDir)
+ {
+ skip("apphelp.dll not loaded, or does not export
SdbGetAppPatchDir\n");
+ return;
+ }
+
+ pSdbGetAppPatchDir(NULL, buf, MAX_PATH);
+ lstrcatW(buf, aclayers);
+ dll = LoadLibraryW(buf);
+ pGetHookAPIs = (void*)GetProcAddress(dll, "GetHookAPIs");
+
+ if (!pGetHookAPIs)
+ {
+ skip("aclayers.dll not loaded, or does not export GetHookAPIs\n");
+ return;
+ }
+ g_WinVersion = get_host_winver();
+
+ run_test("Win95VersionLie", &g_Win95);
+ run_test("WinNT4SP5VersionLie", &g_WinNT4SP5);
+ run_test("Win98VersionLie", &g_Win98);
+ run_test("Win2000VersionLie", &g_Win2000);
+ run_test("Win2000SP1VersionLie", &g_Win2000SP1);
+ run_test("Win2000SP2VersionLie", &g_Win2000SP2);
+ run_test("Win2000SP3VersionLie", &g_Win2000SP3);
+ run_test("WinXPVersionLie", &g_WinXP);
+ run_test("WinXPSP1VersionLie", &g_WinXPSP1);
+ run_test("WinXPSP2VersionLie", &g_WinXPSP2);
+ run_test("WinXPSP3VersionLie", &g_WinXPSP3);
+ run_test("Win2k3RTMVersionLie", &g_Win2k3RTM);
+ run_test("Win2k3SP1VersionLie", &g_Win2k3SP1);
+ run_test("VistaRTMVersionLie", &g_WinVistaRTM);
+ run_test("VistaSP1VersionLie", &g_WinVistaSP1);
+ run_test("VistaSP2VersionLie", &g_WinVistaSP2);
+ run_test("Win7RTMVersionLie", &g_Win7RTM);
+}
Propchange: trunk/rostests/apitests/apphelp/versionlie.c
------------------------------------------------------------------------------
svn:eol-style = native