]> git.saurik.com Git - wxWidgets.git/blob - docs/latex/wx/variant.tex
7dce11fb4aec7220d941f11cf327d8c21d65d57a
[wxWidgets.git] / docs / latex / wx / variant.tex
1 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
2 %% Name: variant.tex
3 %% Purpose: wxVariant docs
4 %% Author: wxWidgets Team
5 %% Modified by:
6 %% Created: 01/30/2005
7 %% RCS-ID: $Id$
8 %% Copyright: (c) wxWidgets Team
9 %% License: wxWindows license
10 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
11
12 \section{\class{wxVariant}}\label{wxvariant}
13
14 The {\bf wxVariant} class represents a container for any type.
15 A variant's value can be changed at run time, possibly to a different type of value.
16
17 As standard, wxVariant can store values of type bool, wxChar, double, long, string,
18 string list, time, date, void pointer, list of strings, and list of variants.
19 However, an application can extend wxVariant's capabilities by deriving from the
20 class \helpref{wxVariantData}{wxvariantdata} and using the wxVariantData form of
21 the wxVariant constructor or assignment operator to assign this data to a variant.
22 Actual values for user-defined types will need to be accessed via the wxVariantData
23 object, unlike the case for basic data types where convenience functions such as
24 \helpref{GetLong}{wxvariantgetlong} can be used.
25
26 Pointers to any \helpref{wxObject}{helpref} derived class can also easily be stored
27 in a wxVariant. wxVariant will then use wxWidgets' built-in RTTI system to set the
28 type name (returned by \helpref{GetType}{wxvariantgettype}) and to perform
29 type-safety checks at runtime.
30
31 This class is useful for reducing the programming for certain tasks, such as an editor
32 for different data types, or a remote procedure call protocol.
33
34 An optional name member is associated with a wxVariant. This might be used, for example,
35 in CORBA or OLE automation classes, where named parameters are required.
36
37 Note that as of wxWidgets 2.7.1, wxVariant is reference counted. Additionly, the
38 conveniance macros {\bf DECLARE\_VARIANT\_OBJECT} and {\bf IMPLEMENT\_VARIANT\_OBJECT}
39 were added so that adding (limited) support for conversion to and from wxVariant
40 can be very easily implemented without modifiying either the wxVariant or the class
41 to be stored by wxVariant. Since assignement operators cannot be declared outside
42 the class, the shift left operators are used like this:
43
44 \begin{verbatim}
45 // in the header file
46 DECLARE_VARIANT_OBJECT(MyClass)
47
48 // in the implementation file
49 IMPLMENT_VARIANT_OBJECT(MyClass)
50
51 // in the user code
52 wxVariant variant;
53 MyClass value;
54 variant << value;
55
56 // or
57 value << variant;
58 \end{verbatim}
59
60 For this to work, MyClass must derive from \helpref{wxObject}{wxobject}, implement
61 the \helpref{wxWidgets RTTI system}{runtimeclassoverview}
62 and support the assignment operator and equality operator for itself. Ideally, it
63 should also be reference counted to make copying operations cheap and fast. This
64 can be most easily implemented using the reference counting support offered by
65 \helpref{wxObject}{wxobject} itself. By default, wxWidgets already implements
66 the shift operator conversion for a few of its drawing related classes:
67
68 \begin{verbatim}
69 IMPLEMENT_VARIANT_OBJECT(wxColour)
70 IMPLEMENT_VARIANT_OBJECT(wxImage)
71 IMPLEMENT_VARIANT_OBJECT(wxIcon)
72 IMPLEMENT_VARIANT_OBJECT(wxBitmap)
73 \end{verbatim}
74
75 \wxheading{Derived from}
76
77 \helpref{wxObject}{wxobject}
78
79 \wxheading{Include files}
80
81 <wx/variant.h>
82
83 \wxheading{See also}
84
85 \helpref{wxVariantData}{wxvariantdata}
86
87 \latexignore{\rtfignore{\wxheading{Members}}}
88
89 \membersection{wxVariant::wxVariant}\label{wxvariantctor}
90
91 \func{}{wxVariant}{\void}
92
93 Default constructor.
94
95 \func{}{wxVariant}{\param{const wxVariant\& }{variant}}
96
97 Copy constructor.
98
99 \func{}{wxVariant}{\param{const wxChar*}{ value}, \param{const wxString\& }{name = ``"}}
100
101 \func{}{wxVariant}{\param{const wxString\&}{ value}, \param{const wxString\& }{name = ``"}}
102
103 Construction from a string value.
104
105 \func{}{wxVariant}{\param{wxChar}{ value}, \param{const wxString\& }{name = ``"}}
106
107 Construction from a character value.
108
109 \func{}{wxVariant}{\param{long}{ value}, \param{const wxString\& }{name = ``"}}
110
111 Construction from an integer value. You may need to cast to (long) to
112 avoid confusion with other constructors (such as the bool constructor).
113
114 \func{}{wxVariant}{\param{bool}{ value}, \param{const wxString\& }{name = ``"}}
115
116 Construction from a boolean value.
117
118 \func{}{wxVariant}{\param{double}{ value}, \param{const wxString\& }{name = ``"}}
119
120 Construction from a double-precision floating point value.
121
122 \func{}{wxVariant}{\param{const wxList\&}{ value}, \param{const wxString\& }{name = ``"}}
123
124 Construction from a list of wxVariant objects. This constructor
125 copies {\it value}, the application is still responsible for
126 deleting {\it value} and its contents.
127
128 \func{}{wxVariant}{\param{void*}{ value}, \param{const wxString\& }{name = ``"}}
129
130 Construction from a void pointer.
131
132 \func{}{wxVariant}{\param{wxObject*}{ value}, \param{const wxString\& }{name = ``"}}
133
134 Construction from a wxObject pointer.
135
136 \func{}{wxVariant}{\param{wxVariantData*}{ data}, \param{const wxString\& }{name = ``"}}
137
138 Construction from user-defined data. The variant holds onto the {\it data} pointer.
139
140 \func{}{wxVariant}{\param{wxDateTime\&}{ val}, \param{const wxString\& }{name = ``"}}
141
142 Construction from a \helpref{wxDateTime}{wxdatetime}.
143
144 \func{}{wxVariant}{\param{wxArrayString\&}{ val}, \param{const wxString\& }{name = ``"}}
145
146 Construction from an array of strings. This constructor copies {\it value} and its contents.
147
148 \func{}{wxVariant}{\param{DATE\_STRUCT*}{ val}, \param{const wxString\& }{name = ``"}}
149
150 Construction from a odbc date value. Represented internally by a \helpref{wxDateTime}{wxdatetime} value.
151
152 \func{}{wxVariant}{\param{TIME\_STRUCT*}{ val}, \param{const wxString\& }{name = ``"}}
153
154 Construction from a odbc time value. Represented internally by a \helpref{wxDateTime}{wxdatetime} value.
155
156 \func{}{wxVariant}{\param{TIMESTAMP\_STRUCT*}{ val}, \param{const wxString\& }{name = ``"}}
157
158 Construction from a odbc timestamp value. Represented internally by a \helpref{wxDateTime}{wxdatetime} value.
159
160 \membersection{wxVariant::\destruct{wxVariant}}\label{wxvariantdtor}
161
162 \func{}{\destruct{wxVariant}}{\void}
163
164 Destructor.
165
166 Note that destructor is protected, so wxVariantData cannot usually
167 be deleted. Instead, \helpref{DecRef}{wxvariantdatadecref} should be called.
168
169
170 \membersection{wxVariant::Append}\label{wxvariantappend}
171
172 \func{void}{Append}{\param{const wxVariant\&}{ value}}
173
174 Appends a value to the list.
175
176 \membersection{wxVariant::Clear}\label{wxvariantclear}
177
178 \func{void}{Clear}{\void}
179
180 Makes the variant null by deleting the internal data and
181 set the name to {\it wxEmptyString}.
182
183 \membersection{wxVariant::ClearList}\label{wxvariantclearlist}
184
185 \func{void}{ClearList}{\void}
186
187 Deletes the contents of the list.
188
189
190 \membersection{wxVariant::Convert}\label{wxvariantconvert}
191
192 \constfunc{bool}{Convert}{\param{long*}{ value}}
193
194 \constfunc{bool}{Convert}{\param{bool*}{ value}}
195
196 \constfunc{bool}{Convert}{\param{double*}{ value}}
197
198 \constfunc{bool}{Convert}{\param{wxString*}{ value}}
199
200 \constfunc{bool}{Convert}{\param{wxChar*}{ value}}
201
202 \constfunc{bool}{Convert}{\param{wxDateTime*}{ value}}
203
204 Retrieves and converts the value of this variant to the type that {\it value} is.
205
206
207 \membersection{wxVariant::GetCount}\label{wxvariantgetcount}
208
209 \constfunc{size\_t}{GetCount}{\void}
210
211 Returns the number of elements in the list.
212
213 \membersection{wxVariant::Delete}\label{wxvariantdelete}
214
215 \func{bool}{Delete}{\param{size\_t }{item}}
216
217 Deletes the zero-based {\it item} from the list.
218
219 \membersection{wxVariant::GetArrayString}\label{wxvariantgetarraystring}
220
221 \constfunc{wxArrayString}{GetArrayString}{\void}
222
223 Returns the string array value.
224
225 \membersection{wxVariant::GetBool}\label{wxvariantgetbool}
226
227 \constfunc{bool}{GetBool}{\void}
228
229 Returns the boolean value.
230
231 \membersection{wxVariant::GetChar}\label{wxvariantgetchar}
232
233 \constfunc{wxChar}{GetChar}{\void}
234
235 Returns the character value.
236
237 \membersection{wxVariant::GetData}\label{wxvariantgetdata}
238
239 \constfunc{wxVariantData*}{GetData}{\void}
240
241 Returns a pointer to the internal variant data. To take ownership
242 of this data, you must call its \helpref{IncRef}{wxvariantdataincref}
243 method. When you stop using it, \helpref{DecRef}{wxvariantdatadecref}
244 must be likewise called.
245
246 \membersection{wxVariant::GetDateTime}\label{wxvariantgetdatetime}
247
248 \constfunc{wxDateTime}{GetDateTime}{\void}
249
250 Returns the date value.
251
252 \membersection{wxVariant::GetDouble}\label{wxvariantgetdouble}
253
254 \constfunc{double}{GetDouble}{\void}
255
256 Returns the floating point value.
257
258 \membersection{wxVariant::GetLong}\label{wxvariantgetlong}
259
260 \constfunc{long}{GetLong}{\void}
261
262 Returns the integer value.
263
264 \membersection{wxVariant::GetName}\label{wxvariantgetname}
265
266 \constfunc{const wxString\&}{GetName}{\void}
267
268 Returns a constant reference to the variant name.
269
270 \membersection{wxVariant::GetString}\label{wxvariantgetstring}
271
272 \constfunc{wxString}{GetString}{\void}
273
274 Gets the string value.
275
276 \membersection{wxVariant::GetType}\label{wxvariantgettype}
277
278 \constfunc{wxString}{GetType}{\void}
279
280 Returns the value type as a string. The built-in types are: bool, char, date, double, list, long, string, stringlist, time, void*.
281
282 If the variant is null, the value type returned is the string ``null" (not the empty string).
283
284 \membersection{wxVariant::GetVoidPtr}\label{wxvariantgetvoidptr}
285
286 \constfunc{void*}{GetVoidPtr}{\void}
287
288 Gets the void pointer value.
289
290 \membersection{wxVariant::GetWxObjectPtr}\label{wxvariantgetwxobjectptr}
291
292 \constfunc{wxObject*}{GetWxObjectPtr}{\void}
293
294 Gets the wxObject pointer value.
295
296 \membersection{wxVariant::Insert}\label{wxvariantinsert}
297
298 \func{void}{Insert}{\param{const wxVariant\&}{ value}}
299
300 Inserts a value at the front of the list.
301
302 \membersection{wxVariant::IsNull}\label{wxvariantisnull}
303
304 \constfunc{bool}{IsNull}{\void}
305
306 Returns true if there is no data associated with this variant, false if there is data.
307
308 \membersection{wxVariant::IsType}\label{wxvariantistype}
309
310 \constfunc{bool}{IsType}{\param{const wxString\&}{ type}}
311
312 Returns true if {\it type} matches the type of the variant, false otherwise.
313
314 \membersection{wxVariant::IsValueKindOf}\label{wxvariantisvaluekindof}
315
316 \constfunc{bool}{IsValueKindOf}{\param{const wxClassInfo* type}{ type}}
317
318 Returns true if the data is derived from the class described by {\it type}, false otherwise.
319
320 \membersection{wxVariant::MakeNull}\label{wxvariantmakenull}
321
322 \func{void}{MakeNull}{\void}
323
324 Makes the variant null by deleting the internal data.
325
326 \membersection{wxVariant::MakeString}\label{wxvariantmakestring}
327
328 \constfunc{wxString}{MakeString}{\void}
329
330 Makes a string representation of the variant value (for any type).
331
332 \membersection{wxVariant::Member}\label{wxvariantmember}
333
334 \constfunc{bool}{Member}{\param{const wxVariant\&}{ value}}
335
336 Returns true if {\it value} matches an element in the list.
337
338 \membersection{wxVariant::NullList}\label{wxvariantnulllist}
339
340 \func{void}{NullList}{\void}
341
342 Makes an empty list. This differs from a null variant which has no data; a null list
343 is of type list, but the number of elements in the list is zero.
344
345 \membersection{wxVariant::SetData}\label{wxvariantsetdata}
346
347 \func{void}{SetData}{\param{wxVariantData*}{ data}}
348
349 Sets the internal variant data, deleting the existing data if there is any.
350
351 \membersection{wxVariant::operator $=$}\label{wxvariantassignment}
352
353 \func{void}{operator $=$}{\param{const wxVariant\& }{value}}
354
355 \func{void}{operator $=$}{\param{wxVariantData* }{value}}
356
357 \func{void}{operator $=$}{\param{const wxString\& }{value}}
358
359 \func{void}{operator $=$}{\param{const wxChar* }{value}}
360
361 \func{void}{operator $=$}{\param{wxChar }{value}}
362
363 \func{void}{operator $=$}{\param{const long }{value}}
364
365 \func{void}{operator $=$}{\param{const bool }{value}}
366
367 \func{void}{operator $=$}{\param{const double }{value}}
368
369 \func{void}{operator $=$}{\param{void* }{value}}
370
371 \func{void}{operator $=$}{\param{wxObject* }{value}}
372
373 \func{void}{operator $=$}{\param{const wxList\& }{value}}
374
375 \func{void}{operator $=$}{\param{const wxDateTime\& }{value}}
376
377 \func{void}{operator $=$}{\param{const wxArrayString\& }{value}}
378
379 \func{void}{operator $=$}{\param{const DATE\_STRUCT* }{value}}
380
381 \func{void}{operator $=$}{\param{const TIME\_STRUCT* }{value}}
382
383 \func{void}{operator $=$}{\param{const TIMESTAMP\_STRUCT* }{value}}
384
385 Assignment operators.
386
387 \membersection{wxVariant::operator $==$}\label{wxvarianteq}
388
389 \constfunc{bool}{operator $==$}{\param{const wxVariant\& }{value}}
390
391 \constfunc{bool}{operator $==$}{\param{const wxString\& }{value}}
392
393 \constfunc{bool}{operator $==$}{\param{const wxChar* }{value}}
394
395 \constfunc{bool}{operator $==$}{\param{wxChar }{value}}
396
397 \constfunc{bool}{operator $==$}{\param{const long }{value}}
398
399 \constfunc{bool}{operator $==$}{\param{const bool }{value}}
400
401 \constfunc{bool}{operator $==$}{\param{const double }{value}}
402
403 \constfunc{bool}{operator $==$}{\param{void* }{value}}
404
405 \constfunc{bool}{operator $==$}{\param{wxObject* }{value}}
406
407 \constfunc{bool}{operator $==$}{\param{const wxList\& }{value}}
408
409 \constfunc{bool}{operator $==$}{\param{const wxArrayString\& }{value}}
410
411 \constfunc{bool}{operator $==$}{\param{const wxDateTime\& }{value}}
412
413 Equality test operators.
414
415 \membersection{wxVariant::operator $!=$}\label{wxvariantneq}
416
417 \constfunc{bool}{operator $!=$}{\param{const wxVariant\& }{value}}
418
419 \constfunc{bool}{operator $!=$}{\param{const wxString\& }{value}}
420
421 \constfunc{bool}{operator $!=$}{\param{const wxChar* }{value}}
422
423 \constfunc{bool}{operator $!=$}{\param{wxChar }{value}}
424
425 \constfunc{bool}{operator $!=$}{\param{const long }{value}}
426
427 \constfunc{bool}{operator $!=$}{\param{const bool }{value}}
428
429 \constfunc{bool}{operator $!=$}{\param{const double }{value}}
430
431 \constfunc{bool}{operator $!=$}{\param{void* }{value}}
432
433 \constfunc{bool}{operator $!=$}{\param{wxObject* }{value}}
434
435 \constfunc{bool}{operator $!=$}{\param{const wxList\& }{value}}
436
437 \constfunc{bool}{operator $!=$}{\param{const wxArrayString\& }{value}}
438
439 \constfunc{bool}{operator $!=$}{\param{const wxDateTime\& }{value}}
440
441 Inequality test operators.
442
443 \membersection{wxVariant::operator $[]$}\label{wxvariantarray}
444
445 \constfunc{wxVariant}{operator $[]$}{\param{size\_t }{idx}}
446
447 Returns the value at {\it idx} (zero-based).
448
449 \func{wxVariant\&}{operator $[]$}{\param{size\_t }{idx}}
450
451 Returns a reference to the value at {\it idx} (zero-based). This can be used
452 to change the value at this index.
453
454 \membersection{wxVariant::operator wxChar}\label{wxvariantchar}
455
456 \constfunc{char}{operator wxChar}{\void}
457
458 Operator for implicit conversion to a wxChar, using \helpref{wxVariant::GetChar}{wxvariantgetchar}.
459
460 \membersection{wxVariant::operator double}\label{wxvariantdouble}
461
462 \constfunc{double}{operator double}{\void}
463
464 Operator for implicit conversion to a double, using \helpref{wxVariant::GetDouble}{wxvariantgetdouble}.
465
466 \constfunc{long}{operator long}{\void}
467
468 Operator for implicit conversion to a long, using \helpref{wxVariant::GetLong}{wxvariantgetlong}.
469
470 \membersection{wxVariant::operator wxString}\label{wxvariantwxstring}
471
472 \constfunc{wxString}{operator wxString}{\void}
473
474 Operator for implicit conversion to a string, using \helpref{wxVariant::MakeString}{wxvariantmakestring}.
475
476 \membersection{wxVariant::operator void*}\label{wxvariantvoid}
477
478 \constfunc{void*}{operator void*}{\void}
479
480 Operator for implicit conversion to a pointer to a void, using \helpref{wxVariant::GetVoidPtr}{wxvariantgetvoidptr}.
481
482 \membersection{wxVariant::operator wxDateTime}\label{wxvariantdatetime}
483
484 \constfunc{void*}{operator wxDateTime}{\void}
485
486 Operator for implicit conversion to a pointer to a \helpref{wxDateTime}{wxdatetime}, using \helpref{wxVariant::GetDateTime}{wxvariantgetdatetime}.
487
488 \section{\class{wxVariantData}}\label{wxvariantdata}
489
490 The {\bf wxVariantData} is used to implement a new type for wxVariant. Derive from wxVariantData,
491 and override the pure virtual functions.
492
493 wxVariantData is reference counted, but you don't normally have to care about this, as
494 wxVariant manages the count automatically. However, incase your application needs to take
495 ownership of wxVariantData, be aware that the object is created with reference count of 1,
496 and passing it to wxVariant will not increase this. In other words, \helpref{IncRef}{wxvariantdataincref}
497 needs to be called only if you both take ownership of wxVariantData and pass it to a wxVariant.
498 Also note that the destructor is protected, so you can never explicitly delete a wxVariantData
499 instance. Instead, \helpref{DecRef}{wxvariantdatadecref} will delete the object automatically
500 when the reference count reaches zero.
501
502 \wxheading{Derived from}
503
504 \helpref{wxObject}{wxobject}
505
506 \wxheading{Include files}
507
508 <wx/variant.h>
509
510 \wxheading{See also}
511
512 \helpref{wxVariant}{wxvariant}
513
514 \latexignore{\rtfignore{\wxheading{Members}}}
515
516 \membersection{wxVariantData::wxVariantData}\label{wxvariantdatactor}
517
518 \func{}{wxVariantData}{\void}
519
520 Default constructor.
521
522 \membersection{wxVariantData::DecRef}\label{wxvariantdatadecref}
523
524 \func{void}{DecRef}{\void}
525
526 Decreases reference count. If the count reaches zero, the object is
527 automatically deleted.
528
529 Note that destructor of wxVariantData is protected, so delete
530 cannot be used as normal. Instead, DecRef should be called.
531
532 \membersection{wxVariantData::Eq}\label{wxvariantdataeq}
533
534 \constfunc{bool}{Eq}{\param{wxVariantData\&}{ data}}
535
536 Returns true if this object is equal to {\it data}.
537
538 \membersection{wxVariantData::GetType}\label{wxvariantdatagettype}
539
540 \constfunc{wxString}{GetType}{\void}
541
542 Returns the string type of the data.
543
544 \membersection{wxVariantData::GetValueClassInfo}\label{wxvariantdatagetvalueclassinfo}
545
546 \constfunc{wxClassInfo*}{GetValueClassInfo}{\void}
547
548 If the data is a wxObject returns a pointer to the objects wxClassInfo structure, if
549 the data isn't a wxObject the method returns NULL.
550
551 \membersection{wxVariantData::IncRef}\label{wxvariantdataincref}
552
553 \func{void}{IncRef}{\void}
554
555 Increases reference count. Note that initially wxVariantData has reference count of 1.
556
557 \membersection{wxVariantData::Read}\label{wxvariantdataread}
558
559 \func{bool}{Read}{\param{ostream\&}{ stream}}
560
561 \func{bool}{Read}{\param{wxString\&}{ string}}
562
563 Reads the data from {\it stream} or {\it string}.
564
565 \membersection{wxVariantData::Write}\label{wxvariantdatawrite}
566
567 \constfunc{bool}{Write}{\param{ostream\&}{ stream}}
568
569 \constfunc{bool}{Write}{\param{wxString\&}{ string}}
570
571 Writes the data to {\it stream} or {\it string}.
572
573
574 \membersection{wxGetVariantCast}\label{wxgetvariantcast}
575
576 \func{classname *}{wxGetVariantCast}{wxVariant\&, classname}
577
578 This macro returns the data stored in {\it variant} cast to the type {\it classname *} if
579 the data is of this type (the check is done during the run-time) or
580 {\tt NULL} otherwise.
581
582
583 \wxheading{See also}
584
585 \helpref{RTTI overview}{runtimeclassoverview}\\
586 \helpref{wxDynamicCast}{wxdynamiccast}