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