localefwd.h: Remove redundant inline qualifiers.

2007-04-29  Paolo Carlini  <pcarlini@suse.de>

	* include/bits/localefwd.h: Remove redundant inline qualifiers.
	(__check_facet): Move...
	* include/bits/basic_ios.h: ... here.
	(widen(char), narrow(char_type, char)): Define inline.
	* include/bits/basic_ios.tcc (widen(char), narrow(char_type, char)):
	Remove.

From-SVN: r124282
This commit is contained in:
Paolo Carlini 2007-04-29 16:06:09 +00:00 committed by Paolo Carlini
parent fc9f54d5b5
commit 677e29e167
4 changed files with 53 additions and 51 deletions

View File

@ -1,3 +1,12 @@
2007-04-29 Paolo Carlini <pcarlini@suse.de>
* include/bits/localefwd.h: Remove redundant inline qualifiers.
(__check_facet): Move...
* include/bits/basic_ios.h: ... here.
(widen(char), narrow(char_type, char)): Define inline.
* include/bits/basic_ios.tcc (widen(char), narrow(char_type, char)):
Remove.
2007-04-27 Paolo Carlini <pcarlini@suse.de> 2007-04-27 Paolo Carlini <pcarlini@suse.de>
DR 438, [DR]. DR 438, [DR].

View File

@ -1,6 +1,7 @@
// Iostreams base classes -*- C++ -*- // Iostreams base classes -*- C++ -*-
// Copyright (C) 1997, 1998, 1999, 2001, 2002, 2003, 2004, 2005 // Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005,
// 2006, 2007
// Free Software Foundation, Inc. // Free Software Foundation, Inc.
// //
// This file is part of the GNU ISO C++ Library. This library is free // This file is part of the GNU ISO C++ Library. This library is free
@ -38,13 +39,22 @@
#pragma GCC system_header #pragma GCC system_header
#include <bits/streambuf_iterator.h>
#include <bits/localefwd.h> #include <bits/localefwd.h>
#include <bits/locale_classes.h> #include <bits/locale_classes.h>
#include <bits/locale_facets.h> #include <bits/locale_facets.h>
#include <bits/streambuf_iterator.h>
_GLIBCXX_BEGIN_NAMESPACE(std) _GLIBCXX_BEGIN_NAMESPACE(std)
template<typename _Facet>
inline const _Facet&
__check_facet(const _Facet* __f)
{
if (!__f)
__throw_bad_cast();
return *__f;
}
// 27.4.5 Template class basic_ios // 27.4.5 Template class basic_ios
/** /**
* @brief Virtual base class for all stream classes. * @brief Virtual base class for all stream classes.
@ -255,7 +265,7 @@ _GLIBCXX_BEGIN_NAMESPACE(std)
explicit explicit
basic_ios(basic_streambuf<_CharT, _Traits>* __sb) basic_ios(basic_streambuf<_CharT, _Traits>* __sb)
: ios_base(), _M_tie(0), _M_fill(), _M_fill_init(false), _M_streambuf(0), : ios_base(), _M_tie(0), _M_fill(), _M_fill_init(false), _M_streambuf(0),
_M_ctype(0), _M_num_put(0), _M_num_get(0) _M_ctype(0), _M_num_put(0), _M_num_get(0)
{ this->init(__sb); } { this->init(__sb); }
/** /**
@ -413,7 +423,8 @@ _GLIBCXX_BEGIN_NAMESPACE(std)
* http://gcc.gnu.org/onlinedocs/libstdc++/22_locale/howto.html * http://gcc.gnu.org/onlinedocs/libstdc++/22_locale/howto.html
*/ */
char char
narrow(char_type __c, char __dfault) const; narrow(char_type __c, char __dfault) const
{ return __check_facet(_M_ctype).narrow(__c, __dfault); }
/** /**
* @brief Widens characters. * @brief Widens characters.
@ -431,7 +442,8 @@ _GLIBCXX_BEGIN_NAMESPACE(std)
* http://gcc.gnu.org/onlinedocs/libstdc++/22_locale/howto.html * http://gcc.gnu.org/onlinedocs/libstdc++/22_locale/howto.html
*/ */
char_type char_type
widen(char __c) const; widen(char __c) const
{ return __check_facet(_M_ctype).widen(__c); }
protected: protected:
// 27.4.5.1 basic_ios constructors // 27.4.5.1 basic_ios constructors
@ -443,7 +455,7 @@ _GLIBCXX_BEGIN_NAMESPACE(std)
*/ */
basic_ios() basic_ios()
: ios_base(), _M_tie(0), _M_fill(char_type()), _M_fill_init(false), : ios_base(), _M_tie(0), _M_fill(char_type()), _M_fill_init(false),
_M_streambuf(0), _M_ctype(0), _M_num_put(0), _M_num_get(0) _M_streambuf(0), _M_ctype(0), _M_num_put(0), _M_num_get(0)
{ } { }
/** /**

View File

@ -1,6 +1,6 @@
// basic_ios member functions -*- C++ -*- // basic_ios member functions -*- C++ -*-
// Copyright (C) 1999, 2001, 2002, 2003, 2004, 2005 // Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007
// Free Software Foundation, Inc. // Free Software Foundation, Inc.
// //
// This file is part of the GNU ISO C++ Library. This library is free // This file is part of the GNU ISO C++ Library. This library is free
@ -112,16 +112,6 @@ _GLIBCXX_BEGIN_NAMESPACE(std)
return *this; return *this;
} }
template<typename _CharT, typename _Traits>
char
basic_ios<_CharT, _Traits>::narrow(char_type __c, char __dfault) const
{ return __check_facet(_M_ctype).narrow(__c, __dfault); }
template<typename _CharT, typename _Traits>
_CharT
basic_ios<_CharT, _Traits>::widen(char __c) const
{ return __check_facet(_M_ctype).widen(__c); }
// Locales: // Locales:
template<typename _CharT, typename _Traits> template<typename _CharT, typename _Traits>
locale locale

View File

@ -1,6 +1,7 @@
// Locale support -*- C++ -*- // Locale support -*- C++ -*-
// Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2005, 2006, 2007 // Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005,
// 2006, 2007
// Free Software Foundation, Inc. // Free Software Foundation, Inc.
// //
// This file is part of the GNU ISO C++ Library. This library is free // This file is part of the GNU ISO C++ Library. This library is free
@ -43,67 +44,74 @@
#pragma GCC system_header #pragma GCC system_header
#include <bits/c++config.h> #include <bits/c++config.h>
#include <bits/c++locale.h> // Defines __c_locale, config-specific includes #include <bits/c++locale.h> // Defines __c_locale, config-specific include
#include <iosfwd> // For ostreambuf_iterator, istreambuf_iterator #include <iosfwd> // For ostreambuf_iterator, istreambuf_iterator
#include <cctype> #include <cctype>
#include <bits/functexcept.h>
_GLIBCXX_BEGIN_NAMESPACE(std) _GLIBCXX_BEGIN_NAMESPACE(std)
// 22.1.1 Locale // 22.1.1 Locale
class locale; class locale;
template<typename _Facet>
bool
has_facet(const locale&) throw();
template<typename _Facet>
const _Facet&
use_facet(const locale&);
// 22.1.3 Convenience interfaces // 22.1.3 Convenience interfaces
template<typename _CharT> template<typename _CharT>
inline bool bool
isspace(_CharT, const locale&); isspace(_CharT, const locale&);
template<typename _CharT> template<typename _CharT>
inline bool bool
isprint(_CharT, const locale&); isprint(_CharT, const locale&);
template<typename _CharT> template<typename _CharT>
inline bool bool
iscntrl(_CharT, const locale&); iscntrl(_CharT, const locale&);
template<typename _CharT> template<typename _CharT>
inline bool bool
isupper(_CharT, const locale&); isupper(_CharT, const locale&);
template<typename _CharT> template<typename _CharT>
inline bool bool
islower(_CharT, const locale&); islower(_CharT, const locale&);
template<typename _CharT> template<typename _CharT>
inline bool bool
isalpha(_CharT, const locale&); isalpha(_CharT, const locale&);
template<typename _CharT> template<typename _CharT>
inline bool bool
isdigit(_CharT, const locale&); isdigit(_CharT, const locale&);
template<typename _CharT> template<typename _CharT>
inline bool bool
ispunct(_CharT, const locale&); ispunct(_CharT, const locale&);
template<typename _CharT> template<typename _CharT>
inline bool bool
isxdigit(_CharT, const locale&); isxdigit(_CharT, const locale&);
template<typename _CharT> template<typename _CharT>
inline bool bool
isalnum(_CharT, const locale&); isalnum(_CharT, const locale&);
template<typename _CharT> template<typename _CharT>
inline bool bool
isgraph(_CharT, const locale&); isgraph(_CharT, const locale&);
template<typename _CharT> template<typename _CharT>
inline _CharT _CharT
toupper(_CharT, const locale&); toupper(_CharT, const locale&);
template<typename _CharT> template<typename _CharT>
inline _CharT _CharT
tolower(_CharT, const locale&); tolower(_CharT, const locale&);
// 22.2.1 and 22.2.1.3 ctype // 22.2.1 and 22.2.1.3 ctype
@ -175,23 +183,6 @@ _GLIBCXX_END_LDBL_NAMESPACE
template<typename _CharT> template<typename _CharT>
class messages_byname; class messages_byname;
template<typename _Facet>
bool
has_facet(const locale& __loc) throw();
template<typename _Facet>
const _Facet&
use_facet(const locale& __loc);
template<typename _Facet>
inline const _Facet&
__check_facet(const _Facet* __f)
{
if (!__f)
__throw_bad_cast();
return *__f;
}
_GLIBCXX_END_NAMESPACE _GLIBCXX_END_NAMESPACE
#endif #endif