Boost C++ Libraries

...one of the most highly regarded and expertly designed C++ library projects in the world. Herb Sutter and Andrei Alexandrescu, C++ Coding Standards

This is the documentation for an old version of boost. Click here for the latest Boost documentation.
PrevUpHomeNext

Class template basic_ivectorstream

boost::interprocess::basic_ivectorstream

Synopsis

// In header: <boost/interprocess/interprocess_fwd.hpp>

template<typename CharVector, 
         typename CharTraits = std::char_traits<typename CharVector::value_type> > 
class basic_ivectorstream :
  public std::basic_istream< CharVector::value_type, CharTraits >
{
public:
  // construct/copy/destruct
  basic_ivectorstream(std::ios_base::openmode = std::ios_base::in);
  template<typename VectorParameter> 
    basic_ivectorstream(const VectorParameter &, 
                        std::ios_base::openmode = std::ios_base::in);

  // public member functions
  basic_vectorbuf< CharVector, CharTraits > * rdbuf() const;
  void swap_vector(vector_type &);
  const vector_type & vector() const;
  void reserve(typename vector_type::size_type);
  void clear();
};

Description

A basic_istream class that holds a character vector specified by CharVector template parameter as its formatting buffer. The vector must have contiguous storage, like std::vector, boost::interprocess::vector or boost::interprocess::basic_string

basic_ivectorstream public construct/copy/destruct

  1. basic_ivectorstream(std::ios_base::openmode mode = std::ios_base::in);

    Constructor. Throws if vector_type default constructor throws.

  2. template<typename VectorParameter> 
      basic_ivectorstream(const VectorParameter & param, 
                          std::ios_base::openmode mode = std::ios_base::in);

    Constructor. Throws if vector_type(const VectorParameter &param) throws.

basic_ivectorstream public member functions

  1. basic_vectorbuf< CharVector, CharTraits > * rdbuf() const;

    Returns the address of the stored stream buffer.

  2. void swap_vector(vector_type & vect);

    Swaps the underlying vector with the passed vector. This function resets the read position in the stream. Does not throw.

  3. const vector_type & vector() const;

    Returns a const reference to the internal vector. Does not throw.

  4. void reserve(typename vector_type::size_type size);

    Calls reserve() method of the internal vector. Resets the stream to the first position. Throws if the internals vector's reserve throws.

  5. void clear();

    Calls clear() method of the internal vector. Resets the stream to the first position.


PrevUpHomeNext