2005-02-06 03:17:39 +00:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
%% Name: regkey.tex
|
|
|
|
%% Purpose: wxRegKey docs
|
|
|
|
%% Author: Ryan Norton <wxprojects@comcast.net>, C.C.Chakkaradeep
|
|
|
|
%% Modified by:
|
|
|
|
%% Created: 2/5/2005
|
|
|
|
%% RCS-ID: $Id$
|
|
|
|
%% Copyright: (c) Ryan Norton (C.C.Chakkaradeep?)
|
|
|
|
%% License: wxWindows license
|
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
|
|
|
|
\section{\class{wxRegKey}}\label{wxregkey}
|
|
|
|
|
2005-08-31 10:24:05 +00:00
|
|
|
wxRegKey is a class representing the Windows registry (it is only available
|
|
|
|
under Windows). One can create, query and delete registry keys using this
|
|
|
|
class.
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-08-31 10:24:05 +00:00
|
|
|
The Windows registry is easy to understand. There are five registry keys,
|
|
|
|
namely:
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-02-09 16:22:25 +00:00
|
|
|
\begin{enumerate}\itemsep=0pt
|
|
|
|
\item HKEY\_CLASSES\_ROOT (HKCR)
|
|
|
|
\item HKEY\_CURRENT\_USER (HKCU)
|
|
|
|
\item HKEY\_LOCAL\_MACHINE (HKLM)
|
|
|
|
\item HKEY\_CURRENT\_CONFIG (HKCC)
|
|
|
|
\item HKEY\_USERS (HKU)
|
|
|
|
\end{enumerate}
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
After creating a key, it can hold a value. The values can be:
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-02-09 16:22:25 +00:00
|
|
|
\begin{enumerate}\itemsep=0pt
|
|
|
|
\item String Value
|
|
|
|
\item Binary Value
|
|
|
|
\item DWORD Value
|
|
|
|
\item Multi String Value
|
|
|
|
\item Expandable String Value
|
|
|
|
\end{enumerate}
|
|
|
|
|
|
|
|
\wxheading{Derived from}
|
|
|
|
|
|
|
|
None
|
|
|
|
|
|
|
|
\wxheading{Include files}
|
|
|
|
|
2005-08-31 10:24:05 +00:00
|
|
|
<wx/msw/registry.h>
|
2005-02-09 16:22:25 +00:00
|
|
|
|
|
|
|
\wxheading{Example}
|
2005-02-06 03:17:39 +00:00
|
|
|
|
|
|
|
\begin{verbatim}
|
|
|
|
wxRegKey *pRegKey = new wxRegKey("HKEY_LOCAL_MACHINE\\Software\\MyKey");
|
|
|
|
|
|
|
|
//will create the Key if it does not exist
|
|
|
|
if( !pRegKey->Exists() )
|
|
|
|
pRegKey->Create();
|
|
|
|
|
|
|
|
//will create a new value MYVALUE and set it to 12
|
|
|
|
pRegKey->SetValue("MYVALUE",12);
|
|
|
|
|
|
|
|
//Query for the Value and Retrieve it
|
|
|
|
long lMyVal;
|
|
|
|
wxString strTemp;
|
|
|
|
pRegKey->QueryValue("MYVALUE",&lMyVal);
|
|
|
|
strTemp.Printf("%d",lMyVal);
|
|
|
|
wxMessageBox(strTemp,"Registry Value",0,this);
|
|
|
|
|
|
|
|
//Retrive the number of SubKeys and enumerate them
|
|
|
|
size_t nSubKeys;
|
|
|
|
pRegKey->GetKeyInfo(&nSubKeys,NULL,NULL,NULL);
|
|
|
|
|
|
|
|
pRegKey->GetFirstKey(strTemp,1);
|
|
|
|
for(int i=0;i<nSubKeys;i++)
|
|
|
|
{
|
|
|
|
wxMessageBox(strTemp,"SubKey Name",0,this);
|
|
|
|
pRegKey->GetNextKey(strTemp,1);
|
|
|
|
}
|
|
|
|
\end{verbatim}
|
|
|
|
|
2005-02-09 16:22:25 +00:00
|
|
|
\latexignore{\rtfignore{\wxheading{Members}}}
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-08-31 22:25:19 +00:00
|
|
|
|
2005-02-09 16:22:25 +00:00
|
|
|
\membersection{wxRegKey::wxRegKey}\label{wxregkeyctor}
|
2005-02-06 03:17:39 +00:00
|
|
|
|
|
|
|
\func{}{wxRegKey}{\void}
|
|
|
|
|
|
|
|
The Constructor to set to HKCR
|
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
\func{}{wxRegKey}{\param{const wxString\&}{ strKey}}
|
2005-02-06 03:17:39 +00:00
|
|
|
|
|
|
|
The constructor to set the full name of the key.
|
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
\func{}{wxRegKey}{\param{const wxRegKey\&}{ keyParent}, \param{const wxString\&}{ strKey}}
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
The constructor to set the full name of the key under a previously created parent.
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-08-31 22:25:19 +00:00
|
|
|
|
2005-02-06 03:17:39 +00:00
|
|
|
\membersection{wxRegKey::Close}\label{wxregkeyclose}
|
|
|
|
|
|
|
|
\func{void}{Close}{\void}
|
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
Closes the key.
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-08-31 22:25:19 +00:00
|
|
|
|
2005-02-06 03:17:39 +00:00
|
|
|
\membersection{wxRegKey::Create}\label{wxregkeycreate}
|
|
|
|
|
2005-02-09 16:22:25 +00:00
|
|
|
\func{bool}{Create}{\param{bool }{bOkIfExists = true}}
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
Creates the key. Will fail if the key already exists and {\it bOkIfExists} is false.
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-08-31 22:25:19 +00:00
|
|
|
|
2005-02-06 03:17:39 +00:00
|
|
|
\membersection{wxRegKey::DeleteSelf}\label{wxregkeydeleteself}
|
|
|
|
|
|
|
|
\func{void}{DeleteSelf}{\void}
|
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
Deletes this key and all of its subkeys and values recursively.
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-08-31 22:25:19 +00:00
|
|
|
|
2005-02-06 03:17:39 +00:00
|
|
|
\membersection{wxRegKey::DeleteKey}\label{wxregkeydeletekey}
|
|
|
|
|
|
|
|
\func{void}{DeleteKey}{\param{const wxChar *}{szKey}}
|
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
Deletes the subkey with all of its subkeys/values recursively.
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-08-31 22:25:19 +00:00
|
|
|
|
2005-02-06 03:17:39 +00:00
|
|
|
\membersection{wxRegKey::DeleteValue}\label{wxregkeydeletevalue}
|
|
|
|
|
|
|
|
\func{void}{DeleteValue}{\param{const wxChar *}{szKey}}
|
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
Deletes the named value.
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-08-31 22:25:19 +00:00
|
|
|
|
2005-02-06 03:17:39 +00:00
|
|
|
\membersection{wxRegKey::Exists}\label{wxregkeyexists}
|
|
|
|
|
|
|
|
\constfunc{static bool}{Exists}{\void}
|
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
Returns true if the key exists.
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-08-31 22:25:19 +00:00
|
|
|
|
2005-02-06 03:17:39 +00:00
|
|
|
\membersection{wxRegKey::GetName}\label{wxregkeygetname}
|
|
|
|
|
2005-02-09 16:22:25 +00:00
|
|
|
\constfunc{wxString}{GetName}{\param{bool }{bShortPrefix = true}}
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
Gets the name of the registry key.
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-08-31 22:25:19 +00:00
|
|
|
|
2005-02-06 03:17:39 +00:00
|
|
|
\membersection{wxRegKey::GetFirstKey}\label{wxregkeygetfirstkey}
|
|
|
|
|
2007-03-26 09:42:43 +00:00
|
|
|
\func{bool}{GetFirstKey}{\param{wxString\&}{ strKeyName}, \param{long\&}{ lIndex}}
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
Gets the first key.
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-08-31 22:25:19 +00:00
|
|
|
|
2005-02-06 03:17:39 +00:00
|
|
|
\membersection{wxRegKey::GetFirstValue}\label{wxregkeygetfirstvalue}
|
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
\func{bool}{GetFirstValue}{\param{wxString\&}{ strValueName}, \param{long\&}{ lIndex}}
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
Gets the first value of this key.
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-08-31 22:25:19 +00:00
|
|
|
|
2005-02-06 03:17:39 +00:00
|
|
|
\membersection{wxRegKey::GetKeyInfo}\label{wxregkeygetkeyinfo}
|
|
|
|
|
|
|
|
\constfunc{bool}{Exists}{\param{size\_t *}{pnSubKeys}, \param{size\_t *}{pnValues}, \param{size\_t *}{pnMaxValueLen}}
|
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
Gets information about the key.
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
\wxheading{Parameters}
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
\docparam{pnSubKeys}{The number of subkeys.}
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
\docparam{pnMaxKeyLen}{The maximum length of the subkey name.}
|
|
|
|
|
|
|
|
\docparam{pnValues}{The number of values.}
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-08-31 22:25:19 +00:00
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
\membersection{wxRegKey::GetNextKey}\label{wxregkeygetnextkey}
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
\constfunc{bool}{GetNextKey}{\param{wxString\&}{ strKeyName}, \param{long\&}{ lIndex}}
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
Gets the next key.
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-08-31 22:25:19 +00:00
|
|
|
|
2005-02-06 03:17:39 +00:00
|
|
|
\membersection{wxRegKey::GetNextValue}\label{wxregkeygetnextvalue}
|
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
\constfunc{bool}{GetNextValue}{\param{wxString\&}{ strValueName}, \param{long\&}{ lIndex}}
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
Gets the next key value for this key.
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-08-31 22:25:19 +00:00
|
|
|
|
2005-02-06 03:17:39 +00:00
|
|
|
\membersection{wxRegKey::HasValue}\label{wxregkeyhasvalue}
|
|
|
|
|
|
|
|
\constfunc{bool}{HasValue}{\param{const wxChar *}{szValue}}
|
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
Returns true if the value exists.
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-08-31 22:25:19 +00:00
|
|
|
|
2005-02-06 03:17:39 +00:00
|
|
|
\membersection{wxRegKey::HasValues}\label{wxregkeyhasvalues}
|
|
|
|
|
|
|
|
\constfunc{bool}{HasValues}{\void}
|
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
Returns true if any values exist.
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-08-31 22:25:19 +00:00
|
|
|
|
2005-02-06 03:17:39 +00:00
|
|
|
\membersection{wxRegKey::HasSubKey}\label{wxregkeyhassubkey}
|
|
|
|
|
|
|
|
\constfunc{bool}{HasSubKey}{\param{const wxChar *}{szKey}}
|
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
Returns true if given subkey exists.
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-08-31 22:25:19 +00:00
|
|
|
|
2005-02-06 03:17:39 +00:00
|
|
|
\membersection{wxRegKey::HasSubKeys}\label{wxregkeyhassubkeys}
|
|
|
|
|
|
|
|
\constfunc{bool}{HasSubKeys}{\void}
|
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
Returns true if any subkeys exist.
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-08-31 22:25:19 +00:00
|
|
|
|
2005-02-06 03:17:39 +00:00
|
|
|
\membersection{wxRegKey::IsEmpty}\label{wxregkeyisempty}
|
|
|
|
|
|
|
|
\constfunc{bool}{IsEmpty}{\void}
|
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
Returns true if this key is empty, nothing under this key.
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-08-31 22:25:19 +00:00
|
|
|
|
2005-02-06 03:17:39 +00:00
|
|
|
\membersection{wxRegKey::IsOpened}\label{wxregkeyisopened}
|
|
|
|
|
|
|
|
\constfunc{bool}{IsOpened}{\void}
|
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
Returns true if the key is opened.
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-08-31 22:25:19 +00:00
|
|
|
|
2005-02-06 03:17:39 +00:00
|
|
|
\membersection{wxRegKey::Open}\label{wxregkeyopen}
|
|
|
|
|
2005-08-31 22:25:19 +00:00
|
|
|
\func{bool}{Open}{\param{AccessMode }{mode = Write}}
|
|
|
|
|
|
|
|
Explicitly opens the key. This method also allows the key to be opened in
|
|
|
|
read-only mode by passing \texttt{wxRegKey::Read} instead of default
|
|
|
|
\texttt{wxRegKey::Write} parameter.
|
2005-02-06 03:17:39 +00:00
|
|
|
|
|
|
|
|
|
|
|
\membersection{wxRegKey::QueryValue}\label{wxregkeyqueryvalue}
|
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
\constfunc{bool}{QueryValue}{\param{const wxChar *}{szValue}, \param{wxString\&}{ strValue}}
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
Retrieves the string value.
|
2005-02-06 03:17:39 +00:00
|
|
|
|
|
|
|
\constfunc{bool}{QueryValue}{\param{const wxChar *}{szValue}, \param{long *}{plValue}}
|
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
Retrieves the numeric value.
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-08-31 22:25:19 +00:00
|
|
|
|
2005-02-06 03:17:39 +00:00
|
|
|
\membersection{wxRegKey::Rename}\label{wxregkeyrename}
|
|
|
|
|
|
|
|
\func{bool}{Rename}{\param{const wxChar *}{ szNewName}}
|
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
Renames the key.
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-08-31 22:25:19 +00:00
|
|
|
|
2005-02-06 03:17:39 +00:00
|
|
|
\membersection{wxRegKey::RenameValue}\label{wxregkeyrenamevalue}
|
|
|
|
|
|
|
|
\func{bool}{RenameValue}{\param{const wxChar *}{szValueOld}, \param{const wxChar *}{szValueNew}}
|
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
Renames a value.
|
2005-02-06 03:17:39 +00:00
|
|
|
|
2005-08-31 22:25:19 +00:00
|
|
|
|
2005-02-06 03:17:39 +00:00
|
|
|
\membersection{wxRegKey::SetValue}\label{wxregkeysetvalue}
|
|
|
|
|
2005-02-11 17:46:05 +00:00
|
|
|
\func{bool}{SetValue}{\param{const wxChar *}{szValue}, \param{long}{ lValue}}
|
|
|
|
|
2006-01-21 03:25:31 +00:00
|
|
|
\func{bool}{SetValue}{\param{const wxChar *}{szValue}, \param{const wxString\&}{ strValue}}
|
|
|
|
|
|
|
|
\func{bool}{SetValue}{\param{const wxChar *}{szValue}, \param{const wxMemoryBuffer\&}{ buf}}
|
|
|
|
|
|
|
|
Sets the given \arg{szValue} which must be numeric, string or binary depending
|
|
|
|
on the overload used. If the value doesn't exist, it is created.
|
2005-02-06 03:17:39 +00:00
|
|
|
|