git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@26072
c3d73ce0-8a6f-49c7-b76d-
6d57e0e08775
+ // access mode for the key
+ enum AccessMode
+ {
+ Read, // read-only
+ Write // read and write
+ };
+
// information about standard (predefined) registry keys
// number of standard keys
static const size_t nStdKeys;
// information about standard (predefined) registry keys
// number of standard keys
static const size_t nStdKeys;
wxRegKey(StdKey keyParent, const wxString& strKey);
// strKey is the name of key under (previously created) keyParent
wxRegKey(const wxRegKey& keyParent, const wxString& strKey);
wxRegKey(StdKey keyParent, const wxString& strKey);
// strKey is the name of key under (previously created) keyParent
wxRegKey(const wxRegKey& keyParent, const wxString& strKey);
~wxRegKey();
// change key (closes the previously opened key if any)
~wxRegKey();
// change key (closes the previously opened key if any)
// operations on the key itself
// explicitly open the key (will be automatically done by all functions
// which need the key to be opened if the key is not opened yet)
// operations on the key itself
// explicitly open the key (will be automatically done by all functions
// which need the key to be opened if the key is not opened yet)
+ bool Open(AccessMode mode = Write);
// create the key: will fail if the key already exists and !bOkIfExists
bool Create(bool bOkIfExists = TRUE);
// rename a value from old name to new one
// create the key: will fail if the key already exists and !bOkIfExists
bool Create(bool bOkIfExists = TRUE);
// rename a value from old name to new one
// ----------------------------------------------------------------------------
// opens key (it's not an error to call Open() on an already opened key)
// ----------------------------------------------------------------------------
// opens key (it's not an error to call Open() on an already opened key)
+bool wxRegKey::Open(AccessMode mode)
{
if ( IsOpened() )
return TRUE;
{
if ( IsOpened() )
return TRUE;
(HKEY) m_hRootKey,
m_strKey,
RESERVED,
(HKEY) m_hRootKey,
m_strKey,
RESERVED,
+ mode == Read ? KEY_READ : KEY_ALL_ACCESS,
(HKEY)hRootKey,
szKey,
RESERVED,
(HKEY)hRootKey,
szKey,
RESERVED,
+ KEY_READ, // we might not have enough rights for rw access
&hkeyDummy
) == ERROR_SUCCESS )
{
&hkeyDummy
) == ERROR_SUCCESS )
{