time_formatters.hpp
来自「CGAL is a collaborative effort of severa」· HPP 代码 · 共 414 行
HPP
414 行
#ifndef POSIXTIME_FORMATTERS_HPP___#define POSIXTIME_FORMATTERS_HPP___/* Copyright (c) 2002-2004 CrystalClear Software, Inc. * Use, modification and distribution is subject to the * Boost Software License, Version 1.0. (See accompanying * file LICENSE-1.0 or http://www.boost.org/LICENSE-1.0) * Author: Jeff Garland, Bart Garst * $Date: 2004/11/20 10:36:43 $ */#include "boost/date_time/gregorian/gregorian.hpp"#include "boost/date_time/compiler_config.hpp"#include "boost/date_time/iso_format.hpp"#include "boost/date_time/date_format_simple.hpp"#include "boost/date_time/posix_time/posix_time_types.hpp"#include "boost/date_time/time_formatting_streams.hpp"#include "boost/date_time/time_parsing.hpp"/* NOTE: The "to_*_string" code for older compilers, ones that define * BOOST_DATE_TIME_INCLUDE_LIMITED_HEADERS, is located in * formatters_limited.hpp */namespace boost {namespace posix_time { // template function called by wrapper functions: // to_*_string(time_duration) & to_*_wstring(time_duration) template<class charT> inline std::basic_string<charT> to_simple_string_type(time_duration td) { std::basic_ostringstream<charT> ss; if(td.is_special()) { /* simply using 'ss << td.get_rep()' won't work on compilers * that don't support locales. This way does. */ // switch copied from date_names_put.hpp switch(td.get_rep().as_special()) { case not_a_date_time: //ss << "not-a-number"; ss << "not-a-date-time"; break; case pos_infin: ss << "+infinity"; break; case neg_infin: ss << "-infinity"; break; default: ss << ""; } } else { charT fill_char = '0'; if(td.is_negative()) { ss << '-'; } ss << std::setw(2) << std::setfill(fill_char) << date_time::absolute_value(td.hours()) << ":"; ss << std::setw(2) << std::setfill(fill_char) << date_time::absolute_value(td.minutes()) << ":"; ss << std::setw(2) << std::setfill(fill_char) << date_time::absolute_value(td.seconds()); //TODO the following is totally non-generic, yelling FIXME#if (defined(BOOST_MSVC) && (_MSC_VER <= 1200)) // 1200 == VC++ 6.0 boost::int64_t frac_sec = date_time::absolute_value(td.fractional_seconds()); // JDG [7/6/02 VC++ compatibility] charT buff[32]; _i64toa(frac_sec, buff, 10);#else time_duration::fractional_seconds_type frac_sec = date_time::absolute_value(td.fractional_seconds());#endif if (frac_sec != 0) { ss << "." << std::setw(time_duration::num_fractional_digits()) << std::setfill(fill_char) // JDG [7/6/02 VC++ compatibility]#if (defined(BOOST_MSVC) && (_MSC_VER <= 1200)) // 1200 == VC++ 6.0 << buff;#else << frac_sec;#endif } }// else return ss.str(); } //! Time duration to string -hh::mm::ss.fffffff. Example: 10:09:03.0123456 /*!\ingroup time_format */ inline std::string to_simple_string(time_duration td) { return to_simple_string_type<char>(td); } // template function called by wrapper functions: // to_*_string(time_duration) & to_*_wstring(time_duration) template<class charT> inline std::basic_string<charT> to_iso_string_type(time_duration td) { std::basic_ostringstream<charT> ss; if(td.is_special()) { /* simply using 'ss << td.get_rep()' won't work on compilers * that don't support locales. This way does. */ // switch copied from date_names_put.hpp switch(td.get_rep().as_special()) { case not_a_date_time: //ss << "not-a-number"; ss << "not-a-date-time"; break; case pos_infin: ss << "+infinity"; break; case neg_infin: ss << "-infinity"; break; default: ss << ""; } } else { charT fill_char = '0'; if(td.is_negative()) { ss << '-'; } ss << std::setw(2) << std::setfill(fill_char) << date_time::absolute_value(td.hours()); ss << std::setw(2) << std::setfill(fill_char) << date_time::absolute_value(td.minutes()); ss << std::setw(2) << std::setfill(fill_char) << date_time::absolute_value(td.seconds()); //TODO the following is totally non-generic, yelling FIXME#if (defined(BOOST_MSVC) && (_MSC_VER <= 1200)) // 1200 == VC++ 6.0 boost::int64_t frac_sec = date_time::absolute_value(td.fractional_seconds()); // JDG [7/6/02 VC++ compatibility] charT buff[32]; _i64toa(frac_sec, buff, 10);#else time_duration::fractional_seconds_type frac_sec = date_time::absolute_value(td.fractional_seconds());#endif if (frac_sec != 0) { ss << "." << std::setw(time_duration::num_fractional_digits()) << std::setfill(fill_char) // JDG [7/6/02 VC++ compatibility]#if (defined(BOOST_MSVC) && (_MSC_VER <= 1200)) // 1200 == VC++ 6.0 << buff;#else << frac_sec;#endif } }// else return ss.str(); } //! Time duration in iso format -hhmmss,fffffff Example: 10:09:03,0123456 /*!\ingroup time_format */ inline std::string to_iso_string(time_duration td){ return to_iso_string_type<char>(td); } //! Time to simple format CCYY-mmm-dd hh:mm:ss.fffffff /*!\ingroup time_format */ template<class charT> inline std::basic_string<charT> to_simple_string_type(ptime t) { // can't use this w/gcc295, no to_simple_string_type<>(td) available std::basic_string<charT> ts = gregorian::to_simple_string_type<charT>(t.date());// + " "; if(!t.time_of_day().is_special()) { charT space = ' '; return ts + space + to_simple_string_type<charT>(t.time_of_day()); } else { return ts; } } inline std::string to_simple_string(ptime t){ return to_simple_string_type<char>(t); } // function called by wrapper functions to_*_string(time_period) // & to_*_wstring(time_period) template<class charT> inline std::basic_string<charT> to_simple_string_type(time_period tp) { charT beg = '[', mid = '/', end = ']'; std::basic_string<charT> d1(to_simple_string_type<charT>(tp.begin())); std::basic_string<charT> d2(to_simple_string_type<charT>(tp.last())); return std::basic_string<charT>(beg + d1 + mid + d2 + end); } //! Convert to string of form [YYYY-mmm-DD HH:MM::SS.ffffff/YYYY-mmm-DD HH:MM::SS.fffffff] /*!\ingroup time_format */ inline std::string to_simple_string(time_period tp){ return to_simple_string_type<char>(tp); } // function called by wrapper functions to_*_string(time_period) // & to_*_wstring(time_period) template<class charT> inline std::basic_string<charT> to_iso_string_type(ptime t) { std::basic_string<charT> ts = gregorian::to_iso_string_type<charT>(t.date());// + "T"; if(!t.time_of_day().is_special()) { charT sep = 'T'; return ts + sep + to_iso_string_type<charT>(t.time_of_day()); } else { return ts; } } //! Convert iso short form YYYYMMDDTHHMMSS where T is the date-time separator /*!\ingroup time_format */ inline std::string to_iso_string(ptime t){ return to_iso_string_type<char>(t); } // function called by wrapper functions to_*_string(time_period) // & to_*_wstring(time_period) template<class charT> inline std::basic_string<charT> to_iso_extended_string_type(ptime t) { std::basic_string<charT> ts = gregorian::to_iso_extended_string_type<charT>(t.date());// + "T"; if(!t.time_of_day().is_special()) { charT sep = 'T'; return ts + sep + to_simple_string_type<charT>(t.time_of_day()); } else { return ts; } } //! Convert to form YYYY-MM-DDTHH:MM:SS where T is the date-time separator /*!\ingroup time_format */ inline std::string to_iso_extended_string(ptime t){ return to_iso_extended_string_type<char>(t); }#if !defined(BOOST_NO_STD_WSTRING) //! Time duration to wstring -hh::mm::ss.fffffff. Example: 10:09:03.0123456 /*!\ingroup time_format */ inline std::wstring to_simple_wstring(time_duration td) { return to_simple_string_type<wchar_t>(td); } //! Time duration in iso format -hhmmss,fffffff Example: 10:09:03,0123456 /*!\ingroup time_format */ inline std::wstring to_iso_wstring(time_duration td){ return to_iso_string_type<wchar_t>(td); } inline std::wstring to_simple_wstring(ptime t){ return to_simple_string_type<wchar_t>(t); } //! Convert to wstring of form [YYYY-mmm-DD HH:MM::SS.ffffff/YYYY-mmm-DD HH:MM::SS.fffffff] /*!\ingroup time_format */ inline std::wstring to_simple_wstring(time_period tp){ return to_simple_string_type<wchar_t>(tp); } //! Convert iso short form YYYYMMDDTHHMMSS where T is the date-time separator /*!\ingroup time_format */ inline std::wstring to_iso_wstring(ptime t){ return to_iso_string_type<wchar_t>(t); } //! Convert to form YYYY-MM-DDTHH:MM:SS where T is the date-time separator /*!\ingroup time_format */ inline std::wstring to_iso_extended_wstring(ptime t){ return to_iso_extended_string_type<wchar_t>(t); }#endif // BOOST_NO_STD_WSTRING /* ATTENTION: The following operator<< functions are exactly duplicated * in time_formatters_limited.hpp. Any changes here must also be made there *///The following code is removed for configurations with good std::locale support (eg: MSVC6, gcc 2.9x)#ifndef BOOST_DATE_TIME_NO_LOCALE //! ostream operator for posix_time::time_duration template <class charT, class traits> inline std::basic_ostream<charT, traits>& operator<<(std::basic_ostream<charT, traits>& os, const time_duration& td) { typedef boost::date_time::ostream_time_duration_formatter<time_duration, charT> duration_formatter; duration_formatter::duration_put(td, os); return os; } //! ostream operator for posix_time::ptime template <class charT, class traits> inline std::basic_ostream<charT, traits>& operator<<(std::basic_ostream<charT, traits>& os, const ptime& t) { typedef boost::date_time::ostream_time_formatter<ptime, charT> time_formatter; time_formatter::time_put(t, os); return os; } //! ostream operator for posix_time::time_period template <class charT, class traits> inline std::basic_ostream<charT, traits>& operator<<(std::basic_ostream<charT, traits>& os, const time_period& tp) { typedef boost::date_time::ostream_time_period_formatter<time_period, charT> period_formatter; period_formatter::period_put(tp, os); return os; }/******** input streaming ********/ template<class charT> inline std::basic_istream<charT>& operator>>(std::basic_istream<charT>& is, time_duration& td) { // need to create a std::string and parse it std::basic_string<charT> inp_s; std::stringstream out_ss; is >> inp_s; typename std::basic_string<charT>::iterator b = inp_s.begin(); // need to use both iterators because there is no requirement // for the data held by a std::basic_string<> be terminated with // any marker (such as '\0'). typename std::basic_string<charT>::iterator e = inp_s.end(); while(b != e){ out_ss << out_ss.narrow(*b, 0); ++b; } td = date_time::parse_delimited_time_duration<time_duration>(out_ss.str()); return is; } template<class charT> inline std::basic_istream<charT>& operator>>(std::basic_istream<charT>& is, ptime& pt) { gregorian::date d(not_a_date_time); time_duration td(0,0,0); is >> d >> td; pt = ptime(d, td); return is; } /** operator>> for time_period. time_period must be in * "[date time_duration/date time_duration]" format. */ template<class charT> inline std::basic_istream<charT>& operator>>(std::basic_istream<charT>& is, time_period& tp) { gregorian::date d(not_a_date_time); time_duration td(0,0,0); ptime beg(d, td); ptime end(beg); std::basic_string<charT> s; // get first date string and remove leading '[' is >> s; { std::basic_stringstream<charT> ss; ss << s.substr(s.find('[')+1); ss >> d; } // get first time_duration & second date string, remove the '/' // and split into 2 strings is >> s; { std::basic_stringstream<charT> ss; ss << s.substr(0, s.find('/')); ss >> td; } beg = ptime(d, td); { std::basic_stringstream<charT> ss; ss << s.substr(s.find('/')+1); ss >> d; } // get last time_duration and remove the trailing ']' is >> s; { std::basic_stringstream<charT> ss; ss << s.substr(0, s.find(']')); ss >> td; } end = ptime(d, td); tp = time_period(beg,end); return is; }#endif //BOOST_DATE_TIME_NO_LOCALE} } //namespace posix_time#endif
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?