Commit 65a468ef authored by Nikolay Sivov's avatar Nikolay Sivov Committed by Alexandre Julliard

advapi32: Use heap* helpers in service code.

parent 4c782606
...@@ -42,6 +42,12 @@ static inline void *heap_alloc( size_t len ) ...@@ -42,6 +42,12 @@ static inline void *heap_alloc( size_t len )
return HeapAlloc( GetProcessHeap(), 0, len ); return HeapAlloc( GetProcessHeap(), 0, len );
} }
static void *heap_alloc_zero( size_t len ) __WINE_ALLOC_SIZE(1);
static inline void *heap_alloc_zero( size_t len )
{
return HeapAlloc( GetProcessHeap(), HEAP_ZERO_MEMORY, len );
}
static void *heap_realloc( void *mem, size_t len ) __WINE_ALLOC_SIZE(2); static void *heap_realloc( void *mem, size_t len ) __WINE_ALLOC_SIZE(2);
static inline void *heap_realloc( void *mem, size_t len ) static inline void *heap_realloc( void *mem, size_t len )
{ {
......
...@@ -51,12 +51,12 @@ WINE_DEFAULT_DEBUG_CHANNEL(service); ...@@ -51,12 +51,12 @@ WINE_DEFAULT_DEBUG_CHANNEL(service);
void __RPC_FAR * __RPC_USER MIDL_user_allocate(SIZE_T len) void __RPC_FAR * __RPC_USER MIDL_user_allocate(SIZE_T len)
{ {
return HeapAlloc(GetProcessHeap(), 0, len); return heap_alloc(len);
} }
void __RPC_USER MIDL_user_free(void __RPC_FAR * ptr) void __RPC_USER MIDL_user_free(void __RPC_FAR * ptr)
{ {
HeapFree(GetProcessHeap(), 0, ptr); heap_free(ptr);
} }
typedef struct service_data_t typedef struct service_data_t
...@@ -111,7 +111,7 @@ LPWSTR SERV_dup( LPCSTR str ) ...@@ -111,7 +111,7 @@ LPWSTR SERV_dup( LPCSTR str )
if( !str ) if( !str )
return NULL; return NULL;
len = MultiByteToWideChar( CP_ACP, 0, str, -1, NULL, 0 ); len = MultiByteToWideChar( CP_ACP, 0, str, -1, NULL, 0 );
wstr = HeapAlloc( GetProcessHeap(), 0, len*sizeof (WCHAR) ); wstr = heap_alloc( len*sizeof (WCHAR) );
MultiByteToWideChar( CP_ACP, 0, str, -1, wstr, len ); MultiByteToWideChar( CP_ACP, 0, str, -1, wstr, len );
return wstr; return wstr;
} }
...@@ -130,7 +130,7 @@ static inline LPWSTR SERV_dupmulti(LPCSTR str) ...@@ -130,7 +130,7 @@ static inline LPWSTR SERV_dupmulti(LPCSTR str)
len++; len++;
n++; n++;
wstr = HeapAlloc( GetProcessHeap(), 0, len*sizeof (WCHAR) ); wstr = heap_alloc( len*sizeof (WCHAR) );
MultiByteToWideChar( CP_ACP, 0, str, n, wstr, len ); MultiByteToWideChar( CP_ACP, 0, str, n, wstr, len );
return wstr; return wstr;
} }
...@@ -234,7 +234,7 @@ static LPWSTR service_get_pipe_name(void) ...@@ -234,7 +234,7 @@ static LPWSTR service_get_pipe_name(void)
if (ret != ERROR_SUCCESS || type != REG_DWORD) if (ret != ERROR_SUCCESS || type != REG_DWORD)
return NULL; return NULL;
len = sizeof(format)/sizeof(WCHAR) + 10 /* strlenW("4294967295") */; len = sizeof(format)/sizeof(WCHAR) + 10 /* strlenW("4294967295") */;
name = HeapAlloc(GetProcessHeap(), 0, len * sizeof(WCHAR)); name = heap_alloc(len * sizeof(WCHAR));
if (!name) if (!name)
return NULL; return NULL;
snprintfW(name, len, format, service_current); snprintfW(name, len, format, service_current);
...@@ -254,7 +254,7 @@ static HANDLE service_open_pipe(void) ...@@ -254,7 +254,7 @@ static HANDLE service_open_pipe(void)
if (GetLastError() != ERROR_PIPE_BUSY) if (GetLastError() != ERROR_PIPE_BUSY)
break; break;
} while (WaitNamedPipeW(szPipe, NMPWAIT_USE_DEFAULT_WAIT)); } while (WaitNamedPipeW(szPipe, NMPWAIT_USE_DEFAULT_WAIT));
HeapFree(GetProcessHeap(), 0, szPipe); heap_free(szPipe);
return handle; return handle;
} }
...@@ -294,13 +294,13 @@ static DWORD WINAPI service_thread(LPVOID arg) ...@@ -294,13 +294,13 @@ static DWORD WINAPI service_thread(LPVOID arg)
{ {
LPWSTR *argv, p; LPWSTR *argv, p;
argv = HeapAlloc(GetProcessHeap(), 0, (argc+1)*sizeof(LPWSTR)); argv = heap_alloc((argc+1)*sizeof(LPWSTR));
for (argc=0, p=str; *p; p += strlenW(p) + 1) for (argc=0, p=str; *p; p += strlenW(p) + 1)
argv[argc++] = p; argv[argc++] = p;
argv[argc] = NULL; argv[argc] = NULL;
info->proc.w(argc, argv); info->proc.w(argc, argv);
HeapFree(GetProcessHeap(), 0, argv); heap_free(argv);
} }
else else
{ {
...@@ -308,17 +308,17 @@ static DWORD WINAPI service_thread(LPVOID arg) ...@@ -308,17 +308,17 @@ static DWORD WINAPI service_thread(LPVOID arg)
DWORD lenA; DWORD lenA;
lenA = WideCharToMultiByte(CP_ACP,0, str, len, NULL, 0, NULL, NULL); lenA = WideCharToMultiByte(CP_ACP,0, str, len, NULL, 0, NULL, NULL);
strA = HeapAlloc(GetProcessHeap(), 0, lenA); strA = heap_alloc(lenA);
WideCharToMultiByte(CP_ACP,0, str, len, strA, lenA, NULL, NULL); WideCharToMultiByte(CP_ACP,0, str, len, strA, lenA, NULL, NULL);
argv = HeapAlloc(GetProcessHeap(), 0, (argc+1)*sizeof(LPSTR)); argv = heap_alloc((argc+1)*sizeof(LPSTR));
for (argc=0, p=strA; *p; p += strlen(p) + 1) for (argc=0, p=strA; *p; p += strlen(p) + 1)
argv[argc++] = p; argv[argc++] = p;
argv[argc] = NULL; argv[argc] = NULL;
info->proc.a(argc, argv); info->proc.a(argc, argv);
HeapFree(GetProcessHeap(), 0, argv); heap_free(argv);
HeapFree(GetProcessHeap(), 0, strA); heap_free(strA);
} }
return 0; return 0;
} }
...@@ -336,8 +336,8 @@ static DWORD service_handle_start(service_data *service, const WCHAR *data, DWOR ...@@ -336,8 +336,8 @@ static DWORD service_handle_start(service_data *service, const WCHAR *data, DWOR
return ERROR_SERVICE_ALREADY_RUNNING; return ERROR_SERVICE_ALREADY_RUNNING;
} }
HeapFree(GetProcessHeap(), 0, service->args); heap_free(service->args);
service->args = HeapAlloc(GetProcessHeap(), 0, count * sizeof(WCHAR)); service->args = heap_alloc(count * sizeof(WCHAR));
memcpy( service->args, data, count * sizeof(WCHAR) ); memcpy( service->args, data, count * sizeof(WCHAR) );
service->thread = CreateThread( NULL, 0, service_thread, service->thread = CreateThread( NULL, 0, service_thread,
service, 0, NULL ); service, 0, NULL );
...@@ -390,19 +390,19 @@ static DWORD WINAPI service_control_dispatcher(LPVOID arg) ...@@ -390,19 +390,19 @@ static DWORD WINAPI service_control_dispatcher(LPVOID arg)
if (count < info.total_size) if (count < info.total_size)
{ {
data_size = info.total_size - FIELD_OFFSET(service_start_info,data); data_size = info.total_size - FIELD_OFFSET(service_start_info,data);
data = HeapAlloc( GetProcessHeap(), 0, data_size ); data = heap_alloc( data_size );
r = ReadFile( disp->pipe, data, data_size, &count, NULL ); r = ReadFile( disp->pipe, data, data_size, &count, NULL );
if (!r) if (!r)
{ {
if (GetLastError() != ERROR_BROKEN_PIPE) if (GetLastError() != ERROR_BROKEN_PIPE)
ERR( "pipe read failed error %u\n", GetLastError() ); ERR( "pipe read failed error %u\n", GetLastError() );
HeapFree( GetProcessHeap(), 0, data ); heap_free( data );
break; break;
} }
if (count != data_size) if (count != data_size)
{ {
ERR( "partial pipe read %u/%u\n", count, data_size ); ERR( "partial pipe read %u/%u\n", count, data_size );
HeapFree( GetProcessHeap(), 0, data ); heap_free( data );
break; break;
} }
} }
...@@ -442,12 +442,12 @@ static DWORD WINAPI service_control_dispatcher(LPVOID arg) ...@@ -442,12 +442,12 @@ static DWORD WINAPI service_control_dispatcher(LPVOID arg)
done: done:
WriteFile( disp->pipe, &result, sizeof(result), &count, NULL ); WriteFile( disp->pipe, &result, sizeof(result), &count, NULL );
HeapFree( GetProcessHeap(), 0, data ); heap_free( data );
} }
CloseHandle( disp->pipe ); CloseHandle( disp->pipe );
CloseServiceHandle( disp->manager ); CloseServiceHandle( disp->manager );
HeapFree( GetProcessHeap(), 0, disp ); heap_free( disp );
return 1; return 1;
} }
...@@ -459,13 +459,13 @@ static BOOL service_run_main_thread(void) ...@@ -459,13 +459,13 @@ static BOOL service_run_main_thread(void)
DWORD i, n, ret; DWORD i, n, ret;
HANDLE wait_handles[MAXIMUM_WAIT_OBJECTS]; HANDLE wait_handles[MAXIMUM_WAIT_OBJECTS];
UINT wait_services[MAXIMUM_WAIT_OBJECTS]; UINT wait_services[MAXIMUM_WAIT_OBJECTS];
dispatcher_data *disp = HeapAlloc( GetProcessHeap(), 0, sizeof(*disp) ); dispatcher_data *disp = heap_alloc( sizeof(*disp) );
disp->manager = OpenSCManagerW( NULL, NULL, SC_MANAGER_CONNECT ); disp->manager = OpenSCManagerW( NULL, NULL, SC_MANAGER_CONNECT );
if (!disp->manager) if (!disp->manager)
{ {
ERR("failed to open service manager error %u\n", GetLastError()); ERR("failed to open service manager error %u\n", GetLastError());
HeapFree( GetProcessHeap(), 0, disp ); heap_free( disp );
return FALSE; return FALSE;
} }
...@@ -474,7 +474,7 @@ static BOOL service_run_main_thread(void) ...@@ -474,7 +474,7 @@ static BOOL service_run_main_thread(void)
{ {
WARN("failed to create control pipe error %u\n", GetLastError()); WARN("failed to create control pipe error %u\n", GetLastError());
CloseServiceHandle( disp->manager ); CloseServiceHandle( disp->manager );
HeapFree( GetProcessHeap(), 0, disp ); heap_free( disp );
SetLastError( ERROR_FAILED_SERVICE_CONTROLLER_CONNECT ); SetLastError( ERROR_FAILED_SERVICE_CONTROLLER_CONNECT );
return FALSE; return FALSE;
} }
...@@ -590,13 +590,13 @@ BOOL WINAPI StartServiceCtrlDispatcherA( const SERVICE_TABLE_ENTRYA *servent ) ...@@ -590,13 +590,13 @@ BOOL WINAPI StartServiceCtrlDispatcherA( const SERVICE_TABLE_ENTRYA *servent )
return FALSE; return FALSE;
} }
services = HeapAlloc( GetProcessHeap(), 0, nb_services * sizeof(*services) ); services = heap_alloc( nb_services * sizeof(*services) );
for (i = 0; i < nb_services; i++) for (i = 0; i < nb_services; i++)
{ {
DWORD len = MultiByteToWideChar(CP_ACP, 0, servent[i].lpServiceName, -1, NULL, 0); DWORD len = MultiByteToWideChar(CP_ACP, 0, servent[i].lpServiceName, -1, NULL, 0);
DWORD sz = FIELD_OFFSET( service_data, name[len] ); DWORD sz = FIELD_OFFSET( service_data, name[len] );
info = HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, sz ); info = heap_alloc_zero( sz );
MultiByteToWideChar(CP_ACP, 0, servent[i].lpServiceName, -1, info->name, len); MultiByteToWideChar(CP_ACP, 0, servent[i].lpServiceName, -1, info->name, len);
info->proc.a = servent[i].lpServiceProc; info->proc.a = servent[i].lpServiceProc;
info->unicode = FALSE; info->unicode = FALSE;
...@@ -638,13 +638,13 @@ BOOL WINAPI StartServiceCtrlDispatcherW( const SERVICE_TABLE_ENTRYW *servent ) ...@@ -638,13 +638,13 @@ BOOL WINAPI StartServiceCtrlDispatcherW( const SERVICE_TABLE_ENTRYW *servent )
return FALSE; return FALSE;
} }
services = HeapAlloc( GetProcessHeap(), 0, nb_services * sizeof(*services) ); services = heap_alloc( nb_services * sizeof(*services) );
for (i = 0; i < nb_services; i++) for (i = 0; i < nb_services; i++)
{ {
DWORD len = strlenW(servent[i].lpServiceName) + 1; DWORD len = strlenW(servent[i].lpServiceName) + 1;
DWORD sz = FIELD_OFFSET( service_data, name[len] ); DWORD sz = FIELD_OFFSET( service_data, name[len] );
info = HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, sz ); info = heap_alloc_zero( sz );
strcpyW(info->name, servent[i].lpServiceName); strcpyW(info->name, servent[i].lpServiceName);
info->proc.w = servent[i].lpServiceProc; info->proc.w = servent[i].lpServiceProc;
info->unicode = TRUE; info->unicode = TRUE;
...@@ -767,14 +767,14 @@ SetServiceStatus( SERVICE_STATUS_HANDLE hService, LPSERVICE_STATUS lpStatus ) ...@@ -767,14 +767,14 @@ SetServiceStatus( SERVICE_STATUS_HANDLE hService, LPSERVICE_STATUS lpStatus )
SC_HANDLE WINAPI OpenSCManagerA( LPCSTR lpMachineName, LPCSTR lpDatabaseName, SC_HANDLE WINAPI OpenSCManagerA( LPCSTR lpMachineName, LPCSTR lpDatabaseName,
DWORD dwDesiredAccess ) DWORD dwDesiredAccess )
{ {
LPWSTR lpMachineNameW, lpDatabaseNameW; LPWSTR machineW, databaseW;
SC_HANDLE ret; SC_HANDLE ret;
lpMachineNameW = SERV_dup(lpMachineName); machineW = SERV_dup(lpMachineName);
lpDatabaseNameW = SERV_dup(lpDatabaseName); databaseW = SERV_dup(lpDatabaseName);
ret = OpenSCManagerW(lpMachineNameW, lpDatabaseNameW, dwDesiredAccess); ret = OpenSCManagerW(machineW, databaseW, dwDesiredAccess);
HeapFree(GetProcessHeap(), 0, lpDatabaseNameW); heap_free(databaseW);
HeapFree(GetProcessHeap(), 0, lpMachineNameW); heap_free(machineW);
return ret; return ret;
} }
...@@ -925,7 +925,7 @@ SC_HANDLE WINAPI OpenServiceA( SC_HANDLE hSCManager, LPCSTR lpServiceName, ...@@ -925,7 +925,7 @@ SC_HANDLE WINAPI OpenServiceA( SC_HANDLE hSCManager, LPCSTR lpServiceName,
lpServiceNameW = SERV_dup(lpServiceName); lpServiceNameW = SERV_dup(lpServiceName);
ret = OpenServiceW( hSCManager, lpServiceNameW, dwDesiredAccess); ret = OpenServiceW( hSCManager, lpServiceNameW, dwDesiredAccess);
HeapFree(GetProcessHeap(), 0, lpServiceNameW); heap_free(lpServiceNameW);
return ret; return ret;
} }
...@@ -1059,13 +1059,13 @@ CreateServiceA( SC_HANDLE hSCManager, LPCSTR lpServiceName, ...@@ -1059,13 +1059,13 @@ CreateServiceA( SC_HANDLE hSCManager, LPCSTR lpServiceName,
lpBinaryPathNameW, lpLoadOrderGroupW, lpdwTagId, lpBinaryPathNameW, lpLoadOrderGroupW, lpdwTagId,
lpDependenciesW, lpServiceStartNameW, lpPasswordW ); lpDependenciesW, lpServiceStartNameW, lpPasswordW );
HeapFree( GetProcessHeap(), 0, lpServiceNameW ); heap_free( lpServiceNameW );
HeapFree( GetProcessHeap(), 0, lpDisplayNameW ); heap_free( lpDisplayNameW );
HeapFree( GetProcessHeap(), 0, lpBinaryPathNameW ); heap_free( lpBinaryPathNameW );
HeapFree( GetProcessHeap(), 0, lpLoadOrderGroupW ); heap_free( lpLoadOrderGroupW );
HeapFree( GetProcessHeap(), 0, lpDependenciesW ); heap_free( lpDependenciesW );
HeapFree( GetProcessHeap(), 0, lpServiceStartNameW ); heap_free( lpServiceStartNameW );
HeapFree( GetProcessHeap(), 0, lpPasswordW ); heap_free( lpPasswordW );
return r; return r;
} }
...@@ -1141,8 +1141,7 @@ BOOL WINAPI StartServiceA( SC_HANDLE hService, DWORD dwNumServiceArgs, ...@@ -1141,8 +1141,7 @@ BOOL WINAPI StartServiceA( SC_HANDLE hService, DWORD dwNumServiceArgs,
TRACE("(%p,%d,%p)\n",hService,dwNumServiceArgs,lpServiceArgVectors); TRACE("(%p,%d,%p)\n",hService,dwNumServiceArgs,lpServiceArgVectors);
if (dwNumServiceArgs) if (dwNumServiceArgs)
lpwstr = HeapAlloc( GetProcessHeap(), 0, lpwstr = heap_alloc( dwNumServiceArgs*sizeof(LPWSTR) );
dwNumServiceArgs*sizeof(LPWSTR) );
for(i=0; i<dwNumServiceArgs; i++) for(i=0; i<dwNumServiceArgs; i++)
lpwstr[i]=SERV_dup(lpServiceArgVectors[i]); lpwstr[i]=SERV_dup(lpServiceArgVectors[i]);
...@@ -1152,8 +1151,8 @@ BOOL WINAPI StartServiceA( SC_HANDLE hService, DWORD dwNumServiceArgs, ...@@ -1152,8 +1151,8 @@ BOOL WINAPI StartServiceA( SC_HANDLE hService, DWORD dwNumServiceArgs,
if (dwNumServiceArgs) if (dwNumServiceArgs)
{ {
for(i=0; i<dwNumServiceArgs; i++) for(i=0; i<dwNumServiceArgs; i++)
HeapFree(GetProcessHeap(), 0, lpwstr[i]); heap_free(lpwstr[i]);
HeapFree(GetProcessHeap(), 0, lpwstr); heap_free(lpwstr);
} }
return r; return r;
...@@ -1291,7 +1290,7 @@ BOOL WINAPI QueryServiceConfigA( SC_HANDLE hService, LPQUERY_SERVICE_CONFIGA con ...@@ -1291,7 +1290,7 @@ BOOL WINAPI QueryServiceConfigA( SC_HANDLE hService, LPQUERY_SERVICE_CONFIGA con
TRACE("%p %p %d %p\n", hService, config, size, needed); TRACE("%p %p %d %p\n", hService, config, size, needed);
if (!(buffer = HeapAlloc( GetProcessHeap(), 0, 2 * size ))) if (!(buffer = heap_alloc( 2 * size )))
{ {
SetLastError( ERROR_NOT_ENOUGH_MEMORY ); SetLastError( ERROR_NOT_ENOUGH_MEMORY );
return FALSE; return FALSE;
...@@ -1337,7 +1336,7 @@ BOOL WINAPI QueryServiceConfigA( SC_HANDLE hService, LPQUERY_SERVICE_CONFIGA con ...@@ -1337,7 +1336,7 @@ BOOL WINAPI QueryServiceConfigA( SC_HANDLE hService, LPQUERY_SERVICE_CONFIGA con
ret = TRUE; ret = TRUE;
done: done:
HeapFree( GetProcessHeap(), 0, buffer ); heap_free( buffer );
return ret; return ret;
} }
...@@ -1457,7 +1456,7 @@ BOOL WINAPI QueryServiceConfig2A(SC_HANDLE hService, DWORD dwLevel, LPBYTE buffe ...@@ -1457,7 +1456,7 @@ BOOL WINAPI QueryServiceConfig2A(SC_HANDLE hService, DWORD dwLevel, LPBYTE buffe
LPBYTE bufferW = NULL; LPBYTE bufferW = NULL;
if(buffer && size) if(buffer && size)
bufferW = HeapAlloc( GetProcessHeap(), 0, size); bufferW = heap_alloc(size);
ret = QueryServiceConfig2W(hService, dwLevel, bufferW, size, needed); ret = QueryServiceConfig2W(hService, dwLevel, bufferW, size, needed);
if(!ret) goto cleanup; if(!ret) goto cleanup;
...@@ -1492,7 +1491,7 @@ BOOL WINAPI QueryServiceConfig2A(SC_HANDLE hService, DWORD dwLevel, LPBYTE buffe ...@@ -1492,7 +1491,7 @@ BOOL WINAPI QueryServiceConfig2A(SC_HANDLE hService, DWORD dwLevel, LPBYTE buffe
} }
cleanup: cleanup:
HeapFree( GetProcessHeap(), 0, bufferW); heap_free( bufferW);
return ret; return ret;
} }
...@@ -1568,7 +1567,7 @@ EnumServicesStatusA( SC_HANDLE hmngr, DWORD type, DWORD state, LPENUM_SERVICE_ST ...@@ -1568,7 +1567,7 @@ EnumServicesStatusA( SC_HANDLE hmngr, DWORD type, DWORD state, LPENUM_SERVICE_ST
returned, resume_handle); returned, resume_handle);
sz = max( 2 * size, sizeof(*servicesW) ); sz = max( 2 * size, sizeof(*servicesW) );
if (!(servicesW = HeapAlloc( GetProcessHeap(), 0, sz ))) if (!(servicesW = heap_alloc( sz )))
{ {
SetLastError( ERROR_NOT_ENOUGH_MEMORY ); SetLastError( ERROR_NOT_ENOUGH_MEMORY );
return FALSE; return FALSE;
...@@ -1602,7 +1601,7 @@ EnumServicesStatusA( SC_HANDLE hmngr, DWORD type, DWORD state, LPENUM_SERVICE_ST ...@@ -1602,7 +1601,7 @@ EnumServicesStatusA( SC_HANDLE hmngr, DWORD type, DWORD state, LPENUM_SERVICE_ST
ret = TRUE; ret = TRUE;
done: done:
HeapFree( GetProcessHeap(), 0, servicesW ); heap_free( servicesW );
return ret; return ret;
} }
...@@ -1683,7 +1682,7 @@ EnumServicesStatusExA( SC_HANDLE hmngr, SC_ENUM_TYPE level, DWORD type, DWORD st ...@@ -1683,7 +1682,7 @@ EnumServicesStatusExA( SC_HANDLE hmngr, SC_ENUM_TYPE level, DWORD type, DWORD st
size, needed, returned, resume_handle, debugstr_a(group)); size, needed, returned, resume_handle, debugstr_a(group));
sz = max( 2 * size, sizeof(*servicesW) ); sz = max( 2 * size, sizeof(*servicesW) );
if (!(servicesW = HeapAlloc( GetProcessHeap(), 0, sz ))) if (!(servicesW = heap_alloc( sz )))
{ {
SetLastError( ERROR_NOT_ENOUGH_MEMORY ); SetLastError( ERROR_NOT_ENOUGH_MEMORY );
return FALSE; return FALSE;
...@@ -1691,10 +1690,10 @@ EnumServicesStatusExA( SC_HANDLE hmngr, SC_ENUM_TYPE level, DWORD type, DWORD st ...@@ -1691,10 +1690,10 @@ EnumServicesStatusExA( SC_HANDLE hmngr, SC_ENUM_TYPE level, DWORD type, DWORD st
if (group) if (group)
{ {
int len = MultiByteToWideChar( CP_ACP, 0, group, -1, NULL, 0 ); int len = MultiByteToWideChar( CP_ACP, 0, group, -1, NULL, 0 );
if (!(groupW = HeapAlloc( GetProcessHeap(), 0, len * sizeof(WCHAR) ))) if (!(groupW = heap_alloc( len * sizeof(WCHAR) )))
{ {
SetLastError( ERROR_NOT_ENOUGH_MEMORY ); SetLastError( ERROR_NOT_ENOUGH_MEMORY );
HeapFree( GetProcessHeap(), 0, servicesW ); heap_free( servicesW );
return FALSE; return FALSE;
} }
MultiByteToWideChar( CP_ACP, 0, group, -1, groupW, len * sizeof(WCHAR) ); MultiByteToWideChar( CP_ACP, 0, group, -1, groupW, len * sizeof(WCHAR) );
...@@ -1729,8 +1728,8 @@ EnumServicesStatusExA( SC_HANDLE hmngr, SC_ENUM_TYPE level, DWORD type, DWORD st ...@@ -1729,8 +1728,8 @@ EnumServicesStatusExA( SC_HANDLE hmngr, SC_ENUM_TYPE level, DWORD type, DWORD st
ret = TRUE; ret = TRUE;
done: done:
HeapFree( GetProcessHeap(), 0, servicesW ); heap_free( servicesW );
HeapFree( GetProcessHeap(), 0, groupW ); heap_free( groupW );
return ret; return ret;
} }
...@@ -1813,7 +1812,7 @@ BOOL WINAPI GetServiceKeyNameA( SC_HANDLE hSCManager, LPCSTR lpDisplayName, ...@@ -1813,7 +1812,7 @@ BOOL WINAPI GetServiceKeyNameA( SC_HANDLE hSCManager, LPCSTR lpDisplayName,
lpDisplayNameW = SERV_dup(lpDisplayName); lpDisplayNameW = SERV_dup(lpDisplayName);
if (lpServiceName) if (lpServiceName)
lpServiceNameW = HeapAlloc(GetProcessHeap(), 0, *lpcchBuffer * sizeof(WCHAR)); lpServiceNameW = heap_alloc(*lpcchBuffer * sizeof(WCHAR));
else else
lpServiceNameW = NULL; lpServiceNameW = NULL;
...@@ -1839,8 +1838,8 @@ BOOL WINAPI GetServiceKeyNameA( SC_HANDLE hSCManager, LPCSTR lpDisplayName, ...@@ -1839,8 +1838,8 @@ BOOL WINAPI GetServiceKeyNameA( SC_HANDLE hSCManager, LPCSTR lpDisplayName,
ret = TRUE; ret = TRUE;
cleanup: cleanup:
HeapFree(GetProcessHeap(), 0, lpServiceNameW); heap_free(lpServiceNameW);
HeapFree(GetProcessHeap(), 0, lpDisplayNameW); heap_free(lpDisplayNameW);
return ret; return ret;
} }
...@@ -1936,7 +1935,7 @@ BOOL WINAPI GetServiceDisplayNameA( SC_HANDLE hSCManager, LPCSTR lpServiceName, ...@@ -1936,7 +1935,7 @@ BOOL WINAPI GetServiceDisplayNameA( SC_HANDLE hSCManager, LPCSTR lpServiceName,
lpServiceNameW = SERV_dup(lpServiceName); lpServiceNameW = SERV_dup(lpServiceName);
if (lpDisplayName) if (lpDisplayName)
lpDisplayNameW = HeapAlloc(GetProcessHeap(), 0, *lpcchBuffer * sizeof(WCHAR)); lpDisplayNameW = heap_alloc(*lpcchBuffer * sizeof(WCHAR));
else else
lpDisplayNameW = NULL; lpDisplayNameW = NULL;
...@@ -1963,8 +1962,8 @@ BOOL WINAPI GetServiceDisplayNameA( SC_HANDLE hSCManager, LPCSTR lpServiceName, ...@@ -1963,8 +1962,8 @@ BOOL WINAPI GetServiceDisplayNameA( SC_HANDLE hSCManager, LPCSTR lpServiceName,
ret = TRUE; ret = TRUE;
cleanup: cleanup:
HeapFree(GetProcessHeap(), 0, lpDisplayNameW); heap_free(lpDisplayNameW);
HeapFree(GetProcessHeap(), 0, lpServiceNameW); heap_free(lpServiceNameW);
return ret; return ret;
} }
...@@ -2089,12 +2088,12 @@ BOOL WINAPI ChangeServiceConfigA( SC_HANDLE hService, DWORD dwServiceType, ...@@ -2089,12 +2088,12 @@ BOOL WINAPI ChangeServiceConfigA( SC_HANDLE hService, DWORD dwServiceType,
wLoadOrderGroup, lpdwTagId, wDependencies, wLoadOrderGroup, lpdwTagId, wDependencies,
wServiceStartName, wPassword, wDisplayName); wServiceStartName, wPassword, wDisplayName);
HeapFree( GetProcessHeap(), 0, wBinaryPathName ); heap_free( wBinaryPathName );
HeapFree( GetProcessHeap(), 0, wLoadOrderGroup ); heap_free( wLoadOrderGroup );
HeapFree( GetProcessHeap(), 0, wDependencies ); heap_free( wDependencies );
HeapFree( GetProcessHeap(), 0, wServiceStartName ); heap_free( wServiceStartName );
HeapFree( GetProcessHeap(), 0, wPassword ); heap_free( wPassword );
HeapFree( GetProcessHeap(), 0, wDisplayName ); heap_free( wDisplayName );
return r; return r;
} }
...@@ -2118,7 +2117,7 @@ BOOL WINAPI ChangeServiceConfig2A( SC_HANDLE hService, DWORD dwInfoLevel, ...@@ -2118,7 +2117,7 @@ BOOL WINAPI ChangeServiceConfig2A( SC_HANDLE hService, DWORD dwInfoLevel,
r = ChangeServiceConfig2W( hService, dwInfoLevel, &sdw ); r = ChangeServiceConfig2W( hService, dwInfoLevel, &sdw );
HeapFree( GetProcessHeap(), 0, sdw.lpDescription ); heap_free( sdw.lpDescription );
} }
else if (dwInfoLevel == SERVICE_CONFIG_FAILURE_ACTIONS) else if (dwInfoLevel == SERVICE_CONFIG_FAILURE_ACTIONS)
{ {
...@@ -2133,8 +2132,8 @@ BOOL WINAPI ChangeServiceConfig2A( SC_HANDLE hService, DWORD dwInfoLevel, ...@@ -2133,8 +2132,8 @@ BOOL WINAPI ChangeServiceConfig2A( SC_HANDLE hService, DWORD dwInfoLevel,
r = ChangeServiceConfig2W( hService, dwInfoLevel, &faw ); r = ChangeServiceConfig2W( hService, dwInfoLevel, &faw );
HeapFree( GetProcessHeap(), 0, faw.lpRebootMsg ); heap_free( faw.lpRebootMsg );
HeapFree( GetProcessHeap(), 0, faw.lpCommand ); heap_free( faw.lpCommand );
} }
else if (dwInfoLevel == SERVICE_CONFIG_PRESHUTDOWN_INFO) else if (dwInfoLevel == SERVICE_CONFIG_PRESHUTDOWN_INFO)
{ {
...@@ -2277,7 +2276,7 @@ SERVICE_STATUS_HANDLE WINAPI RegisterServiceCtrlHandlerExA( LPCSTR name, LPHANDL ...@@ -2277,7 +2276,7 @@ SERVICE_STATUS_HANDLE WINAPI RegisterServiceCtrlHandlerExA( LPCSTR name, LPHANDL
nameW = SERV_dup(name); nameW = SERV_dup(name);
ret = RegisterServiceCtrlHandlerExW( nameW, handler, context ); ret = RegisterServiceCtrlHandlerExW( nameW, handler, context );
HeapFree( GetProcessHeap(), 0, nameW ); heap_free( nameW );
return ret; return ret;
} }
......
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