]> git.saurik.com Git - wxWidgets.git/blame - interface/wx/xrc/xmlres.h
clarify the usage of debug macros, in particular for wxFAIL (which doesn't need ...
[wxWidgets.git] / interface / wx / xrc / xmlres.h
CommitLineData
23324ae1
FM
1/////////////////////////////////////////////////////////////////////////////
2// Name: xrc/xmlres.h
e54c96f1 3// Purpose: interface of wxXmlResource
23324ae1
FM
4// Author: wxWidgets team
5// RCS-ID: $Id$
6// Licence: wxWindows license
7/////////////////////////////////////////////////////////////////////////////
8
18e8e19b
FM
9/**
10 Flags which can be used with wxXmlResource::wxXmlResource.
11*/
12enum wxXmlResourceFlags
13{
14 /** Translatable strings will be translated via _(). */
15 wxXRC_USE_LOCALE = 1,
16
17 /** Subclass property of object nodes will be ignored (useful for previews in XRC editors). */
18 wxXRC_NO_SUBCLASSING = 2,
19
20 /** Prevent the XRC files from being reloaded from disk in case they have been modified there
21 since being last loaded (may slightly speed up loading them). */
22 wxXRC_NO_RELOADING = 4
23};
24
25
23324ae1
FM
26/**
27 @class wxXmlResource
7c913512 28
23324ae1 29 This is the main class for interacting with the XML-based resource system.
7c913512 30
23324ae1
FM
31 The class holds XML resources from one or more .xml files, binary files or zip
32 archive files.
7c913512 33
a302d595 34 @see @ref overview_xrc, @ref xrc_format
7c913512 35
23324ae1
FM
36 @library{wxxrc}
37 @category{xrc}
38*/
39class wxXmlResource : public wxObject
40{
41public:
23324ae1
FM
42 /**
43 Constructor.
f41d6c8c 44
18e8e19b
FM
45 @param filemask
46 The XRC file, archive file, or wildcard specification that will be
47 used to load all resource files inside a zip archive.
7c913512 48 @param flags
18e8e19b 49 One or more value of the ::wxXmlResourceFlags enumeration.
7c913512 50 @param domain
18e8e19b
FM
51 The name of the gettext catalog to search for translatable strings.
52 By default all loaded catalogs will be searched.
53 This provides a way to allow the strings to only come from a specific catalog.
23324ae1
FM
54 */
55 wxXmlResource(const wxString& filemask,
56 int flags = wxXRC_USE_LOCALE,
57 const wxString domain = wxEmptyString);
76e9224e
FM
58
59 /**
60 Constructor.
61
62 @param flags
63 One or more value of the ::wxXmlResourceFlags enumeration.
64 @param domain
65 The name of the gettext catalog to search for translatable strings.
66 By default all loaded catalogs will be searched.
67 This provides a way to allow the strings to only come from a specific catalog.
68 */
7c913512
FM
69 wxXmlResource(int flags = wxXRC_USE_LOCALE,
70 const wxString domain = wxEmptyString);
23324ae1
FM
71
72 /**
73 Destructor.
74 */
adaaa686 75 virtual ~wxXmlResource();
23324ae1
FM
76
77 /**
18e8e19b
FM
78 Initializes only a specific handler (or custom handler).
79 Convention says that the handler name is equal to the control's name plus
80 'XmlHandler', for example wxTextCtrlXmlHandler, wxHtmlWindowXmlHandler.
81
82 The XML resource compiler (wxxrc) can create include file that contains
83 initialization code for all controls used within the resource.
84 Note that this handler must be allocated on the heap, since it will be
85 deleted by ClearHandlers() later.
23324ae1
FM
86 */
87 void AddHandler(wxXmlResourceHandler* handler);
88
89 /**
90 Attaches an unknown control to the given panel/window/dialog.
18e8e19b 91 Unknown controls are used in conjunction with \<object class="unknown"\>.
23324ae1
FM
92 */
93 bool AttachUnknownControl(const wxString& name,
94 wxWindow* control,
4cc4bfaf 95 wxWindow* parent = NULL);
23324ae1
FM
96
97 /**
18e8e19b
FM
98 Removes all handlers and deletes them (this means that any handlers
99 added using AddHandler() must be allocated on the heap).
23324ae1
FM
100 */
101 void ClearHandlers();
102
103 /**
18e8e19b
FM
104 Compares the XRC version to the argument.
105
106 Returns -1 if the XRC version is less than the argument,
107 +1 if greater, and 0 if they are equal.
23324ae1 108 */
18e8e19b 109 int CompareVersion(int major, int minor, int release, int revision) const;
23324ae1 110
cc378c2d
VZ
111 /**
112 Returns a string ID corresponding to the given numeric ID.
113
114 The string returned is such that calling GetXRCID() with it as
115 parameter yields @a numId. If there is no string identifier
116 corresponding to the given numeric one, an empty string is returned.
117
118 Notice that, unlike GetXRCID(), this function is slow as it checks all
119 of the identifiers used in XRC.
120
121 @since 2.9.0
122 */
123 static wxString wxXmlResource::FindXRCIDById(int numId);
124
23324ae1
FM
125 /**
126 Gets the global resources object or creates one if none exists.
127 */
adaaa686 128 static wxXmlResource* Get();
23324ae1
FM
129
130 /**
131 Returns the domain (message catalog) that will be used to load
132 translatable strings in the XRC.
133 */
95b4a59e 134 const wxString& GetDomain() const;
23324ae1
FM
135
136 /**
18e8e19b
FM
137 Returns flags, which may be a bitlist of ::wxXmlResourceFlags
138 enumeration values.
23324ae1 139 */
adaaa686 140 int GetFlags() const;
23324ae1
FM
141
142 /**
18e8e19b 143 Returns version information (a.b.c.d = d + 256*c + 2562*b + 2563*a).
23324ae1 144 */
328f5751 145 long GetVersion() const;
23324ae1
FM
146
147 /**
18e8e19b
FM
148 Returns a numeric ID that is equivalent to the string ID used in an XML resource.
149
150 If an unknown @a str_id is requested (i.e. other than wxID_XXX or integer),
151 a new record is created which associates the given string with a number.
152
153 If @a value_if_not_found is @c wxID_NONE, the number is obtained via
e54c96f1 154 wxNewId(). Otherwise @a value_if_not_found is used.
23324ae1
FM
155 Macro @c XRCID(name) is provided for convenient use in event tables.
156 */
18e8e19b 157 static int GetXRCID(const wxString& str_id, int value_if_not_found = wxID_NONE);
23324ae1
FM
158
159 /**
18e8e19b
FM
160 Initializes handlers for all supported controls/windows.
161
162 This will make the executable quite big because it forces linking against
23324ae1
FM
163 most of the wxWidgets library.
164 */
165 void InitAllHandlers();
166
167 /**
168 Loads resources from XML files that match given filemask.
169 This method understands VFS (see filesys.h).
170 */
171 bool Load(const wxString& filemask);
172
173 /**
174 Loads a bitmap resource from a file.
175 */
176 wxBitmap LoadBitmap(const wxString& name);
177
23324ae1 178 /**
18e8e19b
FM
179 Loads a dialog. @a parent points to parent window (if any).
180 */
181 wxDialog* LoadDialog(wxWindow* parent, const wxString& name);
182
183 /**
184 Loads a dialog. @a parent points to parent window (if any).
185
23324ae1 186 This form is used to finish creation of an already existing instance (the main
18e8e19b 187 reason for this is that you may want to use derived class with a new event table).
23324ae1 188 Example:
18e8e19b
FM
189
190 @code
191 MyDialog dlg;
192 wxTheXmlResource->LoadDialog(&dlg, mainFrame, "my_dialog");
193 dlg.ShowModal();
194 @endcode
23324ae1 195 */
18e8e19b 196 bool LoadDialog(wxDialog* dlg, wxWindow* parent, const wxString& name);
23324ae1
FM
197
198 /**
199 Loads a frame.
200 */
201 bool LoadFrame(wxFrame* frame, wxWindow* parent,
202 const wxString& name);
203
204 /**
205 Loads an icon resource from a file.
206 */
207 wxIcon LoadIcon(const wxString& name);
208
209 /**
210 Loads menu from resource. Returns @NULL on failure.
211 */
212 wxMenu* LoadMenu(const wxString& name);
213
214 //@{
215 /**
216 Loads a menubar from resource. Returns @NULL on failure.
217 */
218 wxMenuBar* LoadMenuBar(wxWindow* parent, const wxString& name);
7c913512 219 wxMenuBar* LoadMenuBar(const wxString& name);
23324ae1
FM
220 //@}
221
222 //@{
223 /**
224 Load an object from the resource specifying both the resource name and the
225 class name.
18e8e19b
FM
226
227 The first overload lets you load nonstandard container windows and returns
228 @NULL on failure. The second one lets you finish the creation of an existing
23324ae1
FM
229 instance and returns @false on failure.
230 */
231 wxObject* LoadObject(wxWindow* parent, const wxString& name,
232 const wxString& classname);
7c913512
FM
233 bool LoadObject(wxObject* instance, wxWindow* parent,
234 const wxString& name,
235 const wxString& classname);
23324ae1
FM
236 //@}
237
23324ae1 238 /**
18e8e19b 239 Loads a panel. @a panel points to parent window (if any).
23324ae1
FM
240 */
241 wxPanel* LoadPanel(wxWindow* parent, const wxString& name);
18e8e19b
FM
242
243 /**
244 Loads a panel. @a panel points to parent window (if any).
245 This form is used to finish creation of an already existing instance.
246 */
247 bool LoadPanel(wxPanel* panel, wxWindow* parent, const wxString& name);
23324ae1
FM
248
249 /**
250 Loads a toolbar.
251 */
252 wxToolBar* LoadToolBar(wxWindow* parent, const wxString& name);
253
254 /**
18e8e19b
FM
255 Sets the global resources object and returns a pointer to the previous one
256 (may be @NULL).
23324ae1 257 */
adaaa686 258 static wxXmlResource* Set(wxXmlResource* res);
23324ae1
FM
259
260 /**
261 Sets the domain (message catalog) that will be used to load
262 translatable strings in the XRC.
263 */
95b4a59e 264 void SetDomain(const wxString& domain);
23324ae1
FM
265
266 /**
18e8e19b 267 Sets flags (bitlist of ::wxXmlResourceFlags enumeration values).
23324ae1
FM
268 */
269 void SetFlags(int flags);
270
271 /**
18e8e19b
FM
272 This function unloads a resource previously loaded by Load().
273
23324ae1 274 Returns @true if the resource was successfully unloaded and @false if it
18e8e19b 275 hasn't been found in the list of loaded resources.
23324ae1
FM
276 */
277 bool Unload(const wxString& filename);
278};
279
280
e54c96f1 281
23324ae1
FM
282/**
283 @class wxXmlResourceHandler
7c913512 284
23324ae1
FM
285 wxXmlResourceHandler is an abstract base class for resource handlers
286 capable of creating a control from an XML node.
7c913512 287
f41d6c8c 288 See @ref overview_xrc for details.
7c913512 289
23324ae1
FM
290 @library{wxxrc}
291 @category{xrc}
292*/
293class wxXmlResourceHandler : public wxObject
294{
295public:
296 /**
297 Default constructor.
298 */
299 wxXmlResourceHandler();
300
301 /**
302 Destructor.
303 */
adaaa686 304 virtual ~wxXmlResourceHandler();
23324ae1
FM
305
306 /**
95b4a59e
FM
307 Creates an object (menu, dialog, control, ...) from an XML node.
308 Should check for validity. @a parent is a higher-level object
309 (usually window, dialog or panel) that is often necessary to
310 create the resource.
311
312 If @b instance is non-@NULL it should not create a new instance via
313 'new' but should rather use this one, and call its Create method.
23324ae1 314 */
95b4a59e
FM
315 wxObject* CreateResource(wxXmlNode* node, wxObject* parent,
316 wxObject* instance);
23324ae1
FM
317
318 /**
95b4a59e 319 Called from CreateResource after variables were filled.
23324ae1 320 */
95b4a59e 321 virtual wxObject* DoCreateResource() = 0;
23324ae1
FM
322
323 /**
324 Returns @true if it understands this node and can create
325 a resource from it, @false otherwise.
18e8e19b
FM
326
327 @note
328 You must not call any wxXmlResourceHandler methods except IsOfClass()
329 from this method! The instance is not yet initialized with node data
330 at the time CanHandle() is called and it is only safe to operate on
331 node directly or to call IsOfClass().
23324ae1 332 */
95b4a59e
FM
333 virtual bool CanHandle(wxXmlNode* node) = 0;
334
335 /**
336 Sets the parent resource.
337 */
338 void SetParentResource(wxXmlResource* res);
339
340
341protected:
342
343 /**
344 Add a style flag (e.g. @c wxMB_DOCKABLE) to the list of flags
345 understood by this handler.
346 */
347 void AddStyle(const wxString& name, int value);
348
349 /**
350 Add styles common to all wxWindow-derived classes.
351 */
352 void AddWindowStyles();
23324ae1
FM
353
354 /**
355 Creates children.
356 */
4cc4bfaf 357 void CreateChildren(wxObject* parent, bool this_hnd_only = false);
23324ae1
FM
358
359 /**
360 Helper function.
361 */
362 void CreateChildrenPrivately(wxObject* parent,
4cc4bfaf 363 wxXmlNode* rootnode = NULL);
23324ae1
FM
364
365 /**
366 Creates a resource from a node.
367 */
368 wxObject* CreateResFromNode(wxXmlNode* node, wxObject* parent,
4cc4bfaf 369 wxObject* instance = NULL);
23324ae1 370
23324ae1 371 /**
18e8e19b 372 Creates an animation (see wxAnimation) from the filename specified in @a param.
23324ae1 373 */
18e8e19b 374 wxAnimation GetAnimation(const wxString& param = wxT("animation"));
23324ae1
FM
375
376 /**
23324ae1
FM
377 Gets a bitmap.
378 */
95b4a59e
FM
379 wxBitmap GetBitmap(const wxString& param = "bitmap",
380 const wxArtClient& defaultArtClient = wxART_OTHER,
381 wxSize size = wxDefaultSize);
23324ae1
FM
382
383 /**
f41d6c8c 384 Gets a bool flag (1, t, yes, on, true are @true, everything else is @false).
23324ae1 385 */
4cc4bfaf 386 bool GetBool(const wxString& param, bool defaultv = false);
23324ae1
FM
387
388 /**
3f5506cf 389 Gets colour in HTML syntax (\#RRGGBB).
23324ae1
FM
390 */
391 wxColour GetColour(const wxString& param,
18e8e19b 392 const wxColour& defaultColour = wxNullColour);
23324ae1
FM
393
394 /**
395 Returns the current file system.
396 */
95b4a59e 397 wxFileSystem& GetCurFileSystem();
23324ae1
FM
398
399 /**
400 Gets a dimension (may be in dialog units).
401 */
95b4a59e
FM
402 wxCoord GetDimension(const wxString& param, wxCoord defaultv = 0,
403 wxWindow* windowToUse = 0);
23324ae1
FM
404
405 /**
23324ae1
FM
406 Gets a font.
407 */
95b4a59e 408 wxFont GetFont(const wxString& param = "font");
23324ae1
FM
409
410 /**
411 Returns the XRCID.
412 */
4cc4bfaf 413 int GetID();
23324ae1
FM
414
415 /**
23324ae1
FM
416 Returns an icon.
417 */
95b4a59e
FM
418 wxIcon GetIcon(const wxString& param = "icon",
419 const wxArtClient& defaultArtClient = wxART_OTHER,
420 wxSize size = wxDefaultSize);
23324ae1
FM
421
422 /**
423 Gets the integer value from the parameter.
424 */
425 long GetLong(const wxString& param, long defaultv = 0);
426
427 /**
428 Returns the resource name.
429 */
430 wxString GetName();
431
432 /**
433 Gets node content from wxXML_ENTITY_NODE.
434 */
435 wxString GetNodeContent(wxXmlNode* node);
436
437 /**
438 Finds the node or returns @NULL.
439 */
440 wxXmlNode* GetParamNode(const wxString& param);
441
442 /**
443 Finds the parameter value or returns the empty string.
444 */
445 wxString GetParamValue(const wxString& param);
446
447 /**
23324ae1
FM
448 Gets the position (may be in dialog units).
449 */
18e8e19b 450 wxPoint GetPosition(const wxString& param = wxT("pos"));
23324ae1
FM
451
452 /**
23324ae1
FM
453 Gets the size (may be in dialog units).
454 */
95b4a59e 455 wxSize GetSize(const wxString& param = "size", wxWindow* windowToUse = 0);
23324ae1
FM
456
457 /**
23324ae1 458 Gets style flags from text in form "flag | flag2| flag3 |..."
18e8e19b 459 Only understands flags added with AddStyle().
23324ae1 460 */
18e8e19b 461 int GetStyle(const wxString& param = wxT("style"), int defaults = 0);
23324ae1
FM
462
463 /**
464 Gets text from param and does some conversions:
f41d6c8c
FM
465 - replaces \\n, \\r, \\t by respective characters (according to C syntax)
466 - replaces @c $ by @c and @c $$ by @c $ (needed for @c _File to @c File
467 translation because of XML syntax)
468 - calls wxGetTranslations (unless disabled in wxXmlResource)
23324ae1 469 */
95b4a59e 470 wxString GetText(const wxString& param, bool translate = true);
23324ae1
FM
471
472 /**
473 Check to see if a parameter exists.
474 */
475 bool HasParam(const wxString& param);
476
477 /**
18e8e19b
FM
478 Convenience function.
479 Returns @true if the node has a property class equal to classname,
23324ae1
FM
480 e.g. object class="wxDialog".
481 */
482 bool IsOfClass(wxXmlNode* node, const wxString& classname);
483
23324ae1
FM
484 /**
485 Sets common window options.
486 */
487 void SetupWindow(wxWindow* wnd);
488};
e54c96f1 489