]> git.saurik.com Git - wxWidgets.git/blame_incremental - wxPython/src/_config.i
Fixed PyDropTarget rename
[wxWidgets.git] / wxPython / src / _config.i
... / ...
CommitLineData
1/////////////////////////////////////////////////////////////////////////////
2// Name: _config.i
3// Purpose: SWIG interface for wxConfig, wxFileConfig, etc.
4//
5// Author: Robin Dunn
6//
7// Created: 25-Nov-1998
8// RCS-ID: $Id$
9// Copyright: (c) 2003 by Total Control Software
10// Licence: wxWindows license
11/////////////////////////////////////////////////////////////////////////////
12
13// Not a %module
14
15
16//---------------------------------------------------------------------------
17%newgroup
18
19%{
20%}
21
22//---------------------------------------------------------------------------
23
24
25%{
26 static PyObject* __EnumerationHelper(bool flag, wxString& str, long index) {
27 PyObject* ret = PyTuple_New(3);
28 if (ret) {
29 PyTuple_SET_ITEM(ret, 0, PyInt_FromLong(flag));
30 PyTuple_SET_ITEM(ret, 1, wx2PyString(str));
31 PyTuple_SET_ITEM(ret, 2, PyInt_FromLong(index));
32 }
33 return ret;
34 }
35%}
36
37
38enum
39{
40 wxCONFIG_USE_LOCAL_FILE,
41 wxCONFIG_USE_GLOBAL_FILE,
42 wxCONFIG_USE_RELATIVE_PATH,
43 wxCONFIG_USE_NO_ESCAPE_CHARACTERS
44};
45
46
47
48DocStr(wxConfigBase,
49"wx.ConfigBase class defines the basic interface of all config
50classes. It can not be used by itself (it is an abstract base
51class) and you will always use one of its derivations: wx.Config
52or wx.FileConfig.
53
54wx.ConfigBase organizes the items in a tree-like structure
55(modeled after the Unix/Dos filesystem). There are groups
56(directories) and keys (files). There is always one current
57group given by the current path. As in the file system case, to
58specify a key in the config class you must use a path to it.
59Config classes also support the notion of the current group,
60which makes it possible to use relative paths.
61
62Keys are pairs \"key_name = value\" where value may be of string, integer
63floating point or boolean, you can not store binary data without first
64encoding it as a string. For performance reasons items should be kept small,
65no more than a couple kilobytes.
66");
67
68
69class wxConfigBase {
70public:
71// wxConfigBase(const wxString& appName = wxPyEmptyString, **** An ABC
72// const wxString& vendorName = wxPyEmptyString,
73// const wxString& localFilename = wxPyEmptyString,
74// const wxString& globalFilename = wxPyEmptyString,
75// long style = 0);
76 ~wxConfigBase();
77
78 enum EntryType
79 {
80 Type_Unknown,
81 Type_String,
82 Type_Boolean,
83 Type_Integer, // use Read(long *)
84 Type_Float // use Read(double *)
85 };
86
87
88 DocDeclStr(
89 static wxConfigBase *, Set(wxConfigBase *config),
90 "Sets the global config object (the one returned by Get) and\n"
91 "returns a reference to the previous global config object.");
92
93
94 DocDeclStr(
95 static wxConfigBase *, Get(bool createOnDemand = True),
96 "Returns the current global config object, creating one if neccessary.");
97
98
99 DocDeclStr(
100 static wxConfigBase *, Create(),
101 "Create and return a new global config object. This function will\n"
102 "create the \"best\" implementation of wx.Config available for the\n"
103 "current platform.");
104
105
106
107 DocDeclStr(
108 static void , DontCreateOnDemand(),
109 "Should Get() try to create a new log object if there isn't a current one?");
110
111
112
113
114 DocDeclStr(
115 virtual void , SetPath(const wxString& path),
116 "Set current path: if the first character is '/', it's the absolute path,\n"
117 "otherwise it's a relative path. '..' is supported. If the strPath\n"
118 "doesn't exist it is created.");
119
120
121 DocDeclStr(
122 virtual const wxString& , GetPath() const,
123 "Retrieve the current path (always as absolute path)");
124
125
126
127 %extend {
128 DocAStr(GetFirstGroup,
129 "GetFirstGroup() -> (more, value, index)",
130 "Allows enumerating the subgroups in a config object. Returns\n"
131 "a tuple containing a flag indicating there are more items, the\n"
132 "name of the current item, and an index to pass to GetNextGroup to\n"
133 "fetch the next item.");
134 PyObject* GetFirstGroup() {
135 bool cont;
136 long index = 0;
137 wxString value;
138
139 cont = self->GetFirstGroup(value, index);
140 return __EnumerationHelper(cont, value, index);
141 }
142
143
144
145 DocAStr(GetNextGroup,
146 "GetNextGroup(long index) -> (more, value, index)",
147 "Allows enumerating the subgroups in a config object. Returns\n"
148 "a tuple containing a flag indicating there are more items, the\n"
149 "name of the current item, and an index to pass to GetNextGroup to\n"
150 "fetch the next item.");
151 PyObject* GetNextGroup(long index) {
152 bool cont;
153 wxString value;
154
155 cont = self->GetNextGroup(value, index);
156 return __EnumerationHelper(cont, value, index);
157 }
158
159
160 DocAStr(GetFirstEntry,
161 "GetFirstEntry() -> (more, value, index)",
162 "Allows enumerating the entries in the current group in a config\n"
163 "object. Returns a tuple containing a flag indicating there are\n"
164 "more items, the name of the current item, and an index to pass to\n"
165 "GetNextGroup to fetch the next item.");
166 PyObject* GetFirstEntry() {
167 bool cont;
168 long index = 0;
169 wxString value;
170
171 cont = self->GetFirstEntry(value, index);
172 return __EnumerationHelper(cont, value, index);
173 }
174
175
176 DocAStr(GetNextEntry,
177 "GetNextEntry(long index) -> (more, value, index)",
178 "Allows enumerating the entries in the current group in a config\n"
179 "object. Returns a tuple containing a flag indicating there are\n"
180 "more items, the name of the current item, and an index to pass to\n"
181 "GetNextGroup to fetch the next item.");
182 PyObject* GetNextEntry(long index) {
183 bool cont;
184 wxString value;
185
186 cont = self->GetNextEntry(value, index);
187 return __EnumerationHelper(cont, value, index);
188 }
189 }
190
191
192
193 DocDeclStr(
194 virtual size_t , GetNumberOfEntries(bool recursive = False) const,
195 "Get the number of entries in the current group, with or\n"
196 "without its subgroups.");
197
198 DocDeclStr(
199 virtual size_t , GetNumberOfGroups(bool recursive = False) const,
200 "Get the number of subgroups in the current group, with or\n"
201 "without its subgroups.");
202
203
204
205 DocDeclStr(
206 virtual bool , HasGroup(const wxString& name) const,
207 "Returns True if the group by this name exists");
208
209
210 DocDeclStr(
211 virtual bool , HasEntry(const wxString& name) const,
212 "Returns True if the entry by this name exists");
213
214
215 DocDeclStr(
216 bool , Exists(const wxString& name) const,
217 "Returns True if either a group or an entry with a given name exists");
218
219
220 // get the entry type
221 DocDeclStr(
222 virtual EntryType , GetEntryType(const wxString& name) const,
223 "Get the type of the entry. Returns one of the wx.Config.Type_XXX values.");
224
225
226
227 DocDeclStr(
228 wxString , Read(const wxString& key, const wxString& defaultVal = wxPyEmptyString),
229 "Returns the value of key if it exists, defaultVal otherwise.");
230
231
232 %extend {
233 DocStr(ReadInt,
234 "Returns the value of key if it exists, defaultVal otherwise.");
235 long ReadInt(const wxString& key, long defaultVal = 0) {
236 long rv;
237 self->Read(key, &rv, defaultVal);
238 return rv;
239 }
240
241 DocStr(ReadFloat,
242 "Returns the value of key if it exists, defaultVal otherwise.");
243 double ReadFloat(const wxString& key, double defaultVal = 0.0) {
244 double rv;
245 self->Read(key, &rv, defaultVal);
246 return rv;
247 }
248
249 DocStr(ReadBool,
250 "Returns the value of key if it exists, defaultVal otherwise.");
251 bool ReadBool(const wxString& key, bool defaultVal = False) {
252 bool rv;
253 self->Read(key, &rv, defaultVal);
254 return rv;
255 }
256 }
257
258
259 // write the value (return True on success)
260 DocDeclStr(
261 bool , Write(const wxString& key, const wxString& value),
262 "write the value (return True on success)");
263
264 DocDeclStrName(
265 bool, Write(const wxString& key, long value),
266 "write the value (return True on success)",
267 WriteInt);
268
269 DocDeclStrName(
270 bool, Write(const wxString& key, double value),
271 "write the value (return True on success)",
272 WriteFloat);
273
274 DocDeclStrName(
275 bool, Write(const wxString& key, bool value),
276 "write the value (return True on success)",
277 WriteBool);
278
279
280 DocDeclStr(
281 virtual bool , Flush(bool currentOnly = False),
282 "permanently writes all changes");
283
284
285 DocDeclStr(
286 virtual bool , RenameEntry(const wxString& oldName,
287 const wxString& newName),
288 "Rename an entry. Returns False on failure (probably because the new\n"
289 "name is already taken by an existing entry)");
290
291 DocDeclStr(
292 virtual bool , RenameGroup(const wxString& oldName,
293 const wxString& newName),
294 "Rename aa group. Returns False on failure (probably because the new\n"
295 "name is already taken by an existing entry)");
296
297
298 // deletes the specified entry and the group it belongs to if
299 // it was the last key in it and the second parameter is True
300 DocDeclStr(
301 virtual bool , DeleteEntry(const wxString& key,
302 bool deleteGroupIfEmpty = True),
303 "Deletes the specified entry and the group it belongs to if\n"
304 "it was the last key in it and the second parameter is True");
305
306
307 DocDeclStr(
308 virtual bool , DeleteGroup(const wxString& key),
309 "Delete the group (with all subgroups)");
310
311
312 DocDeclStr(
313 virtual bool , DeleteAll(),
314 "Delete the whole underlying object (disk file, registry key, ...)\n"
315 "primarly intended for use by desinstallation routine.");
316
317
318
319 DocDeclStr(
320 void , SetExpandEnvVars(bool doIt = True),
321 "We can automatically expand environment variables in the config entries\n"
322 "(this option is on by default, you can turn it on/off at any time)");
323
324 DocDeclStr(
325 bool , IsExpandingEnvVars() const,
326 "Are we currently expanding environment variables?");
327
328
329 DocDeclStr(
330 void , SetRecordDefaults(bool doIt = True),
331 "Set whether the config objec should record default values.");
332
333 DocDeclStr(
334 bool , IsRecordingDefaults() const,
335 "Are we currently recording default values?");
336
337
338 DocDeclStr(
339 wxString , ExpandEnvVars(const wxString& str) const,
340 "Expand any environment variables in str and return the result");
341
342
343 DocDeclStr(
344 wxString , GetAppName() const,
345 "");
346
347 DocDeclStr(
348 wxString , GetVendorName() const,
349 "");
350
351
352 DocDeclStr(
353 void , SetAppName(const wxString& appName),
354 "");
355
356 DocDeclStr(
357 void , SetVendorName(const wxString& vendorName),
358 "");
359
360
361 DocDeclStr(
362 void , SetStyle(long style),
363 "");
364
365 DocDeclStr(
366 long , GetStyle() const,
367 "");
368
369};
370
371
372//---------------------------------------------------------------------------
373
374DocStr(wxConfig,
375"This ConfigBase-derived class will use the registry on Windows,
376and will be a wx.FileConfig on other platforms.");
377
378class wxConfig : public wxConfigBase {
379public:
380 DocCtorStr(
381 wxConfig(const wxString& appName = wxPyEmptyString,
382 const wxString& vendorName = wxPyEmptyString,
383 const wxString& localFilename = wxPyEmptyString,
384 const wxString& globalFilename = wxPyEmptyString,
385 long style = 0),
386 "");
387
388 ~wxConfig();
389};
390
391
392
393
394DocStr(wxFileConfig,
395 "This config class will use a file for storage on all platforms.");
396
397class wxFileConfig : public wxConfigBase {
398public:
399 DocCtorStr(
400 wxFileConfig(const wxString& appName = wxPyEmptyString,
401 const wxString& vendorName = wxPyEmptyString,
402 const wxString& localFilename = wxPyEmptyString,
403 const wxString& globalFilename = wxPyEmptyString,
404 long style = 0),
405 "");
406
407 ~wxFileConfig();
408};
409
410
411//---------------------------------------------------------------------------
412
413DocStr(wxConfigPathChanger,
414"A handy little class which changes current path to the path of
415given entry and restores it in the destructoir: so if you declare
416a local variable of this type, you work in the entry directory
417and the path is automatically restored when the function returns.");
418
419class wxConfigPathChanger
420{
421public:
422 DocCtorStr(
423 wxConfigPathChanger(const wxConfigBase *config, const wxString& entry),
424 "");
425
426 ~wxConfigPathChanger();
427
428 DocDeclStr(
429 const wxString& , Name() const,
430 "Get the key name");
431};
432
433
434//---------------------------------------------------------------------------
435
436
437
438DocDeclStr(
439 wxString , wxExpandEnvVars(const wxString &sz),
440 "Replace environment variables ($SOMETHING) with their values. The\n"
441 "format is $VARNAME or ${VARNAME} where VARNAME contains\n"
442 "alphanumeric characters and '_' only. '$' must be escaped ('\$')\n"
443 "in order to be taken literally.");
444
445
446
447//---------------------------------------------------------------------------