comsvcs: Implement IPersistStream methods for "new" moniker.

Signed-off-by: Nikolay Sivov <nsivov@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
Nikolay Sivov 2019-11-05 13:09:29 +03:00 committed by Alexandre Julliard
parent f1123366d1
commit 239055cfc7
2 changed files with 92 additions and 11 deletions

View File

@ -476,37 +476,76 @@ static ULONG WINAPI new_moniker_Release(IMoniker* iface)
static HRESULT WINAPI new_moniker_GetClassID(IMoniker *iface, CLSID *clsid) static HRESULT WINAPI new_moniker_GetClassID(IMoniker *iface, CLSID *clsid)
{ {
FIXME("%p, %p.\n", iface, clsid); TRACE("%p, %p.\n", iface, clsid);
return E_NOTIMPL; if (!clsid)
return E_POINTER;
*clsid = CLSID_NewMoniker;
return S_OK;
} }
static HRESULT WINAPI new_moniker_IsDirty(IMoniker* iface) static HRESULT WINAPI new_moniker_IsDirty(IMoniker* iface)
{ {
FIXME("%p.\n", iface); TRACE("%p.\n", iface);
return E_NOTIMPL; return S_FALSE;
} }
static HRESULT WINAPI new_moniker_Load(IMoniker *iface, IStream *stream) static HRESULT WINAPI new_moniker_Load(IMoniker *iface, IStream *stream)
{ {
FIXME("%p, %p.\n", iface, stream); struct new_moniker *moniker = impl_from_IMoniker(iface);
ULARGE_INTEGER pad;
CLSID clsid;
HRESULT hr;
DWORD len;
return E_NOTIMPL; TRACE("%p, %p.\n", iface, stream);
hr = IStream_Read(stream, &clsid, sizeof(clsid), &len);
if (FAILED(hr))
return hr;
pad.QuadPart = 1;
hr = IStream_Read(stream, &pad, sizeof(pad), &len);
if (FAILED(hr))
return hr;
if (pad.QuadPart != 0)
return E_FAIL;
moniker->clsid = clsid;
return S_OK;
} }
static HRESULT WINAPI new_moniker_Save(IMoniker *iface, IStream *stream, BOOL clear_dirty) static HRESULT WINAPI new_moniker_Save(IMoniker *iface, IStream *stream, BOOL clear_dirty)
{ {
FIXME("%p, %p, %d.\n", iface, stream, clear_dirty); struct new_moniker *moniker = impl_from_IMoniker(iface);
static const ULARGE_INTEGER pad;
ULONG written;
HRESULT hr;
return E_NOTIMPL; TRACE("%p, %p, %d.\n", iface, stream, clear_dirty);
hr = IStream_Write(stream, &moniker->clsid, sizeof(moniker->clsid), &written);
if (SUCCEEDED(hr))
hr = IStream_Write(stream, &pad, sizeof(pad), &written);
return hr;
} }
static HRESULT WINAPI new_moniker_GetSizeMax(IMoniker *iface, ULARGE_INTEGER *size) static HRESULT WINAPI new_moniker_GetSizeMax(IMoniker *iface, ULARGE_INTEGER *size)
{ {
FIXME("%p, %p.\n", iface, size); TRACE("%p, %p.\n", iface, size);
return E_NOTIMPL; if (!size)
return E_POINTER;
size->QuadPart = sizeof(CLSID) + 2 * sizeof(DWORD);
return S_OK;
} }
static HRESULT WINAPI new_moniker_BindToObject(IMoniker *iface, IBindCtx *pbc, IMoniker *pmkToLeft, static HRESULT WINAPI new_moniker_BindToObject(IMoniker *iface, IBindCtx *pbc, IMoniker *pmkToLeft,

View File

@ -270,13 +270,17 @@ static void create_dispenser(void)
static void test_new_moniker(void) static void test_new_moniker(void)
{ {
IMoniker *moniker, *moniker2, *inverse, *class_moniker; IMoniker *moniker, *moniker2, *inverse, *class_moniker;
IUnknown *obj, *obj2;
ULARGE_INTEGER size;
DWORD moniker_type; DWORD moniker_type;
IBindCtx *bindctx; IBindCtx *bindctx;
FILETIME filetime; FILETIME filetime;
DWORD hash, eaten; DWORD hash, eaten;
IUnknown *obj, *obj2; IStream *stream;
HGLOBAL hglobal;
CLSID clsid; CLSID clsid;
HRESULT hr; HRESULT hr;
void *ptr;
hr = CreateBindCtx(0, &bindctx); hr = CreateBindCtx(0, &bindctx);
ok(hr == S_OK, "Failed to create bind context, hr %#x.\n", hr); ok(hr == S_OK, "Failed to create bind context, hr %#x.\n", hr);
@ -372,6 +376,44 @@ todo_wine
ok(hr == S_OK, "Unexpected hr %#x.\n", hr); ok(hr == S_OK, "Unexpected hr %#x.\n", hr);
ok(obj == NULL, "Unexpected return value.\n"); ok(obj == NULL, "Unexpected return value.\n");
/* Serialization. */
hr = IMoniker_GetSizeMax(moniker, NULL);
ok(hr == E_POINTER, "Unexpected hr %#x.\n", hr);
size.QuadPart = 0;
hr = IMoniker_GetSizeMax(moniker, &size);
ok(hr == S_OK, "Failed to get size, hr %#x.\n", hr);
ok(size.QuadPart == (sizeof(GUID) + 2 * sizeof(DWORD)), "Unexpected size %s.\n",
wine_dbgstr_longlong(size.QuadPart));
hr = CreateStreamOnHGlobal(NULL, TRUE, &stream);
ok(hr == S_OK, "Failed to create a stream, hr %#x.\n", hr);
hr = IMoniker_Save(moniker, stream, FALSE);
ok(hr == S_OK, "Failed to save moniker, hr %#x.\n", hr);
hr = GetHGlobalFromStream(stream, &hglobal);
ok(hr == S_OK, "Failed to get a handle, hr %#x.\n", hr);
ptr = GlobalLock(hglobal);
ok(!!ptr, "Failed to get data pointer.\n");
hr = CLSIDFromString(L"{20d04fe0-3aea-1069-a2d8-08002b30309d}", &clsid);
ok(hr == S_OK, "Failed to get CLSID, hr %#x.\n", hr);
ok(IsEqualGUID((GUID *)ptr, &clsid), "Unexpected buffer content.\n");
ok(*(DWORD *)((BYTE *)ptr + sizeof(GUID)) == 0, "Unexpected buffer content.\n");
ok(*(DWORD *)((BYTE *)ptr + sizeof(GUID) + sizeof(DWORD)) == 0, "Unexpected buffer content.\n");
GlobalUnlock(hglobal);
IStream_Release(stream);
hr = IMoniker_IsDirty(moniker);
ok(hr == S_FALSE, "Unexpected hr %#x.\n", hr);
hr = IMoniker_GetClassID(moniker, NULL);
ok(hr == E_POINTER, "Unexpected hr %#x.\n", hr);
IMoniker_Release(moniker); IMoniker_Release(moniker);
IBindCtx_Release(bindctx); IBindCtx_Release(bindctx);
} }