]> git.saurik.com Git - wxWidgets.git/blame_incremental - docs/latex/wx/datespan.tex
don't call wxString::Len() from operator==; use IsSameAs() instead of move the length...
[wxWidgets.git] / docs / latex / wx / datespan.tex
... / ...
CommitLineData
1%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
2%% Name: datespan.tex
3%% Purpose: wxDateSpan documentation
4%% Author: Vadim Zeitlin
5%% Modified by:
6%% Created: 04.04.00
7%% RCS-ID: $Id$
8%% Copyright: (c) Vadim Zeitlin
9%% License: wxWindows license
10%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
11
12\section{\class{wxDateSpan}}\label{wxdatespan}
13
14This class is a "logical time span" and is useful for implementing program
15logic for such things as "add one month to the date" which, in general,
16doesn't mean to add $60*60*24*31$ seconds to it, but to take the same date
17the next month (to understand that this is indeed different consider adding
18one month to Feb, 15 -- we want to get Mar, 15, of course).
19
20When adding a month to the date, all lesser components (days, hours, ...)
21won't be changed unless the resulting date would be invalid: for example,
22Jan 31 + 1 month will be Feb 28, not (non-existing) Feb 31.
23
24Because of this feature, adding and subtracting back again the same
25wxDateSpan will {\bf not}, in general give back the original date: Feb 28 - 1
26month will be Jan 28, not Jan 31!
27
28wxDateSpan objects can be either positive or negative. They may be
29multiplied by scalars which multiply all deltas by the scalar: i.e.
30$2*(1 \hbox{ month and } 1 \hbox{ day})$ is $2$ months and $2$ days. They can
31be added together and with \helpref{wxDateTime}{wxdatetime} or
32\helpref{wxTimeSpan}{wxtimespan}, but the type of result is different for each
33case.
34
35Beware about weeks: if you specify both weeks and days, the total number of
36days added will be $7*\hbox{weeks} + \hbox{days}$! See also GetTotalDays()
37function.
38
39Equality operators are defined for wxDateSpans. Two datespans are equal if
40and only if they both give the same target date when added to {\bf every}\rtfsp
41source date. Thus wxDateSpan::Months(1) is not equal to wxDateSpan::Days(30),
42because they don't give the same date when added to 1 Feb. But
43wxDateSpan::Days(14) is equal to wxDateSpan::Weeks(2)
44
45Finally, notice that for adding hours, minutes and so on you don't need this
46class at all: \helpref{wxTimeSpan}{wxtimespan} will do the job because there
47are no subtleties associated with those (we don't support leap seconds).
48
49\wxheading{Derived from}
50
51No base class
52
53\wxheading{Include files}
54
55<wx/datetime.h>
56
57\wxheading{Library}
58
59\helpref{wxBase}{librarieslist}
60
61\wxheading{See also}
62
63\helpref{Date classes overview}{wxdatetimeoverview},\rtfsp
64\helpref{wxDateTime}{wxdatetime}
65
66
67\latexignore{\rtfignore{\wxheading{Members}}}
68
69% wxDateSpan ctor
70\membersection{wxDateSpan::wxDateSpan}\label{wxdatespanwxdatespan}
71
72\func{}{wxDateSpan}{\param{int }{years = $0$}, \param{int }{months = $0$}, \param{int }{weeks = $0$}, \param{int }{days = $0$}}
73
74Constructs the date span object for the given number of years, months, weeks
75and days. Note that the weeks and days add together if both are given.
76
77% wxDateSpan::Add
78\membersection{wxDateSpan::Add}\label{wxdatespanadd}
79
80\constfunc{wxDateSpan}{Add}{\param{const wxDateSpan\& }{other}}
81
82\func{wxDateSpan\&}{Add}{\param{const wxDateSpan\& }{other}}
83
84\func{wxDateSpan\&}{operator$+=$}{\param{const wxDateSpan\& }{other}}
85
86Returns the sum of two date spans. The first version returns a new object, the
87second and third ones modify this object in place.
88
89% wxDateSpan::Day
90\membersection{wxDateSpan::Day}\label{wxdatespanday}
91
92\func{static wxDateSpan}{Day}{\void}
93
94Returns a date span object corresponding to one day.
95
96\wxheading{See also}
97
98\helpref{Days}{wxdatespandays}
99
100% wxDateSpan::Days
101\membersection{wxDateSpan::Days}\label{wxdatespandays}
102
103\func{static wxDateSpan}{Days}{\param{int }{days}}
104
105Returns a date span object corresponding to the given number of days.
106
107\wxheading{See also}
108
109\helpref{Day}{wxdatespanday}
110
111% wxDateSpan::GetDays
112\membersection{wxDateSpan::GetDays}\label{wxdatespangetdays}
113
114\constfunc{int}{GetDays}{\void}
115
116Returns the number of days (only, that it not counting the weeks component!)
117in this date span.
118
119\wxheading{See also}
120
121\helpref{GetTotalDays}{wxdatespangettotaldays}
122
123% wxDateSpan::GetMonths
124\membersection{wxDateSpan::GetMonths}\label{wxdatespangetmonths}
125
126\constfunc{int}{GetMonths}{\void}
127
128Returns the number of the months (not counting the years) in this date span.
129
130% wxDateSpan::GetTotalDays
131\membersection{wxDateSpan::GetTotalDays}\label{wxdatespangettotaldays}
132
133\constfunc{int}{GetTotalDays}{\void}
134
135Returns the combined number of days in this date span, counting both weeks and
136days. It still doesn't take neither months nor years into the account.
137
138\wxheading{See also}
139
140\helpref{GetWeeks}{wxdatespangetweeks}, \helpref{GetDays}{wxdatespangetdays}
141
142% wxDateSpan::GetWeeks
143\membersection{wxDateSpan::GetWeeks}\label{wxdatespangetweeks}
144
145\constfunc{int}{GetWeeks}{\void}
146
147Returns the number of weeks in this date span.
148
149\wxheading{See also}
150
151\helpref{GetTotalDays}{wxdatespangettotaldays}
152
153% wxDateSpan::GetYears
154\membersection{wxDateSpan::GetYears}\label{wxdatespangetyears}
155
156\constfunc{int}{GetYears}{\void}
157
158Returns the number of years in this date span.
159
160% wxDateSpan::Month
161\membersection{wxDateSpan::Month}\label{wxdatespanmonth}
162
163\func{static wxDateSpan}{Month}{\void}
164
165Returns a date span object corresponding to one month.
166
167\wxheading{See also}
168
169\helpref{Months}{wxdatespanmonths}
170
171% wxDateSpan::Months
172\membersection{wxDateSpan::Months}\label{wxdatespanmonths}
173
174\func{static wxDateSpan}{Months}{\param{int }{mon}}
175
176Returns a date span object corresponding to the given number of months.
177
178\wxheading{See also}
179
180\helpref{Month}{wxdatespanmonth}
181
182% wxDateSpan::Multiply
183\membersection{wxDateSpan::Multiply}\label{wxdatespanmultiply}
184
185\constfunc{wxDateSpan}{Multiply}{\param{int }{factor}}
186
187\func{wxDateSpan\&}{Multiply}{\param{int }{factor}}
188
189\func{wxDateSpan\&}{operator$*=$}{\param{int }{factor}}
190
191Returns the product of the date span by the specified {\it factor}. The
192product is computed by multiplying each of the components by the factor.
193
194The first version returns a new object, the second and third ones modify this
195object in place.
196
197% wxDateSpan::Negate
198\membersection{wxDateSpan::Negate}\label{wxdatespannegate}
199
200\constfunc{wxDateSpan}{Negate}{\void}
201
202Returns the date span with the opposite sign.
203
204\wxheading{See also}
205
206\helpref{Neg}{wxdatespanneg}
207
208% wxDateSpan::Neg
209\membersection{wxDateSpan::Neg}\label{wxdatespanneg}
210
211\func{wxDateSpan\&}{Neg}{\void}
212
213\func{wxDateSpan\&}{operator$-$}{\void}
214
215Changes the sign of this date span.
216
217\wxheading{See also}
218
219\helpref{Negate}{wxdatespannegate}
220
221% wxDateSpan::SetDays
222\membersection{wxDateSpan::SetDays}\label{wxdatespansetdays}
223
224\func{wxDateSpan\&}{SetDays}{\param{int }{n}}
225
226Sets the number of days (without modifying any other components) in this date
227span.
228
229% wxDateSpan::SetYears
230\membersection{wxDateSpan::SetYears}\label{wxdatespansetyears}
231
232\func{wxDateSpan\&}{SetYears}{\param{int }{n}}
233
234Sets the number of years (without modifying any other components) in this date
235span.
236
237% wxDateSpan::SetMonths
238\membersection{wxDateSpan::SetMonths}\label{wxdatespansetmonths}
239
240\func{wxDateSpan\&}{SetMonths}{\param{int }{n}}
241
242Sets the number of months (without modifying any other components) in this
243date span.
244
245% wxDateSpan::SetWeeks
246\membersection{wxDateSpan::SetWeeks}\label{wxdatespansetweeks}
247
248\func{wxDateSpan\&}{SetWeeks}{\param{int }{n}}
249
250Sets the number of weeks (without modifying any other components) in this date
251span.
252
253% wxDateSpan::Subtract
254\membersection{wxDateSpan::Subtract}\label{wxdatespansubtract}
255
256\constfunc{wxDateSpan}{Subtract}{\param{const wxDateSpan\& }{other}}
257
258\func{wxDateSpan\&}{Subtract}{\param{const wxDateSpan\& }{other}}
259
260\func{wxDateSpan\&}{operator$+=$}{\param{const wxDateSpan\& }{other}}
261
262Returns the difference of two date spans. The first version returns a new
263object, the second and third ones modify this object in place.
264
265% wxDateSpan::Week
266\membersection{wxDateSpan::Week}\label{wxdatespanweek}
267
268\func{static wxDateSpan}{Week}{\void}
269
270Returns a date span object corresponding to one week.
271
272\wxheading{See also}
273
274\helpref{Weeks}{wxdatespanweeks}
275
276% wxDateSpan::Weeks
277\membersection{wxDateSpan::Weeks}\label{wxdatespanweeks}
278
279\func{static wxDateSpan}{Weeks}{\param{int }{weeks}}
280
281Returns a date span object corresponding to the given number of weeks.
282
283\wxheading{See also}
284
285\helpref{Week}{wxdatespanweek}
286
287% wxDateSpan::Year
288\membersection{wxDateSpan::Year}\label{wxdatespanyear}
289
290\func{static wxDateSpan}{Year}{\void}
291
292Returns a date span object corresponding to one year.
293
294\wxheading{See also}
295
296\helpref{Years}{wxdatespanyears}
297
298% wxDateSpan::Years
299\membersection{wxDateSpan::Years}\label{wxdatespanyears}
300
301\func{static wxDateSpan}{Years}{\param{int }{years}}
302
303Returns a date span object corresponding to the given number of years.
304
305\wxheading{See also}
306
307\helpref{Year}{wxdatespanyear}
308
309% wxDateSpan::operator==
310\membersection{wxDateSpan::operator$==$}\label{wxdatespanoperatorequal}
311
312\constfunc{bool}{operator$==$}{\param{wxDateSpan\&}{ other}}
313
314Returns {\tt true} if this date span is equal to the other one. Two date spans
315are considered equal if and only if they have the same number of years and
316months and the same total number of days (counting both days and weeks).
317
318% wxDateSpan::operator!=
319\membersection{wxDateSpan::operator$!=$}\label{wxdatespanoperatornotequal}
320
321\constfunc{bool}{operator$!=$}{\param{wxDateSpan\&}{ other}}
322
323Returns {\tt true} if this date span is different from the other one.
324
325\wxheading{See also}
326
327\helpref{operator==}{wxdatespanoperatorequal}
328