-class ConfigGroup
-{
-private:
- wxFileConfig *m_pConfig; // config object we belong to
- ConfigGroup *m_pParent; // parent group (NULL for root group)
- wxFileConfig::ArrayEntries m_aEntries; // entries in this group
- wxFileConfig::ArrayGroups m_aSubgroups; // subgroups
- wxString m_strName; // group's name
- bool m_bDirty; // if FALSE => all subgroups are not dirty
- LineList *m_pLine; // pointer to our line in the linked list
- ConfigEntry *m_pLastEntry; // last entry/subgroup of this group in the
- ConfigGroup *m_pLastGroup; // local file (we insert new ones after it)
-
- // DeleteSubgroupByName helper
- bool DeleteSubgroup(ConfigGroup *pGroup);
-
-public:
- // ctor
- ConfigGroup(ConfigGroup *pParent, const wxString& strName, wxFileConfig *);
-
- // dtor deletes all entries and subgroups also
- ~ConfigGroup();
-
- // simple accessors
- const wxString& Name() const { return m_strName; }
- ConfigGroup *Parent() const { return m_pParent; }
- wxFileConfig *Config() const { return m_pConfig; }
- bool IsDirty() const { return m_bDirty; }
-
- const wxFileConfig::ArrayEntries& Entries() const { return m_aEntries; }
- const wxFileConfig::ArrayGroups& Groups() const { return m_aSubgroups; }
- bool IsEmpty() const { return Entries().IsEmpty() && Groups().IsEmpty(); }
-
- // find entry/subgroup (NULL if not found)
- ConfigGroup *FindSubgroup(const wxChar *szName) const;
- ConfigEntry *FindEntry (const wxChar *szName) const;
-
- // delete entry/subgroup, return FALSE if doesn't exist
- bool DeleteSubgroupByName(const wxChar *szName);
- bool DeleteEntry(const wxChar *szName);
-
- // create new entry/subgroup returning pointer to newly created element
- ConfigGroup *AddSubgroup(const wxString& strName);
- ConfigEntry *AddEntry (const wxString& strName, int nLine = wxNOT_FOUND);
-
- // will also recursively set parent's dirty flag
- void SetDirty();
- void SetLine(LineList *pLine);
-
- // rename: no checks are done to ensure that the name is unique!
- void Rename(const wxString& newName);
-
- //
- wxString GetFullName() const;
-
- // get the last line belonging to an entry/subgroup of this group
- LineList *GetGroupLine(); // line which contains [group]
- LineList *GetLastEntryLine(); // after which our subgroups start
- LineList *GetLastGroupLine(); // after which the next group starts
-
- // called by entries/subgroups when they're created/deleted
- void SetLastEntry(ConfigEntry *pEntry) { m_pLastEntry = pEntry; }
- void SetLastGroup(ConfigGroup *pGroup) { m_pLastGroup = pGroup; }
-};