zorba::transcode::streambuf

#include <zorba/util/transcode_stream.h>

A transcode::streambuf is-a std::streambuf for transcoding character encodings from/to UTF-8 on-the-fly. To use it, replace a stream's streambuf:
  istream is;
  // ...
  transcode::streambuf tbuf( "ISO-8859-1", is.rdbuf() );
  is.ios::rdbuf( &tbuf );
Note that the transcode::streambuf must exist for as long as it's being used by the stream. If you are replacing the streabuf for a stream you did not create, you should set it back to the original streambuf:
  void f( ostream &os ) {
    transcode::streambuf tbuf( "ISO-8859-1", os.rdbuf() );
    try {
      os.ios::rdbuf( &tbuf );
      // ...
    }
    catch ( ... ) {
      os.ios::rdbuf( tbuf.orig_streambuf() );
      throw;
    }
    os.ios::rdbuf( tbuf.orig_streambuf() );
  }
Alternatively, you may wish to use either , , or instead.While transcode::streambuf does support seeking, the positions are relative to the original byte stream.

Public Functions

std::streambuf *

orig_streambuf() const

Gets the original streambuf.

streambuf(char const *charset, std::streambuf *orig)

Constructs a transcode::streambuf.

~streambuf()

Destructs a transcode::streambuf.

Protected Functions

void

imbue(std::locale const &)

int_type

overflow(int_type)

int_type

pbackfail(int_type)

pos_type

seekoff(off_type, std::ios_base::seekdir, std::ios_base::openmode)

pos_type

seekpos(pos_type, std::ios_base::openmode)

std::streambuf *

setbuf(char_type *, std::streamsize)

std::streamsize

showmanyc()

int

sync()

int_type

uflow()

int_type

underflow()

std::streamsize

xsgetn(char_type *, std::streamsize)

std::streamsize

xsputn(char_type const *, std::streamsize)

Private Functions

streambuf &

operator=(streambuf const &)

streambuf(streambuf const &)

Private Attributes

proxy_buf_

Public Functions

orig_streambuf

std::streambuf * orig_streambuf() const

Gets the original streambuf.

Returns

said streambuf.

streambuf

 streambuf(char const *charset, std::streambuf *orig)

Constructs a transcode::streambuf.

Parameters

charset The name of the character encoding to convert from/to.
orig The original streambuf to read/write from/to.

Parameters

std::invalid_argument if either charset is not supported or orig is null.

~streambuf

 ~streambuf()

Destructs a transcode::streambuf.

Protected Functions

imbue

void imbue(std::locale const &)

overflow

int_type overflow(int_type)

pbackfail

int_type pbackfail(int_type)

seekoff

pos_type seekoff(off_type, std::ios_base::seekdir, std::ios_base::openmode)

seekpos

pos_type seekpos(pos_type, std::ios_base::openmode)

setbuf

std::streambuf * setbuf(char_type *, std::streamsize)

showmanyc

std::streamsize showmanyc()

sync

int sync()

uflow

int_type uflow()

underflow

int_type underflow()

xsgetn

std::streamsize xsgetn(char_type *, std::streamsize)

xsputn

std::streamsize xsputn(char_type const *, std::streamsize)

Private Functions

operator=

streambuf & operator=(streambuf const &)

streambuf

 streambuf(streambuf const &)