diff options
Diffstat (limited to 'libstdc++-v3/src/string-inst.cc')
-rw-r--r-- | libstdc++-v3/src/string-inst.cc | 406 |
1 files changed, 406 insertions, 0 deletions
diff --git a/libstdc++-v3/src/string-inst.cc b/libstdc++-v3/src/string-inst.cc new file mode 100644 index 0000000..451ffa5 --- /dev/null +++ b/libstdc++-v3/src/string-inst.cc @@ -0,0 +1,406 @@ +// Components for manipulating sequences of characters -*- C++ -*- + +// Copyright (C) 2000, 1999, 1998, 1997 Free Software Foundation, Inc. +// +// This file is part of the GNU ISO C++ Library. This library is free +// software; you can redistribute it and/or modify it under the +// terms of the GNU General Public License as published by the +// Free Software Foundation; either version 2, or (at your option) +// any later version. + +// This library is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. + +// You should have received a copy of the GNU General Public License along +// with this library; see the file COPYING. If not, write to the Free +// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, +// USA. + +// As a special exception, you may use this file as part of a free software +// library without restriction. Specifically, if other files instantiate +// templates or use macros or inline functions from this file, or you compile +// this file and link it with other files to produce an executable, this +// file does not by itself cause the resulting executable to be covered by +// the GNU General Public License. This exception does not however +// invalidate any other reasons why the executable file might be covered by +// the GNU General Public License. + +// +// ISO C++ 14882: 21 Strings library +// + +// Written by Jason Merrill based upon the specification by Takanori Adachi +// in ANSI X3J16/94-0013R2. Rewritten by Nathan Myers. + +#include <bits/std_string.h> +#include <bits/std_algorithm.h> +#include <bits/std_istream.h> +#include <bits/std_ostream.h> + +// NB: Unnecessary if the .h headers include these +#ifndef _GLIBCPP_FULLY_COMPLIANT_HEADERS +#include <bits/istream.tcc> +#include <bits/ostream.tcc> +#endif + +// Instantiation configuration. +#ifndef C +# define C char +# define _GLIBCPP_INSTANTIATING_CHAR 1 +#endif + +namespace std +{ + typedef basic_string<C> S; + +#ifdef MAIN + template C S::_Rep::_S_terminal; + // XXX Fix me: 2000-04-18 g++ ICE. +// template S::size_type S::_S_max_size; +// template S::allocator_type::size_type S::S_empty_rep_storage[]; + template S::basic_string(S const&); + template S::_Rep* S::_Rep::_S_create(size_t, S::allocator_type const&); + template void S::_Rep::_M_destroy(S::allocator_type const&) throw(); +#endif + +#ifdef CTORNC + template + S::basic_string(S::size_type, C, S::allocator_type const&); +#endif + +#ifdef CTORAL + template + S::basic_string(S::allocator_type const&); +#endif + +#ifdef CTORCPR + template + S::basic_string(S const&, S::size_type, S::size_type); +#endif + +#ifdef CTORCPRAL + template + S::basic_string( + S const&, S::size_type, S::size_type, S::allocator_type const&); +#endif + +#ifdef CTORPRAL + template + S::basic_string( + C const*, S::size_type, S::allocator_type const&); +#endif + +#ifdef CTORPAL + template + S::basic_string( + C const*, S::allocator_type const&); +#endif + +#ifdef CTORDUPAL + template + S::basic_string( + S::size_type, C, S::allocator_type const&); +#endif + +#ifdef CTORPP + template + S::basic_string + (C*, C*, const allocator<C>&); +#endif + +#ifdef CTORII + template + S::basic_string + (S::iterator, S::iterator, const allocator<C>&); +#endif + +#ifdef MUTATE + template + void S::_M_leak_hard(); + template + void S::_M_mutate(S::size_type, S::size_type, S::size_type); + template + C* S::_Rep::_M_clone(S::allocator_type const&, S::size_type); +#endif + +#ifdef RESERVE + template + void S::reserve(S::size_type); +#endif + +#ifdef SWAP + template + void S::swap(S&); +#endif + +#ifdef SLOP +# ifdef _GLIBCPP_ALLOC_CONTROL + template + bool (* S::_Rep::_S_excess_slop)(size_t, size_t); + template + bool S::_Rep::_S_default_excess(size_t, size_t); +# endif +#endif + +#ifdef RESIZE + template + void S::resize(S::size_type, C); +#endif + +#ifdef APPCOPY + template + S& S::append(S const&); +#endif + +#ifdef APPCPR + template + S& S::append(S const&, S::size_type, S::size_type); +#endif + +#ifdef APPPR + template + S& S::append(C const*, S::size_type); +#endif + +#ifdef APPDUP + template + S& S::append(S::size_type, C); +#endif + +#ifdef APPII + template + S& + S::append<S::iterator> + (S::iterator, S::iterator); +#endif + +#ifdef ASSCP + template + S& + S::assign(S const&); +#endif + +#ifdef ASSII + template + S& + S::assign<S::iterator> + (S::iterator, S::iterator); +#endif + +#ifdef INSII + template + void + S::insert<S::iterator> //c* + (S::iterator, S::iterator, S::iterator); //it, c+, c+ and temptype = char* +#endif + +#ifdef REPRR + template + S& S::replace( + S::size_type, S::size_type, S const&, S::size_type, S::size_type); +#endif + +#ifdef REPIIDUP + template + S& S::replace(S::iterator, S::iterator, S::size_type, C); +#endif + +#ifdef REPII + template + S& + S::replace<S::iterator> // c* + (S::iterator, S::iterator, S::iterator, S::iterator); //it, it, c+, c+ +#endif + +#ifdef REPIII + template + S& + S::_M_replace<S::iterator> + (S::iterator, S::iterator, S::iterator, S::iterator, forward_iterator_tag); +#endif + +#ifdef REP4I + template + template + S& + S::_M_replace<S::const_iterator> + (S::iterator, S::iterator, + S::const_iterator, S::const_iterator, forward_iterator_tag); +#endif + +#ifdef REPIIPP + template + S& + S::_M_replace<C*> + (S::iterator, S::iterator, C*, C*, forward_iterator_tag); +#endif + +#ifdef REPIIPP2 + template + S& + S::_M_replace<const C*> + (S::iterator, S::iterator, const C*, const C*, forward_iterator_tag); +#endif + +#ifdef COPY + template + S::size_type S::copy(C*, S::size_type, S::size_type) const; +#endif + +#ifdef CONII + template + C* + S::_S_construct<S::iterator> + (S::iterator, S::iterator, const allocator<C>&); +#endif + +#ifdef CONIIF + template + C* + S::_S_construct<S::iterator> + (S::iterator, S::iterator, const allocator<C>&, forward_iterator_tag); +#endif + +#ifdef CONPPF + template + C* + S::_S_construct<C*> + (C*, C*, const allocator<C>&, forward_iterator_tag); +#endif + +#ifdef CONPPF2 + template + C* + S::_S_construct<const C*> + (const C*, const C*, const allocator<C>&, forward_iterator_tag); +#endif + +#ifdef CONSC + template + C* + S::_S_construct<S::iterator> + (S::size_type, C, const allocator<C>&); +#endif + +#ifdef FIND + // These members are explicitly specialized, and can only be in one + // translation unit or else we get multiple copies. . . +#if _GLIBCPP_INSTANTIATING_CHAR + template<> + const char* + string::_S_find(const char* __beg, const char* __end, char __c) + { + char* __retval = strchr(__beg, __c); + return (__retval ? __retval : __end); + } +#else + template<> + const wchar_t* + wstring::_S_find(const wchar_t* __beg, const wchar_t* __end, wchar_t __c) + { + return find_if(__beg, __end, + _Char_traits_match<wchar_t, traits_type>(__c)); + } +#endif +#endif + +#ifdef FINDC + template + S::size_type S::find(C, S::size_type) const; +#endif + +#ifdef RFIND + template + S::size_type S::rfind(C const*, S::size_type, S::size_type) const; +#endif + +#ifdef RFINDC + template + S::size_type S::rfind(C, S::size_type) const; +#endif + +#ifdef FFO + template + S::size_type S::find_first_of(C const*, S::size_type, S::size_type) const; +#endif + +#ifdef FLO + template + S::size_type S::find_last_of(C const*, S::size_type, S::size_type) const; +#endif + +#ifdef FFNO + template + S::size_type S::find_first_not_of( + C const*, S::size_type, S::size_type) const; +#endif + +#ifdef FLNO + template + S::size_type S::find_last_not_of( + C const*, S::size_type, S::size_type) const; +#endif + +#ifdef FLNOC + template + S::size_type S::find_last_not_of(C, S::size_type) const; +#endif + +#ifdef COMPARE + template + int S::compare(S::size_type, S::size_type, S const&) const; +#endif + +#ifdef COMPARE2 + template + int S::compare(S::size_type, S::size_type, S const&, S::size_type, + S::size_type) const; +#endif + +#ifdef COMPAREP + template + int S::compare(C const*) const; +#endif + +#ifdef COMPAREP2 + template + int S::compare( + S::size_type, S::size_type, C const*, S::size_type) const; +#endif + +#ifdef ADDPS + template S operator+(const C*, const S&); +#endif + +#ifdef ADDCS + template S operator+(C, const S&); +#endif + +#ifdef EQ + template bool operator==(const S::iterator&, const S::iterator&); + template bool operator==(const S::const_iterator&, const S::const_iterator&); +#endif + +#ifdef EXTRACT + template basic_istream<C>& operator>>(basic_istream<C>&, S&); +#endif + +#ifdef INSERT + template basic_ostream<C>& operator<<(basic_ostream<C>&, const S&); +#endif + +#ifdef GETLINE + template basic_istream<C>& getline(basic_istream<C>&, S&, C); + template basic_istream<C>& getline(basic_istream<C>&, S&); +#endif + +#ifdef SCOPY + template void _S_string_copy(const S&, C*, allocator<C>::size_type); +#endif + +} // std + + + |