You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
360 lines
8.0 KiB
360 lines
8.0 KiB
#include "reg.h"
|
|
|
|
#include "sfstr.h"
|
|
|
|
#include "dbg.h"
|
|
|
|
#define ARRAYSIZE(a) (sizeof((a))/sizeof((a)[0]))
|
|
|
|
// Forward decl
|
|
HRESULT _RegQueryGeneric(HKEY hkey, LPCWSTR pszSubKey, LPCWSTR pszValueName,
|
|
DWORD* pdwType, PBYTE pbValue, DWORD* pcbValue);
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
HRESULT _RegOpenKey(HKEY hkey, LPCWSTR pszKey, HKEY* phkey)
|
|
{
|
|
HRESULT hres;
|
|
|
|
if (ERROR_SUCCESS == RegOpenKeyEx(hkey, pszKey, 0, MAXIMUM_ALLOWED, phkey))
|
|
{
|
|
hres = S_OK;
|
|
}
|
|
else
|
|
{
|
|
hres = S_FALSE;
|
|
*phkey = NULL;
|
|
}
|
|
|
|
return hres;
|
|
}
|
|
|
|
HRESULT _RegCreateKey(HKEY hkey, LPCWSTR pszKey, HKEY* phkey, DWORD* pdwDisp)
|
|
{
|
|
HRESULT hres;
|
|
|
|
if (ERROR_SUCCESS == RegCreateKeyEx(hkey, pszKey, 0, 0,
|
|
REG_OPTION_NON_VOLATILE, MAXIMUM_ALLOWED, NULL, phkey, pdwDisp))
|
|
{
|
|
hres = S_OK;
|
|
}
|
|
else
|
|
{
|
|
hres = S_FALSE;
|
|
*phkey = NULL;
|
|
}
|
|
|
|
return hres;
|
|
}
|
|
|
|
|
|
HRESULT _RegCloseKey(HKEY hkey)
|
|
{
|
|
RegCloseKey(hkey);
|
|
|
|
return S_OK;
|
|
}
|
|
|
|
HRESULT _RegQueryType(HKEY hkey, LPCWSTR pszSubKey, LPCWSTR pszValueName,
|
|
DWORD* pdwType)
|
|
{
|
|
return _RegQueryGeneric(hkey, pszSubKey, pszValueName, pdwType, NULL,
|
|
NULL);
|
|
}
|
|
|
|
HRESULT _RegQueryDWORD(HKEY hkey, LPCWSTR pszSubKey, LPCWSTR pszValueName,
|
|
DWORD* pdwValue)
|
|
{
|
|
DWORD cbValue = sizeof(*pdwValue);
|
|
|
|
return _RegQueryGeneric(hkey, pszSubKey, pszValueName, NULL,
|
|
(PBYTE)pdwValue, &cbValue);
|
|
}
|
|
|
|
HRESULT _RegQueryGeneric(HKEY hkey, LPCWSTR pszSubKey, LPCWSTR pszValueName,
|
|
DWORD* pdwType, PBYTE pbValue, DWORD* pcbValue)
|
|
{
|
|
HRESULT hres = S_FALSE;
|
|
HKEY hkeyLocal = hkey;
|
|
|
|
if (pszSubKey)
|
|
{
|
|
hres = _RegOpenKey(hkey, pszSubKey, &hkeyLocal);
|
|
}
|
|
else
|
|
{
|
|
hres = S_OK;
|
|
}
|
|
|
|
if (SUCCEEDED(hres) && (S_FALSE != hres))
|
|
{
|
|
if (ERROR_SUCCESS == RegQueryValueEx(hkeyLocal, pszValueName, 0, pdwType,
|
|
pbValue, pcbValue))
|
|
{
|
|
hres = S_OK;
|
|
}
|
|
else
|
|
{
|
|
hres = S_FALSE;
|
|
}
|
|
|
|
if (pszSubKey)
|
|
{
|
|
_RegCloseKey(hkeyLocal);
|
|
}
|
|
}
|
|
|
|
return hres;
|
|
}
|
|
|
|
HRESULT _RegQueryGenericWithType(HKEY hkey, LPCWSTR pszSubKey,
|
|
LPCWSTR pszValueName, DWORD* pdwType, PBYTE pbValue, DWORD cbValue)
|
|
{
|
|
return _RegQueryGeneric(hkey, pszSubKey, pszValueName, pdwType, pbValue,
|
|
&cbValue);
|
|
}
|
|
|
|
HRESULT _RegDeleteValue(HKEY hkey, LPCWSTR pszSubKey, LPCWSTR pszValueName)
|
|
{
|
|
HRESULT hr = S_FALSE;
|
|
HKEY hkeyLocal = hkey;
|
|
|
|
if (pszSubKey)
|
|
{
|
|
hr = _RegOpenKey(hkey, pszSubKey, &hkeyLocal);
|
|
}
|
|
else
|
|
{
|
|
hr = S_OK;
|
|
}
|
|
|
|
if (SUCCEEDED(hr) && (S_FALSE != hr))
|
|
{
|
|
if (ERROR_SUCCESS == RegDeleteValue(hkeyLocal, pszValueName))
|
|
{
|
|
hr = S_OK;
|
|
}
|
|
else
|
|
{
|
|
hr = S_FALSE;
|
|
}
|
|
|
|
if (pszSubKey)
|
|
{
|
|
_RegCloseKey(hkeyLocal);
|
|
}
|
|
}
|
|
|
|
return hr;
|
|
}
|
|
|
|
HRESULT _RegQueryValueSize(HKEY hkey, LPCWSTR pszSubKey, LPCWSTR pszValueName,
|
|
DWORD* pcbValue)
|
|
{
|
|
return _RegQueryGeneric(hkey, pszSubKey, pszValueName, NULL, NULL,
|
|
pcbValue);
|
|
}
|
|
|
|
HRESULT _RegSetGeneric(HKEY hkey, LPCWSTR pszValueName, DWORD dwType,
|
|
PBYTE pbValue, DWORD cbValue)
|
|
{
|
|
HRESULT hres = S_FALSE;
|
|
|
|
if (ERROR_SUCCESS == RegSetValueEx(hkey, pszValueName, 0, dwType, pbValue,
|
|
cbValue))
|
|
{
|
|
hres = S_OK;
|
|
}
|
|
|
|
return hres;
|
|
}
|
|
|
|
HRESULT _RegSetString(HKEY hkey, LPCWSTR pszValueName, LPCWSTR pszValue)
|
|
{
|
|
DWORD cb = (lstrlen(pszValue) + 1) * sizeof(WCHAR);
|
|
|
|
return _RegSetGeneric(hkey, pszValueName, REG_SZ, (PBYTE)pszValue, cb);
|
|
}
|
|
|
|
HRESULT _RegSetDWORD(HKEY hkey, LPCWSTR pszValueName, DWORD dwValue)
|
|
{
|
|
return _RegSetGeneric(hkey, pszValueName, REG_DWORD, (PBYTE)&dwValue,
|
|
sizeof(dwValue));
|
|
}
|
|
|
|
HRESULT _RegSetBinary(HKEY hkey, LPCWSTR pszValueName, PVOID pvValue, DWORD cbValue)
|
|
{
|
|
return _RegSetGeneric(hkey, pszValueName, REG_BINARY, (LPBYTE)pvValue, cbValue);
|
|
}
|
|
|
|
HRESULT _RegQueryString(HKEY hkey, LPCWSTR pszSubKey, LPCWSTR pszValueName,
|
|
LPWSTR pszValue, DWORD cchValue)
|
|
{
|
|
DWORD cb = cchValue * sizeof(WCHAR);
|
|
|
|
HRESULT hr = _RegQueryGeneric(hkey, pszSubKey, pszValueName, NULL,
|
|
(PBYTE)pszValue, &cb);
|
|
|
|
if (SUCCEEDED(hr) && (S_FALSE != hr))
|
|
{
|
|
// Should get back an even number of bytes
|
|
if (!(cb % 2))
|
|
{
|
|
DWORD cchRetrieved = cb / 2;
|
|
|
|
// Is it NULL terminated?
|
|
if (pszValue[cchRetrieved - 1])
|
|
{
|
|
// No
|
|
if (cchRetrieved >= (cchValue - 1))
|
|
{
|
|
pszValue[cchRetrieved] = 0;
|
|
}
|
|
else
|
|
{
|
|
*pszValue = 0;
|
|
hr = S_FALSE;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
*pszValue = 0;
|
|
hr = S_FALSE;
|
|
}
|
|
}
|
|
|
|
return hr;
|
|
}
|
|
|
|
HRESULT _RegEnumStringValue(HKEY hkey, DWORD dwIndex, LPWSTR pszValue,
|
|
DWORD cchValue)
|
|
{
|
|
HRESULT hres = S_FALSE;
|
|
LONG lRes;
|
|
|
|
if (ERROR_SUCCESS == (lRes = RegEnumValue(hkey, dwIndex, pszValue,
|
|
&cchValue, 0, 0, 0, 0)))
|
|
{
|
|
hres = S_OK;
|
|
}
|
|
else
|
|
{
|
|
if ((ERROR_SUCCESS != lRes) && (ERROR_NO_MORE_ITEMS != lRes))
|
|
{
|
|
hres = E_FAIL;
|
|
}
|
|
}
|
|
|
|
return hres;
|
|
}
|
|
|
|
HRESULT _RegEnumStringKey(HKEY hkey, DWORD dwIndex, LPWSTR pszKey,
|
|
DWORD cchKey)
|
|
{
|
|
HRESULT hres = S_FALSE;
|
|
LONG lRes;
|
|
|
|
if (ERROR_SUCCESS == (lRes = RegEnumKeyEx(hkey, dwIndex, pszKey,
|
|
&cchKey, NULL, NULL, NULL, NULL)))
|
|
{
|
|
hres = S_OK;
|
|
}
|
|
else
|
|
{
|
|
if (ERROR_NO_MORE_ITEMS != lRes)
|
|
{
|
|
hres = E_FAIL;
|
|
}
|
|
}
|
|
|
|
return hres;
|
|
}
|
|
|
|
HRESULT _RegSetKeyAndString(HKEY hkey, LPCWSTR pszKey, LPCWSTR pszSubkey,
|
|
LPCWSTR pszValueName, LPCWSTR pszValue)
|
|
{
|
|
ASSERT(pszKey && *pszKey);
|
|
|
|
WCHAR szKeyBuf[MAX_KEY];
|
|
LPWSTR pszNext;
|
|
DWORD cchLeft;
|
|
HRESULT hres = SafeStrCpyNEx(szKeyBuf, pszKey, ARRAYSIZE(szKeyBuf),
|
|
&pszNext, &cchLeft);
|
|
|
|
if (SUCCEEDED(hres))
|
|
{
|
|
HKEY hkeyNew;
|
|
|
|
if (pszSubkey)
|
|
{
|
|
hres = SafeStrCpyNEx(pszNext, TEXT("\\"), cchLeft, &pszNext,
|
|
&cchLeft);
|
|
|
|
if (SUCCEEDED(hres))
|
|
{
|
|
hres = SafeStrCpyNEx(pszNext, pszSubkey, cchLeft, &pszNext,
|
|
&cchLeft);
|
|
}
|
|
}
|
|
|
|
if (SUCCEEDED(hres))
|
|
{
|
|
// Create and open key and subkey.
|
|
hres= _RegCreateKey(hkey, szKeyBuf, &hkeyNew, NULL);
|
|
|
|
if (SUCCEEDED(hres) && (S_FALSE != hres))
|
|
{
|
|
if (pszValue)
|
|
{
|
|
hres = _RegSetString(hkeyNew, pszValueName, pszValue);
|
|
}
|
|
|
|
RegCloseKey(hkeyNew);
|
|
}
|
|
}
|
|
}
|
|
|
|
return hres;
|
|
}
|
|
|
|
HRESULT _RegSubkeyExists(HKEY hkey, LPCWSTR pszPath, LPCWSTR pszSubkey)
|
|
{
|
|
WCHAR szKeyBuf[MAX_PATH];
|
|
LPWSTR pszNext;
|
|
DWORD cchLeft;
|
|
|
|
// Copy keyname into buffer.
|
|
HRESULT hres = SafeStrCpyNEx(szKeyBuf, pszPath, ARRAYSIZE(szKeyBuf),
|
|
&pszNext, &cchLeft);
|
|
|
|
if (SUCCEEDED(hres))
|
|
{
|
|
HKEY hkey2;
|
|
|
|
if (pszSubkey)
|
|
{
|
|
hres = SafeStrCpyNEx(pszNext, TEXT("\\"), cchLeft, &pszNext,
|
|
&cchLeft);
|
|
|
|
if (SUCCEEDED(hres))
|
|
{
|
|
hres = SafeStrCpyNEx(pszNext, pszSubkey, cchLeft, &pszNext,
|
|
&cchLeft);
|
|
}
|
|
}
|
|
|
|
if (SUCCEEDED(hres))
|
|
{
|
|
// Determine if key exists by trying to open it.
|
|
hres = _RegOpenKey(hkey, szKeyBuf, &hkey2);
|
|
|
|
if (SUCCEEDED(hres) && (S_FALSE != hres))
|
|
{
|
|
_RegCloseKey(hkey2);
|
|
}
|
|
}
|
|
}
|
|
|
|
return hres;
|
|
}
|