basic_ios.tcc revision 117397
1// basic_ios locale and locale-related member functions -*- C++ -*- 2 3// Copyright (C) 1999, 2001, 2002, 2003 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 2, 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// You should have received a copy of the GNU General Public License along 17// with this library; see the file COPYING. If not, write to the Free 18// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, 19// USA. 20 21// As a special exception, you may use this file as part of a free software 22// library without restriction. Specifically, if other files instantiate 23// templates or use macros or inline functions from this file, or you compile 24// this file and link it with other files to produce an executable, this 25// file does not by itself cause the resulting executable to be covered by 26// the GNU General Public License. This exception does not however 27// invalidate any other reasons why the executable file might be covered by 28// the GNU General Public License. 29 30#ifndef _CPP_BITS_BASICIOS_TCC 31#define _CPP_BITS_BASICIOS_TCC 1 32 33#pragma GCC system_header 34 35namespace std 36{ 37 template<typename _CharT, typename _Traits> 38 void 39 basic_ios<_CharT, _Traits>::clear(iostate __state) 40 { 41 if (this->rdbuf()) 42 _M_streambuf_state = __state; 43 else 44 _M_streambuf_state = __state | badbit; 45 if ((this->rdstate() & this->exceptions())) 46 __throw_ios_failure("basic_ios::clear(iostate) caused exception"); 47 } 48 49 template<typename _CharT, typename _Traits> 50 basic_streambuf<_CharT, _Traits>* 51 basic_ios<_CharT, _Traits>::rdbuf(basic_streambuf<_CharT, _Traits>* __sb) 52 { 53 basic_streambuf<_CharT, _Traits>* __old = _M_streambuf; 54 _M_streambuf = __sb; 55 this->clear(); 56 return __old; 57 } 58 59 template<typename _CharT, typename _Traits> 60 basic_ios<_CharT, _Traits>& 61 basic_ios<_CharT, _Traits>::copyfmt(const basic_ios& __rhs) 62 { 63 // Per 27.1.1.1, do not call imbue, yet must trash all caches 64 // associated with imbue() 65 66 // Alloc any new word array first, so if it fails we have "rollback". 67 _Words* __words = (__rhs._M_word_size <= _S_local_word_size) ? 68 _M_local_word : new _Words[__rhs._M_word_size]; 69 70 // Bump refs before doing callbacks, for safety. 71 _Callback_list* __cb = __rhs._M_callbacks; 72 if (__cb) 73 __cb->_M_add_reference(); 74 _M_call_callbacks(erase_event); 75 if (_M_word != _M_local_word) 76 { 77 delete [] _M_word; 78 _M_word = 0; 79 } 80 _M_dispose_callbacks(); 81 82 _M_callbacks = __cb; // NB: Don't want any added during above. 83 for (int __i = 0; __i < __rhs._M_word_size; ++__i) 84 __words[__i] = __rhs._M_word[__i]; 85 if (_M_word != _M_local_word) 86 { 87 delete [] _M_word; 88 _M_word = 0; 89 } 90 _M_word = __words; 91 _M_word_size = __rhs._M_word_size; 92 93 this->flags(__rhs.flags()); 94 this->width(__rhs.width()); 95 this->precision(__rhs.precision()); 96 this->tie(__rhs.tie()); 97 this->fill(__rhs.fill()); 98 _M_ios_locale = __rhs.getloc(); 99 100 // This removes the link to __rhs locale cache 101 _M_call_callbacks(copyfmt_event); 102 103 _M_cache_locale(_M_ios_locale); 104 105 106 // The next is required to be the last assignment. 107 this->exceptions(__rhs.exceptions()); 108 109 return *this; 110 } 111 112 template<typename _CharT, typename _Traits> 113 char 114 basic_ios<_CharT, _Traits>::narrow(char_type __c, char __dfault) const 115 { 116 char __ret = __dfault; 117 if (_M_check_facet(_M_fctype)) 118 __ret = _M_fctype->narrow(__c, __dfault); 119 return __ret; 120 } 121 122 template<typename _CharT, typename _Traits> 123 _CharT 124 basic_ios<_CharT, _Traits>::widen(char __c) const 125 { 126 char_type __ret = char_type(); 127 if (_M_check_facet(_M_fctype)) 128 __ret = _M_fctype->widen(__c); 129 return __ret; 130 } 131 132 // Locales: 133 template<typename _CharT, typename _Traits> 134 locale 135 basic_ios<_CharT, _Traits>::imbue(const locale& __loc) 136 { 137 locale __old(this->getloc()); 138 ios_base::imbue(__loc); 139 _M_cache_locale(__loc); 140 if (this->rdbuf() != 0) 141 this->rdbuf()->pubimbue(__loc); 142 return __old; 143 } 144 145 template<typename _CharT, typename _Traits> 146 void 147 basic_ios<_CharT, _Traits>::init(basic_streambuf<_CharT, _Traits>* __sb) 148 { 149 // NB: This may be called more than once on the same object. 150 ios_base::_M_init(); 151 _M_cache_locale(_M_ios_locale); 152 _M_tie = 0; 153 154 // NB: The 27.4.4.1 Postconditions Table specifies requirements 155 // after basic_ios::init() has been called. As part of this, 156 // fill() must return widen(' ') any time after init() has been 157 // called, which needs an imbued ctype facet of char_type to 158 // return without throwing an exception. Unfortunately, 159 // ctype<char_type> is not necessarily a required facet, so 160 // streams with char_type != [char, wchar_t] will not have it by 161 // default. Because of this, the correct value for _M_fill is 162 // constructed on the first call of fill(). That way, 163 // unformatted input and output with non-required basic_ios 164 // instantiations is possible even without imbuing the expected 165 // ctype<char_type> facet. 166 _M_fill = _CharT(); 167 _M_fill_init = false; 168 169 _M_exception = goodbit; 170 _M_streambuf = __sb; 171 _M_streambuf_state = __sb ? goodbit : badbit; 172 } 173 174 template<typename _CharT, typename _Traits> 175 void 176 basic_ios<_CharT, _Traits>::_M_cache_locale(const locale& __loc) 177 { 178 if (__builtin_expect(has_facet<__ctype_type>(__loc), true)) 179 _M_fctype = &use_facet<__ctype_type>(__loc); 180 else 181 _M_fctype = 0; 182 if (__builtin_expect(has_facet<__numput_type>(__loc), true)) 183 _M_fnumput = &use_facet<__numput_type>(__loc); 184 else 185 _M_fnumput = 0; 186 if (__builtin_expect(has_facet<__numget_type>(__loc), true)) 187 _M_fnumget = &use_facet<__numget_type>(__loc); 188 else 189 _M_fnumget = 0; 190 } 191 192#if 1 193 // XXX GLIBCXX_ABI Deprecated, compatibility only. 194 template<typename _CharT, typename _Traits> 195 void 196 basic_ios<_CharT, _Traits>::_M_cache_facets(const locale& __loc) 197 { 198 if (__builtin_expect(has_facet<__ctype_type>(__loc), true)) 199 _M_fctype = &use_facet<__ctype_type>(__loc); 200 if (__builtin_expect(has_facet<__numput_type>(__loc), true)) 201 _M_fnumput = &use_facet<__numput_type>(__loc); 202 if (__builtin_expect(has_facet<__numget_type>(__loc), true)) 203 _M_fnumget = &use_facet<__numget_type>(__loc); 204 } 205#endif 206 207 // Inhibit implicit instantiations for required instantiations, 208 // which are defined via explicit instantiations elsewhere. 209 // NB: This syntax is a GNU extension. 210#if _GLIBCPP_EXTERN_TEMPLATE 211 extern template class basic_ios<char>; 212 213#ifdef _GLIBCPP_USE_WCHAR_T 214 extern template class basic_ios<wchar_t>; 215#endif 216#endif 217} // namespace std 218 219#endif 220