From eed31ca4c8f1d1101dda25d77b1e98b5bbf4fe0f Mon Sep 17 00:00:00 2001 From: Vincent Povirk Date: Thu, 6 Nov 2008 08:22:35 -0600 Subject: [PATCH] setupapi: add a matching CoUninitialize call --- dlls/setupapi/install.c | 4 +++- 1 files changed, 3 insertions(+), 1 deletions(-) diff --git a/dlls/setupapi/install.c b/dlls/setupapi/install.c index 0a4db4f..133fb33 100644 --- a/dlls/setupapi/install.c +++ b/dlls/setupapi/install.c @@ -789,6 +789,7 @@ static BOOL profile_items_callback( HINF hinf, PCWSTR field, void *arg ) INFCONTEXT name_context, context; IShellLinkW* shelllink=NULL; IPersistFile* persistfile=NULL; + HRESULT initresult=E_FAIL; int attrs=0; static const WCHAR dotlnk[] = {'.','l','n','k',0}; @@ -864,7 +865,7 @@ static BOOL profile_items_callback( HINF hinf, PCWSTR field, void *arg ) if (!cmdline) return TRUE; - CoInitialize(NULL); + initresult = CoInitialize(NULL); if (!SUCCEEDED(CoCreateInstance( &CLSID_ShellLink, NULL, CLSCTX_INPROC_SERVER, &IID_IShellLinkW, (LPVOID*)&shelllink))) @@ -881,6 +882,7 @@ static BOOL profile_items_callback( HINF hinf, PCWSTR field, void *arg ) IShellLinkW_Release( shelllink ); done: + if (SUCCEEDED(initresult)) CoUninitialize(); HeapFree( GetProcessHeap(), 0, cmdline ); return TRUE; } -- 1.5.6.3