|
|
#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; }
|