mirror of
https://github.com/reactos/reactos.git
synced 2025-01-03 21:09:19 +00:00
[OLE32]
* Add ole32_ros.diff. CORE-8080 svn path=/trunk/; revision=62944
This commit is contained in:
parent
559ca8b24e
commit
07c28802ff
1 changed files with 187 additions and 0 deletions
187
reactos/dll/win32/ole32/ole32_ros.diff
Normal file
187
reactos/dll/win32/ole32/ole32_ros.diff
Normal file
|
@ -0,0 +1,187 @@
|
||||||
|
diff -prudN e:\Wine\dlls\ole32/compobj.c e:\reactos\dll\win32\ole32/compobj.c
|
||||||
|
--- e:\Wine\dlls\ole32/compobj.c 2014-04-04 14:12:42.091208400 +0100
|
||||||
|
+++ e:\reactos\dll\win32\ole32/compobj.c 2014-04-24 12:30:07.466625200 +0100
|
||||||
|
@@ -331,8 +303,12 @@ static NTSTATUS create_key( HKEY *retkey
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
|
+#ifdef __REACTOS__
|
||||||
|
+static const WCHAR classes_rootW[] = L"\\REGISTRY\\Machine\\Software\\Classes";
|
||||||
|
+#else
|
||||||
|
static const WCHAR classes_rootW[] =
|
||||||
|
{'M','a','c','h','i','n','e','\\','S','o','f','t','w','a','r','e','\\','C','l','a','s','s','e','s',0};
|
||||||
|
+#endif
|
||||||
|
|
||||||
|
static HKEY classes_root_hkey;
|
||||||
|
|
||||||
|
@@ -1635,6 +1611,7 @@ static HRESULT apartment_hostobject_in_h
|
||||||
|
return hr;
|
||||||
|
}
|
||||||
|
|
||||||
|
+#ifndef __REACTOS__
|
||||||
|
static BOOL WINAPI register_class( INIT_ONCE *once, void *param, void **context )
|
||||||
|
{
|
||||||
|
WNDCLASSW wclass;
|
||||||
|
@@ -1655,24 +1632,20 @@ static BOOL WINAPI register_class( INIT_
|
||||||
|
RegisterClassW(&wclass);
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
+#endif
|
||||||
|
|
||||||
|
/* create a window for the apartment or return the current one if one has
|
||||||
|
* already been created */
|
||||||
|
HRESULT apartment_createwindowifneeded(struct apartment *apt)
|
||||||
|
{
|
||||||
|
- static INIT_ONCE class_init_once = INIT_ONCE_STATIC_INIT;
|
||||||
|
-
|
||||||
|
if (apt->multi_threaded)
|
||||||
|
return S_OK;
|
||||||
|
|
||||||
|
if (!apt->win)
|
||||||
|
{
|
||||||
|
- HWND hwnd;
|
||||||
|
-
|
||||||
|
- InitOnceExecuteOnce( &class_init_once, register_class, NULL, NULL );
|
||||||
|
-
|
||||||
|
- hwnd = CreateWindowW(wszAptWinClass, NULL, 0, 0, 0, 0, 0,
|
||||||
|
- HWND_MESSAGE, 0, hProxyDll, NULL);
|
||||||
|
+ HWND hwnd = CreateWindowW(wszAptWinClass, NULL, 0,
|
||||||
|
+ 0, 0, 0, 0,
|
||||||
|
+ HWND_MESSAGE, 0, hProxyDll, NULL);
|
||||||
|
if (!hwnd)
|
||||||
|
{
|
||||||
|
ERR("CreateWindow failed with error %d\n", GetLastError());
|
||||||
|
@@ -1699,6 +1672,35 @@ void apartment_joinmta(void)
|
||||||
|
COM_CurrentInfo()->apt = MTA;
|
||||||
|
}
|
||||||
|
|
||||||
|
+#ifdef __REACTOS__
|
||||||
|
+
|
||||||
|
+static void COMPOBJ_InitProcess( void )
|
||||||
|
+{
|
||||||
|
+ WNDCLASSW wclass;
|
||||||
|
+
|
||||||
|
+ /* Dispatching to the correct thread in an apartment is done through
|
||||||
|
+ * window messages rather than RPC transports. When an interface is
|
||||||
|
+ * marshalled into another apartment in the same process, a window of the
|
||||||
|
+ * following class is created. The *caller* of CoMarshalInterface (i.e., the
|
||||||
|
+ * application) is responsible for pumping the message loop in that thread.
|
||||||
|
+ * The WM_USER messages which point to the RPCs are then dispatched to
|
||||||
|
+ * apartment_wndproc by the user's code from the apartment in which the
|
||||||
|
+ * interface was unmarshalled.
|
||||||
|
+ */
|
||||||
|
+ memset(&wclass, 0, sizeof(wclass));
|
||||||
|
+ wclass.lpfnWndProc = apartment_wndproc;
|
||||||
|
+ wclass.hInstance = hProxyDll;
|
||||||
|
+ wclass.lpszClassName = wszAptWinClass;
|
||||||
|
+ RegisterClassW(&wclass);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static void COMPOBJ_UninitProcess( void )
|
||||||
|
+{
|
||||||
|
+ UnregisterClassW(wszAptWinClass, hProxyDll);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+#endif
|
||||||
|
+
|
||||||
|
static void COM_TlsDestroy(void)
|
||||||
|
{
|
||||||
|
struct oletls *info = NtCurrentTeb()->ReservedForOle;
|
||||||
|
@@ -4984,12 +4986,13 @@ BOOL WINAPI DllMain(HINSTANCE hinstDLL,
|
||||||
|
switch(fdwReason) {
|
||||||
|
case DLL_PROCESS_ATTACH:
|
||||||
|
hProxyDll = hinstDLL;
|
||||||
|
+ COMPOBJ_InitProcess();
|
||||||
|
break;
|
||||||
|
|
||||||
|
case DLL_PROCESS_DETACH:
|
||||||
|
if (reserved) break;
|
||||||
|
release_std_git();
|
||||||
|
- UnregisterClassW( wszAptWinClass, hProxyDll );
|
||||||
|
+ COMPOBJ_UninitProcess();
|
||||||
|
RPC_UnregisterAllChannelHooks();
|
||||||
|
COMPOBJ_DllList_Free();
|
||||||
|
DeleteCriticalSection(&csRegisteredClassList);
|
||||||
|
diff -prudN e:\Wine\dlls\ole32/stg_prop.c e:\reactos\dll\win32\ole32/stg_prop.c
|
||||||
|
--- e:\Wine\dlls\ole32/stg_prop.c 2014-04-04 14:12:42.103216400 +0100
|
||||||
|
+++ e:\reactos\dll\win32\ole32/stg_prop.c 2014-04-08 19:21:32.097336500 +0100
|
||||||
|
@@ -36,32 +36,15 @@
|
||||||
|
* PropertyStorage_ReadFromStream
|
||||||
|
*/
|
||||||
|
|
||||||
|
-#include "config.h"
|
||||||
|
-#include "wine/port.h"
|
||||||
|
-
|
||||||
|
-#include <assert.h>
|
||||||
|
-#include <stdarg.h>
|
||||||
|
-#include <stdio.h>
|
||||||
|
-#include <stdlib.h>
|
||||||
|
-#include <string.h>
|
||||||
|
-
|
||||||
|
-#define COBJMACROS
|
||||||
|
-#define NONAMELESSUNION
|
||||||
|
-#define NONAMELESSSTRUCT
|
||||||
|
-
|
||||||
|
-#include "windef.h"
|
||||||
|
-#include "winbase.h"
|
||||||
|
-#include "winnls.h"
|
||||||
|
-#include "winuser.h"
|
||||||
|
-#include "wine/unicode.h"
|
||||||
|
-#include "wine/debug.h"
|
||||||
|
-#include "dictionary.h"
|
||||||
|
+#include "precomp.h"
|
||||||
|
#include "storage32.h"
|
||||||
|
-#include "enumx.h"
|
||||||
|
-#include "oleauto.h"
|
||||||
|
|
||||||
|
WINE_DEFAULT_DEBUG_CHANNEL(storage);
|
||||||
|
|
||||||
|
+#ifdef _MSC_VER
|
||||||
|
+#define __ASM_STDCALL_FUNC(name,args,code)
|
||||||
|
+#endif
|
||||||
|
+
|
||||||
|
static inline StorageImpl *impl_from_IPropertySetStorage( IPropertySetStorage *iface )
|
||||||
|
{
|
||||||
|
return CONTAINING_RECORD(iface, StorageImpl, base.IPropertySetStorage_iface);
|
||||||
|
@@ -1035,12 +1018,12 @@ static HRESULT PropertyStorage_ReadDicti
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef __i386__
|
||||||
|
-#define __thiscall __stdcall
|
||||||
|
+#define __thiscall_wrapper __stdcall
|
||||||
|
#else
|
||||||
|
-#define __thiscall __cdecl
|
||||||
|
+#define __thiscall_wrapper __cdecl
|
||||||
|
#endif
|
||||||
|
|
||||||
|
-static __thiscall void* Allocate_CoTaskMemAlloc(void *userdata, ULONG size)
|
||||||
|
+static void* __thiscall_wrapper Allocate_CoTaskMemAlloc(void *userdata, ULONG size)
|
||||||
|
{
|
||||||
|
return CoTaskMemAlloc(size);
|
||||||
|
}
|
||||||
|
@@ -1049,7 +1032,7 @@ static __thiscall void* Allocate_CoTaskM
|
||||||
|
* end of the buffer.
|
||||||
|
*/
|
||||||
|
static HRESULT PropertyStorage_ReadProperty(PROPVARIANT *prop, const BYTE *data,
|
||||||
|
- UINT codepage, void* (__thiscall *allocate)(void *userdata, ULONG size), void *allocate_data)
|
||||||
|
+ UINT codepage, void* (__thiscall_wrapper *allocate)(void *userdata, ULONG size), void *allocate_data)
|
||||||
|
{
|
||||||
|
HRESULT hr = S_OK;
|
||||||
|
|
||||||
|
@@ -2738,13 +2721,13 @@ end:
|
||||||
|
"jmp *(4*(" #num "))(%eax)" )
|
||||||
|
|
||||||
|
DEFINE_STDCALL_WRAPPER(0,Allocate_PMemoryAllocator,8)
|
||||||
|
-extern void* __thiscall Allocate_PMemoryAllocator(void *this, ULONG cbSize);
|
||||||
|
+extern void* __stdcall Allocate_PMemoryAllocator(void *this, ULONG cbSize);
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
-static void* __thiscall Allocate_PMemoryAllocator(void *this, ULONG cbSize)
|
||||||
|
+static void* __cdecl Allocate_PMemoryAllocator(void *this, ULONG cbSize)
|
||||||
|
{
|
||||||
|
- void* (__thiscall *fn)(void*,ULONG) = **(void***)this;
|
||||||
|
+ void* (__cdecl *fn)(void*,ULONG) = **(void***)this;
|
||||||
|
return fn(this, cbSize);
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue