| 1 | // Standard stream manipulators -*- C++ -*-  |
| 2 |   |
| 3 | // Copyright (C) 1997-2019 Free Software Foundation, Inc.  |
| 4 | //  |
| 5 | // This file is part of the GNU ISO C++ Library. This library is free  |
| 6 | // software; you can redistribute it and/or modify it under the  |
| 7 | // terms of the GNU General Public License as published by the  |
| 8 | // Free Software Foundation; either version 3, or (at your option)  |
| 9 | // any later version.  |
| 10 |   |
| 11 | // This library is distributed in the hope that it will be useful,  |
| 12 | // but WITHOUT ANY WARRANTY; without even the implied warranty of  |
| 13 | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the  |
| 14 | // GNU General Public License for more details.  |
| 15 |   |
| 16 | // Under Section 7 of GPL version 3, you are granted additional  |
| 17 | // permissions described in the GCC Runtime Library Exception, version  |
| 18 | // 3.1, as published by the Free Software Foundation.  |
| 19 |   |
| 20 | // You should have received a copy of the GNU General Public License and  |
| 21 | // a copy of the GCC Runtime Library Exception along with this program;  |
| 22 | // see the files COPYING3 and COPYING.RUNTIME respectively. If not, see  |
| 23 | // <http://www.gnu.org/licenses/>.  |
| 24 |   |
| 25 | /** @file include/iomanip  |
| 26 | * This is a Standard C++ Library header.  |
| 27 | */  |
| 28 |   |
| 29 | //  |
| 30 | // ISO C++ 14882: 27.6.3 Standard manipulators  |
| 31 | //  |
| 32 |   |
| 33 | #ifndef _GLIBCXX_IOMANIP  |
| 34 | #define _GLIBCXX_IOMANIP 1  |
| 35 |   |
| 36 | #pragma GCC system_header  |
| 37 |   |
| 38 | #include <bits/c++config.h>  |
| 39 | #include <iosfwd>  |
| 40 | #include <bits/ios_base.h>  |
| 41 |   |
| 42 | #if __cplusplus >= 201103L  |
| 43 | #include <locale>  |
| 44 | #if __cplusplus > 201103L  |
| 45 | #include <bits/quoted_string.h>  |
| 46 | #endif  |
| 47 | #endif  |
| 48 |   |
| 49 | namespace std _GLIBCXX_VISIBILITY(default)  |
| 50 | {  |
| 51 | _GLIBCXX_BEGIN_NAMESPACE_VERSION  |
| 52 |   |
| 53 | // [27.6.3] standard manipulators  |
| 54 | // Also see DR 183.  |
| 55 |   |
| 56 | struct _Resetiosflags { ios_base::fmtflags _M_mask; };  |
| 57 |   |
| 58 | /**  |
| 59 | * @brief Manipulator for @c setf.  |
| 60 | * @param __mask A format flags mask.  |
| 61 | *  |
| 62 | * Sent to a stream object, this manipulator resets the specified flags,  |
| 63 | * via @e stream.setf(0,__mask).  |
| 64 | */  |
| 65 | inline _Resetiosflags  |
| 66 | resetiosflags(ios_base::fmtflags __mask)  |
| 67 | { return { __mask }; }  |
| 68 |   |
| 69 | template<typename _CharT, typename _Traits>  |
| 70 | inline basic_istream<_CharT, _Traits>&  |
| 71 | operator>>(basic_istream<_CharT, _Traits>& __is, _Resetiosflags __f)  |
| 72 | {  |
| 73 | __is.setf(ios_base::fmtflags(0), __f._M_mask);  |
| 74 | return __is;  |
| 75 | }  |
| 76 |   |
| 77 | template<typename _CharT, typename _Traits>  |
| 78 | inline basic_ostream<_CharT, _Traits>&  |
| 79 | operator<<(basic_ostream<_CharT, _Traits>& __os, _Resetiosflags __f)  |
| 80 | {  |
| 81 | __os.setf(ios_base::fmtflags(0), __f._M_mask);  |
| 82 | return __os;  |
| 83 | }  |
| 84 |   |
| 85 |   |
| 86 | struct _Setiosflags { ios_base::fmtflags _M_mask; };  |
| 87 |   |
| 88 | /**  |
| 89 | * @brief Manipulator for @c setf.  |
| 90 | * @param __mask A format flags mask.  |
| 91 | *  |
| 92 | * Sent to a stream object, this manipulator sets the format flags  |
| 93 | * to @a __mask.  |
| 94 | */  |
| 95 | inline _Setiosflags  |
| 96 | setiosflags(ios_base::fmtflags __mask)  |
| 97 | { return { __mask }; }  |
| 98 |   |
| 99 | template<typename _CharT, typename _Traits>  |
| 100 | inline basic_istream<_CharT, _Traits>&  |
| 101 | operator>>(basic_istream<_CharT, _Traits>& __is, _Setiosflags __f)  |
| 102 | {  |
| 103 | __is.setf(__f._M_mask);  |
| 104 | return __is;  |
| 105 | }  |
| 106 |   |
| 107 | template<typename _CharT, typename _Traits>  |
| 108 | inline basic_ostream<_CharT, _Traits>&  |
| 109 | operator<<(basic_ostream<_CharT, _Traits>& __os, _Setiosflags __f)  |
| 110 | {  |
| 111 | __os.setf(__f._M_mask);  |
| 112 | return __os;  |
| 113 | }  |
| 114 |   |
| 115 |   |
| 116 | struct _Setbase { int _M_base; };  |
| 117 |   |
| 118 | /**  |
| 119 | * @brief Manipulator for @c setf.  |
| 120 | * @param __base A numeric base.  |
| 121 | *  |
| 122 | * Sent to a stream object, this manipulator changes the  |
| 123 | * @c ios_base::basefield flags to @c oct, @c dec, or @c hex when @a base  |
| 124 | * is 8, 10, or 16, accordingly, and to 0 if @a __base is any other value.  |
| 125 | */  |
| 126 | inline _Setbase  |
| 127 | setbase(int __base)  |
| 128 | { return { __base }; }  |
| 129 |   |
| 130 | template<typename _CharT, typename _Traits>  |
| 131 | inline basic_istream<_CharT, _Traits>&  |
| 132 | operator>>(basic_istream<_CharT, _Traits>& __is, _Setbase __f)  |
| 133 | {  |
| 134 | __is.setf(__f._M_base == 8 ? ios_base::oct :  |
| 135 | __f._M_base == 10 ? ios_base::dec :  |
| 136 | __f._M_base == 16 ? ios_base::hex :  |
| 137 | ios_base::fmtflags(0), ios_base::basefield);  |
| 138 | return __is;  |
| 139 | }  |
| 140 |   |
| 141 | template<typename _CharT, typename _Traits>  |
| 142 | inline basic_ostream<_CharT, _Traits>&  |
| 143 | operator<<(basic_ostream<_CharT, _Traits>& __os, _Setbase __f)  |
| 144 | {  |
| 145 | __os.setf(__f._M_base == 8 ? ios_base::oct :  |
| 146 | __f._M_base == 10 ? ios_base::dec :  |
| 147 | __f._M_base == 16 ? ios_base::hex :  |
| 148 | ios_base::fmtflags(0), ios_base::basefield);  |
| 149 | return __os;  |
| 150 | }  |
| 151 |   |
| 152 |   |
| 153 | template<typename _CharT>  |
| 154 | struct _Setfill { _CharT _M_c; };  |
| 155 |   |
| 156 | /**  |
| 157 | * @brief Manipulator for @c fill.  |
| 158 | * @param __c The new fill character.  |
| 159 | *  |
| 160 | * Sent to a stream object, this manipulator calls @c fill(__c) for that  |
| 161 | * object.  |
| 162 | */  |
| 163 | template<typename _CharT>  |
| 164 | inline _Setfill<_CharT>  |
| 165 | setfill(_CharT __c)  |
| 166 | { return { __c }; }  |
| 167 |   |
| 168 | template<typename _CharT, typename _Traits>  |
| 169 | inline basic_istream<_CharT, _Traits>&  |
| 170 | operator>>(basic_istream<_CharT, _Traits>& __is, _Setfill<_CharT> __f)  |
| 171 | {  |
| 172 | __is.fill(__f._M_c);  |
| 173 | return __is;  |
| 174 | }  |
| 175 |   |
| 176 | template<typename _CharT, typename _Traits>  |
| 177 | inline basic_ostream<_CharT, _Traits>&  |
| 178 | operator<<(basic_ostream<_CharT, _Traits>& __os, _Setfill<_CharT> __f)  |
| 179 | {  |
| 180 | __os.fill(__f._M_c);  |
| 181 | return __os;  |
| 182 | }  |
| 183 |   |
| 184 |   |
| 185 | struct _Setprecision { int _M_n; };  |
| 186 |   |
| 187 | /**  |
| 188 | * @brief Manipulator for @c precision.  |
| 189 | * @param __n The new precision.  |
| 190 | *  |
| 191 | * Sent to a stream object, this manipulator calls @c precision(__n) for  |
| 192 | * that object.  |
| 193 | */  |
| 194 | inline _Setprecision  |
| 195 | setprecision(int __n)  |
| 196 | { return { __n }; }  |
| 197 |   |
| 198 | template<typename _CharT, typename _Traits>  |
| 199 | inline basic_istream<_CharT, _Traits>&  |
| 200 | operator>>(basic_istream<_CharT, _Traits>& __is, _Setprecision __f)  |
| 201 | {  |
| 202 | __is.precision(__f._M_n);  |
| 203 | return __is;  |
| 204 | }  |
| 205 |   |
| 206 | template<typename _CharT, typename _Traits>  |
| 207 | inline basic_ostream<_CharT, _Traits>&  |
| 208 | operator<<(basic_ostream<_CharT, _Traits>& __os, _Setprecision __f)  |
| 209 | {  |
| 210 | __os.precision(__f._M_n);  |
| 211 | return __os;  |
| 212 | }  |
| 213 |   |
| 214 |   |
| 215 | struct _Setw { int _M_n; };  |
| 216 |   |
| 217 | /**  |
| 218 | * @brief Manipulator for @c width.  |
| 219 | * @param __n The new width.  |
| 220 | *  |
| 221 | * Sent to a stream object, this manipulator calls @c width(__n) for  |
| 222 | * that object.  |
| 223 | */  |
| 224 | inline _Setw  |
| 225 | setw(int __n)  |
| 226 | { return { __n }; }  |
| 227 |   |
| 228 | template<typename _CharT, typename _Traits>  |
| 229 | inline basic_istream<_CharT, _Traits>&  |
| 230 | operator>>(basic_istream<_CharT, _Traits>& __is, _Setw __f)  |
| 231 | {  |
| 232 | __is.width(__f._M_n);  |
| 233 | return __is;  |
| 234 | }  |
| 235 |   |
| 236 | template<typename _CharT, typename _Traits>  |
| 237 | inline basic_ostream<_CharT, _Traits>&  |
| 238 | operator<<(basic_ostream<_CharT, _Traits>& __os, _Setw __f)  |
| 239 | {  |
| 240 | __os.width(__f._M_n);  |
| 241 | return __os;  |
| 242 | }  |
| 243 |   |
| 244 | #if __cplusplus >= 201103L  |
| 245 |   |
| 246 | template<typename _MoneyT>  |
| 247 | struct _Get_money { _MoneyT& _M_mon; bool _M_intl; };  |
| 248 |   |
| 249 | /**  |
| 250 | * @brief Extended manipulator for extracting money.  |
| 251 | * @param __mon Either long double or a specialization of @c basic_string.  |
| 252 | * @param __intl A bool indicating whether international format  |
| 253 | * is to be used.  |
| 254 | *  |
| 255 | * Sent to a stream object, this manipulator extracts @a __mon.  |
| 256 | */  |
| 257 | template<typename _MoneyT>  |
| 258 | inline _Get_money<_MoneyT>  |
| 259 | get_money(_MoneyT& __mon, bool __intl = false)  |
| 260 | { return { __mon, __intl }; }  |
| 261 |   |
| 262 | template<typename _CharT, typename _Traits, typename _MoneyT>  |
| 263 | basic_istream<_CharT, _Traits>&  |
| 264 | operator>>(basic_istream<_CharT, _Traits>& __is, _Get_money<_MoneyT> __f)  |
| 265 | {  |
| 266 | typename basic_istream<_CharT, _Traits>::sentry __cerb(__is, false);  |
| 267 | if (__cerb)  |
| 268 | {  |
| 269 | ios_base::iostate __err = ios_base::goodbit;  |
| 270 | __try  |
| 271 | {  |
| 272 | typedef istreambuf_iterator<_CharT, _Traits> _Iter;  |
| 273 | typedef money_get<_CharT, _Iter> _MoneyGet;  |
| 274 |   |
| 275 | const _MoneyGet& __mg = use_facet<_MoneyGet>(__is.getloc());  |
| 276 | __mg.get(_Iter(__is.rdbuf()), _Iter(), __f._M_intl,  |
| 277 | __is, __err, __f._M_mon);  |
| 278 | }  |
| 279 | __catch(__cxxabiv1::__forced_unwind&)  |
| 280 | {  |
| 281 | __is._M_setstate(ios_base::badbit);  |
| 282 | __throw_exception_again;  |
| 283 | }  |
| 284 | __catch(...)  |
| 285 | { __is._M_setstate(ios_base::badbit); }  |
| 286 | if (__err)  |
| 287 | __is.setstate(__err);  |
| 288 | }  |
| 289 | return __is;  |
| 290 | }  |
| 291 |   |
| 292 |   |
| 293 | template<typename _MoneyT>  |
| 294 | struct _Put_money { const _MoneyT& _M_mon; bool _M_intl; };  |
| 295 |   |
| 296 | /**  |
| 297 | * @brief Extended manipulator for inserting money.  |
| 298 | * @param __mon Either long double or a specialization of @c basic_string.  |
| 299 | * @param __intl A bool indicating whether international format  |
| 300 | * is to be used.  |
| 301 | *  |
| 302 | * Sent to a stream object, this manipulator inserts @a __mon.  |
| 303 | */  |
| 304 | template<typename _MoneyT>  |
| 305 | inline _Put_money<_MoneyT>  |
| 306 | put_money(const _MoneyT& __mon, bool __intl = false)  |
| 307 | { return { __mon, __intl }; }  |
| 308 |   |
| 309 | template<typename _CharT, typename _Traits, typename _MoneyT>  |
| 310 | basic_ostream<_CharT, _Traits>&  |
| 311 | operator<<(basic_ostream<_CharT, _Traits>& __os, _Put_money<_MoneyT> __f)  |
| 312 | {  |
| 313 | typename basic_ostream<_CharT, _Traits>::sentry __cerb(__os);  |
| 314 | if (__cerb)  |
| 315 | {  |
| 316 | ios_base::iostate __err = ios_base::goodbit;  |
| 317 | __try  |
| 318 | {  |
| 319 | typedef ostreambuf_iterator<_CharT, _Traits> _Iter;  |
| 320 | typedef money_put<_CharT, _Iter> _MoneyPut;  |
| 321 |   |
| 322 | const _MoneyPut& __mp = use_facet<_MoneyPut>(__os.getloc());  |
| 323 | if (__mp.put(_Iter(__os.rdbuf()), __f._M_intl, __os,  |
| 324 | __os.fill(), __f._M_mon).failed())  |
| 325 | __err |= ios_base::badbit;  |
| 326 | }  |
| 327 | __catch(__cxxabiv1::__forced_unwind&)  |
| 328 | {  |
| 329 | __os._M_setstate(ios_base::badbit);  |
| 330 | __throw_exception_again;  |
| 331 | }  |
| 332 | __catch(...)  |
| 333 | { __os._M_setstate(ios_base::badbit); }  |
| 334 | if (__err)  |
| 335 | __os.setstate(__err);  |
| 336 | }  |
| 337 | return __os;  |
| 338 | }  |
| 339 |   |
| 340 | template<typename _CharT>  |
| 341 | struct _Put_time  |
| 342 | {  |
| 343 | const std::tm* _M_tmb;  |
| 344 | const _CharT* _M_fmt;  |
| 345 | };  |
| 346 |   |
| 347 | /**  |
| 348 | * @brief Extended manipulator for formatting time.  |
| 349 | *  |
| 350 | * This manipulator uses time_put::put to format time.  |
| 351 | * [ext.manip]  |
| 352 | *  |
| 353 | * @param __tmb struct tm time data to format.  |
| 354 | * @param __fmt format string.  |
| 355 | */  |
| 356 | template<typename _CharT>  |
| 357 | inline _Put_time<_CharT>  |
| 358 | put_time(const std::tm* __tmb, const _CharT* __fmt)  |
| 359 | { return { __tmb, __fmt }; }  |
| 360 |   |
| 361 | template<typename _CharT, typename _Traits>  |
| 362 | basic_ostream<_CharT, _Traits>&  |
| 363 | operator<<(basic_ostream<_CharT, _Traits>& __os, _Put_time<_CharT> __f)  |
| 364 | {  |
| 365 | typename basic_ostream<_CharT, _Traits>::sentry __cerb(__os);  |
| 366 | if (__cerb)  |
| 367 | {  |
| 368 | ios_base::iostate __err = ios_base::goodbit;  |
| 369 | __try  |
| 370 | {  |
| 371 | typedef ostreambuf_iterator<_CharT, _Traits> _Iter;  |
| 372 | typedef time_put<_CharT, _Iter> _TimePut;  |
| 373 |   |
| 374 | const _CharT* const __fmt_end = __f._M_fmt +  |
| 375 | _Traits::length(__f._M_fmt);  |
| 376 |   |
| 377 | const _TimePut& __mp = use_facet<_TimePut>(__os.getloc());  |
| 378 | if (__mp.put(_Iter(__os.rdbuf()), __os, __os.fill(),  |
| 379 | __f._M_tmb, __f._M_fmt, __fmt_end).failed())  |
| 380 | __err |= ios_base::badbit;  |
| 381 | }  |
| 382 | __catch(__cxxabiv1::__forced_unwind&)  |
| 383 | {  |
| 384 | __os._M_setstate(ios_base::badbit);  |
| 385 | __throw_exception_again;  |
| 386 | }  |
| 387 | __catch(...)  |
| 388 | { __os._M_setstate(ios_base::badbit); }  |
| 389 | if (__err)  |
| 390 | __os.setstate(__err);  |
| 391 | }  |
| 392 | return __os;  |
| 393 | }  |
| 394 |   |
| 395 | template<typename _CharT>  |
| 396 | struct _Get_time  |
| 397 | {  |
| 398 | std::tm* _M_tmb;  |
| 399 | const _CharT* _M_fmt;  |
| 400 | };  |
| 401 |   |
| 402 | /**  |
| 403 | * @brief Extended manipulator for extracting time.  |
| 404 | *  |
| 405 | * This manipulator uses time_get::get to extract time.  |
| 406 | * [ext.manip]  |
| 407 | *  |
| 408 | * @param __tmb struct to extract the time data to.  |
| 409 | * @param __fmt format string.  |
| 410 | */  |
| 411 | template<typename _CharT>  |
| 412 | inline _Get_time<_CharT>  |
| 413 | get_time(std::tm* __tmb, const _CharT* __fmt)  |
| 414 | { return { __tmb, __fmt }; }  |
| 415 |   |
| 416 | template<typename _CharT, typename _Traits>  |
| 417 | basic_istream<_CharT, _Traits>&  |
| 418 | operator>>(basic_istream<_CharT, _Traits>& __is, _Get_time<_CharT> __f)  |
| 419 | {  |
| 420 | typename basic_istream<_CharT, _Traits>::sentry __cerb(__is, false);  |
| 421 | if (__cerb)  |
| 422 | {  |
| 423 | ios_base::iostate __err = ios_base::goodbit;  |
| 424 | __try  |
| 425 | {  |
| 426 | typedef istreambuf_iterator<_CharT, _Traits> _Iter;  |
| 427 | typedef time_get<_CharT, _Iter> _TimeGet;  |
| 428 |   |
| 429 | const _CharT* const __fmt_end = __f._M_fmt +  |
| 430 | _Traits::length(__f._M_fmt);  |
| 431 |   |
| 432 | const _TimeGet& __mg = use_facet<_TimeGet>(__is.getloc());  |
| 433 | __mg.get(_Iter(__is.rdbuf()), _Iter(), __is,  |
| 434 | __err, __f._M_tmb, __f._M_fmt, __fmt_end);  |
| 435 | }  |
| 436 | __catch(__cxxabiv1::__forced_unwind&)  |
| 437 | {  |
| 438 | __is._M_setstate(ios_base::badbit);  |
| 439 | __throw_exception_again;  |
| 440 | }  |
| 441 | __catch(...)  |
| 442 | { __is._M_setstate(ios_base::badbit); }  |
| 443 | if (__err)  |
| 444 | __is.setstate(__err);  |
| 445 | }  |
| 446 | return __is;  |
| 447 | }  |
| 448 |   |
| 449 | #if __cplusplus >= 201402L  |
| 450 |   |
| 451 | #define __cpp_lib_quoted_string_io 201304  |
| 452 |   |
| 453 | /**  |
| 454 | * @brief Manipulator for quoted strings.  |
| 455 | * @param __string String to quote.  |
| 456 | * @param __delim Character to quote string with.  |
| 457 | * @param __escape Escape character to escape itself or quote character.  |
| 458 | */  |
| 459 | template<typename _CharT>  |
| 460 | inline auto  |
| 461 | quoted(const _CharT* __string,  |
| 462 | _CharT __delim = _CharT('"'), _CharT __escape = _CharT('\\'))  |
| 463 | {  |
| 464 | return __detail::_Quoted_string<const _CharT*, _CharT>(__string, __delim,  |
| 465 | __escape);  |
| 466 | }  |
| 467 |   |
| 468 | template<typename _CharT, typename _Traits, typename _Alloc>  |
| 469 | inline auto  |
| 470 | quoted(const basic_string<_CharT, _Traits, _Alloc>& __string,  |
| 471 | _CharT __delim = _CharT('"'), _CharT __escape = _CharT('\\'))  |
| 472 | {  |
| 473 | return __detail::_Quoted_string<  |
| 474 | const basic_string<_CharT, _Traits, _Alloc>&, _CharT>(  |
| 475 | __string, __delim, __escape);  |
| 476 | }  |
| 477 |   |
| 478 | template<typename _CharT, typename _Traits, typename _Alloc>  |
| 479 | inline auto  |
| 480 | quoted(basic_string<_CharT, _Traits, _Alloc>& __string,  |
| 481 | _CharT __delim = _CharT('"'), _CharT __escape = _CharT('\\'))  |
| 482 | {  |
| 483 | return __detail::_Quoted_string<  |
| 484 | basic_string<_CharT, _Traits, _Alloc>&, _CharT>(  |
| 485 | __string, __delim, __escape);  |
| 486 | }  |
| 487 |   |
| 488 | #if __cplusplus >= 201703L  |
| 489 | // _GLIBCXX_RESOLVE_LIB_DEFECTS  |
| 490 | // 2785. quoted should work with basic_string_view  |
| 491 | template<typename _CharT, typename _Traits>  |
| 492 | inline auto  |
| 493 | quoted(basic_string_view<_CharT, _Traits> __sv,  |
| 494 | _CharT __delim = _CharT('"'), _CharT __escape = _CharT('\\'))  |
| 495 | {  |
| 496 | return __detail::_Quoted_string<  |
| 497 | basic_string_view<_CharT, _Traits>, _CharT>(__sv, __delim, __escape);  |
| 498 | }  |
| 499 | #endif // C++17  |
| 500 | #endif // C++14  |
| 501 |   |
| 502 | #endif // __cplusplus >= 201103L  |
| 503 |   |
| 504 | // Inhibit implicit instantiations for required instantiations,  |
| 505 | // which are defined via explicit instantiations elsewhere.  |
| 506 | // NB: This syntax is a GNU extension.  |
| 507 | #if _GLIBCXX_EXTERN_TEMPLATE  |
| 508 | extern template ostream& operator<<(ostream&, _Setfill<char>);  |
| 509 | extern template ostream& operator<<(ostream&, _Setiosflags);  |
| 510 | extern template ostream& operator<<(ostream&, _Resetiosflags);  |
| 511 | extern template ostream& operator<<(ostream&, _Setbase);  |
| 512 | extern template ostream& operator<<(ostream&, _Setprecision);  |
| 513 | extern template ostream& operator<<(ostream&, _Setw);  |
| 514 | extern template istream& operator>>(istream&, _Setfill<char>);  |
| 515 | extern template istream& operator>>(istream&, _Setiosflags);  |
| 516 | extern template istream& operator>>(istream&, _Resetiosflags);  |
| 517 | extern template istream& operator>>(istream&, _Setbase);  |
| 518 | extern template istream& operator>>(istream&, _Setprecision);  |
| 519 | extern template istream& operator>>(istream&, _Setw);  |
| 520 |   |
| 521 | #ifdef _GLIBCXX_USE_WCHAR_T  |
| 522 | extern template wostream& operator<<(wostream&, _Setfill<wchar_t>);  |
| 523 | extern template wostream& operator<<(wostream&, _Setiosflags);  |
| 524 | extern template wostream& operator<<(wostream&, _Resetiosflags);  |
| 525 | extern template wostream& operator<<(wostream&, _Setbase);  |
| 526 | extern template wostream& operator<<(wostream&, _Setprecision);  |
| 527 | extern template wostream& operator<<(wostream&, _Setw);  |
| 528 | extern template wistream& operator>>(wistream&, _Setfill<wchar_t>);  |
| 529 | extern template wistream& operator>>(wistream&, _Setiosflags);  |
| 530 | extern template wistream& operator>>(wistream&, _Resetiosflags);  |
| 531 | extern template wistream& operator>>(wistream&, _Setbase);  |
| 532 | extern template wistream& operator>>(wistream&, _Setprecision);  |
| 533 | extern template wistream& operator>>(wistream&, _Setw);  |
| 534 | #endif  |
| 535 | #endif  |
| 536 |   |
| 537 | _GLIBCXX_END_NAMESPACE_VERSION  |
| 538 | } // namespace  |
| 539 |   |
| 540 | #endif /* _GLIBCXX_IOMANIP */  |
| 541 | |