epoc32/include/stdapis/stlport/stl/_ostream.h
author William Roberts <williamr@symbian.org>
Wed, 31 Mar 2010 12:33:34 +0100
branchSymbian3
changeset 4 837f303aceeb
permissions -rw-r--r--
Current Symbian^3 public API header files (from PDK 3.0.h)
This is the epoc32/include tree with the "platform" subtrees removed, and
all but a selected few mbg and rsg files removed.
williamr@4
     1
/*
williamr@4
     2
 * © Portions copyright (c) 2006-2007 Nokia Corporation.  All rights reserved.
williamr@4
     3
 *
williamr@4
     4
 * Copyright (c) 1999
williamr@4
     5
 * Silicon Graphics Computer Systems, Inc.
williamr@4
     6
 *
williamr@4
     7
 * Copyright (c) 1999 
williamr@4
     8
 * Boris Fomitchev
williamr@4
     9
 *
williamr@4
    10
 * This material is provided "as is", with absolutely no warranty expressed
williamr@4
    11
 * or implied. Any use is at your own risk.
williamr@4
    12
 *
williamr@4
    13
 * Permission to use or copy this software for any purpose is hereby granted 
williamr@4
    14
 * without fee, provided the above notices are retained on all copies.
williamr@4
    15
 * Permission to modify the code and to distribute modified code is granted,
williamr@4
    16
 * provided the above notices are retained, and a notice that the code was
williamr@4
    17
 * modified is included with the above copyright notice.
williamr@4
    18
 *
williamr@4
    19
 */ 
williamr@4
    20
williamr@4
    21
williamr@4
    22
#ifndef _STLP_INTERNAL_OSTREAM_H
williamr@4
    23
#define _STLP_INTERNAL_OSTREAM_H
williamr@4
    24
williamr@4
    25
#ifndef _STLP_INTERNAL_IOS_H
williamr@4
    26
# include <stl/_ios.h>                  // For basic_ios<>.  Includes <iosfwd>.
williamr@4
    27
#endif
williamr@4
    28
williamr@4
    29
#ifndef _STLP_INTERNAL_OSTREAMBUF_ITERATOR_H
williamr@4
    30
# include <stl/_ostreambuf_iterator.h>
williamr@4
    31
#endif
williamr@4
    32
williamr@4
    33
_STLP_BEGIN_NAMESPACE
williamr@4
    34
williamr@4
    35
template <class _CharT, class _Traits, class _Number> 
williamr@4
    36
basic_ostream<_CharT, _Traits>& _STLP_CALL
williamr@4
    37
_M_put_num(basic_ostream<_CharT, _Traits>& __os, _Number __x);
williamr@4
    38
williamr@4
    39
# if defined (_STLP_USE_TEMPLATE_EXPORT)
williamr@4
    40
template <class _CharT, class _Traits>
williamr@4
    41
class _Osentry;
williamr@4
    42
# endif
williamr@4
    43
williamr@4
    44
template <class _CharT, class _Traits>
williamr@4
    45
bool
williamr@4
    46
_M_init(basic_ostream<_CharT, _Traits>& __str);
williamr@4
    47
williamr@4
    48
//----------------------------------------------------------------------
williamr@4
    49
// class basic_ostream<>
williamr@4
    50
williamr@4
    51
template <class _CharT, class _Traits>
williamr@4
    52
class basic_ostream : virtual public basic_ios<_CharT, _Traits>
williamr@4
    53
{
williamr@4
    54
  typedef basic_ostream<_CharT, _Traits> _Self;
williamr@4
    55
  
williamr@4
    56
public:                         // Types
williamr@4
    57
  typedef _CharT                     char_type;
williamr@4
    58
  typedef typename _Traits::int_type int_type;
williamr@4
    59
  typedef typename _Traits::pos_type pos_type;
williamr@4
    60
  typedef typename _Traits::off_type off_type;
williamr@4
    61
  typedef _Traits                    traits_type;
williamr@4
    62
  typedef basic_ios<_CharT, _Traits> _Basic_ios;
williamr@4
    63
williamr@4
    64
public:                         // Constructor and destructor.
williamr@4
    65
  _STLP_DECLSPEC explicit basic_ostream(basic_streambuf<_CharT, _Traits>* __buf);
williamr@4
    66
  _STLP_DECLSPEC ~basic_ostream();
williamr@4
    67
williamr@4
    68
public:                         // Hooks for manipulators.
williamr@4
    69
  typedef basic_ios<_CharT, _Traits>& (_STLP_CALL *__ios_fn)(basic_ios<_CharT, _Traits>&);
williamr@4
    70
  typedef ios_base& (_STLP_CALL *__ios_base_fn)(ios_base&);
williamr@4
    71
  typedef _Self& (_STLP_CALL *__ostream_fn)(_Self&);
williamr@4
    72
  _Self& operator<< (__ostream_fn __f) { return __f(*this); }
williamr@4
    73
  _Self & operator<< (__ios_base_fn __f) { __f(*this); return *this; }
williamr@4
    74
  _Self& operator<< (__ios_fn __ff) { __ff(*this); return *this; }
williamr@4
    75
williamr@4
    76
private:
williamr@4
    77
  bool _M_copy_buffered(basic_streambuf<_CharT, _Traits>* __from,
williamr@4
    78
                        basic_streambuf<_CharT, _Traits>* __to);
williamr@4
    79
  bool _M_copy_unbuffered(basic_streambuf<_CharT, _Traits>* __from,
williamr@4
    80
                          basic_streambuf<_CharT, _Traits>* __to);
williamr@4
    81
williamr@4
    82
public:
williamr@4
    83
  void _M_put_char(_CharT __c);
williamr@4
    84
williamr@4
    85
  void _M_put_nowiden(const _CharT* __s);
williamr@4
    86
  void _M_put_widen(const char* __s);
williamr@4
    87
  bool _M_put_widen_aux(const char* __s, streamsize __n);
williamr@4
    88
williamr@4
    89
public:                         // Unformatted output.
williamr@4
    90
  _Self& put(char_type __c);
williamr@4
    91
  _Self& write(const char_type* __s, streamsize __n);
williamr@4
    92
williamr@4
    93
public:                         // Formatted output.
williamr@4
    94
  // Formatted output from a streambuf.
williamr@4
    95
  _Self& operator<<(basic_streambuf<_CharT, _Traits>* __buf);
williamr@4
    96
# ifndef _STLP_NO_FUNCTION_TMPL_PARTIAL_ORDER
williamr@4
    97
  // this is needed for compiling with option char = unsigned
williamr@4
    98
  _Self& operator<<(unsigned char __x) { _M_put_char(__x); return *this; }
williamr@4
    99
# endif
williamr@4
   100
#ifdef __SYMBIAN32__
williamr@4
   101
  _Self& operator<<(short __x) 
williamr@4
   102
    { 
williamr@4
   103
	ios_base::fmtflags __fmtf =
williamr@4
   104
		ios_base::flags() & ios_base::basefield;
williamr@4
   105
    long __ly = (__fmtf == ios_base::oct ||  __fmtf == ios_base::hex) ? 
williamr@4
   106
                    (long)(unsigned short)(__x) : (long)__x;
williamr@4
   107
    return _M_put_num(*this,  __ly); 
williamr@4
   108
    }
williamr@4
   109
  _Self& operator<<(int __x) 
williamr@4
   110
  { 
williamr@4
   111
	ios_base::fmtflags __fmtf =
williamr@4
   112
		ios_base::flags() & ios_base::basefield;
williamr@4
   113
    long __ly = (__fmtf == ios_base::oct ||  __fmtf == ios_base::hex) ? 
williamr@4
   114
                    (long)(unsigned int)(__x) : (long)__x;
williamr@4
   115
    return _M_put_num(*this,  __ly); 
williamr@4
   116
  }
williamr@4
   117
#else
williamr@4
   118
  _Self& operator<<(short __x) { return _M_put_num(*this,  __x); }
williamr@4
   119
  _Self& operator<<(int __x) { return _M_put_num(*this,  __x); }
williamr@4
   120
#endif
williamr@4
   121
  _Self& operator<<(unsigned int __x) { return _M_put_num(*this,  __STATIC_CAST(unsigned long,__x)); }
williamr@4
   122
  _Self& operator<<(unsigned short __x) { return _M_put_num(*this,  __STATIC_CAST(unsigned long,__x)); }
williamr@4
   123
  _Self& operator<<(long __x) { return _M_put_num(*this,  __x); }
williamr@4
   124
  _Self& operator<<(unsigned long __x) { return _M_put_num(*this,  __x); }
williamr@4
   125
#ifdef _STLP_LONG_LONG
williamr@4
   126
  _Self& operator<< (_STLP_LONG_LONG __x)     { return _M_put_num(*this,  __x); }
williamr@4
   127
  _Self& operator<< (unsigned _STLP_LONG_LONG __x) { return _M_put_num(*this,  __x); }
williamr@4
   128
#endif 
williamr@4
   129
  _Self& operator<<(float __x)
williamr@4
   130
    { return _M_put_num(*this,  __STATIC_CAST(double,__x)); }
williamr@4
   131
  _Self& operator<<(double __x) { return _M_put_num(*this,  __x); }
williamr@4
   132
# ifndef _STLP_NO_LONG_DOUBLE
williamr@4
   133
  _Self& operator<<(long double __x) { return _M_put_num(*this,  __x); }
williamr@4
   134
# endif
williamr@4
   135
  _Self& operator<<(const void* __x) { return _M_put_num(*this,  __x); }
williamr@4
   136
# ifndef _STLP_NO_BOOL
williamr@4
   137
  _Self& operator<<(bool __x) { return _M_put_num(*this,  __x); }
williamr@4
   138
# endif
williamr@4
   139
williamr@4
   140
public:                         // Buffer positioning and manipulation.
williamr@4
   141
  _Self& flush() {
williamr@4
   142
    if (this->rdbuf())
williamr@4
   143
      if (this->rdbuf()->pubsync() == -1)
williamr@4
   144
        this->setstate(ios_base::badbit);
williamr@4
   145
    return *this;
williamr@4
   146
  }
williamr@4
   147
williamr@4
   148
  pos_type tellp() {
williamr@4
   149
    return this->rdbuf() && !this->fail()
williamr@4
   150
      ? this->rdbuf()->pubseekoff(0, ios_base::cur, ios_base::out)
williamr@4
   151
      : pos_type(-1);
williamr@4
   152
  }
williamr@4
   153
williamr@4
   154
  _Self& seekp(pos_type __pos) {
williamr@4
   155
    if (this->rdbuf() && !this->fail())
williamr@4
   156
      if( pos_type(off_type(-1)) == this->rdbuf()->pubseekpos(__pos, ios_base::out))
williamr@4
   157
        this->setstate(ios_base::failbit);
williamr@4
   158
    return *this;
williamr@4
   159
  }
williamr@4
   160
williamr@4
   161
  _Self& seekp(off_type __off, ios_base::seekdir __dir) {
williamr@4
   162
    if (this->rdbuf() && !this->fail())
williamr@4
   163
      if( pos_type(off_type(-1)) == this->rdbuf()->pubseekoff(__off, __dir, ios_base::out))
williamr@4
   164
        this->setstate(ios_base::failbit);
williamr@4
   165
    return *this;
williamr@4
   166
  }
williamr@4
   167
williamr@4
   168
#if defined (_STLP_USE_TEMPLATE_EXPORT)
williamr@4
   169
  // If we are using DLL specs, we have not to use inner classes
williamr@4
   170
  // end class declaration here
williamr@4
   171
  typedef _Osentry<_CharT, _Traits>  sentry;
williamr@4
   172
};
williamr@4
   173
#  define sentry _Osentry
williamr@4
   174
  template <class _CharT, class _Traits>
williamr@4
   175
  class _Osentry {
williamr@4
   176
    typedef _Osentry<_CharT, _Traits> _Self;
williamr@4
   177
# else
williamr@4
   178
    class sentry {
williamr@4
   179
      typedef sentry _Self;
williamr@4
   180
# endif
williamr@4
   181
    private:
williamr@4
   182
      basic_ostream<_CharT, _Traits>& _M_str;
williamr@4
   183
      //      basic_streambuf<_CharT, _Traits>* _M_buf;
williamr@4
   184
      bool _M_ok;
williamr@4
   185
    public:
williamr@4
   186
      explicit sentry(basic_ostream<_CharT, _Traits>& __str)
williamr@4
   187
        : _M_str(__str), /* _M_buf(__str.rdbuf()), */ _M_ok(_M_init(__str))
williamr@4
   188
      {
williamr@4
   189
      }
williamr@4
   190
      
williamr@4
   191
      ~sentry() {
williamr@4
   192
        if (_M_str.flags() & ios_base::unitbuf)
williamr@4
   193
# ifndef _STLP_INCOMPLETE_EXCEPTION_HEADER 
williamr@4
   194
          if (!_STLP_VENDOR_EXCEPT_STD::uncaught_exception())
williamr@4
   195
# endif
williamr@4
   196
            _M_str.flush();
williamr@4
   197
      }
williamr@4
   198
williamr@4
   199
      operator bool() const { return _M_ok; }
williamr@4
   200
    private:                        // Disable assignment and copy constructor.
williamr@4
   201
      sentry(const _Self& __s) : _M_str (__s._M_str) {};
williamr@4
   202
      void operator=(const _Self&) {};
williamr@4
   203
    };
williamr@4
   204
# if defined (_STLP_USE_TEMPLATE_EXPORT)
williamr@4
   205
#  undef sentry
williamr@4
   206
# else
williamr@4
   207
  // close basic_ostream class definition here    
williamr@4
   208
};
williamr@4
   209
# endif
williamr@4
   210
  
williamr@4
   211
# if defined (_STLP_USE_TEMPLATE_EXPORT)
williamr@4
   212
_STLP_EXPORT_TEMPLATE_CLASS basic_ostream<char, char_traits<char> >;
williamr@4
   213
_STLP_EXPORT_TEMPLATE_CLASS _Osentry<char, char_traits<char> >;
williamr@4
   214
#  if !defined (_STLP_NO_WCHAR_T)
williamr@4
   215
_STLP_EXPORT_TEMPLATE_CLASS basic_ostream<wchar_t, char_traits<wchar_t> >;
williamr@4
   216
_STLP_EXPORT_TEMPLATE_CLASS _Osentry<wchar_t, char_traits<wchar_t> >;
williamr@4
   217
#  endif
williamr@4
   218
# endif /* _STLP_USE_TEMPLATE_EXPORT */
williamr@4
   219
williamr@4
   220
template <class _CharT, class _Traits>
williamr@4
   221
inline basic_streambuf<_CharT, _Traits>* _STLP_CALL 
williamr@4
   222
_M_get_ostreambuf(basic_ostream<_CharT, _Traits>& __St) 
williamr@4
   223
{
williamr@4
   224
  return __St.rdbuf();
williamr@4
   225
}
williamr@4
   226
williamr@4
   227
// Non-member functions.
williamr@4
   228
williamr@4
   229
template <class _CharT, class _Traits>
williamr@4
   230
inline basic_ostream<_CharT, _Traits>& _STLP_CALL
williamr@4
   231
operator<<(basic_ostream<_CharT, _Traits>& __os, _CharT __c) {
williamr@4
   232
  __os._M_put_char(__c);
williamr@4
   233
  return __os;
williamr@4
   234
}
williamr@4
   235
williamr@4
   236
template <class _CharT, class _Traits>
williamr@4
   237
inline basic_ostream<_CharT, _Traits>& _STLP_CALL
williamr@4
   238
operator<<(basic_ostream<_CharT, _Traits>& __os, const _CharT* __s) {
williamr@4
   239
#ifdef __SYMBIAN32__
williamr@4
   240
  !__s ? __os.setstate(ios_base::badbit):__os._M_put_nowiden(__s);
williamr@4
   241
#else
williamr@4
   242
  __os._M_put_nowiden(__s);
williamr@4
   243
#endif
williamr@4
   244
  return __os;
williamr@4
   245
}
williamr@4
   246
williamr@4
   247
# ifdef _STLP_NO_FUNCTION_TMPL_PARTIAL_ORDER
williamr@4
   248
// some specializations
williamr@4
   249
williamr@4
   250
inline basic_ostream<char, char_traits<char> >& _STLP_CALL
williamr@4
   251
operator<<(basic_ostream<char, char_traits<char> >& __os, char __c) {
williamr@4
   252
  __os._M_put_char(__c);
williamr@4
   253
  return __os;
williamr@4
   254
}
williamr@4
   255
williamr@4
   256
inline basic_ostream<char, char_traits<char> >& _STLP_CALL
williamr@4
   257
operator<<(basic_ostream<char, char_traits<char> >& __os, signed char __c) {
williamr@4
   258
  __os._M_put_char(__c);
williamr@4
   259
  return __os;
williamr@4
   260
}
williamr@4
   261
williamr@4
   262
inline basic_ostream<char, char_traits<char> >& _STLP_CALL
williamr@4
   263
operator<<(basic_ostream<char, char_traits<char> >& __os, unsigned char __c) {
williamr@4
   264
  __os._M_put_char(__c);
williamr@4
   265
  return __os;
williamr@4
   266
}
williamr@4
   267
williamr@4
   268
inline basic_ostream<char, char_traits<char> >& _STLP_CALL
williamr@4
   269
operator<<(basic_ostream<char, char_traits<char> >& __os, const char* __s) {
williamr@4
   270
#ifdef __SYMBIAN32__
williamr@4
   271
  !__s ? __os.setstate(ios_base::badbit):__os._M_put_nowiden(__s);
williamr@4
   272
#else
williamr@4
   273
  __os._M_put_nowiden(__s);
williamr@4
   274
#endif
williamr@4
   275
  return __os;
williamr@4
   276
}
williamr@4
   277
williamr@4
   278
inline basic_ostream<char, char_traits<char> >& _STLP_CALL
williamr@4
   279
operator<<(basic_ostream<char, char_traits<char> >& __os, const signed char* __s) {
williamr@4
   280
#ifdef __SYMBIAN32__
williamr@4
   281
   !__s ? __os.setstate(ios_base::badbit):__os._M_put_nowiden(__REINTERPRET_CAST(const char*,__s));
williamr@4
   282
#else
williamr@4
   283
   __os._M_put_nowiden(__REINTERPRET_CAST(const char*,__s));
williamr@4
   284
#endif
williamr@4
   285
  return __os;
williamr@4
   286
}
williamr@4
   287
williamr@4
   288
inline basic_ostream<char, char_traits<char> >&
williamr@4
   289
operator<<(basic_ostream<char, char_traits<char> >& __os, const unsigned char* __s) {
williamr@4
   290
#ifdef __SYMBIAN32__
williamr@4
   291
  !__s ? __os.setstate(ios_base::badbit):__os._M_put_nowiden(__REINTERPRET_CAST(const char*,__s));
williamr@4
   292
#else
williamr@4
   293
  __os._M_put_nowiden(__REINTERPRET_CAST(const char*,__s));
williamr@4
   294
#endif
williamr@4
   295
  return __os;
williamr@4
   296
}
williamr@4
   297
williamr@4
   298
# else
williamr@4
   299
williamr@4
   300
// also for compilers who might use that
williamr@4
   301
template <class _CharT, class _Traits>
williamr@4
   302
inline basic_ostream<_CharT, _Traits>& _STLP_CALL
williamr@4
   303
operator<<(basic_ostream<_CharT, _Traits>& __os, char __c) {
williamr@4
   304
  __os._M_put_char(__os.widen(__c));
williamr@4
   305
  return __os;
williamr@4
   306
}
williamr@4
   307
williamr@4
   308
template <class _Traits>
williamr@4
   309
inline basic_ostream<char, _Traits>& _STLP_CALL
williamr@4
   310
operator<<(basic_ostream<char, _Traits>& __os, char __c) {
williamr@4
   311
  __os._M_put_char(__c);
williamr@4
   312
  return __os;
williamr@4
   313
}
williamr@4
   314
williamr@4
   315
template <class _Traits>
williamr@4
   316
inline basic_ostream<char, _Traits>& _STLP_CALL
williamr@4
   317
operator<<(basic_ostream<char, _Traits>& __os, signed char __c) {
williamr@4
   318
  __os._M_put_char(__c);
williamr@4
   319
  return __os;
williamr@4
   320
}
williamr@4
   321
williamr@4
   322
template <class _Traits>
williamr@4
   323
inline basic_ostream<char, _Traits>& _STLP_CALL
williamr@4
   324
operator<<(basic_ostream<char, _Traits>& __os, unsigned char __c) {
williamr@4
   325
  __os._M_put_char(__c);
williamr@4
   326
  return __os;
williamr@4
   327
}
williamr@4
   328
williamr@4
   329
template <class _CharT, class _Traits>
williamr@4
   330
inline basic_ostream<_CharT, _Traits>& _STLP_CALL
williamr@4
   331
operator<<(basic_ostream<_CharT, _Traits>& __os, const char* __s) {
williamr@4
   332
#ifdef __SYMBIAN32__
williamr@4
   333
  !__s ? __os.setstate(ios_base::badbit):__os._M_put_widen(__s);
williamr@4
   334
#else
williamr@4
   335
  __os._M_put_widen(__s);
williamr@4
   336
#endif
williamr@4
   337
  return __os;
williamr@4
   338
}
williamr@4
   339
williamr@4
   340
template <class _Traits>
williamr@4
   341
inline basic_ostream<char, _Traits>& _STLP_CALL
williamr@4
   342
operator<<(basic_ostream<char, _Traits>& __os, const char* __s) {
williamr@4
   343
#ifdef __SYMBIAN32__
williamr@4
   344
  !__s ? __os.setstate(ios_base::badbit):__os._M_put_nowiden(__s);
williamr@4
   345
#else
williamr@4
   346
  __os._M_put_nowiden(__s);
williamr@4
   347
#endif
williamr@4
   348
  return __os;
williamr@4
   349
}
williamr@4
   350
williamr@4
   351
template <class _Traits>
williamr@4
   352
inline basic_ostream<char, _Traits>& _STLP_CALL
williamr@4
   353
operator<<(basic_ostream<char, _Traits>& __os, const signed char* __s) {
williamr@4
   354
#ifdef __SYMBIAN32__
williamr@4
   355
  !__s ? __os.setstate(ios_base::badbit):__os._M_put_nowiden(__REINTERPRET_CAST(const char*,__s));
williamr@4
   356
#else
williamr@4
   357
  __os._M_put_nowiden(__REINTERPRET_CAST(const char*,__s));
williamr@4
   358
#endif
williamr@4
   359
  return __os;
williamr@4
   360
}
williamr@4
   361
williamr@4
   362
template <class _Traits>
williamr@4
   363
inline basic_ostream<char, _Traits>&
williamr@4
   364
operator<<(basic_ostream<char, _Traits>& __os, const unsigned char* __s) {
williamr@4
   365
#ifdef __SYMBIAN32__
williamr@4
   366
  !__s ? __os.setstate(ios_base::badbit):__os._M_put_nowiden(__REINTERPRET_CAST(const char*,__s));
williamr@4
   367
#else
williamr@4
   368
  __os._M_put_nowiden(__REINTERPRET_CAST(const char*,__s));
williamr@4
   369
#endif
williamr@4
   370
  return __os;
williamr@4
   371
}
williamr@4
   372
# endif /* _STLP_NO_FUNCTION_TMPL_PARTIAL_ORDER */
williamr@4
   373
williamr@4
   374
//----------------------------------------------------------------------
williamr@4
   375
// basic_ostream manipulators.
williamr@4
   376
williamr@4
   377
template <class _CharT, class _Traits>
williamr@4
   378
inline basic_ostream<_CharT, _Traits>& _STLP_CALL
williamr@4
   379
endl(basic_ostream<_CharT, _Traits>& __os) {
williamr@4
   380
  __os.put(__os.widen('\n'));
williamr@4
   381
  __os.flush();
williamr@4
   382
  return __os;
williamr@4
   383
}
williamr@4
   384
williamr@4
   385
template <class _CharT, class _Traits>
williamr@4
   386
inline basic_ostream<_CharT, _Traits>& _STLP_CALL
williamr@4
   387
ends(basic_ostream<_CharT, _Traits>& __os) {
williamr@4
   388
  __os.put(_STLP_DEFAULT_CONSTRUCTED(_CharT));
williamr@4
   389
  return __os;
williamr@4
   390
}
williamr@4
   391
williamr@4
   392
template <class _CharT, class _Traits>
williamr@4
   393
inline basic_ostream<_CharT, _Traits>& _STLP_CALL
williamr@4
   394
flush(basic_ostream<_CharT, _Traits>& __os) {
williamr@4
   395
  __os.flush();
williamr@4
   396
  return __os;
williamr@4
   397
}
williamr@4
   398
williamr@4
   399
_STLP_END_NAMESPACE
williamr@4
   400
williamr@4
   401
#  undef _STLP_MANIP_INLINE
williamr@4
   402
williamr@4
   403
#if defined (_STLP_EXPOSE_STREAM_IMPLEMENTATION) && !defined (_STLP_LINK_TIME_INSTANTIATION)
williamr@4
   404
#  include <stl/_ostream.c>
williamr@4
   405
# endif
williamr@4
   406
williamr@4
   407
#endif /* _STLP_INTERNAL_OSTREAM_H */
williamr@4
   408
williamr@4
   409
// Local Variables:
williamr@4
   410
// mode:C++
williamr@4
   411
// End: