]> git.saurik.com Git - wxWidgets.git/blame - interface/fileconf.h
mention the problem with writing enums to wxConfig (see #8656)
[wxWidgets.git] / interface / fileconf.h
CommitLineData
23324ae1
FM
1/////////////////////////////////////////////////////////////////////////////
2// Name: fileconf.h
e54c96f1 3// Purpose: interface of wxFileConfig
23324ae1
FM
4// Author: wxWidgets team
5// RCS-ID: $Id$
6// Licence: wxWindows license
7/////////////////////////////////////////////////////////////////////////////
8
9/**
10 @class wxFileConfig
11 @wxheader{fileconf.h}
7c913512 12
23324ae1
FM
13 wxFileConfig implements wxConfigBase interface for
14 storing and retrieving configuration information using plain text files. The
15 files have a simple format reminiscent of Windows INI files with lines of the
ea6a2ccb
FM
16 form @c "key = value" defining the keys and lines of special form
17 @c "[group]" indicating the start of each group.
7c913512 18
23324ae1
FM
19 This class is used by default for wxConfig on Unix platforms but may also be
20 used explicitly if you want to use files and not the registry even under
21 Windows.
7c913512 22
23324ae1 23 @library{wxbase}
0ce6d6c8 24 @category{misc}
7c913512 25
e54c96f1 26 @see wxFileConfig::Save
23324ae1
FM
27*/
28class wxFileConfig : public wxConfigBase
29{
30public:
31 /**
23324ae1
FM
32 Read the config data from the specified stream instead of the associated file,
33 as usual.
3c4f71cc 34
4cc4bfaf 35 @see Save()
23324ae1 36 */
0ce6d6c8 37 wxFileConfig(wxInputStream& is, const wxMBConv& conv = wxConvAuto());
23324ae1
FM
38
39 /**
40 Return the full path to the file which would be used by wxFileConfig as global,
0ce6d6c8
FM
41 system-wide, file if it were constructed with @a basename as "global filename"
42 parameter in the constructor.
43
44 Notice that this function cannot be used if @a basename is already a full path name.
23324ae1
FM
45 */
46 static wxFileName GetGlobalFile(const wxString& basename);
47
48 /**
49 Return the full path to the file which would be used by wxFileConfig as local,
0ce6d6c8
FM
50 user-specific, file if it were constructed with @a basename as "local filename"
51 parameter in the constructor.
52
ea6a2ccb 53 @a style has the same meaning as in @ref wxConfigBase::wxConfigBase "wxConfig constructor"
23324ae1
FM
54 and can contain any combination of styles but only wxCONFIG_USE_SUBDIR bit is
55 examined by this function.
0ce6d6c8
FM
56
57 Notice that this function cannot be used if @a basename is already a full path name.
23324ae1 58 */
ea6a2ccb 59 static wxFileName GetLocalFile(const wxString& basename, int style = 0);
23324ae1
FM
60
61 /**
23324ae1
FM
62 Saves all config data to the given stream, returns @true if data was saved
63 successfully or @false on error.
0ce6d6c8
FM
64
65 Note the interaction of this function with the internal "dirty flag": the
23324ae1
FM
66 data is saved unconditionally, i.e. even if the object is not dirty. However
67 after saving it successfully, the dirty flag is reset so no changes will be
68 written back to the file this object is associated with until you change its
69 contents again.
3c4f71cc 70
4cc4bfaf 71 @see wxConfigBase::Flush
23324ae1 72 */
0ce6d6c8 73 bool Save(wxOutputStream& os, const wxMBConv& conv = wxConvAuto());
23324ae1
FM
74
75 /**
76 Allows to set the mode to be used for the config file creation. For example, to
77 create a config file which is not readable by other users (useful if it stores
0ce6d6c8
FM
78 some sensitive information, such as passwords), you could use @c SetUmask(0077).
79
23324ae1 80 This function doesn't do anything on non-Unix platforms.
3c4f71cc 81
e54c96f1 82 @see wxCHANGE_UMASK()
23324ae1
FM
83 */
84 void SetUmask(int mode);
85};
e54c96f1 86