1565 lines
34 KiB
C++
1565 lines
34 KiB
C++
/*++
|
||
|
||
Copyright (c) 1996 Microsoft Corporation
|
||
© 1998 Seagate Software, Inc. All rights reserved
|
||
|
||
Module Name:
|
||
|
||
wsbregty.cpp
|
||
|
||
Abstract:
|
||
|
||
This is the implementation of registry access helper functions
|
||
and is a part of RsCommon.dll.
|
||
|
||
Author:
|
||
|
||
Rohde Wakefield [rohde] 05-Nov-1996
|
||
|
||
Revision History:
|
||
|
||
--*/
|
||
|
||
#include "stdafx.h"
|
||
|
||
|
||
HRESULT
|
||
WsbOpenRegistryKey (
|
||
IN const OLECHAR * szMachine OPTIONAL,
|
||
IN const OLECHAR * szPath,
|
||
IN REGSAM sam,
|
||
OUT HKEY * phKeyMachine,
|
||
OUT HKEY * phKey
|
||
)
|
||
|
||
/*++
|
||
|
||
Routine Description:
|
||
|
||
Given a machine name and path, connect to obtain an HKEY
|
||
that can be used to do registry work.
|
||
|
||
Arguments:
|
||
|
||
szMachine - Name of computer to connect to.
|
||
|
||
szPath - Path inside registry to connect to.
|
||
|
||
sam - permission desired to registry key.
|
||
|
||
phKeyMachine - return of HKEY to machine.
|
||
|
||
phKey - return of HKEY to path.
|
||
|
||
Return Value:
|
||
|
||
S_OK - Connection made, Success.
|
||
|
||
CO_E_OBJNOTCONNECTED - could not connect to registry or key.
|
||
|
||
E_POINTER - invalid pointer in parameters.
|
||
|
||
--*/
|
||
|
||
{
|
||
WsbTraceIn ( L"WsbOpenRegistryKey",
|
||
L"szMachine = '%ls', szPath = '%ls', sam = 0x%p, phKeyMachine = 0x%p, phKey = 0x%p",
|
||
szMachine, szPath, sam, phKeyMachine, phKey );
|
||
|
||
HRESULT hr = S_OK;
|
||
|
||
try {
|
||
|
||
//
|
||
// Ensure parameters are valid
|
||
//
|
||
|
||
WsbAssert ( 0 != szPath, E_POINTER );
|
||
WsbAssert ( 0 != phKey, E_POINTER );
|
||
WsbAssert ( 0 != phKeyMachine, E_POINTER );
|
||
|
||
*phKey = *phKeyMachine = 0;
|
||
|
||
WsbAffirmWin32 ( RegConnectRegistry ( (WCHAR*) szMachine, HKEY_LOCAL_MACHINE, phKeyMachine ) );
|
||
|
||
WsbAffirmWin32 ( RegOpenKeyEx ( *phKeyMachine, szPath, 0, sam, phKey ) );
|
||
|
||
|
||
} WsbCatchAndDo ( hr,
|
||
|
||
//
|
||
// Clean up from error
|
||
//
|
||
|
||
if ( phKeyMachine && *phKeyMachine ) {
|
||
|
||
RegCloseKey ( *phKeyMachine );
|
||
*phKeyMachine = 0;
|
||
|
||
}
|
||
|
||
) // WsbCatchAndDo
|
||
|
||
WsbTraceOut ( L"WsbOpenRegistryKey",
|
||
L"HRESULT = %ls, *phKeyMachine = %ls, *phKey = %ls",
|
||
WsbHrAsString ( hr ),
|
||
WsbStringCopy ( WsbPtrToPtrAsString ( (void**)phKeyMachine ) ),
|
||
WsbStringCopy ( WsbPtrToPtrAsString ( (void**)phKey ) ) );
|
||
|
||
return ( hr );
|
||
}
|
||
|
||
|
||
HRESULT
|
||
WsbCloseRegistryKey (
|
||
IN OUT HKEY * phKeyMachine,
|
||
IN OUT HKEY * phKey
|
||
)
|
||
|
||
/*++
|
||
|
||
Routine Description:
|
||
|
||
As a companion to WsbOpenRegistryKey, close the given keys and zero
|
||
their results.
|
||
|
||
Arguments:
|
||
|
||
phKeyMachine - HKEY to machine.
|
||
|
||
phKey - HKEY to path.
|
||
|
||
Return Value:
|
||
|
||
S_OK - Success.
|
||
|
||
E_POINTER - Invalid pointer passed in.
|
||
|
||
--*/
|
||
|
||
{
|
||
WsbTraceIn ( L"WsbCloseRegistryKey",
|
||
L"phKeyMachine = 0x%p, phKey = 0x%p", phKeyMachine, phKey );
|
||
|
||
HRESULT hr = S_OK;
|
||
|
||
try {
|
||
|
||
//
|
||
// Ensure parameters are valid
|
||
//
|
||
|
||
WsbAssert ( 0 != phKey, E_POINTER );
|
||
WsbAssert ( 0 != phKeyMachine, E_POINTER );
|
||
|
||
//
|
||
// Clean up the keys
|
||
//
|
||
|
||
if ( *phKey ) {
|
||
|
||
RegCloseKey ( *phKey );
|
||
*phKey = 0;
|
||
|
||
}
|
||
|
||
if ( *phKeyMachine ) {
|
||
|
||
RegCloseKey ( *phKeyMachine );
|
||
*phKeyMachine = 0;
|
||
|
||
}
|
||
} WsbCatch ( hr )
|
||
|
||
WsbTraceOut ( L"WsbCloseRegistryKey",
|
||
L"HRESULT = %ls", WsbHrAsString ( hr ) );
|
||
|
||
return ( hr );
|
||
}
|
||
|
||
|
||
HRESULT
|
||
WsbRemoveRegistryKey (
|
||
IN const OLECHAR * szMachine OPTIONAL,
|
||
IN const OLECHAR * szPath,
|
||
IN const OLECHAR * szKey
|
||
)
|
||
|
||
/*++
|
||
|
||
Routine Description:
|
||
|
||
This routine removes the value of a key as specified.
|
||
|
||
Arguments:
|
||
|
||
szMachine - Name of computer to connect to.
|
||
|
||
szPath - Path inside registry to connect to.
|
||
|
||
Return Value:
|
||
|
||
S_OK - Connection made, Success.
|
||
|
||
CO_E_OBJNOTCONNECTED - could not connect to registry or key.
|
||
|
||
E_FAIL - Failure occured setting the value.
|
||
|
||
E_POINTER - invalid pointer passed in as parameter.
|
||
|
||
--*/
|
||
|
||
{
|
||
WsbTraceIn ( L"WsbRemoveRegistryKey",
|
||
L"szMachine = '%ls', szPath = '%ls', szKey = '%ls'",
|
||
szMachine, szPath, szKey );
|
||
|
||
HKEY hKeyMachine = 0,
|
||
hKey = 0;
|
||
|
||
HRESULT hr = S_OK;
|
||
|
||
try {
|
||
|
||
//
|
||
// Ensure parameters are valid
|
||
//
|
||
|
||
WsbAssert ( 0 != szPath, E_POINTER );
|
||
|
||
//
|
||
// Open and delete the key
|
||
//
|
||
|
||
WsbAffirmHr ( WsbOpenRegistryKey ( szMachine, szPath, KEY_SET_VALUE | DELETE, &hKeyMachine, &hKey ) );
|
||
WsbAffirmWin32 ( RegDeleteKey ( hKey, szKey ) );
|
||
|
||
} WsbCatch ( hr )
|
||
|
||
WsbCloseRegistryKey ( &hKeyMachine, &hKey );
|
||
|
||
WsbTraceOut ( L"WsbRemoveRegistryKey",
|
||
L"HRESULT = %ls", WsbHrAsString ( hr ) );
|
||
|
||
return ( hr );
|
||
}
|
||
|
||
|
||
HRESULT
|
||
WsbRemoveRegistryValue (
|
||
IN const OLECHAR * szMachine OPTIONAL,
|
||
IN const OLECHAR * szPath,
|
||
IN const OLECHAR * szValue
|
||
)
|
||
|
||
/*++
|
||
|
||
Routine Description:
|
||
|
||
This routine removes the value of a key as specified.
|
||
|
||
Arguments:
|
||
|
||
szMachine - Name of computer to connect to.
|
||
|
||
szPath - Path inside registry to connect to.
|
||
|
||
szValue - Name of the value to remove.
|
||
|
||
Return Value:
|
||
|
||
S_OK - Connection made, Success.
|
||
|
||
CO_E_OBJNOTCONNECTED - could not connect to registry or key.
|
||
|
||
E_FAIL - Failure occured setting the value.
|
||
|
||
E_POINTER - invalid pointer passed in as parameter.
|
||
|
||
--*/
|
||
|
||
{
|
||
WsbTraceIn ( L"WsbRemoveRegistryValue",
|
||
L"szMachine = '%ls', szPath = '%ls', szValue = '%ls'",
|
||
szMachine, szPath, szValue );
|
||
|
||
HKEY hKeyMachine = 0,
|
||
hKey = 0;
|
||
|
||
HRESULT hr = S_OK;
|
||
|
||
try {
|
||
|
||
//
|
||
// Ensure parameters are valid
|
||
//
|
||
|
||
WsbAssert ( 0 != szPath, E_POINTER );
|
||
WsbAssert ( 0 != szValue, E_POINTER );
|
||
|
||
//
|
||
// Open and write the value in the key
|
||
//
|
||
|
||
WsbAffirmHr ( WsbOpenRegistryKey ( szMachine, szPath, KEY_SET_VALUE, &hKeyMachine, &hKey ) );
|
||
WsbAffirmWin32 ( RegDeleteValue ( hKey, szValue ) );
|
||
|
||
} WsbCatch ( hr )
|
||
|
||
WsbCloseRegistryKey ( &hKeyMachine, &hKey );
|
||
|
||
WsbTraceOut ( L"WsbRemoveRegistryValue",
|
||
L"HRESULT = %ls", WsbHrAsString ( hr ) );
|
||
|
||
return ( hr );
|
||
}
|
||
|
||
|
||
HRESULT
|
||
WsbSetRegistryValueData (
|
||
IN const OLECHAR * szMachine OPTIONAL,
|
||
IN const OLECHAR * szPath,
|
||
IN const OLECHAR * szValue,
|
||
IN const BYTE *pData,
|
||
IN DWORD cbData
|
||
)
|
||
|
||
/*++
|
||
|
||
Routine Description:
|
||
|
||
This routine set the value of a key as specified to the data
|
||
given. Type of the value is REG_BINARY.
|
||
|
||
Arguments:
|
||
|
||
szMachine - Name of computer to connect to.
|
||
|
||
szPath - Path inside registry to connect to.
|
||
|
||
szValue - Name of the value to set.
|
||
|
||
pData - Pointer to the data buffer to copy into value.
|
||
|
||
cbData - Number of bytes to copy from pData.
|
||
|
||
Return Value:
|
||
|
||
S_OK - Connection made, Success.
|
||
|
||
CO_E_OBJNOTCONNECTED - could not connect to registry or key.
|
||
|
||
E_FAIL - Failure occured setting the value.
|
||
|
||
E_POINTER - invalid pointer passed in as parameter.
|
||
|
||
--*/
|
||
|
||
{
|
||
WsbTraceIn ( L"WsbSetRegistryValueData",
|
||
L"szMachine = '%ls', szPath = '%ls', szValue = '%ls', pData = 0x%p, cbData = %ld",
|
||
szMachine, szPath, szValue, pData, cbData );
|
||
|
||
HKEY hKeyMachine = 0,
|
||
hKey = 0;
|
||
|
||
HRESULT hr = S_OK;
|
||
|
||
try {
|
||
|
||
//
|
||
// Ensure parameters are valid
|
||
//
|
||
|
||
WsbAssert ( 0 != szPath, E_POINTER );
|
||
WsbAssert ( 0 != szValue, E_POINTER );
|
||
|
||
//
|
||
// Open and write the value in the key
|
||
//
|
||
|
||
WsbAffirmHr ( WsbOpenRegistryKey ( szMachine, szPath, KEY_SET_VALUE, &hKeyMachine, &hKey ) );
|
||
WsbAffirmWin32 ( RegSetValueEx ( hKey, szValue, 0, REG_BINARY, pData, cbData ) );
|
||
|
||
} WsbCatch ( hr )
|
||
|
||
WsbCloseRegistryKey ( &hKeyMachine, &hKey );
|
||
|
||
WsbTraceOut ( L"WsbSetRegistryValueData",
|
||
L"HRESULT = %ls", WsbHrAsString ( hr ) );
|
||
|
||
return ( hr );
|
||
}
|
||
|
||
|
||
HRESULT
|
||
WsbGetRegistryValueData (
|
||
IN const OLECHAR * szMachine OPTIONAL,
|
||
IN const OLECHAR * szPath,
|
||
IN const OLECHAR * szValue,
|
||
OUT BYTE *pData,
|
||
IN DWORD cbData,
|
||
OUT DWORD * pcbData OPTIONAL
|
||
)
|
||
|
||
/*++
|
||
|
||
Routine Description:
|
||
|
||
This routine retrieves the value of a key as specified. Type of
|
||
the value must be REG_BINARY.
|
||
|
||
Arguments:
|
||
|
||
szMachine - Name of computer to connect to.
|
||
|
||
szPath - Path inside registry to connect to.
|
||
|
||
szValue - Name of the value to get.
|
||
|
||
pData - Pointer to the data buffer to copy into value.
|
||
|
||
cbData - Size in bytes of pData.
|
||
|
||
pcbData - number of bytes filled in pData.
|
||
|
||
Return Value:
|
||
|
||
S_OK - Connection made, Success.
|
||
|
||
CO_E_OBJNOTCONNECTED - could not connect to registry or key.
|
||
|
||
E_POINTER - invalid pointer in parameters.
|
||
|
||
E_FAIL - Failure occured getting the value.
|
||
|
||
--*/
|
||
|
||
{
|
||
WsbTraceIn ( L"WsbGetRegistryValueData",
|
||
L"szMachine = '%ls', szPath = '%ls', szValue = '%ls', pData = 0x%p, cbData = %ld, pcbData = 0x%p",
|
||
szMachine, szPath, szValue, pData, cbData, pcbData );
|
||
|
||
HKEY hKeyMachine = 0,
|
||
hKey = 0;
|
||
|
||
HRESULT hr = S_OK;
|
||
|
||
try {
|
||
|
||
//
|
||
// Ensure parameters are valid
|
||
//
|
||
|
||
WsbAssert ( 0 != szPath, E_POINTER );
|
||
WsbAssert ( 0 != szValue, E_POINTER );
|
||
WsbAssert ( 0 != pData, E_POINTER );
|
||
|
||
//
|
||
// Open the key
|
||
//
|
||
|
||
WsbAffirmHr ( WsbOpenRegistryKey ( szMachine, szPath, KEY_QUERY_VALUE, &hKeyMachine, &hKey ) );
|
||
|
||
//
|
||
// Set up temporary vars in case NULL passed for pcbData
|
||
//
|
||
DWORD dwType, cbData2;
|
||
if ( !pcbData ) {
|
||
|
||
pcbData = &cbData2;
|
||
|
||
}
|
||
|
||
//
|
||
// Query for the REG_BINARY value
|
||
//
|
||
|
||
*pcbData = cbData;
|
||
WsbAffirmWin32 ( RegQueryValueEx ( hKey, szValue, 0, &dwType, pData, pcbData ) );
|
||
|
||
WsbAffirm ( REG_BINARY == dwType, E_FAIL );
|
||
|
||
} WsbCatch ( hr )
|
||
|
||
WsbCloseRegistryKey ( &hKeyMachine, &hKey );
|
||
|
||
WsbTraceOut ( L"WsbGetRegistryValueData",
|
||
L"HRESULT = %ls, *pcbData = %ls", WsbHrAsString ( hr ), WsbPtrToUlongAsString ( pcbData ) );
|
||
|
||
return ( hr );
|
||
}
|
||
|
||
|
||
HRESULT
|
||
WsbSetRegistryValueString (
|
||
IN const OLECHAR * szMachine OPTIONAL,
|
||
IN const OLECHAR * szPath,
|
||
IN const OLECHAR * szValue,
|
||
IN const OLECHAR * szString,
|
||
IN DWORD dwType
|
||
)
|
||
|
||
/*++
|
||
|
||
Routine Description:
|
||
|
||
This routine set the value of a key as specified to the data
|
||
given. Type of the value is dwType (defaults to REG_SZ)
|
||
|
||
Arguments:
|
||
|
||
szMachine - Name of computer to connect to.
|
||
|
||
szPath - Path inside registry to connect to.
|
||
|
||
szValue - Name of the value to set.
|
||
|
||
szString - The string to place in the value.
|
||
|
||
Return Value:
|
||
|
||
S_OK - Connection made, Success.
|
||
|
||
CO_E_OBJNOTCONNECTED - could not connect to registry or key.
|
||
|
||
E_POINTER - invalid pointer in parameters.
|
||
|
||
E_FAIL - Failure occured setting the value.
|
||
|
||
--*/
|
||
|
||
{
|
||
WsbTraceIn ( L"WsbSetRegistryValueString",
|
||
L"szMachine = '%ls', szPath = '%ls', szValue = '%ls', szString = '%ls'",
|
||
szMachine, szPath, szValue, szString );
|
||
|
||
HKEY hKeyMachine = 0,
|
||
hKey = 0;
|
||
|
||
HRESULT hr = S_OK;
|
||
|
||
try {
|
||
|
||
//
|
||
// Ensure parameters are valid
|
||
//
|
||
|
||
WsbAssert ( 0 != szPath, E_POINTER );
|
||
WsbAssert ( 0 != szValue, E_POINTER );
|
||
WsbAssert ( 0 != szString, E_POINTER );
|
||
|
||
//
|
||
// Open the key
|
||
//
|
||
|
||
WsbAffirmHr ( WsbOpenRegistryKey ( szMachine, szPath, KEY_SET_VALUE, &hKeyMachine, &hKey ) );
|
||
|
||
WsbAffirmWin32 ( RegSetValueEx ( hKey, szValue, 0, dwType, (BYTE*)szString, ( wcslen ( szString ) + 1 ) * sizeof ( OLECHAR ) ) );
|
||
|
||
} WsbCatch ( hr )
|
||
|
||
WsbCloseRegistryKey ( &hKeyMachine, &hKey );
|
||
|
||
WsbTraceOut ( L"WsbSetRegistryValueString",
|
||
L"HRESULT = %ls", WsbHrAsString ( hr ) );
|
||
|
||
return ( hr );
|
||
}
|
||
|
||
|
||
HRESULT
|
||
WsbGetRegistryValueString (
|
||
IN const OLECHAR * szMachine OPTIONAL,
|
||
IN const OLECHAR * szPath,
|
||
IN const OLECHAR * szValue,
|
||
OUT OLECHAR * szString,
|
||
IN DWORD cSize,
|
||
OUT DWORD *pcLength OPTIONAL
|
||
)
|
||
|
||
/*++
|
||
|
||
Routine Description:
|
||
|
||
This routine get the value specified
|
||
Type of the value must be REG_SZ or REG_EXPAND_SZ
|
||
|
||
Arguments:
|
||
|
||
szMachine - Name of computer to connect to.
|
||
|
||
szPath - Path inside registry to connect to.
|
||
|
||
szValue - Name of the value to get.
|
||
|
||
szString - The string buffer to fill with the value.
|
||
|
||
cSize - Size of szString in OLECAHR's.
|
||
|
||
pcLength - Number of OLECHAR actually written (without L'\0').
|
||
|
||
Return Value:
|
||
|
||
S_OK - Connection made, Success.
|
||
|
||
CO_E_OBJNOTCONNECTED - could not connect to registry or key.
|
||
|
||
E_POINTER - invalid pointer in parameters.
|
||
|
||
E_FAIL - Failure occured setting the value.
|
||
|
||
--*/
|
||
|
||
{
|
||
WsbTraceIn ( L"WsbGetRegistryValueString",
|
||
L"szMachine = '%ls', szPath = '%ls', szValue = '%ls', szString = 0x%p, cSize = '%ld', pcLength = 0x%p",
|
||
szMachine, szPath, szValue, szString, cSize, pcLength );
|
||
|
||
HKEY hKeyMachine = 0,
|
||
hKey = 0;
|
||
|
||
HRESULT hr = S_OK;
|
||
|
||
try {
|
||
|
||
//
|
||
// Ensure parameters are valid
|
||
//
|
||
|
||
WsbAssert ( 0 != szPath, E_POINTER );
|
||
WsbAssert ( 0 != szValue, E_POINTER );
|
||
WsbAssert ( 0 != szString, E_POINTER );
|
||
|
||
//
|
||
// Open the key
|
||
//
|
||
|
||
WsbAffirmHr ( WsbOpenRegistryKey ( szMachine, szPath, KEY_QUERY_VALUE, &hKeyMachine, &hKey ) );
|
||
|
||
|
||
//
|
||
// Temporary size vars in case pcLength is NULL
|
||
//
|
||
|
||
DWORD dwType, cbData2;
|
||
if ( !pcLength ) {
|
||
|
||
pcLength = &cbData2;
|
||
|
||
}
|
||
|
||
//
|
||
// And do the query
|
||
//
|
||
|
||
*pcLength = cSize * sizeof ( OLECHAR );
|
||
WsbAffirmWin32 ( RegQueryValueEx ( hKey, szValue, 0, &dwType, (BYTE*)szString, pcLength ) ) ;
|
||
|
||
WsbAffirm ( (REG_SZ == dwType) || (REG_EXPAND_SZ == dwType), E_FAIL );
|
||
|
||
//
|
||
// return characters, not bytes
|
||
//
|
||
|
||
*pcLength = ( *pcLength / sizeof ( OLECHAR ) ) - 1;
|
||
|
||
} WsbCatch ( hr )
|
||
|
||
WsbCloseRegistryKey ( &hKeyMachine, &hKey );
|
||
|
||
WsbTraceOut ( L"WsbGetRegistryValueString",
|
||
L"HRESULT = %ls, szString = '%ls', *pcbLength = %ls",
|
||
WsbHrAsString ( hr ), szString, WsbPtrToUlongAsString ( pcLength ) );
|
||
|
||
return ( hr );
|
||
}
|
||
|
||
HRESULT
|
||
WsbGetRegistryValueMultiString (
|
||
IN const OLECHAR * szMachine OPTIONAL,
|
||
IN const OLECHAR * szPath,
|
||
IN const OLECHAR * szValue,
|
||
OUT OLECHAR * szMultiString,
|
||
IN DWORD cSize,
|
||
OUT DWORD *pcLength OPTIONAL
|
||
)
|
||
|
||
/*++
|
||
|
||
Routine Description:
|
||
|
||
This routine get the value specified
|
||
Type of the value must be REG_MULTI_SZ
|
||
|
||
Arguments:
|
||
|
||
szMachine - Name of computer to connect to.
|
||
|
||
szPath - Path inside registry to connect to.
|
||
|
||
szValue - Name of the value to get.
|
||
|
||
szMultiString - The string buffer to fill with the value.
|
||
|
||
cSize - Size of szString in OLECAHR's.
|
||
|
||
pcLength - Number of OLECHAR actually written (without L'\0').
|
||
|
||
Return Value:
|
||
|
||
S_OK - Connection made, Success.
|
||
|
||
CO_E_OBJNOTCONNECTED - could not connect to registry or key.
|
||
|
||
E_POINTER - invalid pointer in parameters.
|
||
|
||
E_FAIL - Failure occured setting the value.
|
||
|
||
--*/
|
||
|
||
{
|
||
WsbTraceIn ( L"WsbGetRegistryValueMultiString",
|
||
L"szMachine = '%ls', szPath = '%ls', szValue = '%ls', szMultiString = 0x%p, cSize = '%ld', pcLength = 0x%p",
|
||
szMachine, szPath, szValue, szMultiString, cSize, pcLength );
|
||
|
||
HKEY hKeyMachine = 0,
|
||
hKey = 0;
|
||
|
||
HRESULT hr = S_OK;
|
||
|
||
try {
|
||
|
||
//
|
||
// Ensure parameters are valid
|
||
//
|
||
|
||
WsbAssert ( 0 != szPath, E_POINTER );
|
||
WsbAssert ( 0 != szValue, E_POINTER );
|
||
WsbAssert ( 0 != szMultiString, E_POINTER );
|
||
|
||
//
|
||
// Open the key
|
||
//
|
||
|
||
WsbAffirmHr ( WsbOpenRegistryKey ( szMachine, szPath, KEY_QUERY_VALUE, &hKeyMachine, &hKey ) );
|
||
|
||
|
||
//
|
||
// Temporary size vars in case pcLength is NULL
|
||
//
|
||
|
||
DWORD dwType, cbData2;
|
||
if ( !pcLength ) {
|
||
|
||
pcLength = &cbData2;
|
||
|
||
}
|
||
|
||
//
|
||
// And do the query
|
||
//
|
||
|
||
*pcLength = cSize * sizeof ( OLECHAR );
|
||
WsbAffirmWin32 ( RegQueryValueEx ( hKey, szValue, 0, &dwType, (BYTE*)szMultiString, pcLength ) ) ;
|
||
|
||
WsbAffirm ( REG_MULTI_SZ == dwType, E_FAIL );
|
||
|
||
//
|
||
// return characters, not bytes
|
||
//
|
||
|
||
*pcLength = ( *pcLength / sizeof ( OLECHAR ) ) - 1;
|
||
|
||
} WsbCatch ( hr )
|
||
|
||
WsbCloseRegistryKey ( &hKeyMachine, &hKey );
|
||
|
||
WsbTraceOut ( L"WsbGetRegistryValueMultiString",
|
||
L"HRESULT = %ls, *pcbLength = %ls",
|
||
WsbHrAsString ( hr ), WsbPtrToUlongAsString ( pcLength ) );
|
||
|
||
return ( hr );
|
||
}
|
||
|
||
|
||
HRESULT
|
||
WsbSetRegistryValueDWORD (
|
||
IN const OLECHAR * szMachine OPTIONAL,
|
||
IN const OLECHAR * szPath,
|
||
IN const OLECHAR * szValue,
|
||
IN DWORD dw
|
||
)
|
||
|
||
/*++
|
||
|
||
Routine Description:
|
||
|
||
This routine set the value of a key as specified to the data
|
||
given. Type of the value is REG_DWORD
|
||
|
||
Arguments:
|
||
|
||
szMachine - Name of computer to connect to.
|
||
|
||
szPath - Path inside registry to connect to.
|
||
|
||
szValue - Name of the value to set.
|
||
|
||
dw - DWORD value to store.
|
||
|
||
Return Value:
|
||
|
||
S_OK - Connection made, Success.
|
||
|
||
CO_E_OBJNOTCONNECTED - could not connect to registry or key.
|
||
|
||
E_POINTER - invalid pointer in parameters.
|
||
|
||
E_FAIL - Failure occured setting the value.
|
||
|
||
--*/
|
||
|
||
{
|
||
WsbTraceIn ( L"WsbSetRegistryValueDWORD",
|
||
L"szMachine = '%ls', szPath = '%ls', szValue = '%ls', dw = %lu [0x%p]",
|
||
szMachine, szPath, szValue, dw, dw );
|
||
|
||
HKEY hKeyMachine = 0,
|
||
hKey = 0;
|
||
|
||
HRESULT hr = S_OK;
|
||
|
||
try {
|
||
|
||
//
|
||
// Ensure parameters are valid
|
||
//
|
||
|
||
WsbAssertPointer( szPath );
|
||
WsbAssertPointer( szValue );
|
||
|
||
//
|
||
// Open the key
|
||
//
|
||
|
||
WsbAffirmHr ( WsbOpenRegistryKey ( szMachine, szPath, KEY_SET_VALUE, &hKeyMachine, &hKey ) );
|
||
|
||
WsbAffirmWin32 ( RegSetValueEx ( hKey, szValue, 0, REG_DWORD, (BYTE*)&dw, sizeof( DWORD ) ) );
|
||
|
||
} WsbCatch ( hr )
|
||
|
||
WsbCloseRegistryKey ( &hKeyMachine, &hKey );
|
||
|
||
WsbTraceOut ( L"WsbSetRegistryValueDWORD",
|
||
L"HRESULT = %ls", WsbHrAsString ( hr ) );
|
||
|
||
return ( hr );
|
||
}
|
||
|
||
|
||
HRESULT
|
||
WsbGetRegistryValueDWORD(
|
||
IN const OLECHAR * szMachine OPTIONAL,
|
||
IN const OLECHAR * szPath,
|
||
IN const OLECHAR * szValue,
|
||
OUT DWORD * pdw
|
||
)
|
||
|
||
/*++
|
||
|
||
Routine Description:
|
||
|
||
This routine set the value of a key as specified to the data
|
||
given. Type of the value is REG_SZ or REG_EXPAND_SZ
|
||
|
||
Arguments:
|
||
|
||
szMachine - Name of computer to connect to.
|
||
|
||
szPath - Path inside registry to connect to.
|
||
|
||
szValue - Name of the value to get.
|
||
|
||
pdw - pointer to a DWORD to store value in.
|
||
|
||
Return Value:
|
||
|
||
S_OK - Connection made, Success.
|
||
|
||
CO_E_OBJNOTCONNECTED - could not connect to registry or key.
|
||
|
||
E_POINTER - invalid pointer in parameters.
|
||
|
||
E_FAIL - Failure occured setting the value.
|
||
|
||
--*/
|
||
|
||
{
|
||
WsbTraceIn ( L"WsbGetRegistryValueDWORD",
|
||
L"szMachine = '%ls', szPath = '%ls', szValue = '%ls', pdw = 0x%p",
|
||
szMachine, szPath, szValue, pdw );
|
||
|
||
HKEY hKeyMachine = 0,
|
||
hKey = 0;
|
||
|
||
HRESULT hr = S_OK;
|
||
|
||
try {
|
||
|
||
//
|
||
// Ensure parameters are valid
|
||
//
|
||
|
||
WsbAssertPointer( szPath );
|
||
WsbAssertPointer( szValue );
|
||
WsbAssertPointer( pdw );
|
||
|
||
//
|
||
// Open the key
|
||
//
|
||
|
||
WsbAffirmHr ( WsbOpenRegistryKey ( szMachine, szPath, KEY_QUERY_VALUE, &hKeyMachine, &hKey ) );
|
||
|
||
|
||
//
|
||
// And do the query
|
||
//
|
||
|
||
DWORD dwType, cbData = sizeof( DWORD );
|
||
WsbAffirmWin32 ( RegQueryValueEx ( hKey, szValue, 0, &dwType, (BYTE*)pdw, &cbData ) ) ;
|
||
|
||
WsbAffirm( REG_DWORD == dwType, E_FAIL );
|
||
|
||
} WsbCatch ( hr )
|
||
|
||
WsbCloseRegistryKey ( &hKeyMachine, &hKey );
|
||
|
||
WsbTraceOut ( L"WsbGetRegistryValueDWORD",
|
||
L"HRESULT = %ls, *pdw = %ls",
|
||
WsbHrAsString ( hr ), WsbPtrToUlongAsString ( pdw ) );
|
||
|
||
return ( hr );
|
||
}
|
||
|
||
|
||
HRESULT
|
||
WsbAddRegistryValueDWORD (
|
||
IN const OLECHAR * szMachine OPTIONAL,
|
||
IN const OLECHAR * szPath,
|
||
IN const OLECHAR * szValue,
|
||
IN DWORD adw
|
||
)
|
||
|
||
/*++
|
||
|
||
Routine Description:
|
||
|
||
This routine adds an amount to a registry value.
|
||
Type of the value must be REG_DWORD
|
||
|
||
Arguments:
|
||
|
||
szMachine - Name of computer to connect to.
|
||
|
||
szPath - Path inside registry to connect to.
|
||
|
||
szValue - Name of the value to increment
|
||
|
||
adw - DWORD value to add.
|
||
|
||
Return Value:
|
||
|
||
S_OK - Connection made, Success.
|
||
|
||
CO_E_OBJNOTCONNECTED - could not connect to registry or key.
|
||
|
||
E_POINTER - invalid pointer in parameters.
|
||
|
||
E_FAIL - Failure occured setting the value.
|
||
|
||
--*/
|
||
|
||
{
|
||
WsbTraceIn ( L"WsbAddRegistryValueDWORD",
|
||
L"szMachine = '%ls', szPath = '%ls', szValue = '%ls', adw = %lu",
|
||
szMachine, szPath, szValue, adw);
|
||
|
||
HRESULT hr = S_OK;
|
||
DWORD value = 0;
|
||
|
||
// Get the old value
|
||
hr = WsbGetRegistryValueDWORD(szMachine, szPath, szValue, &value);
|
||
|
||
// Add to value and replace
|
||
if (S_OK == hr) {
|
||
value += adw;
|
||
} else {
|
||
value = adw;
|
||
}
|
||
hr = WsbSetRegistryValueDWORD(szMachine, szPath, szValue, value);
|
||
|
||
WsbTraceOut ( L"WsbAddRegistryValueDWORD",
|
||
L"HRESULT = %ls", WsbHrAsString ( hr ) );
|
||
|
||
return ( hr );
|
||
}
|
||
|
||
|
||
HRESULT
|
||
WsbIncRegistryValueDWORD (
|
||
IN const OLECHAR * szMachine OPTIONAL,
|
||
IN const OLECHAR * szPath,
|
||
IN const OLECHAR * szValue
|
||
)
|
||
|
||
/*++
|
||
|
||
Routine Description:
|
||
|
||
This routine increments a registry value by one.
|
||
Type of the value must be REG_DWORD
|
||
|
||
Arguments:
|
||
|
||
szMachine - Name of computer to connect to.
|
||
|
||
szPath - Path inside registry to connect to.
|
||
|
||
szValue - Name of the value to increment
|
||
|
||
Return Value:
|
||
|
||
S_OK - Connection made, Success.
|
||
|
||
CO_E_OBJNOTCONNECTED - could not connect to registry or key.
|
||
|
||
E_POINTER - invalid pointer in parameters.
|
||
|
||
E_FAIL - Failure occured setting the value.
|
||
|
||
--*/
|
||
|
||
{
|
||
WsbTraceIn ( L"WsbIncRegistryValueDWORD",
|
||
L"szMachine = '%ls', szPath = '%ls', szValue = '%ls'",
|
||
szMachine, szPath, szValue);
|
||
|
||
HRESULT hr = S_OK;
|
||
|
||
hr = WsbAddRegistryValueDWORD(szMachine, szPath, szValue, 1);
|
||
|
||
WsbTraceOut ( L"WsbIncRegistryValueDWORD",
|
||
L"HRESULT = %ls", WsbHrAsString ( hr ) );
|
||
|
||
return ( hr );
|
||
}
|
||
|
||
|
||
HRESULT
|
||
WsbCheckIfRegistryKeyExists(
|
||
IN const OLECHAR * szMachine OPTIONAL,
|
||
IN const OLECHAR * szPath
|
||
)
|
||
|
||
/*++
|
||
|
||
Routine Description:
|
||
|
||
This routine check if the supplied key exists
|
||
If the key already exists, S_OK is returned.
|
||
If it needed to be created, S_FALSE is returned.
|
||
|
||
Arguments:
|
||
|
||
szMachine - Name of computer to connect to.
|
||
|
||
szPath - Path inside registry to connect to.
|
||
|
||
Return Value:
|
||
|
||
S_OK - Connection made, Key already exists.
|
||
|
||
S_FALSE - Connection made, key did not exist but was created
|
||
|
||
CO_E_OBJNOTCONNECTED - could not connect to registry or key.
|
||
|
||
E_POINTER - invalid pointer in parameters.
|
||
|
||
E_FAIL - Failure occured creating the key.
|
||
|
||
--*/
|
||
|
||
{
|
||
WsbTraceIn ( L"WsbCheckIfRegistryKeyExists",
|
||
L"szMachine = '%ls', szPath = '%ls'", szMachine, szPath );
|
||
|
||
HKEY hKeyMachine = 0,
|
||
hKey = 0;
|
||
|
||
HRESULT hr = S_OK;
|
||
|
||
try {
|
||
|
||
//
|
||
// Ensure parameters are valid
|
||
//
|
||
|
||
WsbAssert ( 0 != szPath, E_POINTER );
|
||
|
||
//
|
||
// Open the key
|
||
//
|
||
|
||
HRESULT resultOpen = WsbOpenRegistryKey ( szMachine, szPath, KEY_QUERY_VALUE, &hKeyMachine, &hKey );
|
||
|
||
//
|
||
// If key could be opened, everything is fine - return S_OK
|
||
//
|
||
|
||
if ( SUCCEEDED ( resultOpen ) ) {
|
||
hr = S_OK;
|
||
WsbCloseRegistryKey ( &hKeyMachine, &hKey );
|
||
} else {
|
||
hr = S_FALSE;
|
||
}
|
||
|
||
} WsbCatch ( hr )
|
||
|
||
|
||
WsbTraceOut ( L"WsbCheckIfRegistryKeyExists",
|
||
L"HRESULT = %ls", WsbHrAsString ( hr ) );
|
||
|
||
return ( hr );
|
||
}
|
||
|
||
|
||
HRESULT
|
||
WsbEnsureRegistryKeyExists (
|
||
IN const OLECHAR * szMachine OPTIONAL,
|
||
IN const OLECHAR * szPath
|
||
)
|
||
|
||
/*++
|
||
|
||
Routine Description:
|
||
|
||
This routine creates the key specified by szPath. Multiple
|
||
levels in the path can be missing and thus created. If the
|
||
key already exists, S_OK is returned. If it needed to be
|
||
created, S_FALSE is returned.
|
||
|
||
Arguments:
|
||
|
||
szMachine - Name of computer to connect to.
|
||
|
||
szPath - Path inside registry to connect to.
|
||
|
||
Return Value:
|
||
|
||
S_OK - Connection made, Key already exists.
|
||
|
||
S_FALSE - Connection made, key did not exist but was created
|
||
|
||
CO_E_OBJNOTCONNECTED - could not connect to registry or key.
|
||
|
||
E_POINTER - invalid pointer in parameters.
|
||
|
||
E_FAIL - Failure occured creating the key.
|
||
|
||
--*/
|
||
|
||
{
|
||
WsbTraceIn ( L"WsbEnsureRegistryKeyExists",
|
||
L"szMachine = '%ls', szPath = '%ls'", szMachine, szPath );
|
||
|
||
HKEY hKeyMachine = 0,
|
||
hKey = 0;
|
||
|
||
HRESULT hr = S_OK;
|
||
|
||
try {
|
||
|
||
//
|
||
// Ensure parameters are valid
|
||
//
|
||
|
||
WsbAssert ( 0 != szPath, E_POINTER );
|
||
|
||
//
|
||
// Open the key
|
||
//
|
||
|
||
HRESULT resultOpen = WsbOpenRegistryKey ( szMachine, szPath, KEY_QUERY_VALUE, &hKeyMachine, &hKey );
|
||
|
||
//
|
||
// If key could be opened, everything is fine - return S_OK
|
||
//
|
||
|
||
if ( SUCCEEDED ( resultOpen ) ) {
|
||
|
||
hr = S_OK;
|
||
|
||
} else {
|
||
|
||
//
|
||
// Otherwise, we need to start at root and create missing portion
|
||
//
|
||
|
||
//
|
||
// Create a copy of the string. Using WsbQuickString so we have
|
||
// automatic freeing of memory
|
||
//
|
||
|
||
WsbQuickString copyString ( szPath );
|
||
WCHAR * pSubKey = copyString;
|
||
|
||
WsbAffirm ( 0 != pSubKey, E_OUTOFMEMORY );
|
||
|
||
DWORD result, createResult;
|
||
HKEY hSubKey;
|
||
|
||
WsbAffirmHr ( WsbOpenRegistryKey ( szMachine, L"", KEY_CREATE_SUB_KEY, &hKeyMachine, &hKey ) );
|
||
|
||
pSubKey = wcstok ( pSubKey, L"\\" );
|
||
|
||
while ( 0 != pSubKey ) {
|
||
|
||
//
|
||
// Create the key. If it exists, RegCreateKeyEx returns
|
||
// REG_OPENED_EXISTING_KEY which is ok here.
|
||
//
|
||
|
||
createResult = 0;
|
||
|
||
result = RegCreateKeyEx ( hKey, pSubKey, 0, L"",
|
||
REG_OPTION_NON_VOLATILE, KEY_CREATE_SUB_KEY, 0, &hSubKey, &createResult );
|
||
|
||
WsbAffirm ( ERROR_SUCCESS == result, E_FAIL );
|
||
|
||
WsbAffirm (
|
||
( REG_CREATED_NEW_KEY == createResult ) ||
|
||
( REG_OPENED_EXISTING_KEY == createResult), E_FAIL );
|
||
|
||
//
|
||
// And move this hkey to be the next parent
|
||
//
|
||
|
||
RegCloseKey ( hKey );
|
||
hKey = hSubKey;
|
||
hSubKey = 0;
|
||
|
||
//
|
||
// And finally, find next token
|
||
//
|
||
|
||
pSubKey = wcstok ( 0, L"\\" );
|
||
|
||
};
|
||
|
||
//
|
||
// If we succeeded to this point, return S_FALSE
|
||
// for successfull creation of path
|
||
//
|
||
|
||
hr = S_FALSE;
|
||
}
|
||
|
||
} WsbCatch ( hr )
|
||
|
||
WsbCloseRegistryKey ( &hKeyMachine, &hKey );
|
||
|
||
WsbTraceOut ( L"WsbEnsureRegistryKeyExists",
|
||
L"HRESULT = %ls", WsbHrAsString ( hr ) );
|
||
|
||
return ( hr );
|
||
}
|
||
|
||
|
||
HRESULT
|
||
WsbSetRegistryValueUlongAsString (
|
||
IN const OLECHAR * szMachine OPTIONAL,
|
||
IN const OLECHAR * szPath,
|
||
IN const OLECHAR * szValue,
|
||
IN ULONG value
|
||
)
|
||
|
||
/*++
|
||
|
||
Routine Description:
|
||
|
||
This routine puts a ULONG value in the registry as a string value.
|
||
|
||
Arguments:
|
||
|
||
szMachine - Name of computer to connect to.
|
||
|
||
szPath - Path inside registry to connect to.
|
||
|
||
szValue - Name of the value to set.
|
||
|
||
value - ULONG value to store.
|
||
|
||
Return Value:
|
||
|
||
S_OK - Connection made, Success.
|
||
|
||
CO_E_OBJNOTCONNECTED - could not connect to registry or key.
|
||
|
||
E_POINTER - invalid pointer in parameters.
|
||
|
||
E_FAIL - Failure occured setting the value.
|
||
|
||
--*/
|
||
|
||
{
|
||
HRESULT hr = S_OK;
|
||
|
||
WsbTraceIn ( L"WsbSetRegistryValueUlongAsString",
|
||
L"szMachine = '%ls', szPath = '%ls', szValue = '%ls', value = %lu",
|
||
szMachine, szPath, szValue, value );
|
||
|
||
try {
|
||
OLECHAR dataString[100];
|
||
|
||
WsbAffirmHr(WsbEnsureRegistryKeyExists(szMachine, szPath));
|
||
wsprintf(dataString, OLESTR("%lu"), value);
|
||
WsbAffirmHr(WsbSetRegistryValueString (szMachine, szPath, szValue,
|
||
dataString, REG_SZ));
|
||
} WsbCatch ( hr )
|
||
|
||
WsbTraceOut ( L"WsbSetRegistryValueUlongAsString",
|
||
L"HRESULT = %ls", WsbHrAsString ( hr ) );
|
||
|
||
return ( hr );
|
||
}
|
||
|
||
|
||
HRESULT
|
||
WsbGetRegistryValueUlongAsString(
|
||
IN const OLECHAR * szMachine OPTIONAL,
|
||
IN const OLECHAR * szPath,
|
||
IN const OLECHAR * szValue,
|
||
OUT ULONG * pvalue
|
||
)
|
||
|
||
/*++
|
||
|
||
Routine Description:
|
||
|
||
This routine gets a string value from the registry and converts
|
||
it to a ULONG value.
|
||
|
||
Arguments:
|
||
|
||
szMachine - Name of computer to connect to.
|
||
|
||
szPath - Path inside registry to connect to.
|
||
|
||
szValue - Name of the value to get.
|
||
|
||
pvalue - pointer to a ULONG to store value in.
|
||
|
||
Return Value:
|
||
|
||
S_OK - Connection made, Success.
|
||
|
||
CO_E_OBJNOTCONNECTED - could not connect to registry or key.
|
||
|
||
E_POINTER - invalid pointer in parameters.
|
||
|
||
E_FAIL - Failure occured setting the value.
|
||
|
||
--*/
|
||
|
||
{
|
||
HRESULT hr = S_OK;
|
||
|
||
WsbTraceIn ( L"WsbGetRegistryValueUlongAsString",
|
||
L"szMachine = '%ls', szPath = '%ls', szValue = '%ls', pvalue = 0x%p",
|
||
szMachine, szPath, szValue, pvalue );
|
||
|
||
try {
|
||
OLECHAR dataString[100];
|
||
DWORD sizeGot;
|
||
OLECHAR * stopString;
|
||
|
||
WsbAssertPointer( pvalue );
|
||
|
||
WsbAffirmHr(WsbGetRegistryValueString(szMachine, szPath, szValue,
|
||
dataString, 100, &sizeGot));
|
||
*pvalue = wcstoul( dataString, &stopString, 10 );
|
||
|
||
} WsbCatch ( hr )
|
||
|
||
WsbTraceOut ( L"WsbGetRegistryValueUlongAsString",
|
||
L"HRESULT = %ls, *pvalue = %ls",
|
||
WsbHrAsString ( hr ), WsbPtrToUlongAsString ( pvalue ) );
|
||
|
||
return ( hr );
|
||
}
|
||
|
||
HRESULT
|
||
WsbGetRegistryValueUlongAsMultiString(
|
||
IN const OLECHAR * szMachine OPTIONAL,
|
||
IN const OLECHAR * szPath,
|
||
IN const OLECHAR * szValue,
|
||
OUT ULONG ** ppValues,
|
||
OUT ULONG * pNumValues
|
||
)
|
||
|
||
/*++
|
||
|
||
Routine Description:
|
||
|
||
This routine gets a multi-string value from the registry and converts
|
||
it to a vector of ULONG values.
|
||
|
||
Arguments:
|
||
|
||
szMachine - Name of computer to connect to.
|
||
|
||
szPath - Path inside registry to connect to.
|
||
|
||
szValue - Name of the value to get.
|
||
|
||
ppvalues - pointer to a ULONG * to alloacte and store the output vector in
|
||
|
||
pNumValues - Number of items returned
|
||
|
||
Return Value:
|
||
|
||
S_OK - Connection made, Success.
|
||
|
||
CO_E_OBJNOTCONNECTED - could not connect to registry or key.
|
||
|
||
E_POINTER - invalid pointer in parameters.
|
||
|
||
E_FAIL - Failure occured getting the value.
|
||
|
||
--*/
|
||
|
||
{
|
||
HRESULT hr = S_OK;
|
||
|
||
WsbTraceIn ( L"WsbGetRegistryValueUlongAsString",
|
||
L"szMachine = '%ls', szPath = '%ls', szValue = '%ls'",
|
||
szMachine, szPath, szValue );
|
||
|
||
try {
|
||
OLECHAR dataString[256];
|
||
DWORD sizeGot;
|
||
OLECHAR * stopString;
|
||
|
||
WsbAssertPointer(ppValues);
|
||
WsbAssertPointer(pNumValues);
|
||
|
||
*pNumValues = 0;
|
||
*ppValues = NULL;
|
||
|
||
WsbAffirmHr(WsbGetRegistryValueMultiString(szMachine, szPath, szValue,
|
||
dataString, 256, &sizeGot));
|
||
|
||
// Build the output vector
|
||
OLECHAR *currentString = dataString;
|
||
int size = 10;
|
||
if ((*currentString) != NULL) {
|
||
// first alocation
|
||
*ppValues = (ULONG *)WsbAlloc(size*sizeof(ULONG));
|
||
WsbAffirm(*ppValues != 0, E_OUTOFMEMORY);
|
||
} else {
|
||
hr = E_FAIL;
|
||
}
|
||
|
||
while ((*currentString) != NULL) {
|
||
(*ppValues)[*pNumValues] = wcstoul( currentString, &stopString, 10 );
|
||
(*pNumValues)++;
|
||
|
||
if (*pNumValues == size) {
|
||
size += 10;
|
||
ULONG* pTmp = (ULONG *)WsbRealloc(*ppValues, size*sizeof(ULONG));
|
||
WsbAffirm(0 != pTmp, E_OUTOFMEMORY);
|
||
*ppValues = pTmp;
|
||
}
|
||
|
||
currentString += wcslen(currentString);
|
||
currentString ++;
|
||
}
|
||
|
||
} WsbCatch ( hr )
|
||
|
||
WsbTraceOut ( L"WsbGetRegistryValueUlongAsString",
|
||
L"HRESULT = %ls, num values = %lu",
|
||
WsbHrAsString ( hr ), *pNumValues );
|
||
|
||
return ( hr );
|
||
}
|
||
|
||
|
||
HRESULT
|
||
WsbRegistryValueUlongAsString(
|
||
IN const OLECHAR * szMachine OPTIONAL,
|
||
IN const OLECHAR * szPath,
|
||
IN const OLECHAR * szValue,
|
||
IN OUT ULONG * pvalue
|
||
)
|
||
|
||
/*++
|
||
|
||
Routine Description:
|
||
|
||
If a registry string value is present, this routine gets it and converts
|
||
it to a ULONG value. If it is not present, this routine sets it to the
|
||
supplied default value.
|
||
|
||
Arguments:
|
||
|
||
szMachine - Name of computer to connect to.
|
||
|
||
szPath - Path inside registry to connect to.
|
||
|
||
szValue - Name of the value to get.
|
||
|
||
pvalue - In: default value , Out: pointer to a ULONG to store value.
|
||
|
||
Return Value:
|
||
|
||
S_OK - Connection made, Success.
|
||
|
||
CO_E_OBJNOTCONNECTED - could not connect to registry or key.
|
||
|
||
E_POINTER - invalid pointer in parameters.
|
||
|
||
E_FAIL - Failure occured setting the value.
|
||
|
||
--*/
|
||
|
||
{
|
||
HRESULT hr = S_OK;
|
||
|
||
WsbTraceIn ( L"WsbRegistryValueUlongAsString",
|
||
L"szMachine = '%ls', szPath = '%ls', szValue = '%ls', pvalue = 0x%p",
|
||
szMachine, szPath, szValue, pvalue );
|
||
|
||
try {
|
||
ULONG l_value;
|
||
|
||
WsbAssertPointer( pvalue );
|
||
|
||
if (S_OK == WsbGetRegistryValueUlongAsString(szMachine, szPath, szValue,
|
||
&l_value)) {
|
||
*pvalue = l_value;
|
||
} else {
|
||
WsbAffirmHr(WsbSetRegistryValueUlongAsString(szMachine, szPath,
|
||
szValue, *pvalue));
|
||
}
|
||
|
||
} WsbCatch ( hr )
|
||
|
||
WsbTraceOut ( L"WsbRegistryValueUlongAsString",
|
||
L"HRESULT = %ls, *pvalue = %ls",
|
||
WsbHrAsString ( hr ), WsbPtrToUlongAsString ( pvalue ) );
|
||
|
||
return ( hr );
|
||
}
|