Documentation fixes.
This commit is contained in:
parent
61daaf8bd3
commit
50ce0844ba
|
@ -145,21 +145,7 @@ inline static HKEY get_special_root_hkey( HKEY hkey )
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
* RegCreateKeyExW [ADVAPI32.@]
|
* RegCreateKeyExW [ADVAPI32.@]
|
||||||
*
|
*
|
||||||
* PARAMS
|
* See RegCreateKeyExA.
|
||||||
* hkey [I] Handle of an open key
|
|
||||||
* name [I] Address of subkey name
|
|
||||||
* reserved [I] Reserved - must be 0
|
|
||||||
* class [I] Address of class string
|
|
||||||
* options [I] Special options flag
|
|
||||||
* access [I] Desired security access
|
|
||||||
* sa [I] Address of key security structure
|
|
||||||
* retkey [O] Address of buffer for opened handle
|
|
||||||
* dispos [O] Receives REG_CREATED_NEW_KEY or REG_OPENED_EXISTING_KEY
|
|
||||||
*
|
|
||||||
* NOTES
|
|
||||||
* in case of failing retkey remains untouched
|
|
||||||
*
|
|
||||||
* FIXME MAXIMUM_ALLOWED in access mask not supported by server
|
|
||||||
*/
|
*/
|
||||||
DWORD WINAPI RegCreateKeyExW( HKEY hkey, LPCWSTR name, DWORD reserved, LPCWSTR class,
|
DWORD WINAPI RegCreateKeyExW( HKEY hkey, LPCWSTR name, DWORD reserved, LPCWSTR class,
|
||||||
DWORD options, REGSAM access, SECURITY_ATTRIBUTES *sa,
|
DWORD options, REGSAM access, SECURITY_ATTRIBUTES *sa,
|
||||||
|
@ -189,7 +175,25 @@ DWORD WINAPI RegCreateKeyExW( HKEY hkey, LPCWSTR name, DWORD reserved, LPCWSTR c
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
* RegCreateKeyExA [ADVAPI32.@]
|
* RegCreateKeyExA [ADVAPI32.@]
|
||||||
*
|
*
|
||||||
* FIXME MAXIMUM_ALLOWED in access mask not supported by server
|
* Open a registry key, creating it if it doesn't exist.
|
||||||
|
*
|
||||||
|
* PARAMS
|
||||||
|
* hkey [I] Handle of the parent registry key
|
||||||
|
* name [I] Name of the new key to open or create
|
||||||
|
* reserved [I] Reserved, pass 0
|
||||||
|
* class [I] The object type of the new key
|
||||||
|
* options [I] Flags controlling the key creation (REG_OPTION_* flags from "winnt.h")
|
||||||
|
* access [I] Access level desired
|
||||||
|
* sa [I] Security attributes for the key
|
||||||
|
* retkey [O] Destination for the resulting handle
|
||||||
|
* dispos [O] Receives REG_CREATED_NEW_KEY or REG_OPENED_EXISTING_KEY
|
||||||
|
*
|
||||||
|
* RETURNS
|
||||||
|
* Success: ERROR_SUCCESS.
|
||||||
|
* Failure: A standard Win32 error code. retkey remains untouched.
|
||||||
|
*
|
||||||
|
* FIXME
|
||||||
|
* MAXIMUM_ALLOWED in access mask not supported by server
|
||||||
*/
|
*/
|
||||||
DWORD WINAPI RegCreateKeyExA( HKEY hkey, LPCSTR name, DWORD reserved, LPCSTR class,
|
DWORD WINAPI RegCreateKeyExA( HKEY hkey, LPCSTR name, DWORD reserved, LPCSTR class,
|
||||||
DWORD options, REGSAM access, SECURITY_ATTRIBUTES *sa,
|
DWORD options, REGSAM access, SECURITY_ATTRIBUTES *sa,
|
||||||
|
@ -253,23 +257,7 @@ DWORD WINAPI RegCreateKeyA( HKEY hkey, LPCSTR name, PHKEY retkey )
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
* RegOpenKeyExW [ADVAPI32.@]
|
* RegOpenKeyExW [ADVAPI32.@]
|
||||||
*
|
*
|
||||||
* Opens the specified key
|
* See RegOpenKeyExA.
|
||||||
*
|
|
||||||
* Unlike RegCreateKeyEx, this does not create the key if it does not exist.
|
|
||||||
*
|
|
||||||
* PARAMS
|
|
||||||
* hkey [I] Handle of open key
|
|
||||||
* name [I] Name of subkey to open
|
|
||||||
* reserved [I] Reserved - must be zero
|
|
||||||
* access [I] Security access mask
|
|
||||||
* retkey [O] Handle to open key
|
|
||||||
*
|
|
||||||
* RETURNS
|
|
||||||
* Success: ERROR_SUCCESS
|
|
||||||
* Failure: Error code
|
|
||||||
*
|
|
||||||
* NOTES
|
|
||||||
* in case of failing is retkey = 0
|
|
||||||
*/
|
*/
|
||||||
DWORD WINAPI RegOpenKeyExW( HKEY hkey, LPCWSTR name, DWORD reserved, REGSAM access, PHKEY retkey )
|
DWORD WINAPI RegOpenKeyExW( HKEY hkey, LPCWSTR name, DWORD reserved, REGSAM access, PHKEY retkey )
|
||||||
{
|
{
|
||||||
|
@ -291,6 +279,23 @@ DWORD WINAPI RegOpenKeyExW( HKEY hkey, LPCWSTR name, DWORD reserved, REGSAM acce
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
* RegOpenKeyExA [ADVAPI32.@]
|
* RegOpenKeyExA [ADVAPI32.@]
|
||||||
|
*
|
||||||
|
* Open a registry key.
|
||||||
|
*
|
||||||
|
* PARAMS
|
||||||
|
* hkey [I] Handle of open key
|
||||||
|
* name [I] Name of subkey to open
|
||||||
|
* reserved [I] Reserved - must be zero
|
||||||
|
* access [I] Security access mask
|
||||||
|
* retkey [O] Handle to open key
|
||||||
|
*
|
||||||
|
* RETURNS
|
||||||
|
* Success: ERROR_SUCCESS
|
||||||
|
* Failure: A standard Win32 error code. retkey is set to 0.
|
||||||
|
*
|
||||||
|
* NOTES
|
||||||
|
* - Unlike RegCreateKeyExA(), this function will not create the key if it
|
||||||
|
* does not exist.
|
||||||
*/
|
*/
|
||||||
DWORD WINAPI RegOpenKeyExA( HKEY hkey, LPCSTR name, DWORD reserved, REGSAM access, PHKEY retkey )
|
DWORD WINAPI RegOpenKeyExA( HKEY hkey, LPCSTR name, DWORD reserved, REGSAM access, PHKEY retkey )
|
||||||
{
|
{
|
||||||
|
@ -322,17 +327,7 @@ DWORD WINAPI RegOpenKeyExA( HKEY hkey, LPCSTR name, DWORD reserved, REGSAM acces
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
* RegOpenKeyW [ADVAPI32.@]
|
* RegOpenKeyW [ADVAPI32.@]
|
||||||
*
|
*
|
||||||
* PARAMS
|
* See RegOpenKeyA.
|
||||||
* hkey [I] Handle of open key
|
|
||||||
* name [I] Address of name of subkey to open
|
|
||||||
* retkey [O] Handle to open key
|
|
||||||
*
|
|
||||||
* RETURNS
|
|
||||||
* Success: ERROR_SUCCESS
|
|
||||||
* Failure: Error code
|
|
||||||
*
|
|
||||||
* NOTES
|
|
||||||
* in case of failing is retkey = 0
|
|
||||||
*/
|
*/
|
||||||
DWORD WINAPI RegOpenKeyW( HKEY hkey, LPCWSTR name, PHKEY retkey )
|
DWORD WINAPI RegOpenKeyW( HKEY hkey, LPCWSTR name, PHKEY retkey )
|
||||||
{
|
{
|
||||||
|
@ -342,6 +337,17 @@ DWORD WINAPI RegOpenKeyW( HKEY hkey, LPCWSTR name, PHKEY retkey )
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
* RegOpenKeyA [ADVAPI32.@]
|
* RegOpenKeyA [ADVAPI32.@]
|
||||||
|
*
|
||||||
|
* Open a registry key.
|
||||||
|
*
|
||||||
|
* PARAMS
|
||||||
|
* hkey [I] Handle of parent key to open the new key under
|
||||||
|
* name [I] Name of the key under hkey to open
|
||||||
|
* retkey [O] Destination for the resulting Handle
|
||||||
|
*
|
||||||
|
* RETURNS
|
||||||
|
* Success: ERROR_SUCCESS
|
||||||
|
* Failure: A standard Win32 error code. retkey is set to 0.
|
||||||
*/
|
*/
|
||||||
DWORD WINAPI RegOpenKeyA( HKEY hkey, LPCSTR name, PHKEY retkey )
|
DWORD WINAPI RegOpenKeyA( HKEY hkey, LPCSTR name, PHKEY retkey )
|
||||||
{
|
{
|
||||||
|
@ -755,7 +761,7 @@ DWORD WINAPI RegQueryInfoKeyA( HKEY hkey, LPSTR class, LPDWORD class_len, LPDWOR
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
* RegCloseKey [ADVAPI32.@]
|
* RegCloseKey [ADVAPI32.@]
|
||||||
*
|
*
|
||||||
* Releases the handle of the specified key
|
* Close an open registry key.
|
||||||
*
|
*
|
||||||
* PARAMS
|
* PARAMS
|
||||||
* hkey [I] Handle of key to close
|
* hkey [I] Handle of key to close
|
||||||
|
@ -774,13 +780,7 @@ DWORD WINAPI RegCloseKey( HKEY hkey )
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
* RegDeleteKeyW [ADVAPI32.@]
|
* RegDeleteKeyW [ADVAPI32.@]
|
||||||
*
|
*
|
||||||
* PARAMS
|
* See RegDeleteKeyA.
|
||||||
* hkey [I] Handle to open key
|
|
||||||
* name [I] Name of subkey to delete
|
|
||||||
*
|
|
||||||
* RETURNS
|
|
||||||
* Success: ERROR_SUCCESS
|
|
||||||
* Failure: Error code
|
|
||||||
*/
|
*/
|
||||||
DWORD WINAPI RegDeleteKeyW( HKEY hkey, LPCWSTR name )
|
DWORD WINAPI RegDeleteKeyW( HKEY hkey, LPCWSTR name )
|
||||||
{
|
{
|
||||||
|
@ -815,6 +815,16 @@ DWORD WINAPI RegDeleteKeyW( HKEY hkey, LPCWSTR name )
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
* RegDeleteKeyA [ADVAPI32.@]
|
* RegDeleteKeyA [ADVAPI32.@]
|
||||||
|
*
|
||||||
|
* Delete a registry key.
|
||||||
|
*
|
||||||
|
* PARAMS
|
||||||
|
* hkey [I] Handle to parent key containing the key to delete
|
||||||
|
* name [I] Name of the key user hkey to delete
|
||||||
|
*
|
||||||
|
* RETURNS
|
||||||
|
* Success: ERROR_SUCCESS
|
||||||
|
* Failure: Error code
|
||||||
*/
|
*/
|
||||||
DWORD WINAPI RegDeleteKeyA( HKEY hkey, LPCSTR name )
|
DWORD WINAPI RegDeleteKeyA( HKEY hkey, LPCSTR name )
|
||||||
{
|
{
|
||||||
|
@ -851,15 +861,15 @@ DWORD WINAPI RegDeleteKeyA( HKEY hkey, LPCSTR name )
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
* RegSetValueExW [ADVAPI32.@]
|
* RegSetValueExW [ADVAPI32.@]
|
||||||
*
|
*
|
||||||
* Sets the data and type of a value under a register key
|
* Set the data and contents of a registry value.
|
||||||
*
|
*
|
||||||
* PARAMS
|
* PARAMS
|
||||||
* hkey [I] Handle of key to set value for
|
* hkey [I] Handle of key to set value for
|
||||||
* name [I] Name of value to set
|
* name [I] Name of value to set
|
||||||
* reserved [I] Reserved - must be zero
|
* reserved [I] Reserved, must be zero
|
||||||
* type [I] Flag for value type
|
* type [I] Type of the value being set
|
||||||
* data [I] Address of value data
|
* data [I] The new contents of the value to set
|
||||||
* count [I] Size of value data
|
* count [I] Size of data
|
||||||
*
|
*
|
||||||
* RETURNS
|
* RETURNS
|
||||||
* Success: ERROR_SUCCESS
|
* Success: ERROR_SUCCESS
|
||||||
|
@ -985,22 +995,7 @@ DWORD WINAPI RegSetValueA( HKEY hkey, LPCSTR name, DWORD type, LPCSTR data, DWOR
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
* RegQueryValueExW [ADVAPI32.@]
|
* RegQueryValueExW [ADVAPI32.@]
|
||||||
*
|
*
|
||||||
* Retrieves type and data for a specified name associated with an open key
|
* See RegQueryValueExA.
|
||||||
*
|
|
||||||
* PARAMS
|
|
||||||
* hkey [I] Handle of key to query
|
|
||||||
* name [I] Name of value to query
|
|
||||||
* reserved [I] Reserved - must be NULL
|
|
||||||
* type [O] Address of buffer for value type. If NULL, the type
|
|
||||||
* is not required.
|
|
||||||
* data [O] Address of data buffer. If NULL, the actual data is
|
|
||||||
* not required.
|
|
||||||
* count [I/O] Address of data buffer size
|
|
||||||
*
|
|
||||||
* RETURNS
|
|
||||||
* ERROR_SUCCESS: Success
|
|
||||||
* ERROR_MORE_DATA: !!! if the specified buffer is not big enough to hold the data
|
|
||||||
* buffer is left untouched. The MS-documentation is wrong (js) !!!
|
|
||||||
*/
|
*/
|
||||||
DWORD WINAPI RegQueryValueExW( HKEY hkey, LPCWSTR name, LPDWORD reserved, LPDWORD type,
|
DWORD WINAPI RegQueryValueExW( HKEY hkey, LPCWSTR name, LPDWORD reserved, LPDWORD type,
|
||||||
LPBYTE data, LPDWORD count )
|
LPBYTE data, LPDWORD count )
|
||||||
|
@ -1068,8 +1063,25 @@ DWORD WINAPI RegQueryValueExW( HKEY hkey, LPCWSTR name, LPDWORD reserved, LPDWOR
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
* RegQueryValueExA [ADVAPI32.@]
|
* RegQueryValueExA [ADVAPI32.@]
|
||||||
*
|
*
|
||||||
* NOTES:
|
* Get the type and contents of a specified value under with a key.
|
||||||
* the documentation is wrong: if the buffer is too small it remains untouched
|
*
|
||||||
|
* PARAMS
|
||||||
|
* hkey [I] Handle of the key to query
|
||||||
|
* name [I] Name of value under hkey to query
|
||||||
|
* reserved [I] Reserved - must be NULL
|
||||||
|
* type [O] Destination for the value type, or NULL if not required
|
||||||
|
* data [O] Destination for the values contents, or NULL if not required
|
||||||
|
* count [I/O] Size of data, updated with the number of bytes returned
|
||||||
|
*
|
||||||
|
* RETURNS
|
||||||
|
* Success: ERROR_SUCCESS. *count is updated with the number of bytes copied to data.
|
||||||
|
* Failure: ERROR_INVALID_HANDLE, if hkey is invalid.
|
||||||
|
* ERROR_INVALID_PARAMETER, if any other parameter is invalid.
|
||||||
|
* ERROR_MORE_DATA, if on input *count is too small to hold the contents.
|
||||||
|
*
|
||||||
|
* NOTES
|
||||||
|
* MSDN states that if data is too small it is partially filled. In reality
|
||||||
|
* it remains untouched.
|
||||||
*/
|
*/
|
||||||
DWORD WINAPI RegQueryValueExA( HKEY hkey, LPCSTR name, LPDWORD reserved, LPDWORD type,
|
DWORD WINAPI RegQueryValueExA( HKEY hkey, LPCSTR name, LPDWORD reserved, LPDWORD type,
|
||||||
LPBYTE data, LPDWORD count )
|
LPBYTE data, LPDWORD count )
|
||||||
|
@ -1781,7 +1793,8 @@ LONG WINAPI RegSetKeySecurity( HKEY hkey, SECURITY_INFORMATION SecurityInfo,
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
* RegGetKeySecurity [ADVAPI32.@]
|
* RegGetKeySecurity [ADVAPI32.@]
|
||||||
* Retrieves a copy of security descriptor protecting the registry key
|
*
|
||||||
|
* Get a copy of the security descriptor for a given registry key.
|
||||||
*
|
*
|
||||||
* PARAMS
|
* PARAMS
|
||||||
* hkey [I] Open handle of key to set
|
* hkey [I] Open handle of key to set
|
||||||
|
@ -1817,17 +1830,15 @@ LONG WINAPI RegGetKeySecurity( HKEY hkey, SECURITY_INFORMATION SecurityInformati
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
* RegFlushKey [ADVAPI32.@]
|
* RegFlushKey [ADVAPI32.@]
|
||||||
* Immediately writes key to registry.
|
*
|
||||||
* Only returns after data has been written to disk.
|
* Immediately write a registry key to registry.
|
||||||
*
|
|
||||||
* FIXME: does it really wait until data is written ?
|
|
||||||
*
|
*
|
||||||
* PARAMS
|
* PARAMS
|
||||||
* hkey [I] Handle of key to write
|
* hkey [I] Handle of key to write
|
||||||
*
|
*
|
||||||
* RETURNS
|
* RETURNS
|
||||||
* Success: ERROR_SUCCESS
|
* Success: ERROR_SUCCESS
|
||||||
* Failure: Error code
|
* Failure: Error code
|
||||||
*/
|
*/
|
||||||
DWORD WINAPI RegFlushKey( HKEY hkey )
|
DWORD WINAPI RegFlushKey( HKEY hkey )
|
||||||
{
|
{
|
||||||
|
@ -1940,18 +1951,19 @@ LONG WINAPI RegNotifyChangeKeyValue( HKEY hkey, BOOL fWatchSubTree,
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
* RegOpenUserClassesRoot [ADVAPI32.@]
|
* RegOpenUserClassesRoot [ADVAPI32.@]
|
||||||
* Opens the HKEY_CLASSES_ROOT key for the user represented by the token
|
*
|
||||||
|
* Open the HKEY_CLASSES_ROOT key for a user.
|
||||||
*
|
*
|
||||||
* PARAMS
|
* PARAMS
|
||||||
* hToken [I] Handle of token representing user
|
* hToken [I] Handle of token representing the user
|
||||||
* dwOptions [I] Reserved
|
* dwOptions [I] Reserved, nust be 0
|
||||||
* samDesired [I] Desired access rights
|
* samDesired [I] Desired access rights
|
||||||
* phkResult [O] Address of buffer for opened handle
|
* phkResult [O] Destination for the resulting key handle
|
||||||
*
|
*
|
||||||
* NOTES:
|
* NOTES
|
||||||
* On Windows 2000 and upwards the HKEY_CLASSES_ROOT key is a view of the
|
* On Windows 2000 and upwards the HKEY_CLASSES_ROOT key is a view of the
|
||||||
* HKEY_LOCAL_MACHINE\Software\Classes and the
|
* "HKEY_LOCAL_MACHINE\Software\Classes" and the
|
||||||
* HKEY_CURRENT_USER\Software\Classes keys merged together.
|
* "HKEY_CURRENT_USER\Software\Classes" keys merged together.
|
||||||
*/
|
*/
|
||||||
LONG WINAPI RegOpenUserClassesRoot(
|
LONG WINAPI RegOpenUserClassesRoot(
|
||||||
HANDLE hToken,
|
HANDLE hToken,
|
||||||
|
|
|
@ -903,10 +903,10 @@ LookupPrivilegeValueW( LPCWSTR lpSystemName, LPCWSTR lpName, PLUID lpLuid )
|
||||||
* PARAMS
|
* PARAMS
|
||||||
* lpSystemName [I] Name of the system
|
* lpSystemName [I] Name of the system
|
||||||
* lpName [I] Name of the privilege
|
* lpName [I] Name of the privilege
|
||||||
* pLuid [O] Destination for the resulting LUID
|
* lpLuid [O] Destination for the resulting LUID
|
||||||
*
|
*
|
||||||
* RETURNS
|
* RETURNS
|
||||||
* Success: TRUE. pLuid contains the requested LUID.
|
* Success: TRUE. lpLuid contains the requested LUID.
|
||||||
* Failure: FALSE.
|
* Failure: FALSE.
|
||||||
*/
|
*/
|
||||||
BOOL WINAPI
|
BOOL WINAPI
|
||||||
|
|
|
@ -240,10 +240,20 @@ SetServiceStatus( SERVICE_STATUS_HANDLE hService, LPSERVICE_STATUS lpStatus )
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
* OpenSCManagerA [ADVAPI32.@]
|
* OpenSCManagerA [ADVAPI32.@]
|
||||||
|
*
|
||||||
|
* Establish a connection to the service control manager and open its database.
|
||||||
|
*
|
||||||
|
* PARAMS
|
||||||
|
* lpMachineName [I] Pointer to machine name string
|
||||||
|
* lpDatabaseName [I] Pointer to database name string
|
||||||
|
* dwDesiredAccess [I] Type of access
|
||||||
|
*
|
||||||
|
* RETURNS
|
||||||
|
* Success: A Handle to the service control manager database
|
||||||
|
* Failure: NULL
|
||||||
*/
|
*/
|
||||||
SC_HANDLE WINAPI
|
SC_HANDLE WINAPI OpenSCManagerA( LPCSTR lpMachineName, LPCSTR lpDatabaseName,
|
||||||
OpenSCManagerA( LPCSTR lpMachineName, LPCSTR lpDatabaseName,
|
DWORD dwDesiredAccess )
|
||||||
DWORD dwDesiredAccess )
|
|
||||||
{
|
{
|
||||||
UNICODE_STRING lpMachineNameW;
|
UNICODE_STRING lpMachineNameW;
|
||||||
UNICODE_STRING lpDatabaseNameW;
|
UNICODE_STRING lpDatabaseNameW;
|
||||||
|
@ -259,23 +269,11 @@ OpenSCManagerA( LPCSTR lpMachineName, LPCSTR lpDatabaseName,
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
* OpenSCManagerW [ADVAPI32.@]
|
* OpenSCManagerW [ADVAPI32.@]
|
||||||
* Establishes a connection to the service control manager and opens database
|
|
||||||
*
|
*
|
||||||
* NOTES
|
* See OpenSCManagerA.
|
||||||
* This should return a SC_HANDLE
|
|
||||||
*
|
|
||||||
* PARAMS
|
|
||||||
* lpMachineName [I] Pointer to machine name string
|
|
||||||
* lpDatabaseName [I] Pointer to database name string
|
|
||||||
* dwDesiredAccess [I] Type of access
|
|
||||||
*
|
|
||||||
* RETURNS
|
|
||||||
* Success: Handle to service control manager database
|
|
||||||
* Failure: NULL
|
|
||||||
*/
|
*/
|
||||||
SC_HANDLE WINAPI
|
SC_HANDLE WINAPI OpenSCManagerW( LPCWSTR lpMachineName, LPCWSTR lpDatabaseName,
|
||||||
OpenSCManagerW( LPCWSTR lpMachineName, LPCWSTR lpDatabaseName,
|
DWORD dwDesiredAccess )
|
||||||
DWORD dwDesiredAccess )
|
|
||||||
{
|
{
|
||||||
HKEY hReg, hKey = NULL;
|
HKEY hReg, hKey = NULL;
|
||||||
LONG r;
|
LONG r;
|
||||||
|
@ -319,18 +317,20 @@ AllocateLocallyUniqueId( PLUID lpluid )
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
* ControlService [ADVAPI32.@]
|
* ControlService [ADVAPI32.@]
|
||||||
* Sends a control code to a Win32-based service.
|
*
|
||||||
|
* Send a control code to a service.
|
||||||
*
|
*
|
||||||
* PARAMS
|
* PARAMS
|
||||||
* hService []
|
* hService [I] Handle of the service control manager database
|
||||||
* dwControl []
|
* dwControl [I] Control code to send (SERVICE_CONTROL_* flags from "winsvc.h")
|
||||||
* lpServiceStatus []
|
* lpServiceStatus [O] Destination for the status of the service, if available
|
||||||
*
|
*
|
||||||
* RETURNS STD
|
* RETURNS
|
||||||
|
* Success: TRUE.
|
||||||
|
* Failure: FALSE.
|
||||||
*/
|
*/
|
||||||
BOOL WINAPI
|
BOOL WINAPI ControlService( SC_HANDLE hService, DWORD dwControl,
|
||||||
ControlService( SC_HANDLE hService, DWORD dwControl,
|
LPSERVICE_STATUS lpServiceStatus )
|
||||||
LPSERVICE_STATUS lpServiceStatus )
|
|
||||||
{
|
{
|
||||||
FIXME("(%p,%ld,%p): stub\n",hService,dwControl,lpServiceStatus);
|
FIXME("(%p,%ld,%p): stub\n",hService,dwControl,lpServiceStatus);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
@ -339,12 +339,15 @@ ControlService( SC_HANDLE hService, DWORD dwControl,
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
* CloseServiceHandle [ADVAPI32.@]
|
* CloseServiceHandle [ADVAPI32.@]
|
||||||
* Close handle to service or service control manager
|
*
|
||||||
|
* Close a handle to a service or the service control manager database.
|
||||||
*
|
*
|
||||||
* PARAMS
|
* PARAMS
|
||||||
* hSCObject [I] Handle to service or service control manager database
|
* hSCObject [I] Handle to service or service control manager database
|
||||||
*
|
*
|
||||||
* RETURNS STD
|
* RETURNS
|
||||||
|
* Success: TRUE
|
||||||
|
* Failure: FALSE
|
||||||
*/
|
*/
|
||||||
BOOL WINAPI
|
BOOL WINAPI
|
||||||
CloseServiceHandle( SC_HANDLE hSCObject )
|
CloseServiceHandle( SC_HANDLE hSCObject )
|
||||||
|
@ -359,10 +362,20 @@ CloseServiceHandle( SC_HANDLE hSCObject )
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
* OpenServiceA [ADVAPI32.@]
|
* OpenServiceA [ADVAPI32.@]
|
||||||
|
*
|
||||||
|
* Open a handle to a service.
|
||||||
|
*
|
||||||
|
* PARAMS
|
||||||
|
* hSCManager [I] Handle of the service control manager database
|
||||||
|
* lpServiceName [I] Name of the service to open
|
||||||
|
* dwDesiredAccess [I] Access required to the service
|
||||||
|
*
|
||||||
|
* RETURNS
|
||||||
|
* Success: Handle to the service
|
||||||
|
* Failure: NULL
|
||||||
*/
|
*/
|
||||||
SC_HANDLE WINAPI
|
SC_HANDLE WINAPI OpenServiceA( SC_HANDLE hSCManager, LPCSTR lpServiceName,
|
||||||
OpenServiceA( SC_HANDLE hSCManager, LPCSTR lpServiceName,
|
DWORD dwDesiredAccess )
|
||||||
DWORD dwDesiredAccess )
|
|
||||||
{
|
{
|
||||||
UNICODE_STRING lpServiceNameW;
|
UNICODE_STRING lpServiceNameW;
|
||||||
SC_HANDLE ret;
|
SC_HANDLE ret;
|
||||||
|
@ -379,20 +392,11 @@ OpenServiceA( SC_HANDLE hSCManager, LPCSTR lpServiceName,
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
* OpenServiceW [ADVAPI32.@]
|
* OpenServiceW [ADVAPI32.@]
|
||||||
* Opens a handle to an existing service
|
|
||||||
*
|
*
|
||||||
* PARAMS
|
* See OpenServiceA.
|
||||||
* hSCManager []
|
|
||||||
* lpServiceName []
|
|
||||||
* dwDesiredAccess []
|
|
||||||
*
|
|
||||||
* RETURNS
|
|
||||||
* Success: Handle to the service
|
|
||||||
* Failure: NULL
|
|
||||||
*/
|
*/
|
||||||
SC_HANDLE WINAPI
|
SC_HANDLE WINAPI OpenServiceW( SC_HANDLE hSCManager, LPCWSTR lpServiceName,
|
||||||
OpenServiceW(SC_HANDLE hSCManager, LPCWSTR lpServiceName,
|
DWORD dwDesiredAccess)
|
||||||
DWORD dwDesiredAccess)
|
|
||||||
{
|
{
|
||||||
HKEY hKey;
|
HKEY hKey;
|
||||||
long r;
|
long r;
|
||||||
|
@ -593,14 +597,16 @@ CreateServiceA( SC_HANDLE hSCManager, LPCSTR lpServiceName,
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
* DeleteService [ADVAPI32.@]
|
* DeleteService [ADVAPI32.@]
|
||||||
*
|
*
|
||||||
|
* Delete a service from the service control manager database.
|
||||||
|
*
|
||||||
* PARAMS
|
* PARAMS
|
||||||
* hService [I] Handle to service
|
* hService [I] Handle of the service to delete
|
||||||
*
|
|
||||||
* RETURNS STD
|
|
||||||
*
|
*
|
||||||
|
* RETURNS
|
||||||
|
* Success: TRUE
|
||||||
|
* Failure: FALSE
|
||||||
*/
|
*/
|
||||||
BOOL WINAPI
|
BOOL WINAPI DeleteService( SC_HANDLE hService )
|
||||||
DeleteService( SC_HANDLE hService )
|
|
||||||
{
|
{
|
||||||
WCHAR valname[MAX_PATH+1];
|
WCHAR valname[MAX_PATH+1];
|
||||||
INT index = 0;
|
INT index = 0;
|
||||||
|
@ -667,6 +673,25 @@ DeleteService( SC_HANDLE hService )
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
* StartServiceA [ADVAPI32.@]
|
* StartServiceA [ADVAPI32.@]
|
||||||
*
|
*
|
||||||
|
* Start a service
|
||||||
|
*
|
||||||
|
* PARAMS
|
||||||
|
* hService [I] Handle of service
|
||||||
|
* dwNumServiceArgs [I] Number of arguments
|
||||||
|
* lpServiceArgVectors [I] Address of array of argument strings
|
||||||
|
*
|
||||||
|
* NOTES
|
||||||
|
* - NT implements this function using an obscure RPC call.
|
||||||
|
* - You might need to do a "setenv SystemRoot \\WINNT" in your .cshrc
|
||||||
|
* to get things like "%SystemRoot%\\System32\\service.exe" to load.
|
||||||
|
* - This will only work for shared address space. How should the service
|
||||||
|
* args be transferred when address spaces are separated?
|
||||||
|
* - Can only start one service at a time.
|
||||||
|
* - Has no concept of privilege.
|
||||||
|
*
|
||||||
|
* RETURNS
|
||||||
|
* Success: TRUE.
|
||||||
|
* Failure: FALSE
|
||||||
*/
|
*/
|
||||||
BOOL WINAPI
|
BOOL WINAPI
|
||||||
StartServiceA( SC_HANDLE hService, DWORD dwNumServiceArgs,
|
StartServiceA( SC_HANDLE hService, DWORD dwNumServiceArgs,
|
||||||
|
@ -705,29 +730,8 @@ StartServiceA( SC_HANDLE hService, DWORD dwNumServiceArgs,
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
* StartServiceW [ADVAPI32.@]
|
* StartServiceW [ADVAPI32.@]
|
||||||
* Starts a service
|
*
|
||||||
*
|
* See StartServiceA.
|
||||||
* PARAMS
|
|
||||||
* hService [I] Handle of service
|
|
||||||
* dwNumServiceArgs [I] Number of arguments
|
|
||||||
* lpServiceArgVectors [I] Address of array of argument string pointers
|
|
||||||
*
|
|
||||||
* NOTES
|
|
||||||
*
|
|
||||||
* NT implements this function using an obscure RPC call...
|
|
||||||
*
|
|
||||||
* Might need to do a "setenv SystemRoot \\WINNT" in your .cshrc
|
|
||||||
* to get things like %SystemRoot%\\System32\\service.exe to load.
|
|
||||||
*
|
|
||||||
* Will only work for shared address space. How should the service
|
|
||||||
* args be transferred when address spaces are separated?
|
|
||||||
*
|
|
||||||
* Can only start one service at a time.
|
|
||||||
*
|
|
||||||
* Has no concept of privilege.
|
|
||||||
*
|
|
||||||
* RETURNS STD
|
|
||||||
*
|
|
||||||
*/
|
*/
|
||||||
BOOL WINAPI
|
BOOL WINAPI
|
||||||
StartServiceW( SC_HANDLE hService, DWORD dwNumServiceArgs,
|
StartServiceW( SC_HANDLE hService, DWORD dwNumServiceArgs,
|
||||||
|
@ -857,13 +861,19 @@ QueryServiceStatus( SC_HANDLE hService, LPSERVICE_STATUS lpservicestatus )
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
* QueryServiceStatusEx [ADVAPI32.@]
|
* QueryServiceStatusEx [ADVAPI32.@]
|
||||||
*
|
*
|
||||||
|
* Get information about a service.
|
||||||
|
*
|
||||||
* PARAMS
|
* PARAMS
|
||||||
* hService [handle to service]
|
* hService [I] Handle to service to get information about
|
||||||
* InfoLevel [information level]
|
* InfoLevel [I] Level of information to get
|
||||||
* lpBuffer [buffer]
|
* lpBuffer [O] Destination for requested information
|
||||||
* cbBufSize [size of buffer]
|
* cbBufSize [I] Size of lpBuffer in bytes
|
||||||
* pcbBytesNeeded [bytes needed]
|
* pcbBytesNeeded [O] Destination for number of bytes needed, if cbBufSize is too small
|
||||||
*/
|
*
|
||||||
|
* RETURNS
|
||||||
|
* Success: TRUE
|
||||||
|
* FAILURE: FALSE
|
||||||
|
*/
|
||||||
BOOL WINAPI QueryServiceStatusEx(SC_HANDLE hService, SC_STATUS_TYPE InfoLevel,
|
BOOL WINAPI QueryServiceStatusEx(SC_HANDLE hService, SC_STATUS_TYPE InfoLevel,
|
||||||
LPBYTE lpBuffer, DWORD cbBufSize,
|
LPBYTE lpBuffer, DWORD cbBufSize,
|
||||||
LPDWORD pcbBytesNeeded)
|
LPDWORD pcbBytesNeeded)
|
||||||
|
|
Loading…
Reference in New Issue