]> git.saurik.com Git - wxWidgets.git/blame_incremental - samples/config/conftest.cpp
gsocket.c has been replaced by gsocket.cpp
[wxWidgets.git] / samples / config / conftest.cpp
... / ...
CommitLineData
1///////////////////////////////////////////////////////////////////////////////
2// Name: conftest.cpp
3// Purpose: demo of wxConfig and related classes
4// Author: Vadim Zeitlin
5// Modified by:
6// Created: 03.08.98
7// RCS-ID: $Id$
8// Copyright: (c) 1998 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
9// Licence: wxWindows license
10///////////////////////////////////////////////////////////////////////////////
11
12// ============================================================================
13// declarations
14// ============================================================================
15
16// ----------------------------------------------------------------------------
17// headers
18// ----------------------------------------------------------------------------
19#include "wx/wxprec.h"
20
21#ifndef WX_PRECOMP
22 #include "wx/wx.h"
23#endif //precompiled headers
24
25#include "wx/log.h"
26#include "wx/config.h"
27
28// ----------------------------------------------------------------------------
29// classes
30// ----------------------------------------------------------------------------
31
32class MyApp: public wxApp
33{
34public:
35 // implement base class virtuals
36 virtual bool OnInit();
37 virtual int OnExit();
38};
39
40class MyFrame: public wxFrame
41{
42public:
43 MyFrame();
44 virtual ~MyFrame();
45
46 // callbacks
47 void OnQuit(wxCommandEvent& event);
48 void OnAbout(wxCommandEvent& event);
49 void OnDelete(wxCommandEvent& event);
50
51private:
52 wxTextCtrl *m_text;
53 wxCheckBox *m_check;
54
55 DECLARE_EVENT_TABLE()
56};
57
58enum
59{
60 ConfTest_Quit,
61 ConfTest_About,
62 ConfTest_Delete
63};
64
65// ----------------------------------------------------------------------------
66// event tables
67// ----------------------------------------------------------------------------
68
69BEGIN_EVENT_TABLE(MyFrame, wxFrame)
70 EVT_MENU(ConfTest_Quit, MyFrame::OnQuit)
71 EVT_MENU(ConfTest_About, MyFrame::OnAbout)
72 EVT_MENU(ConfTest_Delete, MyFrame::OnDelete)
73END_EVENT_TABLE()
74
75// ============================================================================
76// implementation
77// ============================================================================
78
79// ----------------------------------------------------------------------------
80// application
81// ----------------------------------------------------------------------------
82
83IMPLEMENT_APP(MyApp)
84
85// `Main program' equivalent, creating windows and returning main app frame
86bool MyApp::OnInit()
87{
88 // we're using wxConfig's "create-on-demand" feature: it will create the
89 // config object when it's used for the first time. It has a number of
90 // advantages compared with explicitly creating our wxConfig:
91 // 1) we don't pay for it if we don't use it
92 // 2) there is no danger to create it twice
93
94 // application and vendor name are used by wxConfig to construct the name
95 // of the config file/registry key and must be set before the first call
96 // to Get() if you want to override the default values (the application
97 // name is the name of the executable and the vendor name is the same)
98 SetVendorName(_T("wxWidgets"));
99 SetAppName(_T("conftest")); // not needed, it's the default value
100
101 wxConfigBase *pConfig = wxConfigBase::Get();
102
103 // uncomment this to force writing back of the defaults for all values
104 // if they're not present in the config - this can give the user an idea
105 // of all possible settings for this program
106 pConfig->SetRecordDefaults();
107
108 // or you could also write something like this:
109 // wxFileConfig *pConfig = new wxFileConfig("conftest");
110 // wxConfigBase::Set(pConfig);
111 // where you can also specify the file names explicitly if you wish.
112 // Of course, calling Set() is optional and you only must do it if
113 // you want to later retrieve this pointer with Get().
114
115 // create the main program window
116 MyFrame *frame = new MyFrame;
117 frame->Show(true);
118 SetTopWindow(frame);
119
120 // use our config object...
121 if ( pConfig->Read(_T("/Controls/Check"), 1l) != 0 ) {
122 wxMessageBox(_T("You can disable this message box by unchecking\n")
123 _T("the checkbox in the main window (of course, a real\n")
124 _T("program would have a checkbox right here but we\n")
125 _T("keep it simple)"), _T("Welcome to wxConfig demo"),
126 wxICON_INFORMATION | wxOK);
127 }
128
129 return true;
130}
131
132int MyApp::OnExit()
133{
134 // clean up: Set() returns the active config object as Get() does, but unlike
135 // Get() it doesn't try to create one if there is none (definitely not what
136 // we want here!)
137 delete wxConfigBase::Set((wxConfigBase *) NULL);
138
139 return 0;
140}
141
142// ----------------------------------------------------------------------------
143// frame
144// ----------------------------------------------------------------------------
145
146// main frame ctor
147MyFrame::MyFrame()
148 : wxFrame((wxFrame *) NULL, wxID_ANY, _T("wxConfig Demo"))
149{
150 // menu
151 wxMenu *file_menu = new wxMenu;
152
153 file_menu->Append(ConfTest_Delete, _T("&Delete"), _T("Delete config file"));
154 file_menu->AppendSeparator();
155 file_menu->Append(ConfTest_About, _T("&About\tF1"), _T("About this sample"));
156 file_menu->AppendSeparator();
157 file_menu->Append(ConfTest_Quit, _T("E&xit\tAlt-X"), _T("Exit the program"));
158 wxMenuBar *menu_bar = new wxMenuBar;
159 menu_bar->Append(file_menu, _T("&File"));
160 SetMenuBar(menu_bar);
161
162#if wxUSE_STATUSBAR
163 CreateStatusBar();
164#endif // wxUSE_STATUSBAR
165
166 // child controls
167 wxPanel *panel = new wxPanel(this);
168 (void)new wxStaticText(panel, wxID_ANY, _T("These controls remember their values!"),
169 wxPoint(10, 10), wxSize(300, 20));
170 m_text = new wxTextCtrl(panel, wxID_ANY, _T(""), wxPoint(10, 40), wxSize(300, 20));
171 m_check = new wxCheckBox(panel, wxID_ANY, _T("show welcome message box at startup"),
172 wxPoint(10, 70), wxSize(300, 20));
173
174 // restore the control's values from the config
175
176 // NB: in this program, the config object is already created at this moment
177 // because we had called Get() from MyApp::OnInit(). However, if you later
178 // change the code and don't create it before this line, it won't break
179 // anything - unlike if you manually create wxConfig object with Create()
180 // or in any other way (then you must be sure to create it before using it!).
181 wxConfigBase *pConfig = wxConfigBase::Get();
182
183 // we could write Read("/Controls/Text") as well, it's just to show SetPath()
184 pConfig->SetPath(_T("/Controls"));
185
186 m_text->SetValue(pConfig->Read(_T("Text"), _T("")));
187 m_check->SetValue(pConfig->Read(_T("Check"), 1l) != 0);
188
189 // SetPath() understands ".."
190 pConfig->SetPath(_T("../MainFrame"));
191
192 // restore frame position and size
193 int x = pConfig->Read(_T("x"), 50),
194 y = pConfig->Read(_T("y"), 50),
195 w = pConfig->Read(_T("w"), 350),
196 h = pConfig->Read(_T("h"), 200);
197 Move(x, y);
198 SetClientSize(w, h);
199
200 pConfig->SetPath(_T("/"));
201 wxString s;
202 if ( pConfig->Read(_T("TestValue"), &s) )
203 {
204 wxLogStatus(this, wxT("TestValue from config is '%s'"), s.c_str());
205 }
206 else
207 {
208 wxLogStatus(this, wxT("TestValue not found in the config"));
209 }
210}
211
212void MyFrame::OnQuit(wxCommandEvent&)
213{
214 Close(true);
215}
216
217void MyFrame::OnAbout(wxCommandEvent&)
218{
219