// (C) Copyright Howard Hinnant // (C) Copyright 2011 Vicente J. Botet Escriba // 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_DURATION_UNITS_HPP #define BOOST_CHRONO_IO_DURATION_UNITS_HPP #include #include #include #include #include #include #include #include #include #include namespace boost { namespace chrono { class rt_ratio { public: template rt_ratio(Period const&) : num(Period::type::num), den(Period::type::den) { } rt_ratio(intmax_t n = 0, intmax_t d = 0) : num(n), den(d) { } intmax_t num; intmax_t den; }; /** * @c duration_units facet gives useful information about the duration units, * as the number of plural forms, the plural form associated to a duration, * the text associated to a plural form and a duration's period, */ template class duration_units: public std::locale::facet { public: /** * Type of character the facet is instantiated on. */ typedef CharT char_type; /** * Type of character string passed to member functions. */ typedef std::basic_string string_type; /** * Unique identifier for this type of facet. */ static std::locale::id id; /** * Construct a @c duration_units facet. * @param refs * @Effects Construct a @c duration_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 duration_units(size_t refs = 0) : std::locale::facet(refs) { } /** * @return pointer to the start of valid [N/D] units. */ virtual const string_type* get_n_d_valid_units_start() const =0; /** * @effect calls the do_... * @return pointer to the end of valid [N/D] units. */ virtual const string_type* get_n_d_valid_units_end() const=0; /** * @return pointer to the start of valid units, symbol or prefix with its different plural forms. */ virtual const string_type* get_valid_units_start() const=0; /** * @return pointer to the end of valid units. */ virtual const string_type* get_valid_units_end() const=0; /** * @param k the found pointer to the [N/D] unit. * @return true if @c k matches a valid unit. */ virtual bool match_n_d_valid_unit(const string_type* k) const = 0; /** * @param k the found pointer to the unit. * @Effects @c rt is set to the valid Period when the @c k matches a valid unit. * @return true if @c k matches a valid unit. */ virtual bool match_valid_unit(const string_type* k, rt_ratio& rt) const = 0; /** * @effect calls the do_... * @return the pattern to be used by default. */ virtual string_type get_pattern() const=0; /** * @effect calls the do_... * @return the unit associated to this duration. */ template string_type get_unit(duration_style style, duration const& d) const { return do_get_unit(style, rt_ratio(Period()), static_cast(d.count())); } /** * @effect calls the do_... * @return the [N/D] suffix unit associated to this duration. */ template string_type get_n_d_unit(duration_style style, duration const& d) const { return do_get_n_d_unit(style, rt_ratio(Period()), static_cast(d.count())); } /** * @effect calls the do_... * @return true if the unit associated to the given Period is named, false otherwise. */ template bool is_named_unit() const { return do_is_named_unit(rt_ratio(Period())); } protected: /** * @Effects Destroys the facet */ virtual ~duration_units() { } /** * @return the [N/D] suffix unit associated to this duration. */ virtual string_type do_get_n_d_unit(duration_style style, rt_ratio rt, intmax_t v) const = 0; /** * @return the unit associated to this duration. */ virtual string_type do_get_unit(duration_style style,rt_ratio rt, intmax_t v) const = 0; /** * @return true if the unit associated to the given Period is named, false otherwise. */ virtual bool do_is_named_unit(rt_ratio rt) const =0; }; template std::locale::id duration_units::id; namespace detail { template struct duration_units_default_holder { typedef std::basic_string string_type; static string_type* n_d_valid_units_; static string_type* valid_units_; static bool initialized_; }; template typename duration_units_default_holder::string_type* duration_units_default_holder::n_d_valid_units_=0; template typename duration_units_default_holder::string_type* duration_units_default_holder::valid_units_=0; template bool duration_units_default_holder::initialized_ = false; } /** * This class is used to define the strings for the default English */ template class duration_units_default: public duration_units { protected: static const std::size_t pfs_ = 2; public: /** * Type of character the facet is instantiated on. */ typedef CharT char_type; /** * Type of character string passed to member functions. */ typedef std::basic_string string_type; /** * Construct a @c duration_units_default facet. * @param refs * @Effects Construct a @c duration_units_default 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 duration_units_default(size_t refs = 0) : duration_units (refs) { } /** * Destroys the facet. */ ~duration_units_default() { } public: /** * @param k the found pointer to the [N/D] unit. * @return true if @c k matches a valid unit. */ bool match_n_d_valid_unit(const string_type* k) const { std::size_t index = (k - get_n_d_valid_units_start()) / (pfs_ + 1); switch (index) { case 0: break; default: return false; } return true; } /** * @param k the found pointer to the unit. * @Effects @c rt is set to the valid Period when the @c k matches a valid unit. * @return true if @c k matches a valid unit. */ bool match_valid_unit(const string_type* k, rt_ratio& rt) const { std::size_t index = (k - get_valid_units_start()) / (pfs_ + 1); switch (index) { case 0: rt = rt_ratio(atto()); break; case 1: rt = rt_ratio(femto()); break; case 2: rt = rt_ratio(pico()); break; case 3: rt = rt_ratio(nano()); break; case 4: rt = rt_ratio(micro()); break; case 5: rt = rt_ratio(milli()); break; case 6: rt = rt_ratio(centi()); break; case 7: rt = rt_ratio(deci()); break; case 8: rt = rt_ratio(deca()); break; case 9: rt = rt_ratio(hecto()); break; case 10: rt = rt_ratio(kilo()); break; case 11: rt = rt_ratio(mega()); break; case 12: rt = rt_ratio(giga()); break; case 13: rt = rt_ratio(tera()); break; case 14: rt = rt_ratio(peta()); break; case 15: rt = rt_ratio(exa()); break; case 16: rt = rt_ratio(ratio<1> ()); break; case 17: rt = rt_ratio(ratio<60> ()); break; case 18: rt = rt_ratio(ratio<3600> ()); break; default: return false; } return true; } /** * @return pointer to the start of valid [N/D] units. */ virtual const string_type* get_n_d_valid_units_start()const { return detail::duration_units_default_holder::n_d_valid_units_; } /** * @return pointer to the end of valid [N/D] units. */ virtual const string_type* get_n_d_valid_units_end()const { return detail::duration_units_default_holder::n_d_valid_units_ + (pfs_ + 1); } /** * @return pointer to the start of valid units. */ virtual const string_type* get_valid_units_start() const { return detail::duration_units_default_holder::valid_units_; } /** * @return pointer to the end of valid units. */ virtual const string_type* get_valid_units_end() const { return detail::duration_units_default_holder::valid_units_ + 19 * (pfs_ + 1); } string_type get_pattern() const { static const CharT t[] = { '%', 'v', ' ', '%', 'u' }; static const string_type pattern(t, t + sizeof (t) / sizeof (t[0])); return pattern; } protected: /** * * This facet names the units associated to the following periods: * atto,femto,pico,nano,micro,milli,centi,deci,ratio<1>,deca,hecto,kilo,mega,giga,tera,peta,exa,ratio<60> and ratio<3600>. * @return true if the unit associated to the given Period is named, false otherwise. */ bool do_is_named_unit(rt_ratio rt) const { if (rt.num==1) { switch (rt.den) { case BOOST_RATIO_INTMAX_C(1): case BOOST_RATIO_INTMAX_C(10): case BOOST_RATIO_INTMAX_C(100): case BOOST_RATIO_INTMAX_C(1000): case BOOST_RATIO_INTMAX_C(1000000): case BOOST_RATIO_INTMAX_C(1000000000): case BOOST_RATIO_INTMAX_C(1000000000000): case BOOST_RATIO_INTMAX_C(1000000000000000): case BOOST_RATIO_INTMAX_C(1000000000000000000): return true; default: return false; } } else if (rt.den==1) { switch (rt.num) { case BOOST_RATIO_INTMAX_C(10): case BOOST_RATIO_INTMAX_C(60): case BOOST_RATIO_INTMAX_C(100): case BOOST_RATIO_INTMAX_C(1000): case BOOST_RATIO_INTMAX_C(3600): case BOOST_RATIO_INTMAX_C(1000000): case BOOST_RATIO_INTMAX_C(1000000000): case BOOST_RATIO_INTMAX_C(1000000000000): case BOOST_RATIO_INTMAX_C(1000000000000000): case BOOST_RATIO_INTMAX_C(1000000000000000000): return true; default: return false; } } return false; } /** * In English the suffix used after [N/D] is the one associated to the period ratio<1>. * @return the [N/D] suffix unit associated to this duration. */ string_type do_get_n_d_unit(duration_style style, rt_ratio, intmax_t v) const { return do_get_unit(style, ratio<1>(), do_get_plural_form(v)); } /** * @return the unit associated to this duration if it is named, "" otherwise. */ string_type do_get_unit(duration_style style, rt_ratio rt, intmax_t v) const { if (rt.num==1) { switch (rt.den) { case BOOST_RATIO_INTMAX_C(1): return do_get_unit(style, ratio<1>(), do_get_plural_form(v)); case BOOST_RATIO_INTMAX_C(10): return do_get_unit(style, deci(), do_get_plural_form(v)); case BOOST_RATIO_INTMAX_C(100): return do_get_unit(style, centi(), do_get_plural_form(v)); case BOOST_RATIO_INTMAX_C(1000): return do_get_unit(style, milli(), do_get_plural_form(v)); case BOOST_RATIO_INTMAX_C(1000000): return do_get_unit(style, micro(), do_get_plural_form(v)); case BOOST_RATIO_INTMAX_C(1000000000): return do_get_unit(style, nano(), do_get_plural_form(v)); case BOOST_RATIO_INTMAX_C(1000000000000): return do_get_unit(style, pico(), do_get_plural_form(v)); case BOOST_RATIO_INTMAX_C(1000000000000000): return do_get_unit(style, femto(), do_get_plural_form(v)); case BOOST_RATIO_INTMAX_C(1000000000000000000): return do_get_unit(style, atto(), do_get_plural_form(v)); default: ; } } else if (rt.den==1) { switch (rt.num) { case BOOST_RATIO_INTMAX_C(10): return do_get_unit(style, deca(), do_get_plural_form(v)); case BOOST_RATIO_INTMAX_C(60): return do_get_unit(style, ratio<60>(), do_get_plural_form(v)); case BOOST_RATIO_INTMAX_C(100): return do_get_unit(style, hecto(), do_get_plural_form(v)); case BOOST_RATIO_INTMAX_C(1000): return do_get_unit(style, kilo(), do_get_plural_form(v)); case BOOST_RATIO_INTMAX_C(3600): return do_get_unit(style, ratio<3600>(), do_get_plural_form(v)); case BOOST_RATIO_INTMAX_C(1000000): return do_get_unit(style, mega(), do_get_plural_form(v)); case BOOST_RATIO_INTMAX_C(1000000000): return do_get_unit(style, giga(), do_get_plural_form(v)); case BOOST_RATIO_INTMAX_C(1000000000000): return do_get_unit(style, tera(), do_get_plural_form(v)); case BOOST_RATIO_INTMAX_C(1000000000000000): return do_get_unit(style, peta(), do_get_plural_form(v)); case BOOST_RATIO_INTMAX_C(1000000000000000000): return do_get_unit(style, exa(), do_get_plural_form(v)); default: ; } } BOOST_ASSERT(false&&"ratio parameter can not be translated"); //throw "exception"; return string_type(); } protected: /** * @return the number of associated plural forms this facet manages. */ virtual std::size_t do_get_plural_forms() const { return static_get_plural_forms(); } static std::size_t static_get_plural_forms() { return pfs_; } /** * Gets the associated plural form. * @param value the duration representation * @return the plural form associated to the @c value parameter. In English there are 2 plural forms * 0 singular (-1 or 1) * 1 plural for all others */ virtual std::size_t do_get_plural_form(int_least64_t value) const { return static_get_plural_form(value); } static std::size_t static_get_plural_form(int_least64_t value) { return (value == -1 || value == 1) ? 0 : 1; } /** * @param style the duration style. * @param period the period associated to the duration seconds. * @param pf the requested plural form. * @return if style is symbol returns "s", otherwise if pf is 0 return "second", if pf is 1 "seconds" */ virtual string_type do_get_unit(duration_style style, ratio<1> u, std::size_t pf) const { return static_get_unit(style,u,pf); } static string_type static_get_unit(duration_style style, ratio<1> , std::size_t pf) { static const CharT t[] = { 's' }; static const string_type symbol(t, t + sizeof (t) / sizeof (t[0])); static const CharT u[] = { 's', 'e', 'c', 'o', 'n', 'd' }; static const string_type singular(u, u + sizeof (u) / sizeof (u[0])); static const CharT v[] = { 's', 'e', 'c', 'o', 'n', 'd', 's' }; static const string_type plural(v, v + sizeof (v) / sizeof (v[0])); if (style == duration_style::symbol) { return symbol; } if (pf == 0) { return singular; } if (pf == 1) { return plural; } BOOST_ASSERT(false&&"style/pf parameters not valid"); //throw "exception"; return string_type(); } /** * @param style the duration style. * @param period the period associated to the duration minutes. * @param pf the requested plural form. * @return if style is symbol returns "min", otherwise if pf is 0 return "minute", if pf is 1 "minutes" */ virtual string_type do_get_unit(duration_style style, ratio<60> u, std::size_t pf) const { return static_get_unit(style,u,pf); } static string_type static_get_unit(duration_style style, ratio<60> , std::size_t pf) { static const CharT t[] = { 'm', 'i', 'n' }; static const string_type symbol(t, t + sizeof (t) / sizeof (t[0])); static const CharT u[] = { 'm', 'i', 'n', 'u', 't', 'e' }; static const string_type singular(u, u + sizeof (u) / sizeof (u[0])); static const CharT v[] = { 'm', 'i', 'n', 'u', 't', 'e', 's' }; static const string_type plural(v, v + sizeof (v) / sizeof (v[0])); if (style == duration_style::symbol) return symbol; if (pf == 0) return singular; if (pf == 1) return plural; BOOST_ASSERT(false&&"style/pf parameters not valid"); //throw "exception"; return string_type(); } /** * @param style the duration style. * @param period the period associated to the duration hours. * @param pf the requested plural form. * @return if style is symbol returns "h", otherwise if pf is 0 return "hour", if pf is 1 "hours" */ virtual string_type do_get_unit(duration_style style, ratio<3600> u, std::size_t pf) const { return static_get_unit(style,u,pf); } static string_type static_get_unit(duration_style style, ratio<3600> , std::size_t pf) { static const CharT t[] = { 'h' }; static const string_type symbol(t, t + sizeof (t) / sizeof (t[0])); static const CharT u[] = { 'h', 'o', 'u', 'r' }; static const string_type singular(u, u + sizeof (u) / sizeof (u[0])); static const CharT v[] = { 'h', 'o', 'u', 'r', 's' }; static const string_type plural(v, v + sizeof (v) / sizeof (v[0])); if (style == duration_style::symbol) return symbol; if (pf == 0) return singular; if (pf == 1) return plural; BOOST_ASSERT(false&&"style/pf parameters not valid"); //throw "exception"; return string_type(); } /** * @param style the duration style. * @param u the period tag atto. * @param pf the requested plural form. * @return the concatenation of the prefix associated to @c period + the one associated to seconds. */ virtual string_type do_get_unit(duration_style style, atto u, std::size_t pf) const { return do_get_ratio_prefix(style, u) + do_get_unit(style, ratio<1> (), pf); } static string_type static_get_unit(duration_style style, atto u, std::size_t pf) { return static_get_ratio_prefix(style, u) + static_get_unit(style, ratio<1> (), pf); } /** * @param style the duration style. * @param u the period tag femto. * @param pf the requested plural form. * @return the concatenation of the prefix associated to period @c u + the one associated to seconds. */ virtual string_type do_get_unit(duration_style style, femto u, std::size_t pf) const { return do_get_ratio_prefix(style, u) + do_get_unit(style, ratio<1> (), pf); } static string_type static_get_unit(duration_style style, femto u, std::size_t pf) { return static_get_ratio_prefix(style, u) + static_get_unit(style, ratio<1> (), pf); } /** * @param style the duration style. * @param u the period tag femto. * @param pf the requested plural form. * @return the concatenation of the prefix associated to period @c u + the one associated to seconds. */ virtual string_type do_get_unit(duration_style style, pico u, std::size_t pf) const { return do_get_ratio_prefix(style, u) + do_get_unit(style, ratio<1> (), pf); } static string_type static_get_unit(duration_style style, pico u, std::size_t pf) { return static_get_ratio_prefix(style, u) + static_get_unit(style, ratio<1> (), pf); } virtual string_type do_get_unit(duration_style style, nano u, std::size_t pf) const { return do_get_ratio_prefix(style, u) + do_get_unit(style, ratio<1> (), pf); } static string_type static_get_unit(duration_style style, nano u, std::size_t pf) { return static_get_ratio_prefix(style, u) + static_get_unit(style, ratio<1> (), pf); } virtual string_type do_get_unit(duration_style style, micro u, std::size_t pf) const { return do_get_ratio_prefix(style, u) + do_get_unit(style, ratio<1> (), pf); } static string_type static_get_unit(duration_style style, micro u, std::size_t pf) { return static_get_ratio_prefix(style, u) + static_get_unit(style, ratio<1> (), pf); } virtual string_type do_get_unit(duration_style style, milli u, std::size_t pf) const { return do_get_ratio_prefix(style, u) + do_get_unit(style, ratio<1> (), pf); } static string_type static_get_unit(duration_style style, milli u, std::size_t pf) { return static_get_ratio_prefix(style, u) + static_get_unit(style, ratio<1> (), pf); } virtual string_type do_get_unit(duration_style style, centi u, std::size_t pf) const { return do_get_ratio_prefix(style, u) + do_get_unit(style, ratio<1> (), pf); } static string_type static_get_unit(duration_style style, centi u, std::size_t pf) { return static_get_ratio_prefix(style, u) + static_get_unit(style, ratio<1> (), pf); } virtual string_type do_get_unit(duration_style style, deci u, std::size_t pf) const { return do_get_ratio_prefix(style, u) + do_get_unit(style, ratio<1> (), pf); } static string_type static_get_unit(duration_style style, deci u, std::size_t pf) { return static_get_ratio_prefix(style, u) + static_get_unit(style, ratio<1> (), pf); } virtual string_type do_get_unit(duration_style style, deca u, std::size_t pf) const { return do_get_ratio_prefix(style, u) + do_get_unit(style, ratio<1> (), pf); } static string_type static_get_unit(duration_style style, deca u, std::size_t pf) { return static_get_ratio_prefix(style, u) + static_get_unit(style, ratio<1> (), pf); } virtual string_type do_get_unit(duration_style style, hecto u, std::size_t pf) const { return do_get_ratio_prefix(style, u) + do_get_unit(style, ratio<1> (), pf); } static string_type static_get_unit(duration_style style, hecto u, std::size_t pf) { return static_get_ratio_prefix(style, u) + static_get_unit(style, ratio<1> (), pf); } virtual string_type do_get_unit(duration_style style, kilo u, std::size_t pf) const { return do_get_ratio_prefix(style, u) + do_get_unit(style, ratio<1> (), pf); } static string_type static_get_unit(duration_style style, kilo u, std::size_t pf) { return static_get_ratio_prefix(style, u) + static_get_unit(style, ratio<1> (), pf); } virtual string_type do_get_unit(duration_style style, mega u, std::size_t pf) const { return do_get_ratio_prefix(style, u) + do_get_unit(style, ratio<1> (), pf); } static string_type static_get_unit(duration_style style, mega u, std::size_t pf) { return static_get_ratio_prefix(style, u) + static_get_unit(style, ratio<1> (), pf); } virtual string_type do_get_unit(duration_style style, giga u, std::size_t pf) const { return do_get_ratio_prefix(style, u) + do_get_unit(style, ratio<1> (), pf); } static string_type static_get_unit(duration_style style, giga u, std::size_t pf) { return static_get_ratio_prefix(style, u) + static_get_unit(style, ratio<1> (), pf); } virtual string_type do_get_unit(duration_style style, tera u, std::size_t pf) const { return do_get_ratio_prefix(style, u) + do_get_unit(style, ratio<1> (), pf); } static string_type static_get_unit(duration_style style, tera u, std::size_t pf) { return static_get_ratio_prefix(style, u) + static_get_unit(style, ratio<1> (), pf); } virtual string_type do_get_unit(duration_style style, peta u, std::size_t pf) const { return do_get_ratio_prefix(style, u) + do_get_unit(style, ratio<1> (), pf); } static string_type static_get_unit(duration_style style, peta u, std::size_t pf) { return static_get_ratio_prefix(style, u) + static_get_unit(style, ratio<1> (), pf); } virtual string_type do_get_unit(duration_style style, exa u, std::size_t pf) const { return do_get_ratio_prefix(style, u) + do_get_unit(style, ratio<1> (), pf); } static string_type static_get_unit(duration_style style, exa u, std::size_t pf) { return static_get_ratio_prefix(style, u) + static_get_unit(style, ratio<1> (), pf); } protected: /** * @param style the duration style. * @param u the period tag atto. * @return depending on the value of @c style return the ratio_string symbol or prefix. */ virtual string_type do_get_ratio_prefix(duration_style style, atto u) const { return static_get_ratio_prefix(style, u); } static string_type static_get_ratio_prefix(duration_style style, atto) { if (style == duration_style::symbol) return ratio_string::symbol(); return ratio_string::prefix(); } virtual string_type do_get_ratio_prefix(duration_style style, femto u) const { return static_get_ratio_prefix(style, u); } static string_type static_get_ratio_prefix(duration_style style, femto) { if (style == duration_style::symbol) return ratio_string::symbol(); return ratio_string::prefix(); } virtual string_type do_get_ratio_prefix(duration_style style, pico u) const { return static_get_ratio_prefix(style, u); } static string_type static_get_ratio_prefix(duration_style style, pico) { if (style == duration_style::symbol) return ratio_string::symbol(); return ratio_string::prefix(); } virtual string_type do_get_ratio_prefix(duration_style style, nano u) const { return static_get_ratio_prefix(style, u); } static string_type static_get_ratio_prefix(duration_style style, nano) { if (style == duration_style::symbol) return ratio_string::symbol(); return ratio_string::prefix(); } virtual string_type do_get_ratio_prefix(duration_style style, micro u) const { return static_get_ratio_prefix(style, u); } static string_type static_get_ratio_prefix(duration_style style, micro) { if (style == duration_style::symbol) return ratio_string::symbol(); return ratio_string::prefix(); } virtual string_type do_get_ratio_prefix(duration_style style, milli u) const { return static_get_ratio_prefix(style, u); } static string_type static_get_ratio_prefix(duration_style style, milli) { if (style == duration_style::symbol) return ratio_string::symbol(); return ratio_string::prefix(); } virtual string_type do_get_ratio_prefix(duration_style style, centi u) const { return static_get_ratio_prefix(style, u); } static string_type static_get_ratio_prefix(duration_style style, centi) { if (style == duration_style::symbol) return ratio_string::symbol(); return ratio_string::prefix(); } virtual string_type do_get_ratio_prefix(duration_style style, deci u) const { return static_get_ratio_prefix(style, u); } static string_type static_get_ratio_prefix(duration_style style, deci) { if (style == duration_style::symbol) return ratio_string::symbol(); return ratio_string::prefix(); } virtual string_type do_get_ratio_prefix(duration_style style, deca u) const { return static_get_ratio_prefix(style, u); } static string_type static_get_ratio_prefix(duration_style style, deca) { if (style == duration_style::symbol) return ratio_string::symbol(); return ratio_string::prefix(); } virtual string_type do_get_ratio_prefix(duration_style style, hecto u) const { return static_get_ratio_prefix(style, u); } static string_type static_get_ratio_prefix(duration_style style, hecto) { if (style == duration_style::symbol) return ratio_string::symbol(); return ratio_string::prefix(); } virtual string_type do_get_ratio_prefix(duration_style style, kilo u) const { return static_get_ratio_prefix(style, u); } static string_type static_get_ratio_prefix(duration_style style, kilo) { if (style == duration_style::symbol) return ratio_string::symbol(); return ratio_string::prefix(); } virtual string_type do_get_ratio_prefix(duration_style style, mega u) const { return static_get_ratio_prefix(style, u); } static string_type static_get_ratio_prefix(duration_style style, mega) { if (style == duration_style::symbol) return ratio_string::symbol(); return ratio_string::prefix(); } virtual string_type do_get_ratio_prefix(duration_style style, giga u) const { return static_get_ratio_prefix(style, u); } static string_type static_get_ratio_prefix(duration_style style, giga) { if (style == duration_style::symbol) return ratio_string::symbol(); return ratio_string::prefix(); } virtual string_type do_get_ratio_prefix(duration_style style, tera u) const { return static_get_ratio_prefix(style, u); } static string_type static_get_ratio_prefix(duration_style style, tera) { if (style == duration_style::symbol) return ratio_string::symbol(); return ratio_string::prefix(); } virtual string_type do_get_ratio_prefix(duration_style style, peta u) const { return static_get_ratio_prefix(style, u); } static string_type static_get_ratio_prefix(duration_style style, peta) { if (style == duration_style::symbol) return ratio_string::symbol(); return ratio_string::prefix(); } virtual string_type do_get_ratio_prefix(duration_style style, exa u) const { return static_get_ratio_prefix(style, u); } static string_type static_get_ratio_prefix(duration_style style, exa) { if (style == duration_style::symbol) return ratio_string::symbol(); return ratio_string::prefix(); } protected: template string_type* fill_units(string_type* it, Period) const { std::size_t pfs = do_get_plural_forms(); for (std::size_t pf = 0; pf < pfs; ++pf) { *it++ = do_get_unit(duration_style::prefix, Period(), pf); } *it++ = do_get_unit(duration_style::symbol, Period(), 0); return it; } public: template static string_type* static_fill_units(string_type* it, Period) { std::size_t pfs = static_get_plural_forms(); for (std::size_t pf = 0; pf < pfs; ++pf) { *it++ = static_get_unit(duration_style::prefix, Period(), pf); } *it++ = static_get_unit(duration_style::symbol, Period(), 0); return it; } static string_type* static_init_valid_units(string_type* it) { it = static_fill_units(it, atto()); it = static_fill_units(it, femto()); it = static_fill_units(it, pico()); it = static_fill_units(it, nano()); it = static_fill_units(it, micro()); it = static_fill_units(it, milli()); it = static_fill_units(it, centi()); it = static_fill_units(it, deci()); it = static_fill_units(it, deca()); it = static_fill_units(it, hecto()); it = static_fill_units(it, kilo()); it = static_fill_units(it, mega()); it = static_fill_units(it, giga()); it = static_fill_units(it, tera()); it = static_fill_units(it, peta()); it = static_fill_units(it, exa()); it = static_fill_units(it, ratio<1> ()); it = static_fill_units(it, ratio<60> ()); it = static_fill_units(it, ratio<3600> ()); return it; } }; namespace detail { template struct duration_units_default_initializer_t { duration_units_default_initializer_t() { if (!duration_units_default_holder::initialized_) { typedef typename duration_units_default_holder::string_type string_type; duration_units_default_holder::n_d_valid_units_ = new string_type[3]; duration_units_default_holder::valid_units_ = new string_type[19 * 3]; string_type* it = duration_units_default_holder::n_d_valid_units_; it = duration_units_default::static_fill_units(it, ratio<1> ()); it = duration_units_default::static_init_valid_units(duration_units_default_holder::valid_units_); duration_units_default_holder::initialized_ = true; } } ~duration_units_default_initializer_t() { if (duration_units_default_holder::initialized_) { delete[] duration_units_default_holder::n_d_valid_units_; duration_units_default_holder::n_d_valid_units_ = BOOST_NULLPTR; delete[] duration_units_default_holder::valid_units_; duration_units_default_holder::valid_units_ = BOOST_NULLPTR; duration_units_default_holder::initialized_ = false; } } }; namespace /**/ { duration_units_default_initializer_t duration_units_default_initializer; duration_units_default_initializer_t wduration_units_default_initializer; } // namespace } } // chrono } // boost #endif // header