1 | <?xml version="1.0" encoding="utf-8"?> |
---|
2 | <!DOCTYPE library PUBLIC "-//Boost//DTD BoostBook XML V1.0//EN" |
---|
3 | "../../../tools/boostbook/dtd/boostbook.dtd"> |
---|
4 | |
---|
5 | <!-- Copyright (c) 2001-2005 CrystalClear Software, Inc. |
---|
6 | Subject to the Boost Software License, Version 1.0. |
---|
7 | (See accompanying file LICENSE-1.0 or http://www.boost.org/LICENSE-1.0) |
---|
8 | --> |
---|
9 | |
---|
10 | <section id="date_time.gregorian.date_class"> |
---|
11 | <title>Date</title> |
---|
12 | |
---|
13 | <link linkend="date_intro">Introduction</link> -- |
---|
14 | <link linkend="date_header">Header</link> -- |
---|
15 | <link linkend="date_construction">Construction</link> -- |
---|
16 | <link linkend="date_construct_from_string">Construct from String</link> -- |
---|
17 | <link linkend="date_construct_from_clock">Construct from Clock</link> -- |
---|
18 | <link linkend="date_accessors">Accessors</link> -- |
---|
19 | <link linkend="date_convert_to_string">Convert to String</link> -- |
---|
20 | <link linkend="date_operators">Operators</link> -- |
---|
21 | <link linkend="date_tm_funcs">Struct tm Functions</link> |
---|
22 | |
---|
23 | <anchor id="date_intro" /> |
---|
24 | <bridgehead renderas="sect3">Introduction</bridgehead> |
---|
25 | <para> |
---|
26 | The class boost::gregorian::date is the primary interface for date programming. In general, |
---|
27 | the date class is immutable once constructed although it does allow assignment from another |
---|
28 | date. |
---|
29 | Techniques for creating dates include reading the |
---|
30 | <link linkend="date_construct_from_clock">current date from the clock</link>, |
---|
31 | using <link linkend="date_time.gregorian.date_iterators">date iterators</link>, and |
---|
32 | <link linkend="date_time.gregorian.date_algorithms">date algorithms or generators</link>. |
---|
33 | </para> |
---|
34 | |
---|
35 | <para> |
---|
36 | Internally boost::gregorian::date is stored as a 32 bit integer type. The class is specifically |
---|
37 | designed to NOT contain virtual functions. This design allows for efficient |
---|
38 | calculation and memory usage with large collections of dates. |
---|
39 | </para> |
---|
40 | |
---|
41 | <para> |
---|
42 | The construction of a date ensures validates all input such that it is not possible to |
---|
43 | construct and 'invalid' date. That is 2001-Feb-29 cannot be constructed as a date. |
---|
44 | Various exceptions derived from std::out_of_range are thrown to indicate which aspect |
---|
45 | of the date input is invalid. Note that the |
---|
46 | special value not-a-date-time can be used as 'invalid' or 'null' date if so desired. |
---|
47 | </para> |
---|
48 | |
---|
49 | <anchor id="date_header" /> |
---|
50 | <bridgehead renderas="sect3">Header</bridgehead> |
---|
51 | <para> |
---|
52 | <programlisting>#include "boost/date_time/gregorian/gregorian.hpp" //include all types plus i/o |
---|
53 | or |
---|
54 | #include "boost/date_time/gregorian/gregorian_types.hpp" //no i/o just types</programlisting> |
---|
55 | </para> |
---|
56 | |
---|
57 | <anchor id="date_construction" /> |
---|
58 | <bridgehead renderas="sect3">Construction</bridgehead> |
---|
59 | <informaltable frame="all"> |
---|
60 | <tgroup cols="2"> |
---|
61 | <thead> |
---|
62 | <row> |
---|
63 | <entry valign="top" morerows="1">Syntax</entry> |
---|
64 | <entry>Description</entry> |
---|
65 | </row> |
---|
66 | <row> |
---|
67 | <entry>Example</entry> |
---|
68 | </row> |
---|
69 | </thead> |
---|
70 | <tbody> |
---|
71 | <row> |
---|
72 | <entry valign="top" morerows="1"><screen>date(greg_year, greg_month, greg_day)</screen></entry> |
---|
73 | <entry>Construct from parts of date. Throws bad_year, bad_day_of_month, or bad_day_month (derivatives of std::out_of_range) if the year, month or day are out of range.</entry> |
---|
74 | </row> |
---|
75 | <row> |
---|
76 | <entry><screen>date d(2002,Jan,10);</screen></entry> |
---|
77 | </row> |
---|
78 | |
---|
79 | <row> |
---|
80 | <entry valign="top" morerows="1"><screen>date(date d)</screen></entry> |
---|
81 | <entry>Copy constructor</entry> |
---|
82 | </row> |
---|
83 | <row> |
---|
84 | <entry><screen>date d1(d);</screen></entry> |
---|
85 | </row> |
---|
86 | |
---|
87 | <row> |
---|
88 | <entry valign="top" morerows="1"><screen>date(special_values sv)</screen></entry> |
---|
89 | <entry>Constructor for infinities, not-a-date-time, max_date_time, and min_date_time</entry> |
---|
90 | </row> |
---|
91 | <row> |
---|
92 | <entry><screen>date d1(neg_infin); |
---|
93 | date d2(pos_infin); |
---|
94 | date d3(not_a_date_time); |
---|
95 | date d4(max_date_time); |
---|
96 | date d5(min_date_time);</screen></entry> |
---|
97 | </row> |
---|
98 | |
---|
99 | <row> |
---|
100 | <entry valign="top" morerows="1"><screen>date()</screen></entry> |
---|
101 | <entry>Default constructor. Creates a date object initialized to not_a_date_time. NOTE: this constructor can be disabled by defining DATE_TIME_NO_DEFAULT_CONSTRUCTOR (see compiler_config.hpp)</entry> |
---|
102 | </row> |
---|
103 | <row> |
---|
104 | <entry><screen>date d; // d => not_a_date_time</screen></entry> |
---|
105 | </row> |
---|
106 | </tbody> |
---|
107 | </tgroup> |
---|
108 | </informaltable> |
---|
109 | |
---|
110 | <anchor id="date_construct_from_string" /> |
---|
111 | <bridgehead renderas="sect3">Construct from String</bridgehead> |
---|
112 | <informaltable frame="all"> |
---|
113 | <tgroup cols="2"> |
---|
114 | <thead> |
---|
115 | <row> |
---|
116 | <entry valign="top" morerows="1">Syntax</entry> |
---|
117 | <entry>Description</entry> |
---|
118 | </row> |
---|
119 | <row> |
---|
120 | <entry>Example</entry> |
---|
121 | </row> |
---|
122 | </thead> |
---|
123 | <tbody> |
---|
124 | <row> |
---|
125 | <entry valign="top" morerows="1"><screen>date from_string(std::string)</screen></entry> |
---|
126 | <entry>From delimited date string where with order year-month-day eg: 2002-1-25</entry> |
---|
127 | </row> |
---|
128 | <row> |
---|
129 | <entry><screen>std::string ds("2002/1/25"); |
---|
130 | date d(from_string(ds));</screen></entry> |
---|
131 | </row> |
---|
132 | |
---|
133 | <row> |
---|
134 | <entry valign="top" morerows="1"><screen>date from_undelimited_string(std::string)</screen></entry> |
---|
135 | <entry>From iso type date string where with order year-month-day eg: 20020125</entry> |
---|
136 | </row> |
---|
137 | <row> |
---|
138 | <entry><screen>std::string ds("20020125"); |
---|
139 | date d(from_undelimited_string(ds));</screen></entry> |
---|
140 | </row> |
---|
141 | </tbody> |
---|
142 | </tgroup> |
---|
143 | </informaltable> |
---|
144 | |
---|
145 | <anchor id="date_construct_from_clock" /> |
---|
146 | <bridgehead renderas="sect3">Construct from Clock</bridgehead> |
---|
147 | <informaltable frame="all"> |
---|
148 | <tgroup cols="2"> |
---|
149 | <thead> |
---|
150 | <row> |
---|
151 | <entry valign="top" morerows="1">Syntax</entry> |
---|
152 | <entry>Description</entry> |
---|
153 | </row> |
---|
154 | <row> |
---|
155 | <entry>Example</entry> |
---|
156 | </row> |
---|
157 | </thead> |
---|
158 | <tbody> |
---|
159 | <row> |
---|
160 | <entry valign="top" morerows="1"><screen>day_clock::local_day()</screen></entry> |
---|
161 | <entry>Get the local day based on the time zone settings of the computer.</entry> |
---|
162 | </row> |
---|
163 | <row> |
---|
164 | <entry><screen>date d(day_clock::local_day());</screen></entry> |
---|
165 | </row> |
---|
166 | |
---|
167 | <row> |
---|
168 | <entry valign="top" morerows="1"><screen>day_clock::universal_day()</screen></entry> |
---|
169 | <entry>Get the UTC day.</entry> |
---|
170 | </row> |
---|
171 | <row> |
---|
172 | <entry><screen>date d(day_clock::universal_day());</screen></entry> |
---|
173 | </row> |
---|
174 | </tbody> |
---|
175 | </tgroup> |
---|
176 | </informaltable> |
---|
177 | |
---|
178 | <anchor id="date_accessors" /> |
---|
179 | <bridgehead renderas="sect3">Accessors</bridgehead> |
---|
180 | <informaltable frame="all"> |
---|
181 | <tgroup cols="2"> |
---|
182 | <thead> |
---|
183 | <row> |
---|
184 | <entry valign="top" morerows="1">Syntax</entry> |
---|
185 | <entry>Description</entry> |
---|
186 | </row> |
---|
187 | <row> |
---|
188 | <entry>Example</entry> |
---|
189 | </row> |
---|
190 | </thead> |
---|
191 | <tbody> |
---|
192 | <row> |
---|
193 | <entry valign="top" morerows="1"><screen>greg_year year() const</screen></entry> |
---|
194 | <entry>Get the year part of the date.</entry> |
---|
195 | </row> |
---|
196 | <row> |
---|
197 | <entry><screen>date d(2002,Jan,10); |
---|
198 | d.year(); // --> 2002</screen></entry> |
---|
199 | </row> |
---|
200 | |
---|
201 | <row> |
---|
202 | <entry valign="top" morerows="1"><screen>greg_month month() const</screen></entry> |
---|
203 | <entry>Get the month part of the date.</entry> |
---|
204 | </row> |
---|
205 | <row> |
---|
206 | <entry><screen>date d(2002,Jan,10); |
---|
207 | d.month(); // --> 1</screen></entry> |
---|
208 | </row> |
---|
209 | |
---|
210 | <row> |
---|
211 | <entry valign="top" morerows="1"><screen>greg_day day() const</screen></entry> |
---|
212 | <entry> Get the day part of the date.</entry> |
---|
213 | </row> |
---|
214 | <row> |
---|
215 | <entry><screen>date d(2002,Jan,10); |
---|
216 | d.day(); // --> 10</screen></entry> |
---|
217 | </row> |
---|
218 | |
---|
219 | <row> |
---|
220 | <entry valign="top" morerows="1"><screen>greg_ymd year_month_day() const</screen></entry> |
---|
221 | <entry>Return a year_month_day struct. More efficient when all 3 parts of the date are needed.</entry> |
---|
222 | </row> |
---|
223 | <row> |
---|
224 | <entry><screen>date d(2002,Jan,10); |
---|
225 | date::ymd_type ymd = d.year_month_day(); |
---|
226 | // ymd.year --> 2002, |
---|
227 | // ymd.month --> 1, |
---|
228 | // ymd.day --> 10</screen></entry> |
---|
229 | </row> |
---|
230 | |
---|
231 | <row> |
---|
232 | <entry valign="top" morerows="1"><screen>greg_day_of_week day_of_week() const</screen></entry> |
---|
233 | <entry>Get the day of the week (eg: Sunday, Monday, etc.</entry> |
---|
234 | </row> |
---|
235 | <row> |
---|
236 | <entry><screen>date d(2002,Jan,10); |
---|
237 | d.day(); // --> Thursday</screen></entry> |
---|
238 | </row> |
---|
239 | |
---|
240 | <row> |
---|
241 | <entry valign="top" morerows="1"><screen>greg_day_of_year day_of_year() const</screen></entry> |
---|
242 | <entry>Get the day of the year. Number from 1 to 366 </entry> |
---|
243 | </row> |
---|
244 | <row> |
---|
245 | <entry><screen>date d(2000,Jan,10); |
---|
246 | d.day_of_year(); // --> 10</screen></entry> |
---|
247 | </row> |
---|
248 | |
---|
249 | <row> |
---|
250 | <entry valign="top" morerows="1"><screen>date end_of_month() const</screen></entry> |
---|
251 | <entry>Returns a <code>date</code> object set to the last day of the calling objects current month.</entry> |
---|
252 | </row> |
---|
253 | <row> |
---|
254 | <entry><screen>date d(2000,Jan,10); |
---|
255 | d.day_of_year(); // --> 2000-Jan-31</screen></entry> |
---|
256 | </row> |
---|
257 | |
---|
258 | <row> |
---|
259 | <entry valign="top" morerows="1"><screen>bool is_infinity() const</screen></entry> |
---|
260 | <entry>Returns true if date is either positive or negative infinity</entry> |
---|
261 | </row> |
---|
262 | <row> |
---|
263 | <entry><screen>date d(pos_infin); |
---|
264 | d.is_infinity(); // --> true</screen></entry> |
---|
265 | </row> |
---|
266 | |
---|
267 | <row> |
---|
268 | <entry valign="top" morerows="1"><screen>bool is_neg_infinity() const</screen></entry> |
---|
269 | <entry>Returns true if date is negative infinity</entry> |
---|
270 | </row> |
---|
271 | <row> |
---|
272 | <entry><screen>date d(neg_infin); |
---|
273 | d.is_neg_infinity(); // --> true</screen></entry> |
---|
274 | </row> |
---|
275 | |
---|
276 | <row> |
---|
277 | <entry valign="top" morerows="1"><screen>bool is_pos_infinity() const</screen></entry> |
---|
278 | <entry>Returns true if date is positive infinity</entry> |
---|
279 | </row> |
---|
280 | <row> |
---|
281 | <entry><screen>date d(neg_infin); |
---|
282 | d.is_pos_infinity(); // --> true</screen></entry> |
---|
283 | </row> |
---|
284 | |
---|
285 | <row> |
---|
286 | <entry valign="top" morerows="1"><screen>bool is_not_a_date() const</screen></entry> |
---|
287 | <entry>Returns true if value is not a date</entry> |
---|
288 | </row> |
---|
289 | <row> |
---|
290 | <entry><screen>date d(not_a_date_time); |
---|
291 | d.is_not_a_date(); // --> true</screen></entry> |
---|
292 | </row> |
---|
293 | |
---|
294 | <row> |
---|
295 | <entry valign="top" morerows="1"><screen>bool is_special() const</screen></entry> |
---|
296 | <entry>Returns true if date is any <code>special_value</code></entry> |
---|
297 | </row> |
---|
298 | <row> |
---|
299 | <entry><screen>date d(pos_infin); |
---|
300 | date d2(not_a_date_time); |
---|
301 | date d3(2005,Mar,1); |
---|
302 | d.is_special(); // --> true |
---|
303 | d2.is_special(); // --> true |
---|
304 | d3.is_special(); // --> false</screen></entry> |
---|
305 | </row> |
---|
306 | |
---|
307 | <row> |
---|
308 | <entry valign="top" morerows="1"><screen>special_value as_special() const</screen></entry> |
---|
309 | <entry>Returns represented <code>special_value</code> or <code>not_special</code> if the represented date is a normal date.</entry> |
---|
310 | </row> |
---|
311 | <row> |
---|
312 | <entry><screen></screen></entry> |
---|
313 | </row> |
---|
314 | |
---|
315 | <row> |
---|
316 | <entry valign="top" morerows="1"><screen>long modjulian_day() const</screen></entry> |
---|
317 | <entry>Returns the modified julian day for the date.</entry> |
---|
318 | </row> |
---|
319 | <row> |
---|
320 | <entry><screen></screen></entry> |
---|
321 | </row> |
---|
322 | |
---|
323 | <row> |
---|
324 | <entry valign="top" morerows="1"><screen>long julian_day() const</screen></entry> |
---|
325 | <entry>Returns the julian day for the date.</entry> |
---|
326 | </row> |
---|
327 | <row> |
---|
328 | <entry><screen></screen></entry> |
---|
329 | </row> |
---|
330 | |
---|
331 | <row> |
---|
332 | <entry valign="top" morerows="1"><screen>int week_number() const</screen></entry> |
---|
333 | <entry>Returns the ISO 8601 week number for the date.</entry> |
---|
334 | </row> |
---|
335 | <row> |
---|
336 | <entry><screen></screen></entry> |
---|
337 | </row> |
---|
338 | <row> |
---|
339 | <entry valign="top" morerows="1"><screen>date end_of_month_day() const</screen></entry> |
---|
340 | <entry>Returns the last day of the month for the date.</entry> |
---|
341 | </row> |
---|
342 | <row> |
---|
343 | <entry><screen>date d(2000,Feb,1); |
---|
344 | //gets Feb 28 -- 2000 was leap year |
---|
345 | date eom = d.end_of_month_day();</screen></entry> |
---|
346 | </row> |
---|
347 | </tbody> |
---|
348 | </tgroup> |
---|
349 | </informaltable> |
---|
350 | |
---|
351 | <anchor id="date_convert_to_string" /> |
---|
352 | <bridgehead renderas="sect3">Convert to String</bridgehead> |
---|
353 | <informaltable frame="all"> |
---|
354 | <tgroup cols="2"> |
---|
355 | <thead> |
---|
356 | <row> |
---|
357 | <entry valign="top" morerows="1">Syntax</entry> |
---|
358 | <entry>Description</entry> |
---|
359 | </row> |
---|
360 | <row> |
---|
361 | <entry>Example</entry> |
---|
362 | </row> |
---|
363 | </thead> |
---|
364 | <tbody> |
---|
365 | <row> |
---|
366 | <entry valign="top" morerows="1"><screen>std::string to_simple_string(date d)</screen></entry> |
---|
367 | <entry>To <code>YYYY-mmm-DD</code> string where <code>mmm</code> 3 char month name.</entry> |
---|
368 | </row> |
---|
369 | <row> |
---|
370 | <entry><screen>"2002-Jan-01"</screen></entry> |
---|
371 | </row> |
---|
372 | |
---|
373 | <row> |
---|
374 | <entry valign="top" morerows="1"><screen>std::string to_iso_string(date d)</screen></entry> |
---|
375 | <entry>To <code>YYYYMMDD</code> where all components are integers.</entry> |
---|
376 | </row> |
---|
377 | <row> |
---|
378 | <entry><screen>"20020131"</screen></entry> |
---|
379 | </row> |
---|
380 | |
---|
381 | <row> |
---|
382 | <entry valign="top" morerows="1"><screen>std::string to_iso_extended_string(date d)</screen></entry> |
---|
383 | <entry> To <code>YYYY-MM-DD</code> where all components are integers.</entry> |
---|
384 | </row> |
---|
385 | <row> |
---|
386 | <entry><screen>"2002-01-31"</screen></entry> |
---|
387 | </row> |
---|
388 | </tbody> |
---|
389 | </tgroup> |
---|
390 | </informaltable> |
---|
391 | |
---|
392 | <anchor id="date_operators" /> |
---|
393 | <bridgehead renderas="sect3">Operators</bridgehead> |
---|
394 | <informaltable frame="all"> |
---|
395 | <tgroup cols="2"> |
---|
396 | <thead> |
---|
397 | <row> |
---|
398 | <entry valign="top" morerows="1">Syntax</entry> |
---|
399 | <entry>Description</entry> |
---|
400 | </row> |
---|
401 | <row> |
---|
402 | <entry>Example</entry> |
---|
403 | </row> |
---|
404 | </thead> |
---|
405 | <tbody> |
---|
406 | <row> |
---|
407 | <entry valign="top" morerows="1"><screen>operator<<</screen></entry> |
---|
408 | <entry>Stream output operator</entry> |
---|
409 | </row> |
---|
410 | <row> |
---|
411 | <entry><screen>date d(2002,Jan,1); |
---|
412 | std::cout << d << std::endl;</screen> |
---|
413 | </entry> |
---|
414 | </row> |
---|
415 | |
---|
416 | <row> |
---|
417 | <entry valign="top" morerows="1"><screen>operator>></screen></entry> |
---|
418 | <entry>Stream input operator. <emphasis role="strong">Note:</emphasis> As of version 1.33, streaming operations have been greatly improved. See <link linkend="date_time.date_time_io">Date Time IO System</link> for details on exceptions and error conditions.</entry> |
---|
419 | </row> |
---|
420 | <row> |
---|
421 | <entry><screen>date d(not_a_date_time); |
---|
422 | stringstream ss("2002-Jan-01"); |
---|
423 | ss >> d;</screen> |
---|
424 | </entry> |
---|
425 | </row> |
---|
426 | |
---|
427 | <row> |
---|
428 | <entry valign="top" morerows="1"><screen>operator==, operator!=, |
---|
429 | operator>, operator<, |
---|
430 | operator>=, operator<=</screen></entry> |
---|
431 | <entry>A full complement of comparison operators</entry> |
---|
432 | </row> |
---|
433 | <row> |
---|
434 | <entry><screen>d1 == d2, etc</screen></entry> |
---|
435 | </row> |
---|
436 | |
---|
437 | <row> |
---|
438 | <entry valign="top" morerows="1"><screen>date operator+(date_duration) const</screen></entry> |
---|
439 | <entry>Return a date adding a day offset</entry> |
---|
440 | </row> |
---|
441 | <row> |
---|
442 | <entry><screen>date d(2002,Jan,1); |
---|
443 | date_duration dd(1); |
---|
444 | date d2 = d + dd;</screen> |
---|
445 | </entry> |
---|
446 | </row> |
---|
447 | |
---|
448 | <row> |
---|
449 | <entry valign="top" morerows="1"><screen>date operator-(date_duration) const</screen></entry> |
---|
450 | <entry>Return a date by adding a day offset</entry> |
---|
451 | </row> |
---|
452 | <row> |
---|
453 | <entry><screen>date d(2002,Jan,1); |
---|
454 | date_duration dd(1); |
---|
455 | date d2 = d - dd;</screen> |
---|
456 | </entry> |
---|
457 | </row> |
---|
458 | |
---|
459 | <row> |
---|
460 | <entry valign="top" morerows="1"><screen>date_duration operator-(date) const</screen></entry> |
---|
461 | <entry>Return a date_duration by subtracting two dates</entry> |
---|
462 | </row> |
---|
463 | <row> |
---|
464 | <entry><screen>date d1(2002,Jan,1); |
---|
465 | date d2(2002,Jan,2); |
---|
466 | date_duration dd = d2-d1;</screen> |
---|
467 | </entry> |
---|
468 | </row> |
---|
469 | </tbody> |
---|
470 | </tgroup> |
---|
471 | </informaltable> |
---|
472 | |
---|
473 | <anchor id="date_tm_funcs" /> |
---|
474 | <bridgehead renderas="sect3">Struct tm Functions</bridgehead> |
---|
475 | <para>Functions for converting a <code>date</code> object to, and from, a <code>tm</code> struct are provided.</para> |
---|
476 | <informaltable frame="all"> |
---|
477 | <tgroup cols="2"> |
---|
478 | <thead> |
---|
479 | <row> |
---|
480 | <entry valign="top" morerows="1">Syntax</entry> |
---|
481 | <entry>Description</entry> |
---|
482 | </row> |
---|
483 | <row> |
---|
484 | <entry>Example</entry> |
---|
485 | </row> |
---|
486 | </thead> |
---|
487 | <tbody> |
---|
488 | <row> |
---|
489 | <entry valign="top" morerows="1"><screen>tm to_tm(date)</screen></entry> |
---|
490 | <entry>A function for converting a <code>date</code> object to a <code>tm</code> struct. The fields: <code>tm_hour</code>, <code>tm_min</code>, and <code>tm_sec</code> are set to zero. The <code>tm_isdst</code> field is set to -1.</entry> |
---|
491 | </row> |
---|
492 | <row> |
---|
493 | <entry><screen>date d(2005,Jan,1); |
---|
494 | tm d_tm = to_tm(d); |
---|
495 | /* tm_year => 105 |
---|
496 | tm_mon => 0 |
---|
497 | tm_mday => 1 |
---|
498 | tm_wday => 6 (Saturday) |
---|
499 | tm_yday => 0 |
---|
500 | tm_hour => 0 |
---|
501 | tm_min => 0 |
---|
502 | tm_sec => 0 |
---|
503 | tm_isddst => -1 */</screen> |
---|
504 | </entry> |
---|
505 | </row> |
---|
506 | |
---|
507 | <row> |
---|
508 | <entry valign="top" morerows="1"><screen>date date_from_tm(tm datetm)</screen></entry> |
---|
509 | <entry>A function for converting a <code>tm</code> struct to a <code>date</code> object. The fields: <code>tm_wday </code>, <code>tm_yday </code>, <code>tm_hour</code>, <code>tm_min</code>, <code>tm_sec</code>, and <code>tm_isdst</code> are ignored.</entry> |
---|
510 | </row> |
---|
511 | <row> |
---|
512 | <entry><screen>tm d_tm; |
---|
513 | d_tm.tm_year = 105; |
---|
514 | d_tm.tm_mon = 0; |
---|
515 | d_tm.tm_mday = 1; |
---|
516 | date d = date_from_tm(d_tm); |
---|
517 | // d => 2005-Jan-01</screen> |
---|
518 | </entry> |
---|
519 | </row> |
---|
520 | </tbody> |
---|
521 | </tgroup> |
---|
522 | </informaltable> |
---|
523 | |
---|
524 | </section> |
---|