From 3a0ed83fb00ae595e51d72b8b4d0e22ae0f8a98d Mon Sep 17 00:00:00 2001 From: Huw Davies Date: Mon, 20 Oct 2008 15:46:23 +0100 Subject: [PATCH] ole32: Call the object's IPersistStorage_HandsOffStorage() if the object is running. --- dlls/ole32/defaulthandler.c | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/dlls/ole32/defaulthandler.c b/dlls/ole32/defaulthandler.c index 41a5e923d3c..1af0797c0c4 100644 --- a/dlls/ole32/defaulthandler.c +++ b/dlls/ole32/defaulthandler.c @@ -1616,9 +1616,17 @@ static HRESULT WINAPI DefaultHandler_IPersistStorage_SaveCompleted( static HRESULT WINAPI DefaultHandler_IPersistStorage_HandsOffStorage( IPersistStorage* iface) { - DefaultHandler *This = impl_from_IPersistStorage(iface); + DefaultHandler *This = impl_from_IPersistStorage(iface); + HRESULT hr; - return IPersistStorage_HandsOffStorage(This->dataCache_PersistStg); + TRACE("(%p)\n", iface); + + hr = IPersistStorage_HandsOffStorage(This->dataCache_PersistStg); + + if(SUCCEEDED(hr) && object_is_running(This)) + hr = IPersistStorage_HandsOffStorage(This->pPSDelegate); + + return hr; }