Leaked source code of windows server 2003
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

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