aboutsummaryrefslogtreecommitdiff
path: root/libstdc++-v3/src/string-inst.cc
diff options
context:
space:
mode:
Diffstat (limited to 'libstdc++-v3/src/string-inst.cc')
-rw-r--r--libstdc++-v3/src/string-inst.cc406
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
+
+
+