| 1 | //  Boost io/ios_state.hpp header file  --------------------------------------// | 
| 2 |  | 
| 3 | //  Copyright 2002, 2005 Daryle Walker.  Use, modification, and distribution | 
| 4 | //  are subject to the Boost Software License, Version 1.0.  (See accompanying | 
| 5 | //  file LICENSE_1_0.txt or a copy at <http://www.boost.org/LICENSE_1_0.txt>.) | 
| 6 |  | 
| 7 | //  See <http://www.boost.org/libs/io/> for the library's home page. | 
| 8 |  | 
| 9 | #ifndef BOOST_IO_IOS_STATE_HPP | 
| 10 | #define BOOST_IO_IOS_STATE_HPP | 
| 11 |  | 
| 12 | #include <boost/io_fwd.hpp>  // self include | 
| 13 | #include <boost/detail/workaround.hpp> | 
| 14 |  | 
| 15 | #include <ios>        // for std::ios_base, std::basic_ios, etc. | 
| 16 | #ifndef BOOST_NO_STD_LOCALE | 
| 17 | #include <locale>     // for std::locale | 
| 18 | #endif | 
| 19 | #include <ostream>    // for std::basic_ostream | 
| 20 | #include <streambuf>  // for std::basic_streambuf | 
| 21 | #include <string>     // for std::char_traits | 
| 22 |  | 
| 23 |  | 
| 24 | namespace boost | 
| 25 | { | 
| 26 | namespace io | 
| 27 | { | 
| 28 |  | 
| 29 |  | 
| 30 | //  Basic stream state saver class declarations  -----------------------------// | 
| 31 |  | 
| 32 | class ios_flags_saver | 
| 33 | { | 
| 34 | public: | 
| 35 |     typedef ::std::ios_base            state_type; | 
| 36 |     typedef ::std::ios_base::fmtflags  aspect_type; | 
| 37 |  | 
| 38 |     explicit  ios_flags_saver( state_type &s ) | 
| 39 |         : s_save_( s ), a_save_( s.flags() ) | 
| 40 |         {} | 
| 41 |     ios_flags_saver( state_type &s, aspect_type const &a ) | 
| 42 |         : s_save_( s ), a_save_( s.flags(a) ) | 
| 43 |         {} | 
| 44 |     ~ios_flags_saver() | 
| 45 |         { this->restore(); } | 
| 46 |  | 
| 47 |     void  restore() | 
| 48 |         { s_save_.flags( a_save_ ); } | 
| 49 |  | 
| 50 | private: | 
| 51 |     state_type &       s_save_; | 
| 52 |     aspect_type const  a_save_; | 
| 53 |  | 
| 54 |     ios_flags_saver& operator=(const ios_flags_saver&); | 
| 55 | }; | 
| 56 |  | 
| 57 | class ios_precision_saver | 
| 58 | { | 
| 59 | public: | 
| 60 |     typedef ::std::ios_base    state_type; | 
| 61 |     typedef ::std::streamsize  aspect_type; | 
| 62 |  | 
| 63 |     explicit  ios_precision_saver( state_type &s ) | 
| 64 |         : s_save_( s ), a_save_( s.precision() ) | 
| 65 |         {} | 
| 66 |     ios_precision_saver( state_type &s, aspect_type const &a ) | 
| 67 |         : s_save_( s ), a_save_( s.precision(a) ) | 
| 68 |         {} | 
| 69 |     ~ios_precision_saver() | 
| 70 |         { this->restore(); } | 
| 71 |  | 
| 72 |     void  restore() | 
| 73 |         { s_save_.precision( a_save_ ); } | 
| 74 |  | 
| 75 | private: | 
| 76 |     state_type &       s_save_; | 
| 77 |     aspect_type const  a_save_; | 
| 78 |  | 
| 79 |     ios_precision_saver& operator=(const ios_precision_saver&); | 
| 80 | }; | 
| 81 |  | 
| 82 | class ios_width_saver | 
| 83 | { | 
| 84 | public: | 
| 85 |     typedef ::std::ios_base    state_type; | 
| 86 |     typedef ::std::streamsize  aspect_type; | 
| 87 |  | 
| 88 |     explicit  ios_width_saver( state_type &s ) | 
| 89 |         : s_save_( s ), a_save_( s.width() ) | 
| 90 |         {} | 
| 91 |     ios_width_saver( state_type &s, aspect_type const &a ) | 
| 92 |         : s_save_( s ), a_save_( s.width(a) ) | 
| 93 |         {} | 
| 94 |     ~ios_width_saver() | 
| 95 |         { this->restore(); } | 
| 96 |  | 
| 97 |     void  restore() | 
| 98 |         { s_save_.width( a_save_ ); } | 
| 99 |  | 
| 100 | private: | 
| 101 |     state_type &       s_save_; | 
| 102 |     aspect_type const  a_save_; | 
| 103 |     ios_width_saver& operator=(const ios_width_saver&); | 
| 104 | }; | 
| 105 |  | 
| 106 |  | 
| 107 | //  Advanced stream state saver class template declarations  -----------------// | 
| 108 |  | 
| 109 | template < typename Ch, class Tr > | 
| 110 | class basic_ios_iostate_saver | 
| 111 | { | 
| 112 | public: | 
| 113 |     typedef ::std::basic_ios<Ch, Tr>  state_type; | 
| 114 |     typedef ::std::ios_base::iostate  aspect_type; | 
| 115 |  | 
| 116 |     explicit  basic_ios_iostate_saver( state_type &s ) | 
| 117 |         : s_save_( s ), a_save_( s.rdstate() ) | 
| 118 |         {} | 
| 119 |     basic_ios_iostate_saver( state_type &s, aspect_type const &a ) | 
| 120 |         : s_save_( s ), a_save_( s.rdstate() ) | 
| 121 |         { s.clear(a); } | 
| 122 |     ~basic_ios_iostate_saver() | 
| 123 |         { this->restore(); } | 
| 124 |  | 
| 125 |     void  restore() | 
| 126 |         { s_save_.clear( a_save_ ); } | 
| 127 |  | 
| 128 | private: | 
| 129 |     state_type &       s_save_; | 
| 130 |     aspect_type const  a_save_; | 
| 131 |     basic_ios_iostate_saver& operator=(const basic_ios_iostate_saver&); | 
| 132 | }; | 
| 133 |  | 
| 134 | template < typename Ch, class Tr > | 
| 135 | class basic_ios_exception_saver | 
| 136 | { | 
| 137 | public: | 
| 138 |     typedef ::std::basic_ios<Ch, Tr>  state_type; | 
| 139 |     typedef ::std::ios_base::iostate  aspect_type; | 
| 140 |  | 
| 141 |     explicit  basic_ios_exception_saver( state_type &s ) | 
| 142 |         : s_save_( s ), a_save_( s.exceptions() ) | 
| 143 |         {} | 
| 144 | #if BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x582)) | 
| 145 |     basic_ios_exception_saver( state_type &s, aspect_type a ) | 
| 146 | #else | 
| 147 |     basic_ios_exception_saver( state_type &s, aspect_type const &a ) | 
| 148 | #endif | 
| 149 |         : s_save_( s ), a_save_( s.exceptions() ) | 
| 150 |         { s.exceptions(a); } | 
| 151 |     ~basic_ios_exception_saver() | 
| 152 |         { this->restore(); } | 
| 153 |  | 
| 154 |     void  restore() | 
| 155 |         { s_save_.exceptions( a_save_ ); } | 
| 156 |  | 
| 157 | private: | 
| 158 |     state_type &       s_save_; | 
| 159 |     aspect_type const  a_save_; | 
| 160 |     basic_ios_exception_saver& operator=(const basic_ios_exception_saver&); | 
| 161 | }; | 
| 162 |  | 
| 163 | template < typename Ch, class Tr > | 
| 164 | class basic_ios_tie_saver | 
| 165 | { | 
| 166 | public: | 
| 167 |     typedef ::std::basic_ios<Ch, Tr>        state_type; | 
| 168 |     typedef ::std::basic_ostream<Ch, Tr> *  aspect_type; | 
| 169 |  | 
| 170 |     explicit  basic_ios_tie_saver( state_type &s ) | 
| 171 |         : s_save_( s ), a_save_( s.tie() ) | 
| 172 |         {} | 
| 173 |     basic_ios_tie_saver( state_type &s, aspect_type const &a ) | 
| 174 |         : s_save_( s ), a_save_( s.tie(a) ) | 
| 175 |         {} | 
| 176 |     ~basic_ios_tie_saver() | 
| 177 |         { this->restore(); } | 
| 178 |  | 
| 179 |     void  restore() | 
| 180 |         { s_save_.tie( a_save_ ); } | 
| 181 |  | 
| 182 | private: | 
| 183 |     state_type &       s_save_; | 
| 184 |     aspect_type const  a_save_; | 
| 185 |     basic_ios_tie_saver& operator=(const basic_ios_tie_saver&); | 
| 186 | }; | 
| 187 |  | 
| 188 | template < typename Ch, class Tr > | 
| 189 | class basic_ios_rdbuf_saver | 
| 190 | { | 
| 191 | public: | 
| 192 |     typedef ::std::basic_ios<Ch, Tr>          state_type; | 
| 193 |     typedef ::std::basic_streambuf<Ch, Tr> *  aspect_type; | 
| 194 |  | 
| 195 |     explicit  basic_ios_rdbuf_saver( state_type &s ) | 
| 196 |         : s_save_( s ), a_save_( s.rdbuf() ) | 
| 197 |         {} | 
| 198 |     basic_ios_rdbuf_saver( state_type &s, aspect_type const &a ) | 
| 199 |         : s_save_( s ), a_save_( s.rdbuf(a) ) | 
| 200 |         {} | 
| 201 |     ~basic_ios_rdbuf_saver() | 
| 202 |         { this->restore(); } | 
| 203 |  | 
| 204 |     void  restore() | 
| 205 |         { s_save_.rdbuf( a_save_ ); } | 
| 206 |  | 
| 207 | private: | 
| 208 |     state_type &       s_save_; | 
| 209 |     aspect_type const  a_save_; | 
| 210 |     basic_ios_rdbuf_saver& operator=(const basic_ios_rdbuf_saver&); | 
| 211 | }; | 
| 212 |  | 
| 213 | template < typename Ch, class Tr > | 
| 214 | class basic_ios_fill_saver | 
| 215 | { | 
| 216 | public: | 
| 217 |     typedef ::std::basic_ios<Ch, Tr>        state_type; | 
| 218 |     typedef typename state_type::char_type  aspect_type; | 
| 219 |  | 
| 220 |     explicit  basic_ios_fill_saver( state_type &s ) | 
| 221 |         : s_save_( s ), a_save_( s.fill() ) | 
| 222 |         {} | 
| 223 |     basic_ios_fill_saver( state_type &s, aspect_type const &a ) | 
| 224 |         : s_save_( s ), a_save_( s.fill(a) ) | 
| 225 |         {} | 
| 226 |     ~basic_ios_fill_saver() | 
| 227 |         { this->restore(); } | 
| 228 |  | 
| 229 |     void  restore() | 
| 230 |         { s_save_.fill( a_save_ ); } | 
| 231 |  | 
| 232 | private: | 
| 233 |     state_type &       s_save_; | 
| 234 |     aspect_type const  a_save_; | 
| 235 |     basic_ios_fill_saver& operator=(const basic_ios_fill_saver&); | 
| 236 | }; | 
| 237 |  | 
| 238 | #ifndef BOOST_NO_STD_LOCALE | 
| 239 | template < typename Ch, class Tr > | 
| 240 | class basic_ios_locale_saver | 
| 241 | { | 
| 242 | public: | 
| 243 |     typedef ::std::basic_ios<Ch, Tr> state_type; | 
| 244 |     typedef ::std::locale aspect_type; | 
| 245 |  | 
| 246 |     explicit basic_ios_locale_saver( state_type &s ) | 
| 247 |         : s_save_( s ), a_save_( s.getloc() ) | 
| 248 |         {} | 
| 249 |     basic_ios_locale_saver( state_type &s, aspect_type const &a ) | 
| 250 |         : s_save_( s ), a_save_( s.imbue(a) ) | 
| 251 |         {} | 
| 252 |     ~basic_ios_locale_saver() | 
| 253 |         { this->restore(); } | 
| 254 |  | 
| 255 |     void  restore() | 
| 256 |         { s_save_.imbue( a_save_ ); } | 
| 257 |  | 
| 258 | private: | 
| 259 |     state_type &       s_save_; | 
| 260 |     aspect_type const  a_save_; | 
| 261 |     basic_ios_locale_saver& operator=(const basic_ios_locale_saver&); | 
| 262 | }; | 
| 263 | #endif | 
| 264 |  | 
| 265 |  | 
| 266 | //  User-defined stream state saver class declarations  ----------------------// | 
| 267 |  | 
| 268 | class ios_iword_saver | 
| 269 | { | 
| 270 | public: | 
| 271 |     typedef ::std::ios_base  state_type; | 
| 272 |     typedef int              index_type; | 
| 273 |     typedef long             aspect_type; | 
| 274 |  | 
| 275 |     explicit ios_iword_saver( state_type &s, index_type i ) | 
| 276 |         : s_save_( s ), a_save_( s.iword(i) ), i_save_( i ) | 
| 277 |         {} | 
| 278 |     ios_iword_saver( state_type &s, index_type i, aspect_type const &a ) | 
| 279 |         : s_save_( s ), a_save_( s.iword(i) ), i_save_( i ) | 
| 280 |         { s.iword(i) = a; } | 
| 281 |     ~ios_iword_saver() | 
| 282 |         { this->restore(); } | 
| 283 |  | 
| 284 |     void  restore() | 
| 285 |         { s_save_.iword( i_save_ ) = a_save_; } | 
| 286 |  | 
| 287 | private: | 
| 288 |     state_type &       s_save_; | 
| 289 |     aspect_type const  a_save_; | 
| 290 |     index_type const   i_save_; | 
| 291 |  | 
| 292 |     ios_iword_saver& operator=(const ios_iword_saver&); | 
| 293 | }; | 
| 294 |  | 
| 295 | class ios_pword_saver | 
| 296 | { | 
| 297 | public: | 
| 298 |     typedef ::std::ios_base  state_type; | 
| 299 |     typedef int              index_type; | 
| 300 |     typedef void *           aspect_type; | 
| 301 |  | 
| 302 |     explicit  ios_pword_saver( state_type &s, index_type i ) | 
| 303 |         : s_save_( s ), a_save_( s.pword(i) ), i_save_( i ) | 
| 304 |         {} | 
| 305 |     ios_pword_saver( state_type &s, index_type i, aspect_type const &a ) | 
| 306 |         : s_save_( s ), a_save_( s.pword(i) ), i_save_( i ) | 
| 307 |         { s.pword(i) = a; } | 
| 308 |     ~ios_pword_saver() | 
| 309 |         { this->restore(); } | 
| 310 |  | 
| 311 |     void  restore() | 
| 312 |         { s_save_.pword( i_save_ ) = a_save_; } | 
| 313 |  | 
| 314 | private: | 
| 315 |     state_type &       s_save_; | 
| 316 |     aspect_type const  a_save_; | 
| 317 |     index_type const   i_save_; | 
| 318 |  | 
| 319 |     ios_pword_saver operator=(const ios_pword_saver&); | 
| 320 | }; | 
| 321 |  | 
| 322 |  | 
| 323 | //  Combined stream state saver class (template) declarations  ---------------// | 
| 324 |  | 
| 325 | class ios_base_all_saver | 
| 326 | { | 
| 327 | public: | 
| 328 |     typedef ::std::ios_base  state_type; | 
| 329 |  | 
| 330 |     explicit  ios_base_all_saver( state_type &s ) | 
| 331 |         : s_save_( s ), a1_save_( s.flags() ), a2_save_( s.precision() ) | 
| 332 |         , a3_save_( s.width() ) | 
| 333 |         {} | 
| 334 |  | 
| 335 |     ~ios_base_all_saver() | 
| 336 |         { this->restore(); } | 
| 337 |  | 
| 338 |     void  restore() | 
| 339 |     { | 
| 340 |         s_save_.width( a3_save_ ); | 
| 341 |         s_save_.precision( a2_save_ ); | 
| 342 |         s_save_.flags( a1_save_ ); | 
| 343 |     } | 
| 344 |  | 
| 345 | private: | 
| 346 |     state_type &                s_save_; | 
| 347 |     state_type::fmtflags const  a1_save_; | 
| 348 |     ::std::streamsize const     a2_save_; | 
| 349 |     ::std::streamsize const     a3_save_; | 
| 350 |  | 
| 351 |     ios_base_all_saver& operator=(const ios_base_all_saver&); | 
| 352 | }; | 
| 353 |  | 
| 354 | template < typename Ch, class Tr > | 
| 355 | class basic_ios_all_saver | 
| 356 | { | 
| 357 | public: | 
| 358 |     typedef ::std::basic_ios<Ch, Tr>  state_type; | 
| 359 |  | 
| 360 |     explicit  basic_ios_all_saver( state_type &s ) | 
| 361 |         : s_save_( s ), a1_save_( s.flags() ), a2_save_( s.precision() ) | 
| 362 |         , a3_save_( s.width() ), a4_save_( s.rdstate() ) | 
| 363 |         , a5_save_( s.exceptions() ), a6_save_( s.tie() ) | 
| 364 |         , a7_save_( s.rdbuf() ), a8_save_( s.fill() ) | 
| 365 |         #ifndef BOOST_NO_STD_LOCALE | 
| 366 |         , a9_save_( s.getloc() ) | 
| 367 |         #endif | 
| 368 |         {} | 
| 369 |  | 
| 370 |     ~basic_ios_all_saver() | 
| 371 |         { this->restore(); } | 
| 372 |  | 
| 373 |     void  restore() | 
| 374 |     { | 
| 375 |         #ifndef BOOST_NO_STD_LOCALE | 
| 376 |         s_save_.imbue( a9_save_ ); | 
| 377 |         #endif | 
| 378 |         s_save_.fill( a8_save_ ); | 
| 379 |         s_save_.rdbuf( a7_save_ ); | 
| 380 |         s_save_.tie( a6_save_ ); | 
| 381 |         s_save_.exceptions( a5_save_ ); | 
| 382 |         s_save_.clear( a4_save_ ); | 
| 383 |         s_save_.width( a3_save_ ); | 
| 384 |         s_save_.precision( a2_save_ ); | 
| 385 |         s_save_.flags( a1_save_ ); | 
| 386 |     } | 
| 387 |  | 
| 388 | private: | 
| 389 |     state_type &                            s_save_; | 
| 390 |     typename state_type::fmtflags const     a1_save_; | 
| 391 |     ::std::streamsize const                 a2_save_; | 
| 392 |     ::std::streamsize const                 a3_save_; | 
| 393 |     typename state_type::iostate const      a4_save_; | 
| 394 |     typename state_type::iostate const      a5_save_; | 
| 395 |     ::std::basic_ostream<Ch, Tr> * const    a6_save_; | 
| 396 |     ::std::basic_streambuf<Ch, Tr> * const  a7_save_; | 
| 397 |     typename state_type::char_type const    a8_save_; | 
| 398 |     #ifndef BOOST_NO_STD_LOCALE | 
| 399 |     ::std::locale const                     a9_save_; | 
| 400 |     #endif | 
| 401 |  | 
| 402 |     basic_ios_all_saver& operator=(const basic_ios_all_saver&); | 
| 403 | }; | 
| 404 |  | 
| 405 | class ios_all_word_saver | 
| 406 | { | 
| 407 | public: | 
| 408 |     typedef ::std::ios_base  state_type; | 
| 409 |     typedef int              index_type; | 
| 410 |  | 
| 411 |     ios_all_word_saver( state_type &s, index_type i ) | 
| 412 |         : s_save_( s ), i_save_( i ), a1_save_( s.iword(i) ) | 
| 413 |         , a2_save_( s.pword(i) ) | 
| 414 |         {} | 
| 415 |  | 
| 416 |     ~ios_all_word_saver() | 
| 417 |         { this->restore(); } | 
| 418 |  | 
| 419 |     void  restore() | 
| 420 |     { | 
| 421 |         s_save_.pword( i_save_ ) = a2_save_; | 
| 422 |         s_save_.iword( i_save_ ) = a1_save_; | 
| 423 |     } | 
| 424 |  | 
| 425 | private: | 
| 426 |     state_type &      s_save_; | 
| 427 |     index_type const  i_save_; | 
| 428 |     long const        a1_save_; | 
| 429 |     void * const      a2_save_; | 
| 430 |  | 
| 431 |     ios_all_word_saver& operator=(const ios_all_word_saver&); | 
| 432 | }; | 
| 433 |  | 
| 434 |  | 
| 435 | }  // namespace io | 
| 436 | }  // namespace boost | 
| 437 |  | 
| 438 |  | 
| 439 | #endif  // BOOST_IO_IOS_STATE_HPP | 
| 440 |  |