00001 // Components for manipulating sequences of characters -*- C++ -*- 00002 00003 // Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002, 2003 00004 // Free Software Foundation, Inc. 00005 // 00006 // This file is part of the GNU ISO C++ Library. This library is free 00007 // software; you can redistribute it and/or modify it under the 00008 // terms of the GNU General Public License as published by the 00009 // Free Software Foundation; either version 2, or (at your option) 00010 // any later version. 00011 00012 // This library is distributed in the hope that it will be useful, 00013 // but WITHOUT ANY WARRANTY; without even the implied warranty of 00014 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00015 // GNU General Public License for more details. 00016 00017 // You should have received a copy of the GNU General Public License along 00018 // with this library; see the file COPYING. If not, write to the Free 00019 // Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, 00020 // USA. 00021 00022 // As a special exception, you may use this file as part of a free software 00023 // library without restriction. Specifically, if other files instantiate 00024 // templates or use macros or inline functions from this file, or you compile 00025 // this file and link it with other files to produce an executable, this 00026 // file does not by itself cause the resulting executable to be covered by 00027 // the GNU General Public License. This exception does not however 00028 // invalidate any other reasons why the executable file might be covered by 00029 // the GNU General Public License. 00030 00031 // 00032 // ISO C++ 14882: 21 Strings library 00033 // 00034 00035 // Written by Jason Merrill based upon the specification by Takanori Adachi 00036 // in ANSI X3J16/94-0013R2. Rewritten by Nathan Myers. 00037 00038 #include <string> 00039 00040 // Instantiation configuration. 00041 #ifndef C 00042 # define C char 00043 #endif 00044 00045 namespace std 00046 { 00047 typedef basic_string<C> S; 00048 00049 template class basic_string<C>; 00050 template S operator+(const C*, const S&); 00051 template S operator+(C, const S&); 00052 template S operator+(const S&, const S&); 00053 00054 // Only one template keyword allowed here. 00055 // See core issue #46 (NAD) 00056 // http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/cwg_closed.html#46 00057 template 00058 S::basic_string(C*, C*, const allocator<C>&); 00059 00060 template 00061 S::basic_string(const C*, const C*, const allocator<C>&); 00062 00063 template 00064 S::basic_string(S::iterator, S::iterator, const allocator<C>&); 00065 00066 template 00067 C* 00068 S::_S_construct(S::iterator, S::iterator, 00069 const allocator<C>&, forward_iterator_tag); 00070 00071 template 00072 C* 00073 S::_S_construct(C*, C*, const allocator<C>&, forward_iterator_tag); 00074 00075 template 00076 C* 00077 S::_S_construct(const C*, const C*, const allocator<C>&, 00078 forward_iterator_tag); 00079 } // namespace std 00080 00081 namespace __gnu_cxx 00082 { 00083 using std::S; 00084 template bool operator==(const S::iterator&, const S::iterator&); 00085 template bool operator==(const S::const_iterator&, const S::const_iterator&); 00086 } // namespace __gnu_cxx