]> git.saurik.com Git - wxWidgets.git/blame_incremental - docs/latex/wx/variant.tex
explain more clearly the possible usage scenarios
[wxWidgets.git] / docs / latex / wx / variant.tex
... / ...
CommitLineData
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
14The {\bf wxVariant} class represents a container for any type.
15A variant's value can be changed at run time, possibly to a different type of value.
16
17As standard, wxVariant can store values of type bool, wxChar, double, long, string,
18string list, time, date, void pointer, list of strings, and list of variants.
19However, an application can extend wxVariant's capabilities by deriving from the
20class \helpref{wxVariantData}{wxvariantdata} and using the wxVariantData form of
21the wxVariant constructor or assignment operator to assign this data to a variant.
22Actual values for user-defined types will need to be accessed via the wxVariantData
23object, unlike the case for basic data types where convenience functions such as
24\helpref{GetLong}{wxvariantgetlong} can be used.
25
26Pointers to any \helpref{wxObject}{wxobject} derived class can also easily be stored
27in a wxVariant. wxVariant will then use wxWidgets' built-in RTTI system to set the
28type name (returned by \helpref{GetType}{wxvariantgettype}) and to perform
29type-safety checks at runtime.
30
31This class is useful for reducing the programming for certain tasks, such as an editor
32for different data types, or a remote procedure call protocol.
33
34An optional name member is associated with a wxVariant. This might be used, for example,
35in CORBA or OLE automation classes, where named parameters are required.
36
37Note that as of wxWidgets 2.7.1, wxVariant is reference counted. Additionally, the
38conveniance macros {\bf DECLARE\_VARIANT\_OBJECT} and {\bf IMPLEMENT\_VARIANT\_OBJECT}
39were added so that adding (limited) support for conversion to and from wxVariant
40can be very easily implemented without modifiying either wxVariant or the class
41to be stored by wxVariant. Since assignement operators cannot be declared outside
42the 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
60For this to work, MyClass must derive from \helpref{wxObject}{wxobject}, implement
61the \helpref{wxWidgets RTTI system}{runtimeclassoverview}
62and support the assignment operator and equality operator for itself. Ideally, it
63should also be reference counted to make copying operations cheap and fast. This
64can be most easily implemented using the reference counting support offered by
65\helpref{wxObject}{wxobject} itself. By default, wxWidgets already implements
66the shift operator conversion for a few of its drawing related classes:
67
68\begin{verbatim}
69IMPLEMENT_VARIANT_OBJECT(wxColour)
70IMPLEMENT_VARIANT_OBJECT(wxImage)
71IMPLEMENT_VARIANT_OBJECT(wxIcon)
72IMPLEMENT_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
93Default constructor.
94
95\func{}{wxVariant}{\param{const wxVariant\& }{variant}}
96
97Copy 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
103Construction from a string value.
104
105\func{}{wxVariant}{\param{wxChar}{ value}, \param{const wxString\& }{name = ``"}}
106
107Construction from a character value.
108
109\func{}{wxVariant}{\param{long}{ value}, \param{const wxString\& }{name = ``"}}
110
111Construction from an integer value. You may need to cast to (long) to
112avoid confusion with other constructors (such as the bool constructor).
113
114\func{}{wxVariant}{\param{bool}{ value}, \param{const wxString\& }{name = ``"}}
115
116Construction from a boolean value.
117
118\func{}{wxVariant}{\param{double}{ value}, \param{const wxString\& }{name = ``"}}
119
120Construction from a double-precision floating point value.
121
122\func{}{wxVariant}{\param{const wxList\&}{ value}, \param{const wxString\& }{name = ``"}}
123
124Construction from a list of wxVariant objects. This constructor
125copies {\it value}, the application is still responsible for
126deleting {\it value} and its contents.
127
128\func{}{wxVariant}{\param{void*}{ value}, \param{const wxString\& }{name = ``"}}
129
130Construction from a void pointer.
131
132\func{}{wxVariant}{\param{wxObject*}{ value}, \param{const wxString\& }{name = ``"}}
133
134Construction from a wxObject pointer.
135
136\func{}{wxVariant}{\param{wxVariantData*}{ data}, \param{const wxString\& }{name = ``"}}
137
138Construction from user-defined data. The variant holds onto the {\it data} pointer.
139
140\func{}{wxVariant}{\param{wxDateTime\&}{ val}, \param{const wxString\& }{name = ``"}}
141
142Construction from a \helpref{wxDateTime}{wxdatetime}.
143
144\func{}{wxVariant}{\param{wxArrayString\&}{ val}, \param{const wxString\& }{name = ``"}}
145
146Construction 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
150Construction 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
154Construction 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
158Construction 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
164Destructor.
165
166Note that destructor is protected, so wxVariantData cannot usually
167be 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
174Appends a value to the list.
175
176\membersection{wxVariant::Clear}\label{wxvariantclear}
177
178\func{void}{Clear}{\void}
179
180Makes the variant null by deleting the internal data and
181set the name to {\it wxEmptyString}.
182
183\membersection{wxVariant::ClearList}\label{wxvariantclearlist}
184
185\func{void}{ClearList}{\void}
186
187Deletes 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
204Retrieves 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
211Returns the number of elements in the list.
212
213\membersection{wxVariant::Delete}\label{wxvariantdelete}
214
215\func{bool}{Delete}{\param{size\_t }{item}}
216
217Deletes the zero-based {\it item} from the list.
218
219\membersection{wxVariant::GetArrayString}\label{wxvariantgetarraystring}
220
221\constfunc{wxArrayString}{GetArrayString}{\void}
222
223Returns the string array value.
224
225\membersection{wxVariant::GetBool}\label{wxvariantgetbool}
226
227\constfunc{bool}{GetBool}{\void}
228
229Returns the boolean value.
230
231\membersection{wxVariant::GetChar}\label{wxvariantgetchar}
232
233\constfunc{wxChar}{GetChar}{\void}
234
235Returns the character value.
236
237\membersection{wxVariant::GetData}\label{wxvariantgetdata}
238
239\constfunc{wxVariantData*}{GetData}{\void}
240
241Returns a pointer to the internal variant data. To take ownership
242of this data, you must call its \helpref{IncRef}{wxvariantdataincref}
243method. When you stop using it, \helpref{DecRef}{wxvariantdatadecref}
244must be likewise called.
245
246\membersection{wxVariant::GetDateTime}\label{wxvariantgetdatetime}
247
248\constfunc{wxDateTime}{GetDateTime}{\void}
249
250Returns the date value.
251
252\membersection{wxVariant::GetDouble}\label{wxvariantgetdouble}
253
254\constfunc{double}{GetDouble}{\void}
255
256Returns the floating point value.
257
258\membersection{wxVariant::GetLong}\label{wxvariantgetlong}
259
260\constfunc{long}{GetLong}{\void}
261
262Returns the integer value.
263
264\membersection{wxVariant::GetName}\label{wxvariantgetname}
265
266\constfunc{const wxString\&}{GetName}{\void}
267
268Returns a constant reference to the variant name.
269
270\membersection{wxVariant::GetString}\label{wxvariantgetstring}
271
272\constfunc{wxString}{GetString}{\void}
273
274Gets the string value.
275
276\membersection{wxVariant::GetType}\label{wxvariantgettype}
277
278\constfunc{wxString}{GetType}{\void}
279
280Returns the value type as a string. The built-in types are: bool, char, date, double, list, long, string, stringlist, time, void*.
281
282If 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
288Gets the void pointer value.
289
290\membersection{wxVariant::GetWxObjectPtr}\label{wxvariantgetwxobjectptr}
291
292\constfunc{wxObject*}{GetWxObjectPtr}{\void}
293
294Gets the wxObject pointer value.
295
296\membersection{wxVariant::Insert}\label{wxvariantinsert}
297
298\func{void}{Insert}{\param{const wxVariant\&}{ value}}
299
300Inserts a value at the front of the list.
301
302\membersection{wxVariant::IsNull}\label{wxvariantisnull}
303
304\constfunc{bool}{IsNull}{\void}
305
306Returns 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
312Returns 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
318Returns 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
324Makes the variant null by deleting the internal data.
325
326\membersection{wxVariant::MakeString}\label{wxvariantmakestring}
327
328\constfunc{wxString}{MakeString}{\void}
329
330Makes 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
336Returns true if {\it value} matches an element in the list.
337
338\membersection{wxVariant::NullList}\label{wxvariantnulllist}
339
340\func{void}{NullList}{\void}
341
342Makes an empty list. This differs from a null variant which has no data; a null list
343is 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
349Sets 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
385Assignment 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
413Equality 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
441Inequality test operators.
442
443\membersection{wxVariant::operator $[]$}\label{wxvariantarray}
444
445\constfunc{wxVariant}{operator $[]$}{\param{size\_t }{idx}}
446
447Returns the value at {\it idx} (zero-based).
448
449\func{wxVariant\&}{operator $[]$}{\param{size\_t }{idx}}
450
451Returns a reference to the value at {\it idx} (zero-based). This can be used
452to change the value at this index.
453
454\membersection{wxVariant::operator wxChar}\label{wxvariantchar}
455
456\constfunc{char}{operator wxChar}{\void}
457
458Operator 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
464Operator for implicit conversion to a double, using \helpref{wxVariant::GetDouble}{wxvariantgetdouble}.
465
466\constfunc{long}{operator long}{\void}
467
468Operator 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
474Operator 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
480Operator 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
486Operator for implicit conversion to a pointer to a \helpref{wxDateTime}{wxdatetime}, using \helpref{wxVariant::GetDateTime}{wxvariantgetdatetime}.
487
488\section{\class{wxVariantData}}\label{wxvariantdata}
489
490The {\bf wxVariantData} is used to implement a new type for wxVariant. Derive from wxVariantData,
491and override the pure virtual functions.
492
493wxVariantData is reference counted, but you don't normally have to care about this, as
494wxVariant manages the count automatically. However, incase your application needs to take
495ownership of wxVariantData, be aware that the object is created with reference count of 1,
496and passing it to wxVariant will not increase this. In other words, \helpref{IncRef}{wxvariantdataincref}
497needs to be called only if you both take ownership of wxVariantData and pass it to a wxVariant.
498Also note that the destructor is protected, so you can never explicitly delete a wxVariantData
499instance. Instead, \helpref{DecRef}{wxvariantdatadecref} will delete the object automatically
500when 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
520Default constructor.
521
522\membersection{wxVariantData::DecRef}\label{wxvariantdatadecref}
523
524\func{void}{DecRef}{\void}
525
526Decreases reference count. If the count reaches zero, the object is
527automatically deleted.
528
529Note that destructor of wxVariantData is protected, so delete
530cannot 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
536Returns true if this object is equal to {\it data}.
537
538\membersection{wxVariantData::GetType}\label{wxvariantdatagettype}
539
540\constfunc{wxString}{GetType}{\void}
541
542Returns the string type of the data.
543
544\membersection{wxVariantData::GetValueClassInfo}\label{wxvariantdatagetvalueclassinfo}
545
546\constfunc{wxClassInfo*}{GetValueClassInfo}{\void}
547
548If the data is a wxObject returns a pointer to the objects wxClassInfo structure, if
549the data isn't a wxObject the method returns NULL.
550
551\membersection{wxVariantData::IncRef}\label{wxvariantdataincref}
552
553\func{void}{IncRef}{\void}
554
555Increases 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
563Reads 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
571Writes the data to {\it stream} or {\it string}.
572
573
574\membersection{wxGetVariantCast}\label{wxgetvariantcast}
575
576\func{classname *}{wxGetVariantCast}{wxVariant\&, classname}
577
578This macro returns the data stored in {\it variant} cast to the type {\it classname *} if
579the 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}
587