home *** CD-ROM | disk | FTP | other *** search
/ Chip 2002 May / Chip_2002-05_cd1.bin / chplus / cpp / 3 / stl.exe / strngbuf.cpp < prev    next >
C/C++ Source or Header  |  1998-02-09  |  4KB  |  118 lines

  1. #include "stlexam.h"
  2. #pragma hdrstop
  3. /***************************************************************************
  4.  *
  5.  * stringbuf.cpp - basic_stringbuf example
  6.  *
  7.  * $Id: stringbuf.cpp,v 1.4 1996/08/28 01:18:27 smithey Exp $
  8.  *
  9.  ***************************************************************************
  10.  *
  11.  * (c) Copyright 1994, 1995 Rogue Wave Software, Inc.
  12.  * ALL RIGHTS RESERVED *
  13.  * The software and information contained herein are proprietary to, and
  14.  * comprise valuable trade secrets of, Rogue Wave Software, Inc., which
  15.  * intends to preserve as trade secrets such software and information.
  16.  * This software is furnished pursuant to a written license agreement and
  17.  * may be used, copied, transmitted, and stored only in accordance with
  18.  * the terms of such license and with the inclusion of the above copyright
  19.  * notice.  This software and information or any other copies thereof may
  20.  * not be provided or otherwise made available to any other person.
  21.  *
  22.  * Notwithstanding any other lease or license that may pertain to, or
  23.  * accompany the delivery of, this computer software and information, the
  24.  * rights of the Government regarding its use, reproduction and disclosure
  25.  * are as set forth in Section 52.227-19 of the FARS Computer
  26.  * Software-Restricted Rights clause.
  27.  * 
  28.  * Use, duplication, or disclosure by the Government is subject to
  29.  * restrictions as set forth in subparagraph (c)(1)(ii) of the Rights in
  30.  * Technical Data and Computer Software clause at DFARS 252.227-7013.
  31.  * Contractor/Manufacturer is Rogue Wave Software, Inc.,
  32.  * P.O. Box 2328, Corvallis, Oregon 97339.
  33.  *
  34.  * This computer software and information is distributed with "restricted
  35.  * rights."  Use, duplication or disclosure is subject to restrictions as
  36.  * set forth in NASA FAR SUP 18-52.227-79 (April 1985) "Commercial
  37.  * Computer Software-Restricted Rights (April 1985)."  If the Clause at
  38.  * 18-52.227-74 "Rights in Data General" is specified in the contract,
  39.  * then the "Alternate III" clause applies.
  40.  *
  41.  **************************************************************************/
  42.  
  43.   
  44. //
  45. // stdlib/examples/manual/stringbuf.cpp
  46. //
  47. #include<iostream>
  48. #include<sstream>
  49. #include<string>
  50.  
  51.  #ifndef _RWSTD_NO_NAMESPACE
  52.   using namespace std;
  53.  #endif 
  54.  
  55. int main ( )
  56. {
  57.  
  58.   // create a read/write string-stream object on tiny char
  59.   // and attach it to an ostringstream object
  60.   ostringstream out_1(ios_base::in | ios_base::out);
  61.  
  62.   // tie the istream object to the ostringstream object
  63.   istream in_1(out_1.rdbuf());   
  64.  
  65.   // output to out_1
  66.   out_1 << "Here is the first ouput";
  67.  
  68.   // create a string object on tiny char 
  69.   string  string_ex("l'heure est grave !");
  70.  
  71.   // open a read only string-stream object on tiny char
  72.   // and initialize it
  73.   istringstream in_2(string_ex);
  74.  
  75.   // output in_1 to the standard output
  76.   cout << in_1.rdbuf() << endl;
  77.  
  78.   // reposition in_1 at the beginning
  79.   in_1.seekg(0);
  80.  
  81.   // output in_2 to the standard output
  82.   cout << in_2.rdbuf() << endl;
  83.  
  84.   // reposition in_2 at the beginning
  85.   in_2.seekg(0);
  86.  
  87.   stringbuf::pos_type pos;
  88.  
  89.   // get the current put position
  90.   // equivalent to
  91.   // out_1.tellp(); 
  92.   pos = out_1.rdbuf()->pubseekoff(0,ios_base::cur,
  93.                                   ios_base::out);
  94.  
  95.   // append the content of stringbuffer
  96.   // pointed at by in_2 to the one 
  97.   // pointed at by out_1
  98.   out_1 << ' ' << in_2.rdbuf();
  99.  
  100.   // output in_1 to the standard output
  101.   cout << in_1.rdbuf() << endl;
  102.  
  103.   // position the get sequence
  104.   // equivalent to
  105.   // in_1.seekg(pos);
  106.   in_1.rdbuf()->pubseekpos(pos, ios_base::in);
  107.  
  108.   // output "l'heure est grave !"
  109.   cout << in_1.rdbuf() << endl << endl;  
  110.  
  111.   return 0;
  112. }
  113.  
  114.  
  115.  
  116.  
  117.  
  118.