mscoree: Reimplemented GetCORVersion using a helper that checks properly the return buffer; shortened a few FIXMEs (1/4)

Paul Chitescu paulc at voip.null.ro
Mon Nov 13 19:42:24 CST 2006


Changelog: mscoree: Reimplemented GetCORVersion using a helper that checks 
properly the return buffer; shortened a few FIXMEs (1/4)
-------------- next part --------------
--- ./dlls/mscoree/mscoree_main.c.orig	2006-11-13 15:23:51.000000000 +0200
+++ ./dlls/mscoree/mscoree_main.c	2006-11-13 23:01:55.000000000 +0200
@@ -19,17 +19,40 @@
  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
  */
 
-#include <stdarg.h>
+#include "config.h"
+#include "wine/port.h"
+#include "wine/library.h"
+#include "wine/debug.h"
 
 #include "windef.h"
 #include "winbase.h"
 #include "winuser.h"
 #include "ole2.h"
 
-#include "wine/debug.h"
-
 WINE_DEFAULT_DEBUG_CHANNEL( mscoree );
 
+static const WCHAR defaultCORversion[] = {'v','1','.','1','.','4','3','2','2',0};
+/*
+  .NET 1.0: v1.0.3705
+  .NET 1.1: v1.1.4322
+  .NET 2.0: v2.0.50727
+*/
+
+/* this helper is needed very often */
+static HRESULT copyToWBuffer(LPCWSTR str, LPWSTR pBuf, DWORD cchBuf, LPDWORD pBufLen)
+{
+    DWORD len;
+    if (!(pBuf && cchBuf))
+	return E_POINTER;
+    len = lstrlenW(str);
+    if (pBufLen)
+	*pBufLen = len;
+    if (cchBuf < len)
+        return ERROR_INSUFFICIENT_BUFFER;
+    lstrcpyW(pBuf, str);
+    return S_OK;
+}
+
 HRESULT WINAPI CorBindToRuntimeHost(LPCWSTR pwszVersion, LPCWSTR pwszBuildFlavor,
                                     LPCWSTR pwszHostConfigFile, VOID *pReserved,
                                     DWORD startupFlags, REFCLSID rclsid,
@@ -98,30 +121,16 @@
     return E_FAIL;
 }
 
-HRESULT WINAPI GetCORVersion(LPWSTR pbuffer, DWORD cchBuffer, DWORD *dwLength)
+HRESULT WINAPI GetCORVersion(LPWSTR pBuffer, DWORD cchBuffer, DWORD *dwLength)
 {
-    static const WCHAR version[] = {'v','1','.','1','.','4','3','2','2',0};
-
-    FIXME("(%p, %d, %p): semi-stub!\n", pbuffer, cchBuffer, dwLength);
-
-    if (!dwLength)
-        return E_POINTER;
-
-    *dwLength = lstrlenW(version);
-
-    if (cchBuffer < *dwLength)
-        return ERROR_INSUFFICIENT_BUFFER;
-
-    if (pbuffer)
-        lstrcpyW(pbuffer, version);
-
-    return S_OK;
+    WARN("(%p, %d, %p): semi-stub\n", pBuffer, cchBuffer, dwLength);
+    return copyToWBuffer(defaultCORversion, pBuffer, cchBuffer, dwLength);
 }
 
-HRESULT WINAPI LoadLibraryShim( LPCWSTR szDllName, LPCWSTR szVersion, LPVOID pvReserved, HMODULE * phModDll)
+HRESULT WINAPI LoadLibraryShim(LPCWSTR szDllName, LPCWSTR szVersion, LPVOID pvReserved, HMODULE * phModDll)
 {
     *phModDll = LoadLibraryW(szDllName);
-    FIXME("(%p %s, %p, %p, %p): semi-stub\n", szDllName, debugstr_w(szDllName), szVersion, pvReserved, phModDll);
+    FIXME("(%s, %p, %p, %p): semi-stub\n", debugstr_w(szDllName), szVersion, pvReserved, phModDll);
     return S_OK;
 }
 
@@ -133,6 +142,6 @@
 
 HRESULT WINAPI GetAssemblyMDImport(LPCWSTR szFileName, REFIID riid, IUnknown **ppIUnk)
 {
-    FIXME("(%p %s, %p, %p): stub\n", szFileName, debugstr_w(szFileName), riid, *ppIUnk);
+    FIXME("(%s, %p, %p): stub\n", debugstr_w(szFileName), riid, *ppIUnk);
     return ERROR_CALL_NOT_IMPLEMENTED;
 }


More information about the wine-patches mailing list