1998-07-29 12:03:42 +00:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
2001-07-23 17:45:56 +00:00
|
|
|
// Name: wx/fileconf.h
|
1998-08-02 23:06:42 +00:00
|
|
|
// Purpose: wxFileConfig derivation of wxConfigBase
|
1998-07-29 12:03:42 +00:00
|
|
|
// Author: Vadim Zeitlin
|
|
|
|
// Modified by:
|
|
|
|
// Created: 07.04.98 (adapted from appconf.cpp)
|
2007-12-03 22:09:26 +00:00
|
|
|
// Copyright: (c) 1997 Karsten Ballueder & Vadim Zeitlin
|
1998-07-29 12:03:42 +00:00
|
|
|
// Ballueder@usa.net <zeitlin@dptmaths.ens-cachan.fr>
|
2004-05-23 20:53:33 +00:00
|
|
|
// Licence: wxWindows licence
|
1998-07-29 12:03:42 +00:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
1998-05-26 15:07:48 +00:00
|
|
|
|
|
|
|
#ifndef _FILECONF_H
|
|
|
|
#define _FILECONF_H
|
|
|
|
|
1998-09-01 10:26:14 +00:00
|
|
|
#include "wx/defs.h"
|
|
|
|
|
1999-06-15 20:21:59 +00:00
|
|
|
#if wxUSE_CONFIG
|
1999-01-16 00:13:58 +00:00
|
|
|
|
1999-06-15 20:21:59 +00:00
|
|
|
#include "wx/textfile.h"
|
|
|
|
#include "wx/string.h"
|
2003-12-18 14:54:25 +00:00
|
|
|
#include "wx/confbase.h"
|
2007-03-18 17:34:11 +00:00
|
|
|
#include "wx/filename.h"
|
1998-06-02 13:23:24 +00:00
|
|
|
|
1998-05-26 15:07:48 +00:00
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// wxFileConfig
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
/*
|
1998-07-07 13:53:19 +00:00
|
|
|
wxFileConfig derives from base Config and implements file based config class,
|
1998-05-26 15:07:48 +00:00
|
|
|
i.e. it uses ASCII disk files to store the information. These files are
|
1998-07-07 13:53:19 +00:00
|
|
|
alternatively called INI, .conf or .rc in the documentation. They are
|
1998-05-26 15:07:48 +00:00
|
|
|
organized in groups or sections, which can nest (i.e. a group contains
|
|
|
|
subgroups, which contain their own subgroups &c). Each group has some
|
1998-07-07 13:53:19 +00:00
|
|
|
number of entries, which are "key = value" pairs. More precisely, the format
|
1998-05-26 15:07:48 +00:00
|
|
|
is:
|
|
|
|
|
|
|
|
# comments are allowed after either ';' or '#' (Win/UNIX standard)
|
|
|
|
|
|
|
|
# blank lines (as above) are ignored
|
|
|
|
|
|
|
|
# global entries are members of special (no name) top group
|
|
|
|
written_for = Windows
|
|
|
|
platform = Linux
|
|
|
|
|
|
|
|
# the start of the group 'Foo'
|
|
|
|
[Foo] # may put comments like this also
|
|
|
|
# following 3 lines are entries
|
|
|
|
key = value
|
|
|
|
another_key = " strings with spaces in the beginning should be quoted, \
|
|
|
|
otherwise the spaces are lost"
|
|
|
|
last_key = but you don't have to put " normally (nor quote them, like here)
|
|
|
|
|
|
|
|
# subgroup of the group 'Foo'
|
|
|
|
# (order is not important, only the name is: separator is '/', as in paths)
|
|
|
|
[Foo/Bar]
|
|
|
|
# entries prefixed with "!" are immutable, i.e. can't be changed if they are
|
|
|
|
# set in the system-wide config file
|
|
|
|
!special_key = value
|
|
|
|
bar_entry = whatever
|
|
|
|
|
|
|
|
[Foo/Bar/Fubar] # depth is (theoretically :-) unlimited
|
|
|
|
# may have the same name as key in another section
|
|
|
|
bar_entry = whatever not
|
|
|
|
|
|
|
|
You have {read/write/delete}Entry functions (guess what they do) and also
|
|
|
|
setCurrentPath to select current group. enum{Subgroups/Entries} allow you
|
|
|
|
to get all entries in the config file (in the current group). Finally,
|
|
|
|
flush() writes immediately all changed entries to disk (otherwise it would
|
|
|
|
be done automatically in dtor)
|
|
|
|
|
|
|
|
wxFileConfig manages not less than 2 config files for each program: global
|
|
|
|
and local (or system and user if you prefer). Entries are read from both of
|
|
|
|
them and the local entries override the global ones unless the latter is
|
|
|
|
immutable (prefixed with '!') in which case a warning message is generated
|
|
|
|
and local value is ignored. Of course, the changes are always written to local
|
|
|
|
file only.
|
|
|
|
|
1998-07-29 12:03:42 +00:00
|
|
|
The names of these files can be specified in a number of ways. First of all,
|
|
|
|
you can use the standard convention: using the ctor which takes 'strAppName'
|
|
|
|
parameter will probably be sufficient for 90% of cases. If, for whatever
|
|
|
|
reason you wish to use the files with some other names, you can always use the
|
|
|
|
second ctor.
|
|
|
|
|
|
|
|
wxFileConfig also may automatically expand the values of environment variables
|
|
|
|
in the entries it reads: for example, if you have an entry
|
|
|
|
score_file = $HOME/.score
|
|
|
|
a call to Read(&str, "score_file") will return a complete path to .score file
|
2005-04-08 14:34:30 +00:00
|
|
|
unless the expansion was previously disabled with SetExpandEnvVars(false) call
|
1998-07-29 12:03:42 +00:00
|
|
|
(it's on by default, the current status can be retrieved with
|
|
|
|
IsExpandingEnvVars function).
|
1998-05-26 15:07:48 +00:00
|
|
|
*/
|
2007-07-09 10:09:52 +00:00
|
|
|
class WXDLLIMPEXP_FWD_BASE wxFileConfigGroup;
|
|
|
|
class WXDLLIMPEXP_FWD_BASE wxFileConfigEntry;
|
|
|
|
class WXDLLIMPEXP_FWD_BASE wxFileConfigLineList;
|
2004-10-04 08:28:14 +00:00
|
|
|
|
|
|
|
#if wxUSE_STREAMS
|
2007-07-09 10:09:52 +00:00
|
|
|
class WXDLLIMPEXP_FWD_BASE wxInputStream;
|
|
|
|
class WXDLLIMPEXP_FWD_BASE wxOutputStream;
|
2004-10-04 08:28:14 +00:00
|
|
|
#endif // wxUSE_STREAMS
|
1999-01-16 00:13:58 +00:00
|
|
|
|
2003-07-02 01:59:24 +00:00
|
|
|
class WXDLLIMPEXP_BASE wxFileConfig : public wxConfigBase
|
1998-05-26 15:07:48 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
// construct the "standard" full name for global (system-wide) and
|
|
|
|
// local (user-specific) config files from the base file name.
|
|
|
|
//
|
|
|
|
// the following are the filenames returned by this functions:
|
|
|
|
// global local
|
|
|
|
// Unix /etc/file.ext ~/.file
|
|
|
|
// Win %windir%\file.ext %USERPROFILE%\file.ext
|
|
|
|
//
|
2005-04-08 14:34:30 +00:00
|
|
|
// where file is the basename of szFile, ext is its extension
|
1998-05-26 15:07:48 +00:00
|
|
|
// or .conf (Unix) or .ini (Win) if it has none
|
2007-03-18 17:34:11 +00:00
|
|
|
static wxFileName GetGlobalFile(const wxString& szFile);
|
|
|
|
static wxFileName GetLocalFile(const wxString& szFile, int style = 0);
|
|
|
|
|
|
|
|
static wxString GetGlobalFileName(const wxString& szFile)
|
|
|
|
{
|
|
|
|
return GetGlobalFile(szFile).GetFullPath();
|
|
|
|
}
|
|
|
|
|
|
|
|
static wxString GetLocalFileName(const wxString& szFile, int style = 0)
|
|
|
|
{
|
|
|
|
return GetLocalFile(szFile, style).GetFullPath();
|
|
|
|
}
|
1998-05-26 15:07:48 +00:00
|
|
|
|
|
|
|
// ctor & dtor
|
1999-04-07 13:01:50 +00:00
|
|
|
// New constructor: one size fits all. Specify wxCONFIG_USE_LOCAL_FILE or
|
|
|
|
// wxCONFIG_USE_GLOBAL_FILE to say which files should be used.
|
2003-07-10 08:36:14 +00:00
|
|
|
wxFileConfig(const wxString& appName = wxEmptyString,
|
|
|
|
const wxString& vendorName = wxEmptyString,
|
|
|
|
const wxString& localFilename = wxEmptyString,
|
|
|
|
const wxString& globalFilename = wxEmptyString,
|
2004-03-03 23:04:04 +00:00
|
|
|
long style = wxCONFIG_USE_LOCAL_FILE | wxCONFIG_USE_GLOBAL_FILE,
|
2006-04-05 14:37:47 +00:00
|
|
|
const wxMBConv& conv = wxConvAuto());
|
1998-08-27 21:06:02 +00:00
|
|
|
|
2001-11-14 20:40:20 +00:00
|
|
|
#if wxUSE_STREAMS
|
|
|
|
// ctor that takes an input stream.
|
2006-04-05 14:37:47 +00:00
|
|
|
wxFileConfig(wxInputStream &inStream, const wxMBConv& conv = wxConvAuto());
|
2001-11-14 20:40:20 +00:00
|
|
|
#endif // wxUSE_STREAMS
|
|
|
|
|
1998-05-26 15:07:48 +00:00
|
|
|
// dtor will save unsaved data
|
|
|
|
virtual ~wxFileConfig();
|
|
|
|
|
2000-07-15 19:51:35 +00:00
|
|
|
// under Unix, set the umask to be used for the file creation, do nothing
|
|
|
|
// under other systems
|
|
|
|
#ifdef __UNIX__
|
|
|
|
void SetUmask(int mode) { m_umask = mode; }
|
|
|
|
#else // !__UNIX__
|
|
|
|
void SetUmask(int WXUNUSED(mode)) { }
|
|
|
|
#endif // __UNIX__/!__UNIX__
|
|
|
|
|
1998-05-26 15:07:48 +00:00
|
|
|
// implement inherited pure virtual functions
|
|
|
|
virtual void SetPath(const wxString& strPath);
|
2009-05-15 18:02:41 +00:00
|
|
|
virtual const wxString& GetPath() const;
|
1998-05-26 15:07:48 +00:00
|
|
|
|
1998-08-02 23:06:42 +00:00
|
|
|
virtual bool GetFirstGroup(wxString& str, long& lIndex) const;
|
|
|
|
virtual bool GetNextGroup (wxString& str, long& lIndex) const;
|
|
|
|
virtual bool GetFirstEntry(wxString& str, long& lIndex) const;
|
|
|
|
virtual bool GetNextEntry (wxString& str, long& lIndex) const;
|
1998-05-26 15:07:48 +00:00
|
|
|
|
2004-09-14 12:08:28 +00:00
|
|
|
virtual size_t GetNumberOfEntries(bool bRecursive = false) const;
|
|
|
|
virtual size_t GetNumberOfGroups(bool bRecursive = false) const;
|
1998-07-18 21:47:45 +00:00
|
|
|
|
1998-07-07 13:53:19 +00:00
|
|
|
virtual bool HasGroup(const wxString& strName) const;
|
|
|
|
virtual bool HasEntry(const wxString& strName) const;
|
|
|
|
|
2004-09-14 12:08:28 +00:00
|
|
|
virtual bool Flush(bool bCurrentOnly = false);
|
1998-05-26 15:07:48 +00:00
|
|
|
|
1999-01-20 19:54:17 +00:00
|
|
|
virtual bool RenameEntry(const wxString& oldName, const wxString& newName);
|
|
|
|
virtual bool RenameGroup(const wxString& oldName, const wxString& newName);
|
|
|
|
|
2004-09-14 12:08:28 +00:00
|
|
|
virtual bool DeleteEntry(const wxString& key, bool bGroupIfEmptyAlso = true);
|
1998-08-27 21:06:02 +00:00
|
|
|
virtual bool DeleteGroup(const wxString& szKey);
|
1998-05-26 15:07:48 +00:00
|
|
|
virtual bool DeleteAll();
|
|
|
|
|
2004-10-03 22:55:08 +00:00
|
|
|
// additional, wxFileConfig-specific, functionality
|
|
|
|
#if wxUSE_STREAMS
|
|
|
|
// save the entire config file text to the given stream, note that the text
|
|
|
|
// won't be saved again in dtor when Flush() is called if you use this method
|
|
|
|
// as it won't be "changed" any more
|
2006-04-05 14:37:47 +00:00
|
|
|
virtual bool Save(wxOutputStream& os, const wxMBConv& conv = wxConvAuto());
|
2004-10-03 22:55:08 +00:00
|
|
|
#endif // wxUSE_STREAMS
|
|
|
|
|
1998-05-26 15:07:48 +00:00
|
|
|
public:
|
|
|
|
// functions to work with this list
|
2001-07-23 17:45:56 +00:00
|
|
|
wxFileConfigLineList *LineListAppend(const wxString& str);
|
|
|
|
wxFileConfigLineList *LineListInsert(const wxString& str,
|
|
|
|
wxFileConfigLineList *pLine); // NULL => Prepend()
|
|
|
|
void LineListRemove(wxFileConfigLineList *pLine);
|
1998-05-26 15:07:48 +00:00
|
|
|
bool LineListIsEmpty();
|
|
|
|
|
2001-12-14 00:58:59 +00:00
|
|
|
protected:
|
|
|
|
virtual bool DoReadString(const wxString& key, wxString *pStr) const;
|
|
|
|
virtual bool DoReadLong(const wxString& key, long *pl) const;
|
2007-07-16 20:38:42 +00:00
|
|
|
#if wxUSE_BASE64
|
2007-07-12 00:11:03 +00:00
|
|
|
virtual bool DoReadBinary(const wxString& key, wxMemoryBuffer* buf) const;
|
2007-07-16 20:38:42 +00:00
|
|
|
#endif // wxUSE_BASE64
|
2001-12-14 00:58:59 +00:00
|
|
|
|
|
|
|
virtual bool DoWriteString(const wxString& key, const wxString& szValue);
|
|
|
|
virtual bool DoWriteLong(const wxString& key, long lValue);
|
2007-07-16 20:38:42 +00:00
|
|
|
#if wxUSE_BASE64
|
2007-07-12 00:11:03 +00:00
|
|
|
virtual bool DoWriteBinary(const wxString& key, const wxMemoryBuffer& buf);
|
2007-07-16 20:38:42 +00:00
|
|
|
#endif // wxUSE_BASE64
|
2001-12-14 00:58:59 +00:00
|
|
|
|
1998-05-26 15:07:48 +00:00
|
|
|
private:
|
1999-01-20 19:54:17 +00:00
|
|
|
// GetXXXFileName helpers: return ('/' terminated) directory names
|
1998-07-29 12:03:42 +00:00
|
|
|
static wxString GetGlobalDir();
|
2007-03-18 17:34:11 +00:00
|
|
|
static wxString GetLocalDir(int style = 0);
|
1998-07-29 12:03:42 +00:00
|
|
|
|
|
|
|
// common part of all ctors (assumes that m_str{Local|Global}File are already
|
|
|
|
// initialized
|
1998-05-26 15:07:48 +00:00
|
|
|
void Init();
|
|
|
|
|
1998-07-29 12:03:42 +00:00
|
|
|
// common part of from dtor and DeleteAll
|
|
|
|
void CleanUp();
|
|
|
|
|
1998-05-26 15:07:48 +00:00
|
|
|
// parse the whole file
|
2005-09-24 21:43:15 +00:00
|
|
|
void Parse(const wxTextBuffer& buffer, bool bLocal);
|
1998-05-26 15:07:48 +00:00
|
|
|
|
|
|
|
// the same as SetPath("/")
|
|
|
|
void SetRootPath();
|
|
|
|
|
2005-07-01 18:05:10 +00:00
|
|
|
// real SetPath() implementation, returns true if path could be set or false
|
|
|
|
// if path doesn't exist and createMissingComponents == false
|
|
|
|
bool DoSetPath(const wxString& strPath, bool createMissingComponents);
|
|
|
|
|
2004-10-03 22:34:09 +00:00
|
|
|
// set/test the dirty flag
|
|
|
|
void SetDirty() { m_isDirty = true; }
|
|
|
|
void ResetDirty() { m_isDirty = false; }
|
|
|
|
bool IsDirty() const { return m_isDirty; }
|
|
|
|
|
|
|
|
|
1998-05-26 15:07:48 +00:00
|
|
|
// member variables
|
|
|
|
// ----------------
|
2004-10-03 22:34:09 +00:00
|
|
|
wxFileConfigLineList *m_linesHead, // head of the linked list
|
|
|
|
*m_linesTail; // tail
|
1998-05-26 15:07:48 +00:00
|
|
|
|
2007-03-18 17:34:11 +00:00
|
|
|
wxFileName m_fnLocalFile, // local file name passed to ctor
|
|
|
|
m_fnGlobalFile; // global
|
2004-10-03 22:34:09 +00:00
|
|
|
wxString m_strPath; // current path (not '/' terminated)
|
1998-05-26 15:07:48 +00:00
|
|
|
|
2001-07-23 17:45:56 +00:00
|
|
|
wxFileConfigGroup *m_pRootGroup, // the top (unnamed) group
|
|
|
|
*m_pCurrentGroup; // the current group
|
1998-05-26 15:07:48 +00:00
|
|
|
|
2006-04-05 16:54:02 +00:00
|
|
|
wxMBConv *m_conv;
|
2004-09-14 12:08:28 +00:00
|
|
|
|
2000-07-15 19:51:35 +00:00
|
|
|
#ifdef __UNIX__
|
2004-10-03 22:34:09 +00:00
|
|
|
int m_umask; // the umask to use for file creation
|
2000-07-15 19:51:35 +00:00
|
|
|
#endif // __UNIX__
|
2003-01-02 23:38:11 +00:00
|
|
|
|
2004-10-03 22:34:09 +00:00
|
|
|
bool m_isDirty; // if true, we have unsaved changes
|
|
|
|
|
2009-02-08 11:45:59 +00:00
|
|
|
wxDECLARE_NO_COPY_CLASS(wxFileConfig);
|
2007-03-10 18:16:10 +00:00
|
|
|
DECLARE_ABSTRACT_CLASS(wxFileConfig)
|
1999-01-20 19:54:17 +00:00
|
|
|
};
|
|
|
|
|
1999-06-15 20:21:59 +00:00
|
|
|
#endif
|
|
|
|
// wxUSE_CONFIG
|
|
|
|
|
2004-09-14 12:08:28 +00:00
|
|
|
#endif
|
1999-06-15 20:21:59 +00:00
|
|
|
//_FILECONF_H
|
1998-05-26 15:07:48 +00:00
|
|
|
|