Home | History | Annotate | Download | only in include
      1 // <iosfwd> Forward declarations -*- C++ -*-
      2 
      3 // Copyright (C) 1997-2013 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 3, 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 // Under Section 7 of GPL version 3, you are granted additional
     17 // permissions described in the GCC Runtime Library Exception, version
     18 // 3.1, as published by the Free Software Foundation.
     19 
     20 // You should have received a copy of the GNU General Public License and
     21 // a copy of the GCC Runtime Library Exception along with this program;
     22 // see the files COPYING3 and COPYING.RUNTIME respectively.  If not, see
     23 // <http://www.gnu.org/licenses/>.
     24 
     25 /** @file include/iosfwd
     26  *  This is a Standard C++ Library header.
     27  */
     28 
     29 //
     30 // ISO C++ 14882: 27.2  Forward declarations
     31 //
     32 
     33 #ifndef _GLIBCXX_IOSFWD
     34 #define _GLIBCXX_IOSFWD 1
     35 
     36 #pragma GCC system_header
     37 
     38 #include <bits/c++config.h>
     39 #include <bits/stringfwd.h> 	// For string forward declarations.
     40 #include <bits/postypes.h>
     41 
     42 namespace std _GLIBCXX_VISIBILITY(default)
     43 {
     44 _GLIBCXX_BEGIN_NAMESPACE_VERSION
     45 
     46   /**
     47    *  @defgroup io I/O
     48    *
     49    *  Nearly all of the I/O classes are parameterized on the type of
     50    *  characters they read and write.  (The major exception is ios_base at
     51    *  the top of the hierarchy.)  This is a change from pre-Standard
     52    *  streams, which were not templates.
     53    *
     54    *  For ease of use and compatibility, all of the basic_* I/O-related
     55    *  classes are given typedef names for both of the builtin character
     56    *  widths (wide and narrow).  The typedefs are the same as the
     57    *  pre-Standard names, for example:
     58    *
     59    *  @code
     60    *     typedef basic_ifstream<char>  ifstream;
     61    *  @endcode
     62    *
     63    *  Because properly forward-declaring these classes can be difficult, you
     64    *  should not do it yourself.  Instead, include the &lt;iosfwd&gt;
     65    *  header, which contains only declarations of all the I/O classes as
     66    *  well as the typedefs.  Trying to forward-declare the typedefs
     67    *  themselves (e.g., <code>class ostream;</code>) is not valid ISO C++.
     68    *
     69    *  For more specific declarations, see
     70    *  http://gcc.gnu.org/onlinedocs/libstdc++/manual/bk01pt11ch24.html
     71    *
     72    *  @{
     73   */
     74   class ios_base;
     75 
     76   template<typename _CharT, typename _Traits = char_traits<_CharT> >
     77     class basic_ios;
     78 
     79   template<typename _CharT, typename _Traits = char_traits<_CharT> >
     80     class basic_streambuf;
     81 
     82   template<typename _CharT, typename _Traits = char_traits<_CharT> >
     83     class basic_istream;
     84 
     85   template<typename _CharT, typename _Traits = char_traits<_CharT> >
     86     class basic_ostream;
     87 
     88   template<typename _CharT, typename _Traits = char_traits<_CharT> >
     89     class basic_iostream;
     90 
     91   template<typename _CharT, typename _Traits = char_traits<_CharT>,
     92 	    typename _Alloc = allocator<_CharT> >
     93     class basic_stringbuf;
     94 
     95   template<typename _CharT, typename _Traits = char_traits<_CharT>,
     96 	   typename _Alloc = allocator<_CharT> >
     97     class basic_istringstream;
     98 
     99   template<typename _CharT, typename _Traits = char_traits<_CharT>,
    100 	   typename _Alloc = allocator<_CharT> >
    101     class basic_ostringstream;
    102 
    103   template<typename _CharT, typename _Traits = char_traits<_CharT>,
    104 	   typename _Alloc = allocator<_CharT> >
    105     class basic_stringstream;
    106 
    107   template<typename _CharT, typename _Traits = char_traits<_CharT> >
    108     class basic_filebuf;
    109 
    110   template<typename _CharT, typename _Traits = char_traits<_CharT> >
    111     class basic_ifstream;
    112 
    113   template<typename _CharT, typename _Traits = char_traits<_CharT> >
    114     class basic_ofstream;
    115 
    116   template<typename _CharT, typename _Traits = char_traits<_CharT> >
    117     class basic_fstream;
    118 
    119   template<typename _CharT, typename _Traits = char_traits<_CharT> >
    120     class istreambuf_iterator;
    121 
    122   template<typename _CharT, typename _Traits = char_traits<_CharT> >
    123     class ostreambuf_iterator;
    124 
    125 
    126   /// Base class for @c char streams.
    127   typedef basic_ios<char> 		ios; 
    128 
    129   /// Base class for @c char buffers.
    130   typedef basic_streambuf<char> 	streambuf;
    131 
    132   /// Base class for @c char input streams.
    133   typedef basic_istream<char> 		istream;
    134 
    135   /// Base class for @c char output streams.
    136   typedef basic_ostream<char> 		ostream;
    137 
    138   /// Base class for @c char mixed input and output streams.
    139   typedef basic_iostream<char> 		iostream;
    140 
    141   /// Class for @c char memory buffers.
    142   typedef basic_stringbuf<char> 	stringbuf;
    143 
    144   /// Class for @c char input memory streams.
    145   typedef basic_istringstream<char> 	istringstream;
    146 
    147   /// Class for @c char output memory streams.
    148   typedef basic_ostringstream<char> 	ostringstream;
    149 
    150   /// Class for @c char mixed input and output memory streams.
    151   typedef basic_stringstream<char> 	stringstream;
    152 
    153   /// Class for @c char file buffers.
    154   typedef basic_filebuf<char> 		filebuf;
    155 
    156   /// Class for @c char input file streams.
    157   typedef basic_ifstream<char> 		ifstream;
    158 
    159   /// Class for @c char output file streams.
    160   typedef basic_ofstream<char> 		ofstream;
    161 
    162   /// Class for @c char mixed input and output file streams.
    163   typedef basic_fstream<char> 		fstream;
    164 
    165 #ifdef _GLIBCXX_USE_WCHAR_T
    166   /// Base class for @c wchar_t streams.
    167   typedef basic_ios<wchar_t> 		wios;
    168 
    169   /// Base class for @c wchar_t buffers.
    170   typedef basic_streambuf<wchar_t> 	wstreambuf;
    171 
    172   /// Base class for @c wchar_t input streams.
    173   typedef basic_istream<wchar_t> 	wistream;
    174 
    175   /// Base class for @c wchar_t output streams.
    176   typedef basic_ostream<wchar_t> 	wostream;
    177 
    178   /// Base class for @c wchar_t mixed input and output streams.
    179   typedef basic_iostream<wchar_t> 	wiostream;
    180 
    181   /// Class for @c wchar_t memory buffers.
    182   typedef basic_stringbuf<wchar_t> 	wstringbuf;
    183 
    184   /// Class for @c wchar_t input memory streams.
    185   typedef basic_istringstream<wchar_t> 	wistringstream;
    186 
    187   /// Class for @c wchar_t output memory streams.
    188   typedef basic_ostringstream<wchar_t> 	wostringstream;
    189 
    190   /// Class for @c wchar_t mixed input and output memory streams.
    191   typedef basic_stringstream<wchar_t> 	wstringstream;
    192 
    193   /// Class for @c wchar_t file buffers.
    194   typedef basic_filebuf<wchar_t> 	wfilebuf;
    195 
    196   /// Class for @c wchar_t input file streams.
    197   typedef basic_ifstream<wchar_t> 	wifstream;
    198 
    199   /// Class for @c wchar_t output file streams.
    200   typedef basic_ofstream<wchar_t> 	wofstream;
    201 
    202   /// Class for @c wchar_t mixed input and output file streams.
    203   typedef basic_fstream<wchar_t> 	wfstream;
    204 #endif
    205   /** @}  */
    206 
    207 _GLIBCXX_END_NAMESPACE_VERSION
    208 } // namespace
    209 
    210 #endif /* _GLIBCXX_IOSFWD */
    211