strstream(3C++)
strstream --
iostream specialized to arrays
Synopsis
   #include <strstream.h>
   
   class ios {
   public:
   	enum	open_mode { in, out, ate, app, trunc, nocreate, noreplace } ;
   	// and lots of other stuff, see ios(3C++) ...
   } ;
   
   class strstreambase : public virtual ios {
          ...
   } ;
   
   class istrstream : public istream {
   public:
   			istrstream(char*) ;
   			istrstream(char*, int) ;
   	strstreambuf*	rdbuf() ;
   } ;
   
   class ostrstream : public ostream {
   public:
   			ostrstream();
   			ostrstream(char*, int, int=ios::out) ;
   	int		pcount() ;
   	strstreambuf*	rdbuf() ;
   	char*		str();
   };
   
   class strstream : public strstreambase, public iostream {
   public:
   			strstream();
   			strstream(char*, int, int mode);
   	strstreambuf*	rdbuf() ;
   	char*		str();
   };
   
Description
strstream specializes iostream
for ``incore'' operations, that is, storing and fetching from arrays of bytes.
The streambuf associated with a strstream is a
strstreambuf (see
strstreambuf(3C++)).
In the following descriptions assume:
-- ss is a strstream.
-- iss is an istrstream.
-- oss is an ostrstream.
-- cp is a char*.
-- mode is an int representing an open_mode.
-- i and len are ints.
-- ssb is a strstreambuf*.
Constructors
 istrstream(cp)
- 
Characters will be fetched from the (null-terminated) string cp.
The terminating null character will not be part of the sequence.
Seeks (istream::seekg()) are allowed within that space.
 istrstream(cp, len)
- 
Characters will be fetched from the array beginning at cp
and extending for len bytes. 
Seeks (istream::seekg()) are allowed anywhere within that array.
 ostrstream()
- 
Space will be dynamically allocated to hold stored characters.
 ostrstream(cp,n,mode)
- 
Characters will be stored into the array starting at cp
and continuing for n bytes.
If ios::ate or ios::app is set in mode,
cp is assumed to be a null-terminated string
and storing will begin at the null character.
Otherwise storing will begin at cp.
Seeks are allowed anywhere in the array.
 strstream()
- 
Space will be dynamically allocated to hold stored characters.
 strstream(cp,n,mode)
- 
Characters will be stored into the array starting at cp
and continuing for n bytes.
If ios::ate or ios::app is set in mode,
cp is assumed to be a null-terminated string
and storing will begin at the null character.
Otherwise storing will begin at cp.
Seeks are allowed anywhere in the array.
Note that, if mode is set to ios::in|ios::out,
the original string (if any) stored at cp will not be
accessible unless seeks (ostream::seekp()) are used to
adjust the put pointer.
istrstream members
 ssb = iss.rdbuf()
- 
Returns the strstreambuf associated with iss.
ostrstream members
 ssb = oss.rdbuf()
- 
Returns the strstreambuf associated with oss.
 cp=oss.str()
- 
Returns a pointer to the array being used and ``freezes'' the array.
Once str has been called the effect of storing
more characters into oss is undefined.
If oss was constructed with an explicit array,
cp is just a pointer to the array.
Otherwise, cp points
to a dynamically allocated area.
Until str is called, deleting the dynamically allocated area is
the responsibility of oss.
After str returns, the array becomes the responsibility
of the user program.
 i=oss.pcount()
- 
Returns the number of bytes that have been stored into the buffer.
This is mainly of use when binary data has been stored and oss.str()
does not point to a null terminated string.
strstream members
 ssb  = ss.rdbuf()
- 
Returns the strstreambuf associated with ss.
 cp=ss.str()
- 
Returns a pointer to the array being used and ``freezes'' the array.
Once str has been called the effect of storing
more characters into ss is undefined.
If ss was constructed with an explicit array,
cp is just a pointer to the array.
Otherwise, cp points to a dynamically allocated area.
Until str is called, deleting the dynamically allocated area is
the responsibility of ss.
After str returns, the array becomes the responsibility
of the user program.
References
strstreambuf(3C++),
ios(3C++),
istream(3C++),
ostream(3C++)
© 2004 The SCO Group, Inc.  All rights reserved.
UnixWare 7 Release 7.1.4 - 25 April 2004