]> git.saurik.com Git - wxWidgets.git/blame - docs/latex/wx/config.tex
Faster Deselect
[wxWidgets.git] / docs / latex / wx / config.tex
CommitLineData
c4afa2cb
VZ
1\section{\class{wxConfigBase}}\label{wxconfigbase}
2
3wxConfigBase class defines the basic interface of all config classes. It can
f6bcfd97 4not be used by itself (it is an abstract base class) and you will always use one
a121d720
VZ
5of its derivations: wxIniConfig, \helpref{wxFileConfig}{wxfileconfig},
6wxRegConfig or any other.
c4afa2cb
VZ
7
8However, usually you don't even need to know the precise nature of the class
9you're working with but you would just use the wxConfigBase methods. This
10allows you to write the same code regardless of whether you're working with
11the registry under Win32 or text-based config files under Unix (or even
12Windows 3.1 .INI files if you're really unlucky). To make writing the portable
fc2171bd 13code even easier, wxWidgets provides a typedef wxConfig
c4afa2cb 14which is mapped onto the native wxConfigBase implementation on the given
3a5bcc4d 15platform: i.e. wxRegConfig under Win32 (optionally wxIniConfig) and
c4afa2cb
VZ
16wxFileConfig otherwise.
17
5f3cd8a2
VZ
18See \helpref{config overview}{wxconfigoverview} for the descriptions of all
19features of this class.
c4afa2cb 20
eee786e9
VS
21It is highly recommended to use static functions {\it Get()} and/or {\it Set()},
22so please have a \helpref{look at them.}{wxconfigstaticfunctions}
23
c4afa2cb
VZ
24\wxheading{Derived from}
25
26No base class
27
954b8ae6
JS
28\wxheading{Include files}
29
fc2171bd 30<wx/config.h> (to let wxWidgets choose a wxConfig class for your platform)\\
954b8ae6 31<wx/confbase.h> (base config class)\\
2f930c85 32<wx/fileconf.h> (wxFileConfig class)\\
954b8ae6
JS
33<wx/msw/regconf.h> (wxRegConfig class)\\
34<wx/msw/iniconf.h> (wxIniConfig class)
35
c4afa2cb
VZ
36\wxheading{Example}
37
38Here is how you would typically use this class:
39
40\begin{verbatim}
41 // using wxConfig instead of writing wxFileConfig or wxRegConfig enhances
42 // portability of the code
43 wxConfig *config = new wxConfig("MyAppName");
44
45 wxString str;
052ae0e5 46 if ( config->Read("LastPrompt", &str) ) {
b8de493f 47 // last prompt was found in the config file/registry and its value is now
c4afa2cb
VZ
48 // in str
49 ...
50 }
51 else {
52 // no last prompt...
53 }
54
55 // another example: using default values and the full path instead of just
56 // key name: if the key is not found , the value 17 is returned
873fb06d 57 long value = config->Read("/LastRun/CalculatedValues/MaxValue", 17);
c4afa2cb
VZ
58 ...
59 ...
60 ...
61 // at the end of the program we would save everything back
62 config->Write("LastPrompt", str);
63 config->Write("/LastRun/CalculatedValues/MaxValue", value);
64
65 // the changes will be written back automatically
66 delete config;
67\end{verbatim}
68
69This basic example, of course, doesn't show all wxConfig features, such as
70enumerating, testing for existence and deleting the entries and groups of
b8de493f 71entries in the config file, its abilities to automatically store the default
c4afa2cb
VZ
72values or expand the environment variables on the fly. However, the main idea
73is that using this class is easy and that it should normally do what you
74expect it to.
75
76NB: in the documentation of this class, the words "config file" also mean
77"registry hive" for wxRegConfig and, generally speaking, might mean any
b8de493f 78physical storage where a wxConfigBase-derived class stores its data.
c4afa2cb 79
b8de493f 80\latexignore{\rtfignore{\wxheading{Function groups}}}
c4afa2cb 81
a121d720 82
eee786e9 83\membersection{Static functions}\label{wxconfigstaticfunctions}
c4afa2cb 84
052ae0e5 85These functions deal with the "default" config object. Although its usage is
c4afa2cb
VZ
86not at all mandatory it may be convenient to use a global config object
87instead of creating and deleting the local config objects each time you need
88one (especially because creating a wxFileConfig object might be a time
89consuming operation). In this case, you may create this global config object
90in the very start of the program and {\it Set()} it as the default. Then, from
b52ea5c5 91anywhere in your program, you may access it using the {\it Get()} function.
736f28f8 92Note that you must delete this object (usually in \helpref{wxApp::OnExit}{wxapponexit})
fc2171bd 93in order to avoid memory leaks, wxWidgets won't do it automatically.
c4afa2cb
VZ
94
95As it happens, you may even further simplify the procedure described above:
96you may forget about calling {\it Set()}. When {\it Get()} is called and there
97is no current object, it will create one using {\it Create()} function. To
98disable this behaviour {\it DontCreateOnDemand()} is provided.
99
fc2171bd 100{\bf Note:} You should use either {\it Set()} or {\it Get()} because wxWidgets
eee786e9
VS
101library itself would take advantage of it and could save various information
102in it. For example \helpref{wxFontMapper}{wxfontmapper} or Unix version
103of \helpref{wxFileDialog}{wxfiledialog} have ability to use wxConfig class.
104
b8de493f
JS
105\helpref{Set}{wxconfigbaseset}\\
106\helpref{Get}{wxconfigbaseget}\\
107\helpref{Create}{wxconfigbasecreate}\\
108\helpref{DontCreateOnDemand}{wxconfigbasedontcreateondemand}
c4afa2cb 109
a121d720 110
f510b7b2 111\membersection{Constructor and destructor}\label{congigconstructordestructor}
c4afa2cb 112
b8de493f
JS
113\helpref{wxConfigBase}{wxconfigbasector}\\
114\helpref{\destruct{wxConfigBase}}{wxconfigbasedtor}
c4afa2cb 115
a121d720 116
f510b7b2 117\membersection{Path management}\label{configpathmanagement}
c4afa2cb 118
5f3cd8a2
VZ
119As explained in \helpref{config overview}{wxconfigoverview}, the config classes
120support a file system-like hierarchy of keys (files) and groups (directories).
c4afa2cb
VZ
121As in the file system case, to specify a key in the config class you must use
122a path to it. Config classes also support the notion of the current group,
123which makes it possible to use the relative paths. To clarify all this, here
f6bcfd97 124is an example (it is only for the sake of demonstration, it doesn't do anything
c4afa2cb
VZ
125sensible!):
126
127\begin{verbatim}
128 wxConfig *config = new wxConfig("FooBarApp");
129
130 // right now the current path is '/'
131 conf->Write("RootEntry", 1);
132
133 // go to some other place: if the group(s) don't exist, they will be created
134 conf->SetPath("/Group/Subgroup");
135
136 // create an entry in subgroup
137 conf->Write("SubgroupEntry", 3);
21f280f4 138
c4afa2cb
VZ
139 // '..' is understood
140 conf->Write("../GroupEntry", 2);
141 conf->SetPath("..");
142
143 wxASSERT( conf->Read("Subgroup/SubgroupEntry", 0l) == 3 );
144
f6bcfd97 145 // use absolute path: it is allowed, too
c4afa2cb
VZ
146 wxASSERT( conf->Read("/RootEntry", 0l) == 1 );
147\end{verbatim}
148
f6bcfd97 149{\it Warning}: it is probably a good idea to always restore the path to its
c4afa2cb 150old value on function exit:
b8de493f 151
c4afa2cb
VZ
152\begin{verbatim}
153 void foo(wxConfigBase *config)
154 {
155 wxString strOldPath = config->GetPath();
156
157 config->SetPath("/Foo/Data");
158 ...
159
160 config->SetPath(strOldPath);
161 }
162\end{verbatim}
163
164because otherwise the assert in the following example will surely fail
165(we suppose here that {\it foo()} function is the same as above except that it
166doesn't save and restore the path):
167
168\begin{verbatim}
169 void bar(wxConfigBase *config)
170 {
171 config->Write("Test", 17);
21f280f4 172
c4afa2cb
VZ
173 foo(config);
174
175 // we're reading "/Foo/Data/Test" here! -1 will probably be returned...
176 wxASSERT( config->Read("Test", -1) == 17 );
177 }
178\end{verbatim}
179
180Finally, the path separator in wxConfigBase and derived classes is always '/',
f6bcfd97 181regardless of the platform (i.e. it is {\bf not} '$\backslash\backslash$' under Windows).
c4afa2cb 182
b8de493f
JS
183\helpref{SetPath}{wxconfigbasesetpath}\\
184\helpref{GetPath}{wxconfigbasegetpath}
c4afa2cb 185
a121d720 186
f510b7b2 187\membersection{Enumeration}\label{configenumeration}
c4afa2cb
VZ
188
189The functions in this section allow to enumerate all entries and groups in the
cc81d32f 190config file. All functions here return false when there are no more items.
c4afa2cb 191
b8de493f 192You must pass the same index to GetNext and GetFirst (don't modify it).
f6bcfd97 193Please note that it is {\bf not} the index of the current item (you will have
2edb0bde 194some great surprises with wxRegConfig if you assume this) and you shouldn't
f6bcfd97 195even look at it: it is just a "cookie" which stores the state of the
c4afa2cb
VZ
196enumeration. It can't be stored inside the class because it would prevent you
197from running several enumerations simultaneously, that's why you must pass it
198explicitly.
199
200Having said all this, enumerating the config entries/groups is very simple:
201
202\begin{verbatim}
203 wxArrayString aNames;
204
205 // enumeration variables
206 wxString str;
207 long dummy;
208
209 // first enum all entries
210 bool bCont = config->GetFirstEntry(str, dummy);
211 while ( bCont ) {
212 aNames.Add(str);
213
214 bCont = GetConfig()->GetNextEntry(str, dummy);
215 }
216
217 ... we have all entry names in aNames...
218
219 // now all groups...
220 bCont = GetConfig()->GetFirstGroup(str, dummy);
221 while ( bCont ) {
222 aNames.Add(str);
223
224 bCont = GetConfig()->GetNextGroup(str, dummy);
225 }
226
227 ... we have all group (and entry) names in aNames...
228
229\end{verbatim}
230
b8de493f 231There are also functions to get the number of entries/subgroups without
c4afa2cb
VZ
232actually enumerating them, but you will probably never need them.
233
b8de493f
JS
234\helpref{GetFirstGroup}{wxconfigbasegetfirstgroup}\\
235\helpref{GetNextGroup}{wxconfigbasegetnextgroup}\\
236\helpref{GetFirstEntry}{wxconfigbasegetfirstentry}\\
237\helpref{GetNextEntry}{wxconfigbasegetnextentry}\\
238\helpref{GetNumberOfEntries}{wxconfigbasegetnumberofentries}\\
239\helpref{GetNumberOfGroups}{wxconfigbasegetnumberofgroups}
c4afa2cb 240
a121d720 241
f510b7b2 242\membersection{Tests of existence}\label{configtestsofexistence}
c4afa2cb 243
b8de493f
JS
244\helpref{HasGroup}{wxconfigbasehasgroup}\\
245\helpref{HasEntry}{wxconfigbasehasentry}\\
19d40bab
VZ
246\helpref{Exists}{wxconfigbaseexists}\\
247\helpref{GetEntryType}{wxconfigbasegetentrytype}
c4afa2cb 248
a121d720 249
f510b7b2 250\membersection{Miscellaneous functions}\label{configmiscellaneous}
052ae0e5 251
052ae0e5 252\helpref{GetAppName}{wxconfigbasegetappname}\\
f6bcfd97
BP
253\helpref{GetVendorName}{wxconfigbasegetvendorname}\\
254\helpref{SetUmask}{wxfileconfigsetumask}
052ae0e5 255
a121d720 256
f510b7b2 257\membersection{Key access}\label{configkeyaccess}
c4afa2cb
VZ
258
259These function are the core of wxConfigBase class: they allow you to read and
260write config file data. All {\it Read} function take a default value which
261will be returned if the specified key is not found in the config file.
262
263Currently, only two types of data are supported: string and long (but it might
264change in the near future). To work with other types: for {\it int} or {\it
265bool} you can work with function taking/returning {\it long} and just use the
266casts. Better yet, just use {\it long} for all variables which you're going to
7af3ca16 267save in the config file: chances are that {\tt sizeof(bool) == sizeof(int) == sizeof(long)} anyhow on your system. For {\it float}, {\it double} and, in
c4afa2cb
VZ
268general, any other type you'd have to translate them to/from string
269representation and use string functions.
270
271Try not to read long values into string variables and vice versa: although it
272just might work with wxFileConfig, you will get a system error with
273wxRegConfig because in the Windows registry the different types of entries are
274indeed used.
275
276Final remark: the {\it szKey} parameter for all these functions can contain an
277arbitrary path (either relative or absolute), not just the key name.
278
b8de493f
JS
279\helpref{Read}{wxconfigbaseread}\\
280\helpref{Write}{wxconfigbasewrite}\\
281\helpref{Flush}{wxconfigbaseflush}
282
a121d720 283
f510b7b2 284\membersection{Rename entries/groups}\label{configrenaming}
5d1902d6
VZ
285
286The functions in this section allow to rename entries or subgroups of the
cc81d32f 287current group. They will return false on error. typically because either the
5d1902d6
VZ
288entry/group with the original name doesn't exist, because the entry/group with
289the new name already exists or because the function is not supported in this
290wxConfig implementation.
291
292\helpref{RenameEntry}{wxconfigbaserenameentry}\\
293\helpref{RenameGroup}{wxconfigbaserenamegroup}
294
a121d720 295
f510b7b2 296\membersection{Delete entries/groups}\label{configdeleting}
b8de493f
JS
297
298The functions in this section delete entries and/or groups of entries from the
299config file. {\it DeleteAll()} is especially useful if you want to erase all
300traces of your program presence: for example, when you uninstall it.
301
302\helpref{DeleteEntry}{wxconfigbasedeleteentry}\\
303\helpref{DeleteGroup}{wxconfigbasedeletegroup}\\
304\helpref{DeleteAll}{wxconfigbasedeleteall}
305
a121d720 306
f510b7b2 307\membersection{Options}\label{configoptions}
b8de493f
JS
308
309Some aspects of wxConfigBase behaviour can be changed during run-time. The
310first of them is the expansion of environment variables in the string values
311read from the config file: for example, if you have the following in your
312config file:
313
314\begin{verbatim}
315 # config file for my program
316 UserData = $HOME/data
317
318 # the following syntax is valud only under Windows
319 UserData = %windir%\\data.dat
320\end{verbatim}
9722642d 321% $ % help EMACS syntax highlighting...
7af3ca16
VZ
322the call to {\tt config->Read("UserData")} will return something like
323{\tt "/home/zeitlin/data"} if you're lucky enough to run a Linux system ;-)
b8de493f
JS
324
325Although this feature is very useful, it may be annoying if you read a value
326which containts '\$' or '\%' symbols (\% is used for environment variables
327expansion under Windows) which are not used for environment variable
cc81d32f
VS
328expansion. In this situation you may call SetExpandEnvVars(false) just before
329reading this value and SetExpandEnvVars(true) just after. Another solution
b8de493f
JS
330would be to prefix the offending symbols with a backslash.
331
332The following functions control this option:
333
334\helpref{IsExpandingEnvVars}{wxconfigbaseisexpandingenvvars}\\
f6bcfd97 335\helpref{SetExpandEnvVars}{wxconfigbasesetexpandenvvars}\\
b8de493f
JS
336\helpref{SetRecordDefaults}{wxconfigbasesetrecorddefaults}\\
337\helpref{IsRecordingDefaults}{wxconfigbaseisrecordingdefaults}
338
339%%%%% MEMBERS HERE %%%%%
340\helponly{\insertatlevel{2}{
341
342\wxheading{Members}
343
344}}
345
a121d720 346
052ae0e5 347\membersection{wxConfigBase::wxConfigBase}\label{wxconfigbasector}
b8de493f 348
052ae0e5
JS
349\func{}{wxConfigBase}{\param{const wxString\& }{appName = wxEmptyString},
350 \param{const wxString\& }{vendorName = wxEmptyString},
351 \param{const wxString\& }{localFilename = wxEmptyString},
352 \param{const wxString\& }{globalFilename = wxEmptyString},
4561e95d
VS
353 \param{long}{ style = 0},
354 \param{wxMBConv\&}{ conv = wxConvUTF8}}
b8de493f 355
5f3cd8a2
VZ
356This is the default and only constructor of the wxConfigBase class, and
357derived classes.
b8de493f 358
052ae0e5 359\wxheading{Parameters}
b8de493f 360
5f3cd8a2
VZ
361\docparam{appName}{The application name. If this is empty, the class will
362normally use \helpref{wxApp::GetAppName}{wxappgetappname} to set it. The
363application name is used in the registry key on Windows, and can be used to
364deduce the local filename parameter if that is missing.}
b8de493f 365
052ae0e5
JS
366\docparam{vendorName}{The vendor name. If this is empty, it is assumed that
367no vendor name is wanted, if this is optional for the current config class.
368The vendor name is appended to the application name for wxRegConfig.}
b8de493f 369
5f3cd8a2
VZ
370\docparam{localFilename}{Some config classes require a local filename. If this
371is not present, but required, the application name will be used instead.}
b8de493f 372
5f3cd8a2
VZ
373\docparam{globalFilename}{Some config classes require a global filename. If
374this is not present, but required, the application name will be used instead.}
b8de493f 375
5f3cd8a2
VZ
376\docparam{style}{Can be one of wxCONFIG\_USE\_LOCAL\_FILE and
377wxCONFIG\_USE\_GLOBAL\_FILE. The style interpretation depends on the config
378class and is ignored by some. For wxFileConfig, these styles determine whether
379a local or global config file is created or used. If the flag is present but
380the parameter is empty, the parameter will be set to a default. If the
381parameter is present but the style flag not, the relevant flag will be added
3135da71 382to the style. For wxFileConfig you can also add wxCONFIG\_USE\_RELATIVE\_PATH
2b5f62a0 383by logically or'ing it to either of the \_FILE options to tell wxFileConfig to
8dce54c9
VZ
384use relative instead of absolute paths. For wxFileConfig, you can also
385add wxCONFIG\_USE\_NO\_ESCAPE\_CHARACTERS which will turn off character
386escaping for the values of entries stored in the config file: for example
2b5f62a0
VZ
387a {\it foo} key with some backslash characters will be stored as {\tt foo=C:$\backslash$mydir} instead
388of the usual storage of {\tt foo=C:$\backslash\backslash$mydir}.
389
8dce54c9 390The wxCONFIG\_USE\_NO\_ESCAPE\_CHARACTERS style can be helpful if your config
fc2171bd 391file must be read or written to by a non-wxWidgets program (which might not
8dce54c9
VZ
392understand the escape characters). Note, however, that if
393wxCONFIG\_USE\_NO\_ESCAPE\_CHARACTERS style is used, it is is now
394your application's responsibility to ensure that there is no newline or
395other illegal characters in a value, before writing that value to the file.}
b8de493f 396
b867ed68
VS
397\docparam{conv}{This parameter is only used by wxFileConfig when compiled
398in Unicode mode. It specifies the encoding in what the configuration file
399is written.}
400
401
052ae0e5 402\wxheading{Remarks}
b8de493f 403
5f3cd8a2
VZ
404By default, environment variable expansion is on and recording defaults is
405off.
b8de493f 406
a121d720 407
052ae0e5 408\membersection{wxConfigBase::\destruct{wxConfigBase}}\label{wxconfigbasedtor}
b8de493f 409
052ae0e5 410\func{}{\destruct{wxConfigBase}}{\void}
b8de493f 411
052ae0e5 412Empty but ensures that dtor of all derived classes is virtual.
b8de493f 413
a121d720 414
b8de493f
JS
415\membersection{wxConfigBase::Create}\label{wxconfigbasecreate}
416
052ae0e5 417\func{static wxConfigBase *}{Create}{\void}
b8de493f
JS
418
419Create a new config object: this function will create the "best"
5f3cd8a2
VZ
420implementation of wxConfig available for the current platform, see comments
421near the definition of wxCONFIG\_WIN32\_NATIVE for details. It returns the
422created object and also sets it as the current one.
b8de493f 423
a121d720 424
b8de493f
JS
425\membersection{wxConfigBase::DontCreateOnDemand}\label{wxconfigbasedontcreateondemand}
426
427\func{void}{DontCreateOnDemand}{\void}
428
429Calling this function will prevent {\it Get()} from automatically creating a
430new config object if the current one is NULL. It might be useful to call it
431near the program end to prevent new config object "accidental" creation.
432
a121d720 433
052ae0e5 434\membersection{wxConfigBase::DeleteAll}\label{wxconfigbasedeleteall}
b8de493f 435
052ae0e5 436\func{bool}{DeleteAll}{\void}
b8de493f 437
052ae0e5
JS
438Delete the whole underlying object (disk file, registry key, ...). Primarly
439for use by desinstallation routine.
b8de493f 440
a121d720 441
052ae0e5 442\membersection{wxConfigBase::DeleteEntry}\label{wxconfigbasedeleteentry}
b8de493f 443
cc81d32f 444\func{bool}{DeleteEntry}{\param{const wxString\& }{ key}, \param{bool}{ bDeleteGroupIfEmpty = true}}
b8de493f 445
5f3cd8a2
VZ
446Deletes the specified entry and the group it belongs to if it was the last key
447in it and the second parameter is true.
b8de493f 448
a121d720 449
052ae0e5 450\membersection{wxConfigBase::DeleteGroup}\label{wxconfigbasedeletegroup}
b8de493f 451
052ae0e5 452\func{bool}{DeleteGroup}{\param{const wxString\& }{ key}}
b8de493f 453
052ae0e5
JS
454Delete the group (with all subgroups)
455
a121d720 456
052ae0e5
JS
457\membersection{wxConfigBase::Exists}\label{wxconfigbaseexists}
458
459\constfunc{bool}{Exists}{\param{wxString\& }{strName}}
460
cc81d32f 461returns true if either a group or an entry with a given name exists
052ae0e5 462
a121d720 463
052ae0e5
JS
464\membersection{wxConfigBase::Flush}\label{wxconfigbaseflush}
465
cc81d32f 466\func{bool}{Flush}{\param{bool }{bCurrentOnly = false}}
052ae0e5
JS
467
468permanently writes all changes (otherwise, they're only written from object's
469destructor)
470
a121d720 471
052ae0e5
JS
472\membersection{wxConfigBase::Get}\label{wxconfigbaseget}
473
cc81d32f 474\func{static wxConfigBase *}{Get}{\param{bool }{CreateOnDemand = true}}
052ae0e5 475
eee786e9 476Get the current config object. If there is no current object and
cc81d32f 477{\it CreateOnDemand} is true, creates one
052ae0e5
JS
478(using {\it Create}) unless DontCreateOnDemand was called previously.
479
a121d720 480
052ae0e5
JS
481\membersection{wxConfigBase::GetAppName}\label{wxconfigbasegetappname}
482
483\constfunc{wxString}{GetAppName}{\void}
484
485Returns the application name.
486
a121d720 487
19d40bab
VZ
488\membersection{wxConfigBase::GetEntryType}\label{wxconfigbasegetentrytype}
489
490\constfunc{enum wxConfigBase::EntryType}{GetEntryType}{\param{const wxString\& }{name}}
491
492Returns the type of the given entry or {\it Unknown} if the entry doesn't
493exist. This function should be used to decide which version of Read() should
494be used because some of wxConfig implementations will complain about type
495mismatch otherwise: e.g., an attempt to read a string value from an integer
6776a0b2 496key with wxRegConfig will fail.
19d40bab
VZ
497
498The result is an element of enum EntryType:
499
500\begin{verbatim}
501 enum EntryType
502 {
503 Unknown,
504 String,
505 Boolean,
506 Integer,
507 Float
508 };
509\end{verbatim}
510
a121d720 511
052ae0e5
JS
512\membersection{wxConfigBase::GetFirstGroup}\label{wxconfigbasegetfirstgroup}
513
f6bcfd97 514\constfunc{bool}{GetFirstGroup}{\param{wxString\& }{str}, \param{long\&}{ index}}
052ae0e5
JS
515
516Gets the first group.
517
21f280f4
RD
518\pythonnote{The wxPython version of this method returns a 3-tuple
519consisting of the continue flag, the value string, and the index for
520the next call.}
521
9722642d
MB
522\perlnote{In wxPerl this method takes no arguments and returns a 3-element
523list {\tt ( continue, str, index )}.}
524
a121d720 525
052ae0e5
JS
526\membersection{wxConfigBase::GetFirstEntry}\label{wxconfigbasegetfirstentry}
527
f6bcfd97 528\constfunc{bool}{GetFirstEntry}{\param{wxString\& }{str}, \param{long\&}{ index}}
052ae0e5
JS
529
530Gets the first entry.
531
21f280f4
RD
532\pythonnote{The wxPython version of this method returns a 3-tuple
533consisting of the continue flag, the value string, and the index for
534the next call.}
535
9722642d
MB
536\perlnote{In wxPerl this method takes no arguments and returns a 3-element
537list {\tt ( continue, str, index )}.}
538
a121d720 539
052ae0e5
JS
540\membersection{wxConfigBase::GetNextGroup}\label{wxconfigbasegetnextgroup}
541
f6bcfd97 542\constfunc{bool}{GetNextGroup}{\param{wxString\& }{str}, \param{long\&}{ index}}
052ae0e5
JS
543
544Gets the next group.
545
21f280f4
RD
546\pythonnote{The wxPython version of this method returns a 3-tuple
547consisting of the continue flag, the value string, and the index for
548the next call.}
549
9722642d
MB
550\perlnote{In wxPerl this method only takes the {\tt index} parameter
551and returns a 3-element list {\tt ( continue, str, index )}.}
552
a121d720 553
052ae0e5
JS
554\membersection{wxConfigBase::GetNextEntry}\label{wxconfigbasegetnextentry}
555
f6bcfd97 556\constfunc{bool}{GetNextEntry}{\param{wxString\& }{str}, \param{long\&}{ index}}
052ae0e5
JS
557
558Gets the next entry.
559
21f280f4
RD
560\pythonnote{The wxPython version of this method returns a 3-tuple
561consisting of the continue flag, the value string, and the index for
562the next call.}
563
9722642d
MB
564\perlnote{In wxPerl this method only takes the {\tt index} parameter
565and returns a 3-element list {\tt ( continue, str, index )}.}
566
a121d720 567
052ae0e5
JS
568\membersection{wxConfigBase::GetNumberOfEntries}\label{wxconfigbasegetnumberofentries}
569
cc81d32f 570\constfunc{uint }{GetNumberOfEntries}{\param{bool }{bRecursive = false}}
052ae0e5 571
a121d720 572
052ae0e5
JS
573\membersection{wxConfigBase::GetNumberOfGroups}\label{wxconfigbasegetnumberofgroups}
574
cc81d32f 575\constfunc{uint}{GetNumberOfGroups}{\param{bool }{bRecursive = false}}
052ae0e5 576
5f3cd8a2
VZ
577Get number of entries/subgroups in the current group, with or without its
578subgroups.
b8de493f 579
a121d720 580
b8de493f
JS
581\membersection{wxConfigBase::GetPath}\label{wxconfigbasegetpath}
582
052ae0e5 583\constfunc{const wxString\&}{GetPath}{\void}
b8de493f
JS
584
585Retrieve the current path (always as absolute path).
586
a121d720 587
052ae0e5 588\membersection{wxConfigBase::GetVendorName}\label{wxconfigbasegetvendorname}
b8de493f 589
052ae0e5 590\constfunc{wxString}{GetVendorName}{\void}
b8de493f 591
052ae0e5 592Returns the vendor name.
b8de493f 593
a121d720 594
b8de493f
JS
595\membersection{wxConfigBase::HasEntry}\label{wxconfigbasehasentry}
596
597\constfunc{bool}{HasEntry}{\param{wxString\& }{strName}}
598
cc81d32f 599returns true if the entry by this name exists
b8de493f 600
a121d720 601
052ae0e5 602\membersection{wxConfigBase::HasGroup}\label{wxconfigbasehasgroup}
b8de493f 603
052ae0e5 604\constfunc{bool}{HasGroup}{\param{const wxString\& }{strName}}
b8de493f 605
cc81d32f 606returns true if the group by this name exists
052ae0e5 607
a121d720 608
052ae0e5
JS
609\membersection{wxConfigBase::IsExpandingEnvVars}\label{wxconfigbaseisexpandingenvvars}
610
611\constfunc{bool}{IsExpandingEnvVars}{\void}
612
cc81d32f 613Returns true if we are expanding environment variables in key values.
052ae0e5 614
a121d720 615
052ae0e5
JS
616\membersection{wxConfigBase::IsRecordingDefaults}\label{wxconfigbaseisrecordingdefaults}
617
f6bcfd97 618\constfunc{bool}{IsRecordingDefaults}{\void}
052ae0e5 619
cc81d32f 620Returns true if we are writing defaults back to the config file.
b8de493f 621
a121d720 622
b8de493f
JS
623\membersection{wxConfigBase::Read}\label{wxconfigbaseread}
624
f6bcfd97 625\constfunc{bool}{Read}{\param{const wxString\& }{key}, \param{wxString*}{ str}}
052ae0e5 626
cc81d32f 627Read a string from the key, returning true if the value was read. If the key
5f3cd8a2 628was not found, {\it str} is not changed.
052ae0e5 629
f6bcfd97 630\constfunc{bool}{Read}{\param{const wxString\& }{key}, \param{wxString*}{ str}, \param{const wxString\& }{defaultVal}}
052ae0e5 631
5f3cd8a2
VZ
632Read a string from the key. The default value is returned if the key was not
633found.
c4afa2cb 634
cc81d32f 635Returns true if value was really read, false if the default was used.
c4afa2cb 636
5f3cd8a2
VZ
637\constfunc{wxString}{Read}{\param{const wxString\& }{key}, \param{const
638wxString\& }{defaultVal}}
c4afa2cb 639
052ae0e5 640Another version of {\it Read()}, returning the string value directly.
c4afa2cb 641
052ae0e5 642\constfunc{bool}{Read}{\param{const wxString\& }{ key}, \param{long*}{ l}}
c4afa2cb 643
cc81d32f 644Reads a long value, returning true if the value was found. If the value was
5f3cd8a2 645not found, {\it l} is not changed.
c4afa2cb 646
5f3cd8a2
VZ
647\constfunc{bool}{Read}{\param{const wxString\& }{ key}, \param{long*}{ l},
648\param{long}{ defaultVal}}
052ae0e5 649
cc81d32f 650Reads a long value, returning true if the value was found. If the value was
5f3cd8a2 651not found, {\it defaultVal} is used instead.
052ae0e5 652
f6bcfd97 653\constfunc{long }{Read}{\param{const wxString\& }{key}, \param{long}{ defaultVal}}
052ae0e5 654
5f3cd8a2
VZ
655Reads a long value from the key and returns it. {\it defaultVal} is returned
656if the key is not found.
c4afa2cb
VZ
657
658NB: writing
052ae0e5 659
6aa358ae
GT
660{\small
661\begin{verbatim}
662 conf->Read("key", 0);
663\end{verbatim}
664}
052ae0e5 665
5f3cd8a2
VZ
666won't work because the call is ambiguous: compiler can not choose between two
667{\it Read} functions. Instead, write:
052ae0e5 668
6aa358ae
GT
669{\small
670\begin{verbatim}
671 conf->Read("key", 0l);
672\end{verbatim}
673}
c4afa2cb 674
052ae0e5 675\constfunc{bool}{Read}{\param{const wxString\& }{ key}, \param{double*}{ d}}
c4afa2cb 676
cc81d32f 677Reads a double value, returning true if the value was found. If the value was
5f3cd8a2 678not found, {\it d} is not changed.
c4afa2cb 679
5f3cd8a2 680\constfunc{bool}{Read}{\param{const wxString\& }{ key}, \param{double*}{ d},
0d57be45 681 \param{double}{ defaultVal}}
b8de493f 682
cc81d32f 683Reads a double value, returning true if the value was found. If the value was
5f3cd8a2 684not found, {\it defaultVal} is used instead.
b8de493f 685
052ae0e5 686\constfunc{bool}{Read}{\param{const wxString\& }{ key}, \param{bool*}{ b}}
c4afa2cb 687
cc81d32f 688Reads a bool value, returning true if the value was found. If the value was
5f3cd8a2 689not found, {\it b} is not changed.
b8de493f 690
5f3cd8a2
VZ
691\constfunc{bool}{Read}{\param{const wxString\& }{ key}, \param{bool*}{ d},
692\param{bool}{ defaultVal}}
c4afa2cb 693
cc81d32f 694Reads a bool value, returning true if the value was found. If the value was
5f3cd8a2 695not found, {\it defaultVal} is used instead.
c4afa2cb 696
21f280f4
RD
697\pythonnote{In place of a single overloaded method name, wxPython
698implements the following methods:\par
699\indented{2cm}{\begin{twocollist}
c9110876
VS
700\twocolitem{{\bf Read(key, default="")}}{Returns a string.}
701\twocolitem{{\bf ReadInt(key, default=0)}}{Returns an int.}
702\twocolitem{{\bf ReadFloat(key, default=0.0)}}{Returns a floating point number.}
21f280f4
RD
703\end{twocollist}}
704}
705
9722642d
MB
706\perlnote{In place of a single overloaded method, wxPerl uses:\par
707\indented{2cm}{\begin{twocollist}
708\twocolitem{{\bf Read(key, default="")}}{Returns a string}
709\twocolitem{{\bf ReadInt(key, default=0)}}{Returns an integer}
710\twocolitem{{\bf ReadFloat(key, default=0.0)}}{Returns a floating point number}
711\twocolitem{{\bf ReadBool(key, default=0)}}{Returns a boolean}
712\end{twocollist}
713}}
714
a121d720 715
5d1902d6
VZ
716\membersection{wxConfigBase::RenameEntry}\label{wxconfigbaserenameentry}
717
718\func{bool}{RenameEntry}{\param{const wxString\& }{ oldName}, \param{const wxString\& }{ newName}}
719
720Renames an entry in the current group. The entries names (both the old and
721the new one) shouldn't contain backslashes, i.e. only simple names and not
722arbitrary paths are accepted by this function.
723
cc81d32f 724Returns false if the {\it oldName} doesn't exist or if {\it newName} already
5d1902d6
VZ
725exists.
726
a121d720 727
5d1902d6
VZ
728\membersection{wxConfigBase::RenameGroup}\label{wxconfigbaserenamegroup}
729
730\func{bool}{RenameGroup}{\param{const wxString\& }{ oldName}, \param{const wxString\& }{ newName}}
731
732Renames a subgroup of the current group. The subgroup names (both the old and
733the new one) shouldn't contain backslashes, i.e. only simple names and not
734arbitrary paths are accepted by this function.
735
cc81d32f 736Returns false if the {\it oldName} doesn't exist or if {\it newName} already
5d1902d6
VZ
737exists.
738
a121d720 739
052ae0e5 740\membersection{wxConfigBase::Set}\label{wxconfigbaseset}
c4afa2cb 741
142b3bc2 742\func{static wxConfigBase *}{Set}{\param{wxConfigBase *}{pConfig}}
c4afa2cb 743
052ae0e5
JS
744Sets the config object as the current one, returns the pointer to the previous
745current object (both the parameter and returned value may be NULL)
c4afa2cb 746
a121d720 747
f6bcfd97 748\membersection{wxConfigBase::SetExpandEnvVars}\label{wxconfigbasesetexpandenvvars}
c4afa2cb 749
cc81d32f 750\func{void}{SetExpandEnvVars }{\param{bool }{bDoIt = true}}
b8de493f 751
052ae0e5 752Determine whether we wish to expand environment variables in key values.
c4afa2cb 753
a121d720 754
052ae0e5 755\membersection{wxConfigBase::SetPath}\label{wxconfigbasesetpath}
c4afa2cb 756
052ae0e5 757\func{void}{SetPath}{\param{const wxString\& }{strPath}}
c4afa2cb 758
f6bcfd97
BP
759Set current path: if the first character is '/', it is the absolute path,
760otherwise it is a relative path. '..' is supported. If the strPath doesn't
5f3cd8a2 761exist it is created.
c4afa2cb 762
a121d720 763
052ae0e5 764\membersection{wxConfigBase::SetRecordDefaults}\label{wxconfigbasesetrecorddefaults}
c4afa2cb 765
cc81d32f 766\func{void}{SetRecordDefaults}{\param{bool }{bDoIt = true}}
052ae0e5 767
cb3b65d4
VZ
768Sets whether defaults are recorded to the config file whenever an attempt to
769read read the value which is not present in it is done.
c4afa2cb 770
cb3b65d4
VZ
771If on (default is off) all default values for the settings used by the program
772are written back to the config file. This allows the user to see what config
773options may be changed and is probably useful only for wxFileConfig.
c4afa2cb 774
f6bcfd97 775
052ae0e5
JS
776\membersection{wxConfigBase::Write}\label{wxconfigbasewrite}
777
5f3cd8a2
VZ
778\func{bool}{Write}{\param{const wxString\& }{ key}, \param{const wxString\& }{
779value}}
052ae0e5
JS
780
781\func{bool}{Write}{\param{const wxString\& }{ key}, \param{long}{ value}}
782
783\func{bool}{Write}{\param{const wxString\& }{ key}, \param{double}{ value}}
784
785\func{bool}{Write}{\param{const wxString\& }{ key}, \param{bool}{ value}}
786
cc81d32f 787These functions write the specified value to the config file and return true
5f3cd8a2 788on success.
c4afa2cb 789
21f280f4
RD
790\pythonnote{In place of a single overloaded method name, wxPython
791implements the following methods:\par
792\indented{2cm}{\begin{twocollist}
c9110876
VS
793\twocolitem{{\bf Write(key, value)}}{Writes a string.}
794\twocolitem{{\bf WriteInt(key, value)}}{Writes an int.}
795\twocolitem{{\bf WriteFloat(key, value)}}{Writes a floating point number.}
21f280f4
RD
796\end{twocollist}}
797}
798
9722642d
MB
799\perlnote{In place of a single overloaded method, wxPerl uses:\par
800\indented{2cm}{\begin{twocollist}
801\twocolitem{{\bf Write(key, value)}}{Writes a string}
802\twocolitem{{\bf WriteInt(key, value)}}{Writes an integer}
803\twocolitem{{\bf WriteFloat(key, value)}}{Writes a floating point number}
804\twocolitem{{\bf WriteBool(key, value)}}{Writes a boolean}
805\end{twocollist}
806}}