7 #ifndef BOOST_LOCALE_FORMATTING_HPP_INCLUDED 8 #define BOOST_LOCALE_FORMATTING_HPP_INCLUDED 10 #include <boost/locale/time_zone.hpp> 11 #include <boost/locale/util/string.hpp> 12 #include <boost/assert.hpp> 13 #include <boost/cstdint.hpp> 21 # pragma warning(push) 22 # pragma warning(disable : 4275 4251 4231 4660) 25 namespace boost {
namespace locale {
45 display_flags_mask = 31,
47 currency_default = 0 << 5,
48 currency_iso = 1 << 5,
49 currency_national = 2 << 5,
51 currency_flags_mask = 3 << 5,
53 time_default = 0 << 7,
58 time_flags_mask = 7 << 7,
60 date_default = 0 << 10,
62 date_medium = 2 << 10,
65 date_flags_mask = 7 << 10,
96 static ios_info& get(std::ios_base& ios);
99 void display_flags(uint64_t flags);
101 uint64_t display_flags()
const;
104 void currency_flags(uint64_t flags);
106 uint64_t currency_flags()
const;
109 void date_flags(uint64_t flags);
111 uint64_t date_flags()
const;
114 void time_flags(uint64_t flags);
116 uint64_t time_flags()
const;
121 int domain_id()
const;
129 template<
typename CharType>
132 string_set& s = date_time_pattern_set();
136 template<
typename CharType>
139 const string_set& s = date_time_pattern_set();
140 return s.get<CharType>();
150 const string_set& date_time_pattern_set()
const;
151 string_set& date_time_pattern_set();
153 class BOOST_LOCALE_DECL string_set {
157 string_set(
const string_set& other);
158 string_set& operator=(string_set other);
159 void swap(string_set& other);
161 template<
typename Char>
162 void set(
const Char* s)
167 type = &
typeid(Char);
169 ptr =
new char[size];
170 memcpy(ptr, s, size);
173 template<
typename Char>
174 std::basic_string<Char> get()
const 176 if(type == 0 || *type !=
typeid(Char))
177 throw std::bad_cast();
178 std::basic_string<Char> result = reinterpret_cast<const Char*>(ptr);
183 const std::type_info* type;
190 std::string time_zone_;
191 string_set datetime_;
202 inline std::ios_base&
posix(std::ios_base& ios)
210 inline std::ios_base&
number(std::ios_base& ios)
224 inline std::ios_base&
percent(std::ios_base& ios)
231 inline std::ios_base&
date(std::ios_base& ios)
238 inline std::ios_base&
time(std::ios_base& ios)
267 inline std::ios_base&
ordinal(std::ios_base& ios)
366 template<
typename CharType>
368 std::basic_string<CharType>
ftime;
370 void apply(std::basic_ios<CharType>& ios)
const 377 template<
typename CharType>
378 std::basic_ostream<CharType>&
operator<<(std::basic_ostream<CharType>& out,
const add_ftime<CharType>& fmt)
384 template<
typename CharType>
385 std::basic_istream<CharType>&
operator>>(std::basic_istream<CharType>& in,
const add_ftime<CharType>& fmt)
428 template<
typename CharType>
429 #ifdef BOOST_LOCALE_DOXYGEN 432 detail::add_ftime<CharType>
436 detail::add_ftime<CharType> fmt;
442 template<
typename CharType>
443 #ifdef BOOST_LOCALE_DOXYGEN 446 detail::add_ftime<CharType>
450 detail::add_ftime<CharType> fmt;
457 struct set_timezone {
460 template<
typename CharType>
461 std::basic_ostream<CharType>&
operator<<(std::basic_ostream<CharType>& out,
const set_timezone& fmt)
467 template<
typename CharType>
468 std::basic_istream<CharType>&
operator>>(std::basic_istream<CharType>& in,
const set_timezone& fmt)
477 inline std::ios_base&
gmt(std::ios_base& ios)
492 #ifdef BOOST_LOCALE_DOXYGEN 499 detail::set_timezone tz;
506 #ifdef BOOST_LOCALE_DOXYGEN 513 detail::set_timezone tz;
525 # pragma warning(pop)
unspecified_type time_zone(const char *id)
Set time zone using id.
Definition: formatting.hpp:497
std::ios_base & date_long(std::ios_base &ios)
set long date formatting style
Definition: formatting.hpp:351
std::ios_base & time_default(std::ios_base &ios)
set default (medium) time formatting style
Definition: formatting.hpp:295
std::string global()
Get global time zone identifier. If empty, system time zone is used.
std::ios_base & strftime(std::ios_base &ios)
Definition: formatting.hpp:253
std::ios_base & date_medium(std::ios_base &ios)
set medium date formatting style
Definition: formatting.hpp:344
std::ios_base & currency(std::ios_base &ios)
Format currency, number is treated like amount of money.
Definition: formatting.hpp:217
std::ios_base & time_full(std::ios_base &ios)
set full time formatting style
Definition: formatting.hpp:323
std::ios_base & ordinal(std::ios_base &ios)
Write an order of the number like 4th.
Definition: formatting.hpp:267
std::ios_base & date_full(std::ios_base &ios)
set full date formatting style
Definition: formatting.hpp:358
std::ios_base & posix(std::ios_base &ios)
Definition: formatting.hpp:202
std::ios_base & currency_default(std::ios_base &ios)
Set default currency formatting style – national, like "$".
Definition: formatting.hpp:274
std::ios_base & time_medium(std::ios_base &ios)
set medium time formatting style
Definition: formatting.hpp:309
void date_flags(uint64_t flags)
Set flags that define how to format date.
std::ios_base & time_long(std::ios_base &ios)
set long time formatting style
Definition: formatting.hpp:316
std::ios_base & gmt(std::ios_base &ios)
Set GMT time zone to stream.
Definition: formatting.hpp:477
display_flags_type
Definition: formatting.hpp:33
std::ios_base & number(std::ios_base &ios)
Definition: formatting.hpp:210
std::ios_base & percent(std::ios_base &ios)
Format percent, value 0.3 is treated as 30%.
Definition: formatting.hpp:224
std::ios_base & spellout(std::ios_base &ios)
Spell the number, like "one hundred and ten".
Definition: formatting.hpp:260
std::ios_base & currency_national(std::ios_base &ios)
Set national currency formatting style, like "$".
Definition: formatting.hpp:288
time zone name
Definition: formatting.hpp:71
std::ios_base & date(std::ios_base &ios)
Format a date, number is treated as POSIX time.
Definition: formatting.hpp:231
void display_flags(uint64_t flags)
Set flags that define how to format data, e.g. number, spell, currency etc.
static ios_info & get(std::ios_base &ios)
Get ios_info instance for specific stream object.
Char * str_end(Char *str)
Return the end of a C-string, i.e. the pointer to the trailing NULL byte.
Definition: string.hpp:15
This class holds external data beyond existing fmtflags that std::ios_base holds.
Definition: formatting.hpp:86
strftime like formatting
Definition: formatting.hpp:70
unspecified_type time_zone(const std::string &id)
Set time zone using id.
Definition: formatting.hpp:511
void time_flags(uint64_t flags)
Set flags that define how to format time.
std::ios_base & date_default(std::ios_base &ios)
set default (medium) date formatting style
Definition: formatting.hpp:330
std::ios_base & datetime(std::ios_base &ios)
Format a date and time, number is treated as POSIX time.
Definition: formatting.hpp:245
std::basic_ostream< CharType > & operator<<(std::basic_ostream< CharType > &out, const date_time &t)
Definition: date_time.hpp:719
unspecified_type ftime(const std::basic_string< CharType > &format)
Definition: formatting.hpp:434
void date_time_pattern(const std::basic_string< CharType > &str)
Set date/time pattern (strftime like)
Definition: formatting.hpp:130
std::ios_base & time_short(std::ios_base &ios)
set short time formatting style
Definition: formatting.hpp:302
std::ios_base & date_short(std::ios_base &ios)
set short date formatting style
Definition: formatting.hpp:337
std::ios_base & local_time(std::ios_base &ios)
Set local time zone to stream.
Definition: formatting.hpp:484
std::basic_istream< CharType > & operator>>(std::basic_istream< CharType > &in, date_time &t)
Definition: date_time.hpp:739
std::basic_string< CharType > date_time_pattern() const
Get date/time pattern (strftime like)
Definition: formatting.hpp:137
std::ios_base & time(std::ios_base &ios)
Format a time, number is treated as POSIX time.
Definition: formatting.hpp:238
void time_zone(const std::string &)
Set time zone for formatting dates and time.
void currency_flags(uint64_t flags)
Set flags that define how to format currency.
Domain code - for message formatting.
Definition: formatting.hpp:76
pattern_type
Special string patterns that can be used for text formatting.
Definition: formatting.hpp:69
value_type
Special integer values that can be used for formatting.
Definition: formatting.hpp:75
std::ios_base & currency_iso(std::ios_base &ios)
Set ISO currency formatting style, like "USD", (requires ICU >= 4.2)
Definition: formatting.hpp:281