Removed lots of OnClose functions; doc'ed OnCloseWindow better;
[wxWidgets.git] / samples / config / conftest.cpp
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 class MyApp: public wxApp
32 {
33 public:
34 // implement base class virtuals
35 virtual bool OnInit();
36 virtual int OnExit();
37 };
38
39 class MyFrame: public wxFrame
40 {
41 public:
42 MyFrame();
43 virtual ~MyFrame();
44
45 // callbacks
46 void OnQuit(wxCommandEvent& event);
47 void OnAbout(wxCommandEvent& event);
48 void OnDelete(wxCommandEvent& event);
49 void OnCloseWindow(wxCloseEvent& event);
50
51 private:
52 wxTextCtrl *m_text;
53 wxCheckBox *m_check;
54
55 DECLARE_EVENT_TABLE()
56 };
57
58 enum
59 {
60 Minimal_Quit,
61 Minimal_About,
62 Minimal_Delete
63 };
64
65 // ----------------------------------------------------------------------------
66 // event tables
67 // ----------------------------------------------------------------------------
68 BEGIN_EVENT_TABLE(MyFrame, wxFrame)
69 EVT_MENU(Minimal_Quit, MyFrame::OnQuit)
70 EVT_MENU(Minimal_About, MyFrame::OnAbout)
71 EVT_MENU(Minimal_Delete, MyFrame::OnDelete)
72 EVT_CLOSE(MyFrame::OnCloseWindow)
73 END_EVENT_TABLE()
74
75 // ============================================================================
76 // implementation
77 // ============================================================================
78
79 // ----------------------------------------------------------------------------
80 // application
81 // ----------------------------------------------------------------------------
82 IMPLEMENT_APP(MyApp)
83
84 // `Main program' equivalent, creating windows and returning main app frame
85 bool MyApp::OnInit()
86 {
87 // we're using wxConfig's "create-on-demand" feature: it will create the
88 // config object when it's used for the first time. It has a number of
89 // advantages compared with explicitly creating our wxConfig:
90 // 1) we don't pay for it if we don't use it
91 // 2) there is no danger to create it twice
92
93 // application and vendor name are used by wxConfig to construct the name
94 // of the config file/registry key and must be set before the first call
95 // to Get() if you want to override the default values (the application
96 // name is the name of the executable and the vendor name is the same)
97 SetVendorName("wxWindows");
98 SetAppName("conftest"); // not needed, it's the default value
99
100 wxConfigBase *pConfig = wxConfigBase::Get();
101
102 // or you could also write something like this:
103 // wxFileConfig *pConfig = new wxFileConfig("conftest");
104 // wxConfigBase::Set(pConfig);
105 // where you can also specify the file names explicitly if you wish.
106 // Of course, calling Set() is optional and you only must do it if
107 // you want to later retrieve this pointer with Get().
108
109 // create the main program window
110 MyFrame *frame = new MyFrame;
111 frame->Show(TRUE);
112 SetTopWindow(frame);
113
114 // use our config object...
115 if ( pConfig->Read("/Controls/Check", 1l) != 0 ) {
116 wxMessageBox("You can disable this message box by unchecking\n"
117 "the checkbox in the main window (of course, a real\n"
118 "program would have a checkbox right here but we\n"
119 "keep it simple)", "Welcome to wxConfig demo",
120 wxICON_INFORMATION | wxOK);
121 }
122
123 return TRUE;
124 }
125
126 int MyApp::OnExit()
127 {
128 // clean up: Set() returns the active config object as Get() does, but unlike
129 // Get() it doesn't try to create one if there is none (definitely not what
130 // we want here!)
131 delete wxConfigBase::Set((wxConfigBase *) NULL);
132
133 return 0;
134 }
135
136 // ----------------------------------------------------------------------------
137 // frame
138 // ----------------------------------------------------------------------------
139
140 // main frame ctor
141 MyFrame::MyFrame()
142 : wxFrame((wxFrame *) NULL, -1, "wxConfig Demo")
143 {
144 // menu
145 wxMenu *file_menu = new wxMenu;
146
147 file_menu->Append(Minimal_Delete, "&Delete", "Delete config file");
148 file_menu->AppendSeparator();
149 file_menu->Append(Minimal_About, "&About", "About this sample");
150 file_menu->AppendSeparator();
151 file_menu->Append(Minimal_Quit, "E&xit", "Exit the program");
152 wxMenuBar *menu_bar = new wxMenuBar;
153 menu_bar->Append(file_menu, "&File");
154 SetMenuBar(menu_bar);
155
156 CreateStatusBar();
157
158 // child controls
159 wxPanel *panel = new wxPanel(this);
160 (void)new wxStaticText(panel, -1, "These controls remember their values!",
161 wxPoint(10, 10), wxSize(300, 20));
162 m_text = new wxTextCtrl(panel, -1, "", wxPoint(10, 40), wxSize(300, 20));
163 m_check = new wxCheckBox(panel, -1, "show welcome message box at startup",
164 wxPoint(10, 70), wxSize(300, 20));
165
166 // restore the control's values from the config
167
168 // NB: in this program, the config object is already created at this moment
169 // because we had called Get() from MyApp::OnInit(). However, if you later
170 // change the code and don't create it before this line, it won't break
171 // anything - unlike if you manually create wxConfig object with Create()
172 // or in any other way (then you must be sure to create it before using it!).
173 wxConfigBase *pConfig = wxConfigBase::Get();
174
175 // we could write Read("/Controls/Text") as well, it's just to show SetPath()
176 pConfig->SetPath("/Controls");
177
178 m_text->SetValue(pConfig->Read("Text", ""));
179 m_check->SetValue(pConfig->Read("Check", 1l) != 0);
180
181 // SetPath() understands ".."
182 pConfig->SetPath("../MainFrame");
183
184 // restore frame position and size
185 int x = pConfig->Read("x", 50),
186 y = pConfig->Read("y", 50),
187 w = pConfig->Read("w", 350),
188 h = pConfig->Read("h", 200);
189 Move(x, y);
190 SetClientSize(w, h);
191 }
192
193 void MyFrame::OnCloseWindow(wxCloseEvent& event)
194 {
195 this->Destroy();
196 }
197
198 void MyFrame::OnQuit(wxCommandEvent&)
199 {
200 Close(TRUE);
201 }
202
203 void MyFrame::OnAbout(wxCommandEvent&)
204 {
205 wxMessageBox("wxConfig demo\n© Vadim Zeitlin 1998", "About",
206 wxICON_INFORMATION | wxOK);
207 }
208
209 void MyFrame::OnDelete(wxCommandEvent&)
210 {
211 if ( wxConfigBase::Get()->DeleteAll() ) {
212 wxLogMessage("Config file/registry key successfully deleted.");
213
214 delete wxConfigBase::Set((wxConfigBase *) NULL);
215 wxConfigBase::DontCreateOnDemand();
216 }
217 else
218 {
219 wxLogError("Deleting config file/registry key failed.");
220 }
221 }
222
223 MyFrame::~MyFrame()
224 {
225 // save the control's values to the config
226 wxConfigBase *pConfig = wxConfigBase::Get();
227 if ( pConfig == NULL )
228 return;
229 pConfig->Write("/Controls/Text", m_text->GetValue());
230 pConfig->Write("/Controls/Check", m_check->GetValue());
231
232 // save the frame position
233 int x, y, w, h;
234 GetClientSize(&w, &h);
235 GetPosition(&x, &y);
236 pConfig->Write("/MainFrame/x", (long) x);
237 pConfig->Write("/MainFrame/y", (long) y);
238 pConfig->Write("/MainFrame/w", (long) w);
239 pConfig->Write("/MainFrame/h", (long) h);
240 }