1 #ifndef POSIXTIME_FORMATTERS_HPP___
2 #define POSIXTIME_FORMATTERS_HPP___
4 /* Copyright (c) 2002-2004 CrystalClear Software, Inc.
5 * Use, modification and distribution is subject to the
6 * Boost Software License, Version 1.0. (See accompanying
7 * file LICENSE_1_0.txt or http://www.boost.org/LICENSE_1_0.txt)
8 * Author: Jeff Garland, Bart Garst
12 #include "boost/date_time/gregorian/gregorian.hpp"
13 #include "boost/date_time/compiler_config.hpp"
14 #include "boost/date_time/iso_format.hpp"
15 #include "boost/date_time/date_format_simple.hpp"
16 #include "boost/date_time/posix_time/posix_time_types.hpp"
17 #include "boost/date_time/time_formatting_streams.hpp"
19 #include "boost/date_time/time_parsing.hpp"
21 /* NOTE: The "to_*_string" code for older compilers, ones that define
22 * BOOST_DATE_TIME_INCLUDE_LIMITED_HEADERS, is located in
23 * formatters_limited.hpp
28 namespace posix_time
{
30 // template function called by wrapper functions:
31 // to_*_string(time_duration) & to_*_wstring(time_duration)
33 inline std::basic_string
<charT
> to_simple_string_type(time_duration td
) {
34 std::basic_ostringstream
<charT
> ss
;
36 /* simply using 'ss << td.get_rep()' won't work on compilers
37 * that don't support locales. This way does. */
38 // switch copied from date_names_put.hpp
39 switch(td
.get_rep().as_special())
42 //ss << "not-a-number";
43 ss
<< "not-a-date-time";
56 charT fill_char
= '0';
57 if(td
.is_negative()) {
60 ss
<< std::setw(2) << std::setfill(fill_char
)
61 << date_time::absolute_value(td
.hours()) << ":";
62 ss
<< std::setw(2) << std::setfill(fill_char
)
63 << date_time::absolute_value(td
.minutes()) << ":";
64 ss
<< std::setw(2) << std::setfill(fill_char
)
65 << date_time::absolute_value(td
.seconds());
66 //TODO the following is totally non-generic, yelling FIXME
67 #if (defined(BOOST_MSVC) && (_MSC_VER < 1300))
68 boost::int64_t frac_sec
=
69 date_time::absolute_value(td
.fractional_seconds());
70 // JDG [7/6/02 VC++ compatibility]
72 _i64toa(frac_sec
, buff
, 10);
74 time_duration::fractional_seconds_type frac_sec
=
75 date_time::absolute_value(td
.fractional_seconds());
78 ss
<< "." << std::setw(time_duration::num_fractional_digits())
79 << std::setfill(fill_char
)
81 // JDG [7/6/02 VC++ compatibility]
82 #if (defined(BOOST_MSVC) && (_MSC_VER < 1300))
91 //! Time duration to string -hh::mm::ss.fffffff. Example: 10:09:03.0123456
92 /*!\ingroup time_format
94 inline std::string
to_simple_string(time_duration td
) {
95 return to_simple_string_type
<char>(td
);
99 // template function called by wrapper functions:
100 // to_*_string(time_duration) & to_*_wstring(time_duration)
101 template<class charT
>
102 inline std::basic_string
<charT
> to_iso_string_type(time_duration td
)
104 std::basic_ostringstream
<charT
> ss
;
105 if(td
.is_special()) {
106 /* simply using 'ss << td.get_rep()' won't work on compilers
107 * that don't support locales. This way does. */
108 // switch copied from date_names_put.hpp
109 switch(td
.get_rep().as_special()) {
110 case not_a_date_time
:
111 //ss << "not-a-number";
112 ss
<< "not-a-date-time";
125 charT fill_char
= '0';
126 if(td
.is_negative()) {
129 ss
<< std::setw(2) << std::setfill(fill_char
)
130 << date_time::absolute_value(td
.hours());
131 ss
<< std::setw(2) << std::setfill(fill_char
)
132 << date_time::absolute_value(td
.minutes());
133 ss
<< std::setw(2) << std::setfill(fill_char
)
134 << date_time::absolute_value(td
.seconds());
135 //TODO the following is totally non-generic, yelling FIXME
136 #if (defined(BOOST_MSVC) && (_MSC_VER < 1300))
137 boost::int64_t frac_sec
=
138 date_time::absolute_value(td
.fractional_seconds());
139 // JDG [7/6/02 VC++ compatibility]
141 _i64toa(frac_sec
, buff
, 10);
143 time_duration::fractional_seconds_type frac_sec
=
144 date_time::absolute_value(td
.fractional_seconds());
147 ss
<< "." << std::setw(time_duration::num_fractional_digits())
148 << std::setfill(fill_char
)
150 // JDG [7/6/02 VC++ compatibility]
151 #if (defined(BOOST_MSVC) && (_MSC_VER < 1300))
160 //! Time duration in iso format -hhmmss,fffffff Example: 10:09:03,0123456
161 /*!\ingroup time_format
163 inline std::string
to_iso_string(time_duration td
){
164 return to_iso_string_type
<char>(td
);
167 //! Time to simple format CCYY-mmm-dd hh:mm:ss.fffffff
168 /*!\ingroup time_format
170 template<class charT
>
171 inline std::basic_string
<charT
> to_simple_string_type(ptime t
)
173 // can't use this w/gcc295, no to_simple_string_type<>(td) available
174 std::basic_string
<charT
> ts
= gregorian::to_simple_string_type
<charT
>(t
.date());// + " ";
175 if(!t
.time_of_day().is_special()) {
177 return ts
+ space
+ to_simple_string_type
<charT
>(t
.time_of_day());
183 inline std::string
to_simple_string(ptime t
){
184 return to_simple_string_type
<char>(t
);
187 // function called by wrapper functions to_*_string(time_period)
188 // & to_*_wstring(time_period)
189 template<class charT
>
190 inline std::basic_string
<charT
> to_simple_string_type(time_period tp
)
192 charT beg
= '[', mid
= '/', end
= ']';
193 std::basic_string
<charT
> d1(to_simple_string_type
<charT
>(tp
.begin()));
194 std::basic_string
<charT
> d2(to_simple_string_type
<charT
>(tp
.last()));
195 return std::basic_string
<charT
>(beg
+ d1
+ mid
+ d2
+ end
);
197 //! Convert to string of form [YYYY-mmm-DD HH:MM::SS.ffffff/YYYY-mmm-DD HH:MM::SS.fffffff]
198 /*!\ingroup time_format
200 inline std::string
to_simple_string(time_period tp
){
201 return to_simple_string_type
<char>(tp
);
204 // function called by wrapper functions to_*_string(time_period)
205 // & to_*_wstring(time_period)
206 template<class charT
>
207 inline std::basic_string
<charT
> to_iso_string_type(ptime t
)
209 std::basic_string
<charT
> ts
= gregorian::to_iso_string_type
<charT
>(t
.date());// + "T";
210 if(!t
.time_of_day().is_special()) {
212 return ts
+ sep
+ to_iso_string_type
<charT
>(t
.time_of_day());
218 //! Convert iso short form YYYYMMDDTHHMMSS where T is the date-time separator
219 /*!\ingroup time_format
221 inline std::string
to_iso_string(ptime t
){
222 return to_iso_string_type
<char>(t
);
226 // function called by wrapper functions to_*_string(time_period)
227 // & to_*_wstring(time_period)
228 template<class charT
>
229 inline std::basic_string
<charT
> to_iso_extended_string_type(ptime t
)
231 std::basic_string
<charT
> ts
= gregorian::to_iso_extended_string_type
<charT
>(t
.date());// + "T";
232 if(!t
.time_of_day().is_special()) {
234 return ts
+ sep
+ to_simple_string_type
<charT
>(t
.time_of_day());
240 //! Convert to form YYYY-MM-DDTHH:MM:SS where T is the date-time separator
241 /*!\ingroup time_format
243 inline std::string
to_iso_extended_string(ptime t
){
244 return to_iso_extended_string_type
<char>(t
);
247 #if !defined(BOOST_NO_STD_WSTRING)
248 //! Time duration to wstring -hh::mm::ss.fffffff. Example: 10:09:03.0123456
249 /*!\ingroup time_format
251 inline std::wstring
to_simple_wstring(time_duration td
) {
252 return to_simple_string_type
<wchar_t>(td
);
254 //! Time duration in iso format -hhmmss,fffffff Example: 10:09:03,0123456
255 /*!\ingroup time_format
257 inline std::wstring
to_iso_wstring(time_duration td
){
258 return to_iso_string_type
<wchar_t>(td
);
260 inline std::wstring
to_simple_wstring(ptime t
){
261 return to_simple_string_type
<wchar_t>(t
);
263 //! Convert to wstring of form [YYYY-mmm-DD HH:MM::SS.ffffff/YYYY-mmm-DD HH:MM::SS.fffffff]
264 /*!\ingroup time_format
266 inline std::wstring
to_simple_wstring(time_period tp
){
267 return to_simple_string_type
<wchar_t>(tp
);
269 //! Convert iso short form YYYYMMDDTHHMMSS where T is the date-time separator
270 /*!\ingroup time_format
272 inline std::wstring
to_iso_wstring(ptime t
){
273 return to_iso_string_type
<wchar_t>(t
);
275 //! Convert to form YYYY-MM-DDTHH:MM:SS where T is the date-time separator
276 /*!\ingroup time_format
278 inline std::wstring
to_iso_extended_wstring(ptime t
){
279 return to_iso_extended_string_type
<wchar_t>(t
);
282 #endif // BOOST_NO_STD_WSTRING
285 } } //namespace posix_time