261 lines
		
	
	
		
			8.2 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			261 lines
		
	
	
		
			8.2 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| //  (C) Copyright Howard Hinnant
 | |
| //  (C) Copyright 2011 Vicente J. Botet Escriba
 | |
| //  Copyright (c) Microsoft Corporation 2014
 | |
| //  Use, modification and distribution are subject to the Boost Software License,
 | |
| //  Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
 | |
| //  http://www.boost.org/LICENSE_1_0.txt).
 | |
| //
 | |
| 
 | |
| #ifndef BOOST_CHRONO_IO_TIME_POINT_UNITS_HPP
 | |
| #define BOOST_CHRONO_IO_TIME_POINT_UNITS_HPP
 | |
| 
 | |
| #include <boost/chrono/config.hpp>
 | |
| #include <boost/chrono/process_cpu_clocks.hpp>
 | |
| #include <boost/chrono/system_clocks.hpp>
 | |
| #include <boost/chrono/thread_clock.hpp>
 | |
| #include <boost/chrono/io/ios_base_state.hpp>
 | |
| #include <string>
 | |
| #include <iostream>
 | |
| #include <ios>
 | |
| #include <locale>
 | |
| #include <algorithm>
 | |
| 
 | |
| namespace boost
 | |
| {
 | |
|   namespace chrono
 | |
|   {
 | |
|     /**
 | |
|      * customization point to the epoch associated to the clock @c Clock
 | |
|      * The default calls @c f.do_get_epoch(Clock()). The user can overload this function.
 | |
|      * @return the string epoch associated to the @c Clock
 | |
|      */
 | |
|     template <typename CharT, typename Clock, typename TPUFacet>
 | |
|     std::basic_string<CharT> get_epoch_custom(Clock, TPUFacet& f)
 | |
|     {
 | |
|       return f.do_get_epoch(Clock());
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @c time_point_units facet gives useful information about the time_point pattern,
 | |
|      * the text associated to a time_point's epoch,
 | |
|      */
 | |
|     template <typename CharT=char>
 | |
|     class time_point_units: public std::locale::facet
 | |
|     {
 | |
|     public:
 | |
|       /**
 | |
|        * Type of character the facet is instantiated on.
 | |
|        */
 | |
|       typedef CharT char_type;
 | |
|       /**
 | |
|        * Type of character string used by member functions.
 | |
|        */
 | |
|       typedef std::basic_string<char_type> string_type;
 | |
| 
 | |
|       /**
 | |
|        * Unique identifier for this type of facet.
 | |
|        */
 | |
|       static std::locale::id id;
 | |
| 
 | |
|       /**
 | |
|        * Construct a @c time_point_units facet.
 | |
|        * @param refs
 | |
|        * @Effects Construct a @c time_point_units facet.
 | |
|        * If the @c refs argument is @c 0 then destruction of the object is
 | |
|        * delegated to the @c locale, or locales, containing it. This allows
 | |
|        * the user to ignore lifetime management issues. On the other had,
 | |
|        * if @c refs is @c 1 then the object must be explicitly deleted;
 | |
|        * the @c locale will not do so. In this case, the object can be
 | |
|        * maintained across the lifetime of multiple locales.
 | |
|        */
 | |
|       explicit time_point_units(size_t refs = 0) :
 | |
|         std::locale::facet(refs)
 | |
|       {
 | |
|       }
 | |
| 
 | |
|       /**
 | |
|        * @return the pattern to be used by default.
 | |
|        */
 | |
|       virtual string_type get_pattern() const =0;
 | |
| 
 | |
|       /**
 | |
|        * @return the epoch associated to the clock @c Clock calling @c do_get_epoch(Clock())
 | |
|        */
 | |
|       template <typename Clock>
 | |
|       string_type get_epoch() const
 | |
|       {
 | |
|         return get_epoch_custom<CharT>(Clock(), *this);
 | |
|       }
 | |
| 
 | |
|     protected:
 | |
|       /**
 | |
|        * Destroy the facet.
 | |
|        */
 | |
|       virtual ~time_point_units() {}
 | |
| 
 | |
|     public:
 | |
| 
 | |
|       /**
 | |
|        *
 | |
|        * @param c a dummy instance of @c system_clock.
 | |
|        * @return The epoch string associated to the @c system_clock.
 | |
|        */
 | |
|       virtual string_type do_get_epoch(system_clock) const=0;
 | |
| 
 | |
|       /**
 | |
|        *
 | |
|        * @param c a dummy instance of @c steady_clock.
 | |
|        * @return The epoch string associated to the @c steady_clock.
 | |
|        */
 | |
|       virtual string_type do_get_epoch(steady_clock) const=0;
 | |
| 
 | |
| #if defined(BOOST_CHRONO_HAS_PROCESS_CLOCKS)
 | |
|       /**
 | |
|        *
 | |
|        * @param c a dummy instance of @c process_real_cpu_clock.
 | |
|        * @return The epoch string associated to the @c process_real_cpu_clock.
 | |
|        */
 | |
|       virtual string_type do_get_epoch(process_real_cpu_clock) const=0;
 | |
| #if ! BOOST_OS_WINDOWS || BOOST_PLAT_WINDOWS_DESKTOP
 | |
|       /**
 | |
|        *
 | |
|        * @param c a dummy instance of @c process_user_cpu_clock.
 | |
|        * @return The epoch string associated to the @c process_user_cpu_clock.
 | |
|        */
 | |
|       virtual string_type do_get_epoch(process_user_cpu_clock) const=0;
 | |
|       /**
 | |
|        *
 | |
|        * @param c a dummy instance of @c process_system_cpu_clock.
 | |
|        * @return The epoch string associated to the @c process_system_cpu_clock.
 | |
|        */
 | |
|       virtual string_type do_get_epoch(process_system_cpu_clock) const=0;
 | |
|       /**
 | |
|        *
 | |
|        * @param c a dummy instance of @c process_cpu_clock.
 | |
|        * @return The epoch string associated to the @c process_cpu_clock.
 | |
|        */
 | |
|       virtual string_type do_get_epoch(process_cpu_clock) const=0;
 | |
| #endif
 | |
| #endif
 | |
| #if defined(BOOST_CHRONO_HAS_THREAD_CLOCK)
 | |
|       /**
 | |
|        *
 | |
|        * @param c a dummy instance of @c thread_clock.
 | |
|        * @return The epoch string associated to the @c thread_clock.
 | |
|        */
 | |
|       virtual string_type do_get_epoch(thread_clock) const=0;
 | |
| #endif
 | |
| 
 | |
|     };
 | |
| 
 | |
|     template <typename CharT>
 | |
|     std::locale::id time_point_units<CharT>::id;
 | |
| 
 | |
| 
 | |
|     // This class is used to define the strings for the default English
 | |
|     template <typename CharT=char>
 | |
|     class time_point_units_default: public time_point_units<CharT>
 | |
|     {
 | |
|     public:
 | |
|       /**
 | |
|        * Type of character the facet is instantiated on.
 | |
|        */
 | |
|       typedef CharT char_type;
 | |
|       /**
 | |
|        * Type of character string returned by member functions.
 | |
|        */
 | |
|       typedef std::basic_string<char_type> string_type;
 | |
| 
 | |
|       explicit time_point_units_default(size_t refs = 0) :
 | |
|         time_point_units<CharT> (refs)
 | |
|       {
 | |
|       }
 | |
|       ~time_point_units_default() {}
 | |
| 
 | |
|       /**
 | |
|        * @return the default pattern "%d%e".
 | |
|        */
 | |
|       string_type get_pattern() const
 | |
|       {
 | |
|         static const CharT t[] =
 | |
|         { '%', 'd', '%', 'e' };
 | |
|         static const string_type pattern(t, t + sizeof (t) / sizeof (t[0]));
 | |
| 
 | |
|         return pattern;
 | |
|       }
 | |
| 
 | |
|     //protected:
 | |
|       /**
 | |
|        * @param c a dummy instance of @c system_clock.
 | |
|        * @return The epoch string returned by @c clock_string<system_clock,CharT>::since().
 | |
|        */
 | |
|       string_type do_get_epoch(system_clock ) const
 | |
|       {
 | |
|         return clock_string<system_clock,CharT>::since();
 | |
|       }
 | |
|       /**
 | |
|        * @param c a dummy instance of @c steady_clock.
 | |
|        * @return The epoch string returned by @c clock_string<steady_clock,CharT>::since().
 | |
|        */
 | |
|       string_type do_get_epoch(steady_clock ) const
 | |
|       {
 | |
|         return clock_string<steady_clock,CharT>::since();
 | |
|       }
 | |
| 
 | |
| #if defined(BOOST_CHRONO_HAS_PROCESS_CLOCKS)
 | |
|       /**
 | |
|        * @param c a dummy instance of @c process_real_cpu_clock.
 | |
|        * @return The epoch string returned by @c clock_string<process_real_cpu_clock,CharT>::since().
 | |
|        */
 | |
|       string_type do_get_epoch(process_real_cpu_clock ) const
 | |
|       {
 | |
|         return clock_string<process_real_cpu_clock,CharT>::since();
 | |
|       }
 | |
| #if ! BOOST_OS_WINDOWS || BOOST_PLAT_WINDOWS_DESKTOP
 | |
|       /**
 | |
|        * @param c a dummy instance of @c process_user_cpu_clock.
 | |
|        * @return The epoch string returned by @c clock_string<process_user_cpu_clock,CharT>::since().
 | |
|        */
 | |
|       string_type do_get_epoch(process_user_cpu_clock ) const
 | |
|       {
 | |
|         return clock_string<process_user_cpu_clock,CharT>::since();
 | |
|       }
 | |
|       /**
 | |
|        * @param c a dummy instance of @c process_system_cpu_clock.
 | |
|        * @return The epoch string returned by @c clock_string<process_system_cpu_clock,CharT>::since().
 | |
|        */
 | |
|       string_type do_get_epoch(process_system_cpu_clock ) const
 | |
|       {
 | |
|         return clock_string<process_system_cpu_clock,CharT>::since();
 | |
|       }
 | |
|       /**
 | |
|        * @param c a dummy instance of @c process_cpu_clock.
 | |
|        * @return The epoch string returned by @c clock_string<process_cpu_clock,CharT>::since().
 | |
|        */
 | |
|       string_type do_get_epoch(process_cpu_clock ) const
 | |
|       {
 | |
|         return clock_string<process_cpu_clock,CharT>::since();
 | |
|       }
 | |
| 
 | |
| #endif
 | |
| #endif
 | |
| #if defined(BOOST_CHRONO_HAS_THREAD_CLOCK)
 | |
|       /**
 | |
|        * @param c a dummy instance of @c thread_clock.
 | |
|        * @return The epoch string returned by @c clock_string<thread_clock,CharT>::since().
 | |
|        */
 | |
|       string_type do_get_epoch(thread_clock ) const
 | |
|       {
 | |
|         return clock_string<thread_clock,CharT>::since();
 | |
|       }
 | |
| #endif
 | |
| 
 | |
|     };
 | |
| 
 | |
| 
 | |
|   } // chrono
 | |
| 
 | |
| } // boost
 | |
| 
 | |
| #endif  // header
 | 
