Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: downloads/boost_1_33_1/libs/date_time/xmldoc/date_class.xml @ 12

Last change on this file since 12 was 12, checked in by landauf, 17 years ago

added boost

File size: 16.5 KB
Line 
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
53or
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);
93date d2(pos_infin);
94date d3(not_a_date_time);
95date d4(max_date_time);
96date 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 =&gt; 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");
130date 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");
139date 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);
198d.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);
207d.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);
216d.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);
225date::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);
237d.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);
246d.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);
255d.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);
264d.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);
273d.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);
282d.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);
291d.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);
300date d2(not_a_date_time);
301date d3(2005,Mar,1);
302d.is_special(); // --> true
303d2.is_special(); // --> true
304d3.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
345date 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&lt;&lt;</screen></entry>
408          <entry>Stream output operator</entry>
409        </row>
410        <row>
411          <entry><screen>date d(2002,Jan,1);
412std::cout &lt;&lt; d &lt;&lt; std::endl;</screen>
413          </entry>
414        </row>
415
416        <row>
417          <entry valign="top" morerows="1"><screen>operator&gt;&gt;</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);
422stringstream ss("2002-Jan-01");
423ss &gt;&gt; d;</screen>
424          </entry>
425        </row>
426
427        <row>
428          <entry valign="top" morerows="1"><screen>operator==, operator!=,
429operator>, operator&lt;,
430operator>=, operator&lt;=</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);
443date_duration dd(1);
444date 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);
454date_duration dd(1);
455date 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);
465date d2(2002,Jan,2);
466date_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);
494tm 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;
513d_tm.tm_year = 105;
514d_tm.tm_mon  = 0;
515d_tm.tm_mday = 1;
516date 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>
Note: See TracBrowser for help on using the repository browser.