]> git.saurik.com Git - wxWidgets.git/blame - src/palmos/prefconf.cpp
compilo
[wxWidgets.git] / src / palmos / prefconf.cpp
CommitLineData
23a59c2c
WS
1///////////////////////////////////////////////////////////////////////////////
2// Name: src/palmos/prefconf.cpp
3// Purpose: wxPrefConfig implementation
4// Author: Wlodzimierz ABX Skiba
5// Modified by:
6// Created: 28.12.2004
7// RCS-ID: $Id$
8// Copyright: (c) Wlodzimierz Skiba
9// License: wxWindows licence
10///////////////////////////////////////////////////////////////////////////////
11
12#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
13#pragma implementation "prefconf.h"
14#endif
15
16// For compilers that support precompilation, includes "wx.h".
17#include "wx/wxprec.h"
18
19#ifdef __BORLANDC__
20#pragma hdrstop
21#endif
22
23#ifndef WX_PRECOMP
24 #include "wx/string.h"
25#endif //WX_PRECOMP
26
27#if wxUSE_CONFIG && wxUSE_CONFIG_NATIVE
28
29#include "wx/config.h"
30
31// ============================================================================
32// implementation
33// ============================================================================
34
35/*
36
37http://www.palmos.com/dev/support/docs/protein_books/System_Management/PreferenceConcepts.html
38
39This wxPrefConfig class is a wxConfig wrapper around PalmOS Preferences
40functionality. Preferences allow to write any structure into its database so
41wxPrefConfig writes there all entries of single group into one Preference.
42To optimize read/write operations value of preference is cached. Cache is filled
43after each change of the path (including using path to group names in all
44operations) and it is flushed on destructor, any path change on or purpose
45with Flush().
46
47Meaning of styles:
48
49 wxCONFIG_USE_LOCAL_FILE => store config in "saved" preferences database
50 (not to be backed up during a HotSync operation)
51 wxCONFIG_USE_GLOBAL_FILE => store config in "unsaved" preferences database
52 (backed up during a HotSync operation)
53
54
e2731512 55Each Preference is an array of chars. First unsigned char describes
23a59c2c
WS
56number N of chars used for Preference size. Next N chars (string) contains
57length of rest of Preference. Preference consists in serie of entries which
58should be read in loop until in reaches end of Preference.
59
60 Each entry is an set of chars with following structure:
61 1. name (null terminated)
62 2. type (single char): b,s,g,l,d (see value)
63 3. value
64 - for type="b" (bool) it os "0" or "1"
65 - for type="s" (string) it is null terminated set of chars
66 - for type="g" (subgroup) as for "s" but string is converted to
67 uint16_t for id parameter of ::PrefGetAppPreferences()
68 - for type="l" (long) as for "s" but string is converted to long
69 - for type="d" (double) as for "s" but string is converted to double
70 - otherwise it is ""
71
72So all together first Read in group needs 3 reading from Preference:
73 1. take the length N of length
74 2. take the length M of the group content
75 3. take the group content
76and all it is in single Preference to not overload Preferences database.
77As long as each next Read/Write is performed in the same group then none
78access to Preferences is performed. Flushing needs only single writing to
79databease because all 3 parts of Preference can be prepared in memory.
80
81NOTE: wxPrefConfig can read/write only its own entries. It is impossible to
82know structures of Preferences of other non wxW applications.
83
84*/
85
86// ----------------------------------------------------------------------------
87// ctor/dtor
88// ----------------------------------------------------------------------------
89
90wxPrefConfig::wxPrefConfig(const wxString& appName, const wxString& vendorName,
91 const wxString& strLocal, const wxString& strGlobal,
92 long style)
93 : wxConfigBase(appName, vendorName, strLocal, strGlobal, style)
94{
95}
96
97// ----------------------------------------------------------------------------
98// path management
99// ----------------------------------------------------------------------------
100
101void wxPrefConfig::SetPath(const wxString& strPath)
102{
103}
104
105// ----------------------------------------------------------------------------
106// enumeration (works only with current group)
107// ----------------------------------------------------------------------------
108
109bool wxPrefConfig::GetFirstGroup(wxString& str, long& lIndex) const
110{
111}
112
113bool wxPrefConfig::GetNextGroup(wxString& str, long& lIndex) const
114{
115 /* TODO */
116 return false;
117}
118
119bool wxPrefConfig::GetFirstEntry(wxString& str, long& lIndex) const
120{
121 /* TODO */
122 return false;
123}
124
125bool wxPrefConfig::GetNextEntry(wxString& str, long& lIndex) const
126{
127 /* TODO */
128 return false;
129}
130
131size_t wxPrefConfig::GetNumberOfEntries(bool WXUNUSED(bRecursive)) const
132{
133 /* TODO */
134 return 0;
135}
136
137size_t wxPrefConfig::GetNumberOfGroups(bool WXUNUSED(bRecursive)) const
138{
139 /* TODO */
140 return 0;
141}
142
143// ----------------------------------------------------------------------------
144// tests for existence
145// ----------------------------------------------------------------------------
146
147bool wxPrefConfig::HasGroup(const wxString& key) const
148{
149 /* TODO */
150 return false;
151}
152
153bool wxPrefConfig::HasEntry(const wxString& key) const
154{
155 /* TODO */
156 return false;
157}
158
159wxConfigBase::EntryType wxPrefConfig::GetEntryType(const wxString& key) const
160{
161 /* TODO */
162 return wxConfigBase::Type_Unknown;
163}
164
165// ----------------------------------------------------------------------------
166// reading/writing
167// ----------------------------------------------------------------------------
168
169bool wxPrefConfig::DoReadString(const wxString& key, wxString *pStr) const
170{
171 /* TODO */
172 return false;
173}
174
175// this exactly reproduces the string version above except for ExpandEnvVars(),
176// we really should avoid this code duplication somehow...
177
178bool wxPrefConfig::DoReadLong(const wxString& key, long *plResult) const
179{
180 /* TODO */
181 return false;
182}
183
184bool wxPrefConfig::DoWriteString(const wxString& key, const wxString& szValue)
185{
186 /* TODO */
187 return false;
188}
189
190bool wxPrefConfig::DoWriteLong(const wxString& key, long lValue)
191{
192 /* TODO */
193 return false;
194}
195
196// ----------------------------------------------------------------------------
197// renaming
198// ----------------------------------------------------------------------------
199
200bool wxPrefConfig::RenameEntry(const wxString& oldName, const wxString& newName)
201{
202 /* TODO */
203 return false;
204}
205
206bool wxPrefConfig::RenameGroup(const wxString& oldName, const wxString& newName)
207{
208 /* TODO */
209 return false;
210}
211
212// ----------------------------------------------------------------------------
213// deleting
214// ----------------------------------------------------------------------------
215
216bool wxPrefConfig::DeleteEntry(const wxString& value, bool bGroupIfEmptyAlso)
217{
218 /* TODO */
219 return false;
220}
221
222bool wxPrefConfig::DeleteGroup(const wxString& key)
223{
224 /* TODO */
225 return false;
226}
227
228bool wxPrefConfig::DeleteAll()
229{
230 /* TODO */
231 return false;
232}
233
234#endif // wxUSE_CONFIG && wxUSE_CONFIG_NATIVE