/*++ Copyright (C) 1997-2000 Microsoft Corporation Module Name: reg.cpp Abstract: Implementation of the registry helper class History: --*/ #include "precomp.h" #include #define DEPRECATE_SUPPORTED #define STRSAFE_NO_CB_FUNCTIONS #include #include "reg.h" Registry::Registry(char *pszLocalMachineStartKey) { hPrimaryKey = 0; hSubkey = 0; m_nStatus = Open(HKEY_LOCAL_MACHINE, pszLocalMachineStartKey); hSubkey = hPrimaryKey; } Registry::~Registry() { if (hSubkey) RegCloseKey(hSubkey); if (hPrimaryKey != hSubkey) RegCloseKey(hPrimaryKey); } int Registry::Open(HKEY hStart, const char *pszStartKey) { int nStatus = no_error; DWORD dwDisp = 0; m_nLastError = RegCreateKeyEx(hStart, pszStartKey, 0, 0, 0, KEY_ALL_ACCESS, 0, &hPrimaryKey, &dwDisp); if (m_nLastError != 0) nStatus = failed; return nStatus; } char* Registry::GetMultiStr(const char *pszValueName, DWORD &dwSize) { //Find out the size of the buffer required DWORD dwType; m_nLastError = RegQueryValueEx(hSubkey, pszValueName, 0, &dwType, NULL, &dwSize); //If the error is an unexpected one bail out if ((m_nLastError != ERROR_SUCCESS) || (dwType != REG_MULTI_SZ)) { dwSize = 0; return NULL; } if (dwSize == 0) { return NULL; } //allocate the buffer required char *pData = new char[dwSize]; if (!pData) { dwSize = 0; return NULL; } //get the values m_nLastError = RegQueryValueEx(hSubkey, pszValueName, 0, &dwType, LPBYTE(pData), &dwSize); //if an error bail out if (m_nLastError != 0) { delete [] pData; dwSize = 0; return NULL; } return pData; } int Registry::SetMultiStr(const char *pszValueName, const char*pszValue, DWORD dwSize) { m_nLastError = RegSetValueEx(hSubkey, pszValueName, 0, REG_MULTI_SZ, LPBYTE(pszValue), dwSize); if (m_nLastError != 0) return failed; return no_error; } int Registry::GetStr(const char *pszValueName, char **pValue) { *pValue = 0; DWORD dwSize = 0; DWORD dwType = 0; m_nLastError = RegQueryValueEx(hSubkey, pszValueName, 0, &dwType, 0, &dwSize); if (m_nLastError != 0) return failed; if (dwType != REG_SZ && dwType != REG_EXPAND_SZ) return failed; char *p = new char[dwSize]; if (!p) return failed; m_nLastError = RegQueryValueEx(hSubkey, pszValueName, 0, &dwType, LPBYTE(p), &dwSize); if (m_nLastError != 0) { delete [] p; return failed; } if(dwType == REG_EXPAND_SZ) { char tTemp; // Get the initial length DWORD nSize = ExpandEnvironmentStrings(p,&tTemp,1) + 1; TCHAR* pTemp = new TCHAR[nSize+1]; if (!pTemp) return failed; if (!ExpandEnvironmentStrings(p,pTemp,nSize+1)) { delete [] p; delete [] pTemp; return failed; } delete [] p; *pValue = pTemp; } else *pValue = p; return no_error; } int Registry::DeleteEntry(const char *pszValueName) { m_nLastError = RegDeleteValue( hSubkey, pszValueName); if (m_nLastError != 0) { return failed; } else return no_error; } int Registry::SetStr(char *pszValueName, char *pszValue) { m_nLastError = RegSetValueEx(hSubkey, pszValueName, 0, REG_SZ, LPBYTE(pszValue), strlen(pszValue) + 1); if (m_nLastError != 0) return failed; return no_error; } int Registry::GetDWORD(TCHAR *pszValueName, DWORD *pdwValue) { DWORD dwSize = sizeof(DWORD); DWORD dwType = 0; m_nLastError = RegQueryValueEx(hSubkey, pszValueName, 0, &dwType, LPBYTE(pdwValue), &dwSize); if (m_nLastError != 0) return failed; if (dwType != REG_DWORD) return failed; return no_error; }