//@doc /****************************************************** ** ** @module REGISTRY.CPP | Implementation of Registry class ** ** Description: ** ** History: ** Created 12/16/97 Matthew L. Coill (mlc) ** ** (c) 1986-1997 Microsoft Corporation. All Rights Reserved. ******************************************************/ #include "Registry.h" #include UnassignableRegistryKey c_InvalidKey(NULL); /***************** RegistryKey class ********************/ /****************************************************** ** ** RegistryKey::RegistryKey(RegistryKey& rkey) ** ** @mfunc Constructor. ** ******************************************************/ RegistryKey::RegistryKey(RegistryKey& rkey) { if (rkey.m_pReferenceCount == NULL) { rkey.m_pReferenceCount = new UINT; *(rkey.m_pReferenceCount) = 1; } m_pReferenceCount = rkey.m_pReferenceCount; ++(*m_pReferenceCount); m_OSRegistryKey = rkey.m_OSRegistryKey; m_ShouldClose = rkey.m_ShouldClose; } /****************************************************** ** ** RegistryKey::~RegistryKey() ** ** @mfunc Destructor. ** ******************************************************/ RegistryKey::~RegistryKey() { if (m_pReferenceCount != NULL) { if (--(*m_pReferenceCount) == 0) { delete m_pReferenceCount; m_pReferenceCount = NULL; } } if ((m_OSRegistryKey != NULL) && (m_ShouldClose) && (m_pReferenceCount == NULL)) { ::RegCloseKey(m_OSRegistryKey); } m_OSRegistryKey = NULL; m_pReferenceCount = NULL; } /****************************************************** ** ** RegistryKey::operator=(RegistryKey& rhs) ** ** @mfunc operator=. ** ******************************************************/ RegistryKey& RegistryKey::operator=(RegistryKey& rhs) { if (&rhs == this) { return *this; } if (rhs.m_pReferenceCount == NULL) { rhs.m_pReferenceCount = new UINT; *(rhs.m_pReferenceCount) = 1; } if (m_pReferenceCount != NULL) { if (--(*m_pReferenceCount) == 0) { delete m_pReferenceCount; m_pReferenceCount = NULL; } } if ((m_OSRegistryKey != NULL) && (m_ShouldClose) && (m_pReferenceCount == NULL)) { ::RegCloseKey(m_OSRegistryKey); } m_pReferenceCount = rhs.m_pReferenceCount; m_OSRegistryKey = rhs.m_OSRegistryKey; m_ShouldClose = rhs.m_ShouldClose; ++(*m_pReferenceCount); return *this; } /****************************************************** ** ** RegistryKey::operator==(RegistryKey& comparee) ** ** @mfunc operator==. ** ******************************************************/ BOOL RegistryKey::operator==(const RegistryKey& comparee) { return (comparee.m_OSRegistryKey == m_OSRegistryKey); } /****************************************************** ** ** RegistryKey::operator!=(RegistryKey& comparee) ** ** @mfunc operator!=. ** ******************************************************/ BOOL RegistryKey::operator!=(const RegistryKey& comparee) { return (comparee.m_OSRegistryKey != m_OSRegistryKey); } /****************************************************** ** ** RegistryKey::CreateSubKey() ** ** @mfunc CreateSubKey. ** ******************************************************/ RegistryKey RegistryKey::CreateSubkey(const TCHAR* subkeyName, const TCHAR* typeName) { if ((m_OSRegistryKey == NULL) || (subkeyName == NULL) || (subkeyName[0] == '\0') || (subkeyName[0] == '\\')) { return c_InvalidKey; } HKEY newKey = NULL; DWORD creationInfo; HRESULT hr = ::RegCreateKeyEx(m_OSRegistryKey, subkeyName, 0, (TCHAR*)typeName, REG_OPTION_NON_VOLATILE, /*KEY_READ*/ KEY_ALL_ACCESS, NULL, &newKey, &creationInfo); if (newKey == NULL) { TCHAR msg[512]; ::FormatMessage(FORMAT_MESSAGE_FROM_SYSTEM, NULL, hr, 0, msg, 512, NULL); return c_InvalidKey; } RegistryKey newRegistryKey(newKey); newRegistryKey.m_ShouldClose = TRUE; return newRegistryKey; } /****************************************************** ** ** RegistryKey::OpenSubkey() ** ** @mfunc OpenSubkey. ** ******************************************************/ RegistryKey RegistryKey::OpenSubkey(const TCHAR* subkeyName, REGSAM access) { if ((m_OSRegistryKey == NULL) || (subkeyName == NULL) || (subkeyName[0] == '\0') || (subkeyName[0] == '\\')) { return c_InvalidKey; } HKEY newKey = NULL; HRESULT hr = ::RegOpenKeyEx(m_OSRegistryKey, subkeyName, 0, access, &newKey); if (newKey == NULL) { return c_InvalidKey; } RegistryKey newRegistryKey(newKey); newRegistryKey.m_ShouldClose = TRUE; return newRegistryKey; } /****************************************************** ** ** RegistryKey::OpenSubkey() ** ** @mfunc OpenNextSubkey. ** ******************************************************/ RegistryKey RegistryKey::OpenNextSubkey(ULONG& ulCookie, TCHAR* subkeyName, REGSAM access) { if (m_OSRegistryKey == NULL) { return c_InvalidKey; } TCHAR rgtcName[256]; DWORD dwNameSize = 256; if (::RegEnumKeyEx(m_OSRegistryKey, ulCookie, rgtcName, &dwNameSize, NULL, NULL, NULL, NULL) == ERROR_SUCCESS) { if (subkeyName != NULL) { _tcscpy(subkeyName, rgtcName); } ulCookie++; return OpenSubkey(rgtcName, access); } return c_InvalidKey; } /****************************************************** ** ** RegistryKey::OpenCreateSubkey() ** ** @mfunc OpenCreateSubkey. ** ******************************************************/ RegistryKey RegistryKey::OpenCreateSubkey(const TCHAR* subkeyName) { RegistryKey key = OpenSubkey(subkeyName, KEY_READ | KEY_WRITE); if (key == c_InvalidKey) { key = CreateSubkey(subkeyName); } return key; } /****************************************************** ** ** RegistryKey::RemoveSubkey() ** ** @mfunc RemoveSubkey. ** ******************************************************/ HRESULT RegistryKey::RemoveSubkey(const TCHAR* subkeyName) { if ((m_OSRegistryKey == NULL) || (subkeyName == NULL) || (subkeyName[0] == '\0') || (subkeyName[0] == '\\')) { return E_FAIL; } return ::RegDeleteKey(m_OSRegistryKey, subkeyName); } /****************************************************** ** ** RegistryKey::GetNumSubKeys() ** ** @mfunc RemoveSubkey. ** ******************************************************/ DWORD RegistryKey::GetNumSubkeys() const { if (m_OSRegistryKey == NULL) { return 0; } DWORD numSubKeys = 0; ::RegQueryInfoKey(m_OSRegistryKey, NULL, NULL, NULL, &numSubKeys, NULL, NULL, NULL, NULL, NULL, NULL, NULL); return numSubKeys; } /****************************************************** ** ** RegistryKey::QueryValue(const TCHAR* valueName, (BYTE*)& pEntryData, UINT& dataSize) ** ** @mfunc QueryValue(const. ** ******************************************************/ HRESULT RegistryKey::QueryValue(const TCHAR* valueName, BYTE* pEntryData, DWORD& dataSize) { if ((m_OSRegistryKey == NULL) || (pEntryData == NULL)) { return E_FAIL; } DWORD dataType; HRESULT hr = ::RegQueryValueEx(m_OSRegistryKey, valueName, NULL, &dataType, pEntryData, &dataSize); return hr; } /****************************************************** ** ** RegistryKey::SetValue(const TCHAR* valueName, const BYTE* pData, DWORD dataSize, DWORD dataType) ** ** @mfunc SetValue. ** ******************************************************/ HRESULT RegistryKey::SetValue(const TCHAR* valueName, const BYTE* pData, DWORD dataSize, DWORD dataType) { if (m_OSRegistryKey == NULL) { return E_FAIL; } HRESULT hr = ::RegSetValueEx(m_OSRegistryKey, valueName, 0, dataType, pData, dataSize); return hr; }