Commit cd1f67ee authored by Jacek Caban's avatar Jacek Caban Committed by Alexandre Julliard

ole32: Use proper allocators for storing description in ErrorInfoImpl.

parent 4843f031
...@@ -156,7 +156,7 @@ typedef struct ErrorInfoImpl ...@@ -156,7 +156,7 @@ typedef struct ErrorInfoImpl
GUID m_Guid; GUID m_Guid;
WCHAR *source; WCHAR *source;
BSTR bstrDescription; WCHAR *description;
BSTR bstrHelpFile; BSTR bstrHelpFile;
DWORD m_dwHelpContext; DWORD m_dwHelpContext;
} ErrorInfoImpl; } ErrorInfoImpl;
...@@ -230,7 +230,7 @@ static ULONG WINAPI IErrorInfoImpl_Release( ...@@ -230,7 +230,7 @@ static ULONG WINAPI IErrorInfoImpl_Release(
TRACE("-- destroying IErrorInfo(%p)\n",This); TRACE("-- destroying IErrorInfo(%p)\n",This);
heap_free(This->source); heap_free(This->source);
ERRORINFO_SysFreeString(This->bstrDescription); heap_free(This->description);
ERRORINFO_SysFreeString(This->bstrHelpFile); ERRORINFO_SysFreeString(This->bstrHelpFile);
HeapFree(GetProcessHeap(),0,This); HeapFree(GetProcessHeap(),0,This);
return 0; return 0;
...@@ -270,7 +270,7 @@ static HRESULT WINAPI IErrorInfoImpl_GetDescription( ...@@ -270,7 +270,7 @@ static HRESULT WINAPI IErrorInfoImpl_GetDescription(
TRACE("(%p)->(pBstrDescription=%p)\n",This,pBstrDescription); TRACE("(%p)->(pBstrDescription=%p)\n",This,pBstrDescription);
if (pBstrDescription == NULL) if (pBstrDescription == NULL)
return E_INVALIDARG; return E_INVALIDARG;
*pBstrDescription = ERRORINFO_SysAllocString(This->bstrDescription); *pBstrDescription = SysAllocString(This->description);
return S_OK; return S_OK;
} }
...@@ -368,10 +368,9 @@ static HRESULT WINAPI ICreateErrorInfoImpl_SetDescription( ...@@ -368,10 +368,9 @@ static HRESULT WINAPI ICreateErrorInfoImpl_SetDescription(
{ {
ErrorInfoImpl *This = impl_from_ICreateErrorInfo(iface); ErrorInfoImpl *This = impl_from_ICreateErrorInfo(iface);
TRACE("(%p): %s\n",This, debugstr_w(szDescription)); TRACE("(%p): %s\n",This, debugstr_w(szDescription));
if (This->bstrDescription != NULL)
ERRORINFO_SysFreeString(This->bstrDescription);
This->bstrDescription = ERRORINFO_SysAllocString(szDescription);
heap_free(This->description);
This->description = heap_strdupW(szDescription);
return S_OK; return S_OK;
} }
...@@ -458,7 +457,7 @@ static IErrorInfo* IErrorInfoImpl_Constructor(void) ...@@ -458,7 +457,7 @@ static IErrorInfo* IErrorInfoImpl_Constructor(void)
This->ISupportErrorInfo_iface.lpVtbl = &SupportErrorInfoVtbl; This->ISupportErrorInfo_iface.lpVtbl = &SupportErrorInfoVtbl;
This->ref = 1; This->ref = 1;
This->source = NULL; This->source = NULL;
This->bstrDescription = NULL; This->description = NULL;
This->bstrHelpFile = NULL; This->bstrHelpFile = NULL;
This->m_dwHelpContext = 0; This->m_dwHelpContext = 0;
......
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