Commit 68523af9 authored by Huw Davies's avatar Huw Davies Committed by Alexandre Julliard

riched20: Don't take a ref on the text host.

This would result in the host and services objects holding refs on each other. Signed-off-by: 's avatarHuw Davies <huw@codeweavers.com> Signed-off-by: 's avatarAlexandre Julliard <julliard@winehq.org>
parent 83254bb3
...@@ -3221,7 +3221,6 @@ void ME_DestroyEditor(ME_TextEditor *editor) ...@@ -3221,7 +3221,6 @@ void ME_DestroyEditor(ME_TextEditor *editor)
DeleteObject(editor->hbrBackground); DeleteObject(editor->hbrBackground);
if(editor->lpOleCallback) if(editor->lpOleCallback)
IRichEditOleCallback_Release(editor->lpOleCallback); IRichEditOleCallback_Release(editor->lpOleCallback);
ITextHost_Release(editor->texthost);
if (editor->reOle) if (editor->reOle)
{ {
IUnknown_Release(editor->reOle); IUnknown_Release(editor->reOle);
......
...@@ -602,6 +602,7 @@ static BOOL init_texthost(ITextServices **txtserv, ITextHost **ret) ...@@ -602,6 +602,7 @@ static BOOL init_texthost(ITextServices **txtserv, ITextHost **ret)
ITextServices object. */ ITextServices object. */
result = pCreateTextServices(NULL, &dummyTextHost->ITextHost_iface, &init); result = pCreateTextServices(NULL, &dummyTextHost->ITextHost_iface, &init);
ok(result == S_OK, "Did not return S_OK when created (result = %x)\n", result); ok(result == S_OK, "Did not return S_OK when created (result = %x)\n", result);
ok(dummyTextHost->refCount == 1, "host ref %d\n", dummyTextHost->refCount);
if (result != S_OK) { if (result != S_OK) {
CoTaskMemFree(dummyTextHost); CoTaskMemFree(dummyTextHost);
win_skip("CreateTextServices failed.\n"); win_skip("CreateTextServices failed.\n");
......
...@@ -38,7 +38,7 @@ struct text_services ...@@ -38,7 +38,7 @@ struct text_services
ITextServices ITextServices_iface; ITextServices ITextServices_iface;
IUnknown *outer_unk; IUnknown *outer_unk;
LONG ref; LONG ref;
ITextHost *pMyHost; ITextHost *host;
CRITICAL_SECTION csTxtSrv; CRITICAL_SECTION csTxtSrv;
ME_TextEditor *editor; ME_TextEditor *editor;
char spare[256]; char spare[256];
...@@ -385,8 +385,7 @@ HRESULT WINAPI CreateTextServices(IUnknown *pUnkOuter, ITextHost *pITextHost, I ...@@ -385,8 +385,7 @@ HRESULT WINAPI CreateTextServices(IUnknown *pUnkOuter, ITextHost *pITextHost, I
InitializeCriticalSection(&ITextImpl->csTxtSrv); InitializeCriticalSection(&ITextImpl->csTxtSrv);
ITextImpl->csTxtSrv.DebugInfo->Spare[0] = (DWORD_PTR)(__FILE__ ": ITextServicesImpl.csTxtSrv"); ITextImpl->csTxtSrv.DebugInfo->Spare[0] = (DWORD_PTR)(__FILE__ ": ITextServicesImpl.csTxtSrv");
ITextImpl->ref = 1; ITextImpl->ref = 1;
ITextHost_AddRef(pITextHost); ITextImpl->host = pITextHost; /* Don't take a ref of the host - this would lead to a mutual dependency */
ITextImpl->pMyHost = pITextHost;
ITextImpl->IUnknown_inner.lpVtbl = &textservices_inner_vtbl; ITextImpl->IUnknown_inner.lpVtbl = &textservices_inner_vtbl;
ITextImpl->ITextServices_iface.lpVtbl = &textservices_vtbl; ITextImpl->ITextServices_iface.lpVtbl = &textservices_vtbl;
ITextImpl->editor = ME_MakeEditor(pITextHost, FALSE); ITextImpl->editor = ME_MakeEditor(pITextHost, FALSE);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment