Just realized that I didn't add the first argument in WdsSetupLogMessage. It's supposed to have 11 arguments, not 10. I'll submit a revision. Sorry about that.
Required by the Windows MediaCreationTool21H2.
Signed-off-by: Mohamad Al-Jaf <mohamadaljaf@gmail.com>
---
v3: - Rebase patch
- Fix unknown argument names
I changed unknown5 to src after I saw the debug output but got
distracted trying to see if I could figure out the other parameters
and forgot to rename them.
---
dlls/wdscore/main.c | 28 ++++++++++++++++++++++++++++
dlls/wdscore/wdscore.spec | 4 ++--
dlls/wdscore/wdscore_internal.h | 27 +++++++++++++++++++++++++++
3 files changed, 57 insertions(+), 2 deletions(-)
diff --git a/dlls/wdscore/main.c b/dlls/wdscore/main.c
index 3bd5eed8ec5..bda01772d9f 100644
--- a/dlls/wdscore/main.c
+++ b/dlls/wdscore/main.c
@@ -74,3 +74,31 @@ LPVOID WINAPI ConstructPartialMsgVW( WdsLogLevel level, LPCWSTR msg, va_list arg
FIXME( "%u %s - stub\n", level, debugstr_w(msg) );
return NULL;
}
+
+
+/***********************************************************************
+ * WdsSetupLogMessageA (wdscore.@)
+ */
+HRESULT WINAPI WdsSetupLogMessageA( WdsLogSource log, LPCSTR unknown1, LPCSTR unknown2,
+ ULONG unknown3, LPCSTR unknown4, LPCSTR src,
+ void* ip, ULONG unknown5, void* unknown6, UINT unknown7 )
+{
+ FIXME( "%u, %s, %s, %u, %s, %s, %p, %u, %p, %u - stub\n", log, debugstr_a(unknown1),
+ debugstr_a(unknown2), unknown3, debugstr_a(unknown4), debugstr_a(src),
+ ip, unknown5, unknown6, unknown7 );
+ return S_OK;
+}
+
+
+/***********************************************************************
+ * WdsSetupLogMessageW (wdscore.@)
+ */
+HRESULT WINAPI WdsSetupLogMessageW( WdsLogSource log, LPCWSTR unknown1, LPCWSTR unknown2,
+ ULONG unknown3, LPCWSTR unknown4, LPCWSTR src,
+ void* ip, ULONG unknown5, void* unknown6, UINT unknown7 )
+{
+ FIXME( "%u, %s, %s, %u, %s, %s, %p, %u, %p, %u - stub\n", log, debugstr_w(unknown1),
+ debugstr_w(unknown2), unknown3, debugstr_w(unknown4), debugstr_w(src),
+ ip, unknown5, unknown6, unknown7 );
+ return S_OK;
+}
diff --git a/dlls/wdscore/wdscore.spec b/dlls/wdscore/wdscore.spec
index b14778001a8..18de37d1ed7 100644
--- a/dlls/wdscore/wdscore.spec
+++ b/dlls/wdscore/wdscore.spec
@@ -150,8 +150,8 @@
@ stub WdsSetUILanguage
@ stub WdsSetupLogDestroy
@ stub WdsSetupLogInit
-@ stub WdsSetupLogMessageA
-@ stub WdsSetupLogMessageW
+@ stdcall WdsSetupLogMessageA(long str str long str str ptr long ptr long)
+@ stdcall WdsSetupLogMessageW(long wstr wstr long wstr wstr ptr long ptr long)
@ stub WdsSubscribeEx
@ stub WdsTerminate
@ stub WdsUnlockExecutionGroup
diff --git a/dlls/wdscore/wdscore_internal.h b/dlls/wdscore/wdscore_internal.h
index b5cbe3c8c25..f029023f8ce 100644
--- a/dlls/wdscore/wdscore_internal.h
+++ b/dlls/wdscore/wdscore_internal.h
@@ -19,6 +19,33 @@
#ifndef __WDSCORE_INTERNAL_H
#define __WDSCORE_INTERNAL_H
+typedef enum _WdsLogSource {
+ WdsLogSourceDPX = 0x1000000,
+ WdsLogSourceCBS = 0x2000000,
+ WdsLogSourceCSI = 0x1800000,
+ WdsLogSourceSXS = 0x2800000,
+ WdsLogSourceCMI = 0x3000000,
+ WdsLogSourceDEPLOY = 0x4000000,
+ WdsLogSourceDU = 0x5000000,
+ WdsLogSourceIBS = 0x6000000,
+ WdsLogSourceIBSLIB = 0x6400000,
+ WdsLogSourceDIAG = 0x7000000,
+ WdsLogSourceDIAGER = 0x7400000,
+ WdsLogSourceMIG = 0x8000000,
+ WdsLogSourceHWARE = 0x8400000,
+ WdsLogSourceMIGUI = 0x8800000,
+ WdsLogSourceUI = 0xA000000,
+ WdsLogSourceCONX = 0xA400000,
+ WdsLogSourceMOUPG = 0xA800000,
+ WdsLogSourceWDS = 0xB000000,
+ WdsLogSourceDISM = 0xB800000,
+ WdsLogSourcePANTHR = 0x9000000,
+ WdsLogSourceWINPE = 0xC000000,
+ WdsLogSourceSP = 0xC800000,
+ WdsLogSourceLIB = 0xD000000,
+ WdsLogSourceTOOL = 0xE000000
+} WdsLogSource;
+
typedef enum _WdsLogLevel {
WdsLogLevelAssert = 0x0000000,
WdsLogLevelFatalError = 0x1000000,
--
2.35.0