gcc/libstdc++-v3/testsuite/21_strings/inserters_extractors.cc

316 lines
6.9 KiB
C++
Raw Normal View History

// 1999-07-01 bkoz
// Copyright (C) 1999, 2000 Free Software Foundation, Inc.
//
// This file is part of the GNU ISO C++ Library. This library is free
// software; you can redistribute it and/or modify it under the
// terms of the GNU General Public License as published by the
// Free Software Foundation; either version 2, or (at your option)
// any later version.
// This library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
// You should have received a copy of the GNU General Public License along
// with this library; see the file COPYING. If not, write to the Free
// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
// USA.
// 21.3.7.9 inserters and extractors
// NB: This file is predicated on sstreams, istreams, and ostreams
// working, not to mention other major details like char_traits, and
// all of the string class.
#include <string>
#include <stdexcept>
#include <sstream>
#include <fstream>
#include <iostream>
#ifdef DEBUG_ASSERT
#include <assert.h>
#endif
bool test01(void)
{
bool test = true;
typedef std::string::size_type csize_type;
typedef std::string::const_reference cref;
typedef std::string::reference ref;
csize_type npos = std::string::npos;
csize_type csz01, csz02;
const char str_lit01[] = "sailing grand traverse bay
from Elk Rapids to the point reminds me of miles";
const std::string str01(str_lit01);
const std::string str02("sailing");
const std::string str03("grand");
const std::string str04("traverse");
const std::string str05;
std::string str10;
// istream& operator>>(istream&, string&)
std::istringstream istrs01(str01);
istrs01 >> str10;
test &= str10 == str02;
try {
std::istringstream::int_type i01 = istrs01.peek(); //a-boo
test &= std::istringstream::traits_type::to_char_type(i01) == ' ';
}
catch(std::exception& fail) {
test &= false; // shouldn't throw
}
istrs01 >> str10;
test &= str10 == str03;
istrs01 >> str10;
test &= str10 == str04; // sentry picks out the white spaces. .
std::istringstream istrs02(str05); // empty
istrs02 >> str10;
test &= str10 == str04;
// istream& getline(istream&, string&, char)
// istream& getline(istream&, string&)
try {
getline(istrs01, str10);
test &= !istrs01.fail();
test &= !istrs01.eof();
test &= istrs01.good();
test &= str10 == " bay";
}
catch(std::exception& fail) {
test &= false; // shouldn't throw
}
try {
istrs01.clear();
getline(istrs01, str10,'\t');
test &= !istrs01.fail();
test &= !istrs01.eof();
test &= istrs01.good();
test &= str10 == str05;
}
catch(std::exception& fail) {
test &= false; // shouldn't throw
}
try {
istrs01.clear();
getline(istrs01, str10,'\t');
test &= !istrs01.fail();
test &= !istrs01.eof();
test &= istrs01.good();
test &= str10 == str05;
}
catch(std::exception& fail) {
test &= false; // shouldn't throw
}
try {
istrs01.clear();
getline(istrs01, str10, '.');
test &= !istrs01.fail();
test &= istrs01.eof();
test &= !istrs01.good();
test &= str10 == "\t from Elk Rapids to the point reminds me of miles";
}
catch(std::exception& fail) {
test &= false; // shouldn't throw
}
try {
getline(istrs02, str10);
test &= istrs02.fail();
test &= istrs02.eof();
test &= str10 == "\t from Elk Rapids to the point reminds me of miles";
}
catch(std::exception& fail) {
test &= false; // shouldn't throw
}
// ostream& operator<<(ostream&, const basic_string&)
std::ostringstream ostrs01;
try {
ostrs01 << str01;
test &= ostrs01.str() == str01;
}
catch(std::exception& fail) {
test &= false;
}
std::string hello_world;
std::cout << hello_world;
#ifdef DEBUG_ASSERT
assert(test);
#endif
return test;
}
// testing basic_stringbuf::xsputn via stress testing with large strings
// based on a bug report libstdc++ 9
void test04(int size)
{
bool test = true;
std::string str(size, 's');
int expected_size = (2 * (size + sizeof(char)));
std::ostringstream oss(str);
// sanity checks
test &= str.size() == size;
test &= oss.good();
// stress test
oss << str << std::endl;
if (!oss.good())
test = false;
oss << str << std::endl;
if (!oss.good())
test = false;
test &= str.size() == size;
test &= oss.good();
std::string str_tmp = oss.str();
test &= str_tmp.size() == expected_size;
#ifdef DEBUG_ASSERT
assert(test);
#endif
}
// testing basic_filebuf::xsputn via stress testing with large strings
// based on a bug report libstdc++ 9
// mode == out
void test05(int size)
{
bool test = true;
const char* filename = "testsuite/inserters_extractors-1.txt";
const char fillc = 'f';
std::ofstream ofs(filename);
std::string str(size, fillc);
// sanity checks
test &= str.size() == size;
test &= ofs.good();
// stress test
ofs << str << std::endl;
if (!ofs.good())
test = false;
ofs << str << std::endl;
if (!ofs.good())
test = false;
test &= str.size() == size;
test &= ofs.good();
ofs.close();
// sanity check on the written file
std::ifstream ifs(filename);
int count = 0;
char c;
while (count <= (2 * size) + 4)
{
ifs >> c;
if (ifs.good() && c == fillc)
{
++count;
c = '0';
}
else
break;
}
test &= count == 2 * size;
#ifdef DEBUG_ASSERT
assert(test);
#endif
}
// istringstream/stringbuf extractor properly size buffer based on
// actual, not allocated contents (string.size() vs. string.capacity()).
// http://sourceware.cygnus.com/ml/libstdc++/1999-q4/msg00049.html
void test06(void)
{
bool test = true;
typedef std::string::size_type size_type;
std::string str01("@silent");
size_type i01 = str01.size();
size_type i02 = str01.capacity();
str01.erase(0, 1);
size_type i03 = str01.size();
size_type i04 = str01.capacity();
test &= i01 - 1 == i03;
test &= i02 >= i04;
std::istringstream is(str01);
std::string str02;
is >> str02 >> std::ws;
size_type i05 = str02.size();
size_type i06 = str02.capacity();
test &= i05 == i03;
test &= i06 <= i04;
#ifdef DEBUG_ASSERT
assert(test);
#endif
}
// http://sourceware.cygnus.com/ml/libstdc++/2000-q1/msg00085.html
// istream::operator>>(string)
// sets failbit
// NB: this is a defect in the standard.
void test07(void)
{
bool test = true;
const std::string name("z6.cc");
std::istringstream iss (name);
int i = 0;
std::string s;
while (iss >> s)
++i;
test &= i < 3;
test &= static_cast<bool>(iss.rdstate() & std::ios_base::failbit);
#ifdef DEBUG_ASSERT
assert(test);
#endif
}
int main()
{
test01();
test04(1); // expected_size == 4
test04(1000); // expected_size == 2002
test04(10000); // expected_size == 20002
test05(1);
test05(1000);
test05(10000);
test06();
test07();
return 0;
}