libMesh::BasicOStreamProxy< charT, traits > Class Template Reference

#include <ostream_proxy.h>

Public Types

typedef std::basic_ostream< charT, traits > streamT
 
typedef std::basic_streambuf< charT, traits > streambufT
 

Public Member Functions

 BasicOStreamProxy (streamT &target)
 
 BasicOStreamProxy (BasicOStreamProxy &old)
 
BasicOStreamProxyoperator= (streamT &target)
 
BasicOStreamProxyoperator= (const BasicOStreamProxy &old)
 
 ~BasicOStreamProxy ()
 
 operator streamT & ()
 
 operator const streamT & () const
 
template<typename T >
BasicOStreamProxyoperator<< (const T &in)
 
BasicOStreamProxyoperator<< (streamT &(*in)(streamT &))
 
BasicOStreamProxyoperator<< (std::basic_ios< charT, traits > &(*in)(std::basic_ios< charT, traits > &))
 
BasicOStreamProxyoperator<< (std::ios_base &(*in)(std::ios_base &))
 
streambufTrdbuf () const
 
streambufTrdbuf (streambufT *sb)
 
BasicOStreamProxyflush ()
 
std::ios_base::fmtflags flags () const
 
std::ios_base::fmtflags flags (std::ios_base::fmtflags fmtfl)
 
std::ios_base::fmtflags setf (std::ios_base::fmtflags fmtfl)
 
std::ios_base::fmtflags setf (std::ios_base::fmtflags fmtfl, std::ios_base::fmtflags mask)
 
void unsetf (std::ios_base::fmtflags mask)
 
std::streamsize precision () const
 
std::streamsize precision (std::streamsize prec)
 
void reset (streamT &target)
 
streamTget ()
 
const streamTget () const
 

Private Attributes

streamT_target
 

Detailed Description

template<typename charT = char, typename traits = std::char_traits<charT>>
class libMesh::BasicOStreamProxy< charT, traits >

This class is intended to be reseatable like a pointer-to-ostream for flexibility, but to look like a reference when used to produce less awkward user code.

It is up to the user to ensure that the target ostream remains valid.

Author
Roy Stogner
Date
2010

Definition at line 42 of file ostream_proxy.h.

Member Typedef Documentation

◆ streambufT

template<typename charT = char, typename traits = std::char_traits<charT>>
typedef std::basic_streambuf<charT,traits> libMesh::BasicOStreamProxy< charT, traits >::streambufT

This class is going to be used to proxy for ostream, but other character and traits types are possible

Definition at line 55 of file ostream_proxy.h.

◆ streamT

template<typename charT = char, typename traits = std::char_traits<charT>>
typedef std::basic_ostream<charT,traits> libMesh::BasicOStreamProxy< charT, traits >::streamT

This class is going to be used to proxy for ostream, but other character and traits types are possible

Definition at line 49 of file ostream_proxy.h.

Constructor & Destructor Documentation

◆ BasicOStreamProxy() [1/2]

template<typename charT = char, typename traits = std::char_traits<charT>>
libMesh::BasicOStreamProxy< charT, traits >::BasicOStreamProxy ( streamT target)
inline

Default constructor. Takes a reference to the target ostream to which we pass output. The user is responsible for ensuring that this target exists for as long as the proxy does.

Definition at line 62 of file ostream_proxy.h.

62 : _target(&target) {}

◆ BasicOStreamProxy() [2/2]

template<typename charT = char, typename traits = std::char_traits<charT>>
libMesh::BasicOStreamProxy< charT, traits >::BasicOStreamProxy ( BasicOStreamProxy< charT, traits > &  old)
inline

Shallow copy constructor. Output in the new object is passed to the same target ostream as in the old object. The user is responsible for ensuring that this target exists for as long as the proxies do.

Definition at line 70 of file ostream_proxy.h.

70 : _target(old._target) {}

◆ ~BasicOStreamProxy()

template<typename charT = char, typename traits = std::char_traits<charT>>
libMesh::BasicOStreamProxy< charT, traits >::~BasicOStreamProxy ( )
inline

Default destructor.

Definition at line 93 of file ostream_proxy.h.

93 {}

Member Function Documentation

◆ flags() [1/2]

template<typename charT = char, typename traits = std::char_traits<charT>>
std::ios_base::fmtflags libMesh::BasicOStreamProxy< charT, traits >::flags ( ) const
inline

Get the associated format flags

Definition at line 158 of file ostream_proxy.h.

References libMesh::BasicOStreamProxy< charT, traits >::_target.

159  { return _target->flags(); }

◆ flags() [2/2]

template<typename charT = char, typename traits = std::char_traits<charT>>
std::ios_base::fmtflags libMesh::BasicOStreamProxy< charT, traits >::flags ( std::ios_base::fmtflags  fmtfl)
inline

Set/get the associated format flags

Definition at line 164 of file ostream_proxy.h.

References libMesh::BasicOStreamProxy< charT, traits >::_target.

165  { return _target->flags(fmtfl); }

◆ flush()

template<typename charT = char, typename traits = std::char_traits<charT>>
BasicOStreamProxy& libMesh::BasicOStreamProxy< charT, traits >::flush ( )
inline

Flush the associated stream buffer

Definition at line 153 of file ostream_proxy.h.

References libMesh::BasicOStreamProxy< charT, traits >::_target.

Referenced by libMesh::PltLoader::read_data().

153 { _target->flush(); return *this; }

◆ get() [1/2]

template<typename charT = char, typename traits = std::char_traits<charT>>
streamT* libMesh::BasicOStreamProxy< charT, traits >::get ( )
inline

Rather than implement every ostream/ios/ios_base function, we'll be lazy and make esoteric uses go through a get() function.

Definition at line 213 of file ostream_proxy.h.

References libMesh::BasicOStreamProxy< charT, traits >::_target.

213  {
214  return _target;
215  }

◆ get() [2/2]

template<typename charT = char, typename traits = std::char_traits<charT>>
const streamT* libMesh::BasicOStreamProxy< charT, traits >::get ( ) const
inline

Rather than implement every ostream/ios/ios_base function, we'll be lazy and make esoteric uses go through a get() function.

Definition at line 221 of file ostream_proxy.h.

References libMesh::BasicOStreamProxy< charT, traits >::_target.

221  {
222  return _target;
223  }

◆ operator const streamT &()

template<typename charT = char, typename traits = std::char_traits<charT>>
libMesh::BasicOStreamProxy< charT, traits >::operator const streamT & ( ) const
inline

Conversion to const ostream &, for when we get passed to a function requesting one.

Definition at line 109 of file ostream_proxy.h.

References libMesh::BasicOStreamProxy< charT, traits >::_target.

109 { return *_target; }

◆ operator streamT &()

template<typename charT = char, typename traits = std::char_traits<charT>>
libMesh::BasicOStreamProxy< charT, traits >::operator streamT & ( )
inline

Conversion to ostream &, for when we get passed to a function requesting one.

Definition at line 103 of file ostream_proxy.h.

References libMesh::BasicOStreamProxy< charT, traits >::_target.

103 { return *_target; }

◆ operator<<() [1/4]

template<typename charT = char, typename traits = std::char_traits<charT>>
template<typename T >
BasicOStreamProxy& libMesh::BasicOStreamProxy< charT, traits >::operator<< ( const T &  in)
inline

Redirect any output to the target.

Definition at line 115 of file ostream_proxy.h.

115  {
116  (*_target) << in; return *this;
117  }

◆ operator<<() [2/4]

template<typename charT = char, typename traits = std::char_traits<charT>>
BasicOStreamProxy& libMesh::BasicOStreamProxy< charT, traits >::operator<< ( streamT &(*)(streamT &)  in)
inline

Redirect any ostream manipulators to the target.

Definition at line 122 of file ostream_proxy.h.

122  {
123  (*_target) << in; return *this;
124  }

◆ operator<<() [3/4]

template<typename charT = char, typename traits = std::char_traits<charT>>
BasicOStreamProxy& libMesh::BasicOStreamProxy< charT, traits >::operator<< ( std::basic_ios< charT, traits > &(*)(std::basic_ios< charT, traits > &)  in)
inline

Redirect any ios manipulators to the target.

Definition at line 129 of file ostream_proxy.h.

129  {
130  (*_target) << in; return *this;
131  }

◆ operator<<() [4/4]

template<typename charT = char, typename traits = std::char_traits<charT>>
BasicOStreamProxy& libMesh::BasicOStreamProxy< charT, traits >::operator<< ( std::ios_base &(*)(std::ios_base &)  in)
inline

Redirect any ios_base manipulators to the target.

Definition at line 136 of file ostream_proxy.h.

136  {
137  (*_target) << in; return *this;
138  }

◆ operator=() [1/2]

template<typename charT = char, typename traits = std::char_traits<charT>>
BasicOStreamProxy& libMesh::BasicOStreamProxy< charT, traits >::operator= ( streamT target)
inline

Reset the internal target to a new target output stream.

Definition at line 75 of file ostream_proxy.h.

References libMesh::BasicOStreamProxy< charT, traits >::_target.

76  {
77  _target = &target;
78  return *this;
79  }

◆ operator=() [2/2]

template<typename charT = char, typename traits = std::char_traits<charT>>
BasicOStreamProxy& libMesh::BasicOStreamProxy< charT, traits >::operator= ( const BasicOStreamProxy< charT, traits > &  old)
inline

Reset the target to the same output stream as in old

Definition at line 84 of file ostream_proxy.h.

References libMesh::BasicOStreamProxy< charT, traits >::_target.

85  {
86  _target = old._target;
87  return *this;
88  }

◆ precision() [1/2]

template<typename charT = char, typename traits = std::char_traits<charT>>
std::streamsize libMesh::BasicOStreamProxy< charT, traits >::precision ( ) const
inline

◆ precision() [2/2]

template<typename charT = char, typename traits = std::char_traits<charT>>
std::streamsize libMesh::BasicOStreamProxy< charT, traits >::precision ( std::streamsize  prec)
inline

Set the associated write precision

Definition at line 195 of file ostream_proxy.h.

References libMesh::BasicOStreamProxy< charT, traits >::_target.

196  { return _target->precision(prec); }

◆ rdbuf() [1/2]

template<typename charT = char, typename traits = std::char_traits<charT>>
streambufT* libMesh::BasicOStreamProxy< charT, traits >::rdbuf ( ) const
inline

Get the associated stream buffer

Definition at line 143 of file ostream_proxy.h.

References libMesh::BasicOStreamProxy< charT, traits >::_target.

Referenced by libMesh::LibMeshInit::LibMeshInit().

143 { return _target->rdbuf(); }

◆ rdbuf() [2/2]

template<typename charT = char, typename traits = std::char_traits<charT>>
streambufT* libMesh::BasicOStreamProxy< charT, traits >::rdbuf ( streambufT sb)
inline

Set the associated stream buffer

Definition at line 148 of file ostream_proxy.h.

References libMesh::BasicOStreamProxy< charT, traits >::_target.

148 { return _target->rdbuf(sb); }

◆ reset()

template<typename charT = char, typename traits = std::char_traits<charT>>
void libMesh::BasicOStreamProxy< charT, traits >::reset ( streamT target)
inline

Reset the proxy to point to a different target.

Note
This does not delete the previous target.

Definition at line 207 of file ostream_proxy.h.

References libMesh::BasicOStreamProxy< charT, traits >::_target.

207 { _target = &target; }

◆ setf() [1/2]

template<typename charT = char, typename traits = std::char_traits<charT>>
std::ios_base::fmtflags libMesh::BasicOStreamProxy< charT, traits >::setf ( std::ios_base::fmtflags  fmtfl)
inline

Set the associated flags

Definition at line 170 of file ostream_proxy.h.

References libMesh::BasicOStreamProxy< charT, traits >::_target.

Referenced by libMesh::ContinuationSystem::continuation_solve(), and libMesh::ContinuationSystem::update_solution().

171  { return _target->setf(fmtfl); }

◆ setf() [2/2]

template<typename charT = char, typename traits = std::char_traits<charT>>
std::ios_base::fmtflags libMesh::BasicOStreamProxy< charT, traits >::setf ( std::ios_base::fmtflags  fmtfl,
std::ios_base::fmtflags  mask 
)
inline

Set the associated flags

Definition at line 176 of file ostream_proxy.h.

References libMesh::BasicOStreamProxy< charT, traits >::_target.

178  { return _target->setf(fmtfl, mask); }

◆ unsetf()

template<typename charT = char, typename traits = std::char_traits<charT>>
void libMesh::BasicOStreamProxy< charT, traits >::unsetf ( std::ios_base::fmtflags  mask)
inline

Member Data Documentation

◆ _target


The documentation for this class was generated from the following file: