Objective Toolkit provides an encapsulation of the Win32 registry APIs. Using Objective Toolkit's registry abstraction, you can modify the registry through a common interface consistent under all supported platforms.
SECRegistry encapsulates the APIs used to access and modify the Windows registry in a single class. The bulk of the SECRegistry methods are wrappers for the Win32 API. One advantage of using the class instead of the Win32 API is that you can recursively delete keys in a 32-bit environment.
The SECRegistry class encapsulates the Win32 registry API. An SECRegistry instance contains a member handle to a registry key. This same key is then used as a parameter to some of the Windows registry APIs (SECRegistry shields the user from having to keep track of the handle).
The following terms are used in the following descriptions:
Keys. Nodes that can contain one or more keys or values. A key is like a folder that can contain other folders (keys) or items (values).
Values. An item that is contained by a key that has two attributes: a name and an associated evaluation. For example:
Name | Value |
"Path" | "C:\Program Files\WordView\WordView.exe" |
"Password" | "GX325PF" |
Version | 5.1 |
The following section show you how to use SECRegistry to modify registry settings.
Call the Connect() method. If a computer name is specified, the application attempts to open the registry remotely. There must be sufficient permissions for remote registry connections to work. For example:
// connect to the local registry m_registry.Connect(HKEY_CURRENT_USER); // connect to a remote registry m_registry.Connect(HKEY_LOCAL_MACHINE, _T("\\\\TARZAN")); |
Connect() to the registry.
m_registry.Connect(HKEY_CURRENT_USER); |
Open the subkey with the Open() method.
m_registry.Open(_T("Software")); |
Connect() to the registry.
m_registry.Connect(HKEY_CURRENT_USER); |
You can also open a subkey.
m_registry.Open(_T("Environment")); |
Call the EnumerateKeys() method.
// Enumerate all the subkeys // and add them to the listbox DWORD dwCount = 0; CString strKey; CString strClass; while (m_registry.EnumerateKeys(dwCount++, strKey, strClass)) pListBox->InsertString(-1, (LPCTSTR)strKey); |
Connect() to the registry.
m_registry.Connect(HKEY_CURRENT_USER); |
You can also open a subkey.
m_registry.Open(_T("Environment")); |
Call the EnumerateValues() method.
DWORD dwCount = 0; Cstring strName; SECRegistry::KeyValueTypes typeCode; while (m_registry.EnumerateValues(dwCount++, strName, typeCode)) pListBox->InsertString(-1, (LPCTSTR)strName); |
Connect() to the registry.
m_registry.Connect(HKEY_CURRENT_USER); |
You can also open a subkey.
m_registry.Open(_T("Environment")); |
Call one of the following methods to retrieve the value. These methods assume you know the type of the value. See Section 16.8.2.4.
GetBinaryValue() GetDoubleWordValue() GetStringArrayValue() GetStringValue() |
You can also call one of the overloaded GetValue() methods or the QueryValue() method.
Connect() to the registry.
m_registry.Connect(HKEY_CURRENT_USER); |
You can also open a subkey.
m_registry.Open(_T("Software")); |
Call the Create() method to create the new key.
m_registry.Create(_T("MyKey")); |
Connect() to the registry and open the parent of the key about to be deleted.
m_registry.Connect(HKEY_CURRENT_USER); m_registry.Open(_T("Software")); |
Call the DeleteKey() method to delete a particular subkey.
m_registry.DeleteKey(_T("MyKey")); |
Connect() to the registry, and open the parent of the key about to be deleted.
m_registry.Connect(HKEY_CURRENT_USER); m_registry.Open(_T("Software")); |
Call the DeleteKey() method to delete a particular subkey and specify a recursive delete.
m_registry.DeleteKey(_T("MyKey"), TRUE); // TRUE = recursive delete |
Call the Close() method.
m_registry.Close(); |
If this method is not called explicitly, it is called implicitly by the SECRegistry destructor.
The Objective Toolkit regdemo sample (Samples\Toolkit\MFC\Utility\regdemo) illustrates how to use SECRegistry in a 32-bit environment. This sample does not ship with the product. For information on how to obtain this sample, see Section 3.6.1, "Location of Sample Code," in the Stingray Studio Getting Started Guide.
Copyright © Rogue Wave Software, Inc. All Rights Reserved.
The Rogue Wave name and logo, and Stingray, are registered trademarks of Rogue Wave Software. All other trademarks are the property of their respective owners.
Provide feedback to Rogue Wave about its documentation.