ole32: Don't free handles that are just copied in the inproc case.
Based on a patch by Zebediah Figura. Wine-Bug: https://bugs.winehq.org/show_bug.cgi?id=46270 Signed-off-by: Huw Davies <huw@codeweavers.com> Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
parent
1344dcee39
commit
25b136d400
|
@ -2036,11 +2036,29 @@ unsigned char * __RPC_USER STGMEDIUM_UserUnmarshal(ULONG *pFlags, unsigned char
|
||||||
* which the first parameter is a ULONG.
|
* which the first parameter is a ULONG.
|
||||||
* This function is only intended to be called by the RPC runtime.
|
* This function is only intended to be called by the RPC runtime.
|
||||||
*/
|
*/
|
||||||
void __RPC_USER STGMEDIUM_UserFree(ULONG *pFlags, STGMEDIUM *pStgMedium)
|
void __RPC_USER STGMEDIUM_UserFree(ULONG *flags, STGMEDIUM *med)
|
||||||
{
|
{
|
||||||
TRACE("(%s, %p\n", debugstr_user_flags(pFlags), pStgMedium);
|
TRACE("(%s, %p)\n", debugstr_user_flags(flags), med);
|
||||||
|
|
||||||
ReleaseStgMedium(pStgMedium);
|
switch (med->tymed)
|
||||||
|
{
|
||||||
|
case TYMED_NULL:
|
||||||
|
case TYMED_FILE:
|
||||||
|
case TYMED_ISTREAM:
|
||||||
|
case TYMED_ISTORAGE:
|
||||||
|
ReleaseStgMedium(med);
|
||||||
|
break;
|
||||||
|
case TYMED_HGLOBAL:
|
||||||
|
case TYMED_GDI:
|
||||||
|
case TYMED_MFPICT:
|
||||||
|
case TYMED_ENHMF:
|
||||||
|
if (LOWORD(*flags) == MSHCTX_INPROC)
|
||||||
|
med->tymed = TYMED_NULL;
|
||||||
|
ReleaseStgMedium(med);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
RaiseException(DV_E_TYMED, 0, 0, NULL);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ULONG __RPC_USER ASYNC_STGMEDIUM_UserSize(ULONG *pFlags, ULONG StartingSize, ASYNC_STGMEDIUM *pStgMedium)
|
ULONG __RPC_USER ASYNC_STGMEDIUM_UserSize(ULONG *pFlags, ULONG StartingSize, ASYNC_STGMEDIUM *pStgMedium)
|
||||||
|
|
Loading…
Reference in New Issue