163 lines
		
	
	
		
			5.7 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			163 lines
		
	
	
		
			5.7 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| #ifndef GREGORIAN_FORMATTERS_HPP___
 | |
| #define GREGORIAN_FORMATTERS_HPP___
 | |
| 
 | |
| /* Copyright (c) 2002,2003 CrystalClear Software, Inc.
 | |
|  * Use, modification and distribution is subject to the 
 | |
|  * Boost Software License, Version 1.0. (See accompanying
 | |
|  * file LICENSE_1_0.txt or http://www.boost.org/LICENSE_1_0.txt)
 | |
|  * Author: Jeff Garland, Bart Garst
 | |
|  * $Date$
 | |
|  */
 | |
| 
 | |
| #include "boost/date_time/compiler_config.hpp"
 | |
| #include "boost/date_time/gregorian/gregorian_types.hpp"
 | |
| #if defined(BOOST_DATE_TIME_INCLUDE_LIMITED_HEADERS)
 | |
| #include "boost/date_time/date_formatting_limited.hpp"
 | |
| #else
 | |
| #include "boost/date_time/date_formatting.hpp"
 | |
| #endif
 | |
| #include "boost/date_time/iso_format.hpp"
 | |
| #include "boost/date_time/date_format_simple.hpp"
 | |
| 
 | |
| /* NOTE: "to_*_string" code for older compilers, ones that define 
 | |
|  * BOOST_DATE_TIME_INCLUDE_LIMITED_HEADERS, is located in 
 | |
|  * formatters_limited.hpp
 | |
|  */
 | |
| 
 | |
| namespace boost {
 | |
| namespace gregorian {
 | |
| 
 | |
|   // wrapper function for to_simple_(w)string(date)
 | |
|   template<class charT>
 | |
|   inline 
 | |
|   std::basic_string<charT> to_simple_string_type(const date& d) {
 | |
|     return date_time::date_formatter<date,date_time::simple_format<charT>,charT>::date_to_string(d);
 | |
|   }
 | |
|   //! To YYYY-mmm-DD string where mmm 3 char month name. Example:  2002-Jan-01
 | |
|   /*!\ingroup date_format
 | |
|    */
 | |
|   inline std::string to_simple_string(const date& d) {
 | |
|     return to_simple_string_type<char>(d);
 | |
|   }
 | |
| 
 | |
| 
 | |
|   // wrapper function for to_simple_(w)string(date_period)
 | |
|   template<class charT>
 | |
|   inline std::basic_string<charT> to_simple_string_type(const date_period& d) {
 | |
|     typedef std::basic_string<charT> string_type;
 | |
|     charT b = '[', m = '/', e=']';
 | |
| 
 | |
|     string_type d1(date_time::date_formatter<date,date_time::simple_format<charT>,charT>::date_to_string(d.begin()));
 | |
|     string_type d2(date_time::date_formatter<date,date_time::simple_format<charT>,charT>::date_to_string(d.last()));
 | |
|     return string_type(b + d1 + m + d2 + e);
 | |
|   }
 | |
|   //! Convert date period to simple string. Example: [2002-Jan-01/2002-Jan-02]
 | |
|   /*!\ingroup date_format
 | |
|    */
 | |
|   inline std::string to_simple_string(const date_period& d) {
 | |
|     return to_simple_string_type<char>(d);
 | |
|   }
 | |
| 
 | |
|   // wrapper function for to_iso_(w)string(date_period)
 | |
|   template<class charT>
 | |
|   inline std::basic_string<charT> to_iso_string_type(const date_period& d) {
 | |
|     charT sep = '/';
 | |
|     std::basic_string<charT> s(date_time::date_formatter<date,date_time::iso_format<charT>,charT>::date_to_string(d.begin()));
 | |
|     return s + sep + date_time::date_formatter<date,date_time::iso_format<charT>,charT>::date_to_string(d.last());
 | |
|   }
 | |
|   //! Date period to iso standard format CCYYMMDD/CCYYMMDD. Example: 20021225/20021231
 | |
|   /*!\ingroup date_format
 | |
|    */
 | |
|   inline std::string to_iso_string(const date_period& d) {
 | |
|     return to_iso_string_type<char>(d);
 | |
|   }
 | |
| 
 | |
| 
 | |
|   // wrapper function for to_iso_extended_(w)string(date)
 | |
|   template<class charT>
 | |
|   inline std::basic_string<charT> to_iso_extended_string_type(const date& d) {
 | |
|     return date_time::date_formatter<date,date_time::iso_extended_format<charT>,charT>::date_to_string(d);
 | |
|   }
 | |
|   //! Convert to iso extended format string CCYY-MM-DD. Example 2002-12-31
 | |
|   /*!\ingroup date_format
 | |
|    */
 | |
|   inline std::string to_iso_extended_string(const date& d) {
 | |
|     return to_iso_extended_string_type<char>(d);
 | |
|   }
 | |
| 
 | |
|   // wrapper function for to_iso_(w)string(date)
 | |
|   template<class charT>
 | |
|   inline std::basic_string<charT> to_iso_string_type(const date& d) {
 | |
|     return date_time::date_formatter<date,date_time::iso_format<charT>,charT>::date_to_string(d);
 | |
|   }
 | |
|   //! Convert to iso standard string YYYYMMDD. Example: 20021231
 | |
|   /*!\ingroup date_format
 | |
|    */
 | |
|   inline std::string to_iso_string(const date& d) {
 | |
|     return to_iso_string_type<char>(d);
 | |
|   }
 | |
| 
 | |
|   
 | |
|   
 | |
| 
 | |
|   // wrapper function for to_sql_(w)string(date)
 | |
|   template<class charT>
 | |
|   inline std::basic_string<charT> to_sql_string_type(const date& d) 
 | |
|   {
 | |
|     date::ymd_type ymd = d.year_month_day();
 | |
|     std::basic_ostringstream<charT> ss;
 | |
|     ss << ymd.year << "-"
 | |
|        << std::setw(2) << std::setfill(ss.widen('0')) 
 | |
|        << ymd.month.as_number() //solves problem with gcc 3.1 hanging
 | |
|        << "-"
 | |
|        << std::setw(2) << std::setfill(ss.widen('0')) 
 | |
|        << ymd.day;
 | |
|     return ss.str();
 | |
|   }
 | |
|   inline std::string to_sql_string(const date& d) {
 | |
|     return to_sql_string_type<char>(d);
 | |
|   }
 | |
| 
 | |
| 
 | |
| #if !defined(BOOST_NO_STD_WSTRING)
 | |
|   //! Convert date period to simple string. Example: [2002-Jan-01/2002-Jan-02]
 | |
|   /*!\ingroup date_format
 | |
|    */
 | |
|   inline std::wstring to_simple_wstring(const date_period& d) {
 | |
|     return to_simple_string_type<wchar_t>(d);
 | |
|   }
 | |
|   //! To YYYY-mmm-DD string where mmm 3 char month name. Example:  2002-Jan-01
 | |
|   /*!\ingroup date_format
 | |
|    */
 | |
|   inline std::wstring to_simple_wstring(const date& d) {
 | |
|     return to_simple_string_type<wchar_t>(d);
 | |
|   }
 | |
|   //! Date period to iso standard format CCYYMMDD/CCYYMMDD. Example: 20021225/20021231
 | |
|   /*!\ingroup date_format
 | |
|    */
 | |
|   inline std::wstring to_iso_wstring(const date_period& d) {
 | |
|     return to_iso_string_type<wchar_t>(d);
 | |
|   }
 | |
|   //! Convert to iso extended format string CCYY-MM-DD. Example 2002-12-31
 | |
|   /*!\ingroup date_format
 | |
|    */
 | |
|   inline std::wstring to_iso_extended_wstring(const date& d) {
 | |
|     return to_iso_extended_string_type<wchar_t>(d);
 | |
|   }
 | |
|   //! Convert to iso standard string YYYYMMDD. Example: 20021231
 | |
|   /*!\ingroup date_format
 | |
|    */
 | |
|   inline std::wstring to_iso_wstring(const date& d) {
 | |
|     return to_iso_string_type<wchar_t>(d);
 | |
|   }
 | |
|   inline std::wstring to_sql_wstring(const date& d) {
 | |
|     return to_sql_string_type<wchar_t>(d);
 | |
|   }
 | |
| #endif // BOOST_NO_STD_WSTRING
 | |
| 
 | |
| } } //namespace gregorian
 | |
| 
 | |
| 
 | |
| #endif
 | |
| 
 | 
