summaryrefslogtreecommitdiffstats
path: root/Source/kwsys/testIOS.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'Source/kwsys/testIOS.cxx')
-rw-r--r--Source/kwsys/testIOS.cxx164
1 files changed, 164 insertions, 0 deletions
diff --git a/Source/kwsys/testIOS.cxx b/Source/kwsys/testIOS.cxx
new file mode 100644
index 0000000..5ff7955
--- /dev/null
+++ b/Source/kwsys/testIOS.cxx
@@ -0,0 +1,164 @@
+/*============================================================================
+ KWSys - Kitware System Library
+ Copyright 2000-2009 Kitware, Inc., Insight Software Consortium
+
+ Distributed under the OSI-approved BSD License (the "License");
+ see accompanying file Copyright.txt for details.
+
+ This software is distributed WITHOUT ANY WARRANTY; without even the
+ implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
+ See the License for more information.
+============================================================================*/
+#include "kwsysPrivate.h"
+#include KWSYS_HEADER(Configure.hxx)
+
+#include <sstream>
+#include <fstream>
+#include <iostream>
+#include <vector>
+#include <string.h> /* strlen */
+
+// Work-around CMake dependency scanning limitation. This must
+// duplicate the above list of headers.
+#if 0
+# include "Configure.hxx.in"
+#endif
+
+int testIOS(int, char*[])
+{
+ std::ostringstream ostr;
+ const char hello[] = "hello";
+ ostr << hello;
+ if(ostr.str() != hello)
+ {
+ std::cerr << "failed to write hello to ostr" << std::endl;
+ return 1;
+ }
+ const char world[] = "world";
+ std::ostringstream ostr2;
+ ostr2.write( hello, strlen(hello) ); /* I could do sizeof */
+ ostr2.put( '\0' );
+ ostr2.write( world, strlen(world) );
+ if(ostr2.str().size() != strlen(hello) + 1 + strlen(world) )
+ {
+ std::cerr << "failed to write hello to ostr2" << std::endl;
+ return 1;
+ }
+ static const unsigned char array[] = { 0xff,0x4f,0xff,0x51,0x00,0x29,0x00,0x00,0x00,0x00,0x00,0x30,0x00,0x00,0x00,0x3e,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x30,0x00,0x00,0x00,0x3e,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x01,0x07,0x01,0x01,0xff,0x52,0x00,0x0c,0x00,0x00,0x00,0x01,0x00,0x05,0x04,0x04,0x00,0x01,0xff,0x5c,0x00,0x13,0x40,0x40,0x48,0x48,0x50,0x48,0x48,0x50,0x48,0x48,0x50,0x48,0x48,0x50,0x48,0x48,0x50,0xff,0x64,0x00,0x2c,0x00,0x00,0x43,0x72,0x65,0x61,0x74,0x65,0x64,0x20,0x62,0x79,0x20,0x49,0x54,0x4b,0x2f,0x47,0x44,0x43,0x4d,0x2f,0x4f,0x70,0x65,0x6e,0x4a,0x50,0x45,0x47,0x20,0x76,0x65,0x72,0x73,0x69,0x6f,0x6e,0x20,0x31,0x2e,0x30,0xff,0x90,0x00,0x0a,0x00,0x00,0x00,0x00,0x06,0x2c,0x00,0x01,0xff,0x93,0xcf,0xb0,0x18,0x08,0x7f,0xc6,0x99,0xbf,0xff,0xc0,0xf8,0xc1,0xc1,0xf3,0x05,0x81,0xf2,0x83,0x0a,0xa5,0xff,0x10,0x90,0xbf,0x2f,0xff,0x04,0xa8,0x7f,0xc0,0xf8,0xc4,0xc1,0xf3,0x09,0x81,0xf3,0x0c,0x19,0x34 };
+ const size_t narray = sizeof(array); // 180
+ std::stringstream strstr;
+ strstr.write( (char*)array, narray );
+ //strstr.seekp( narray / 2 ); // set position of put pointer in mid string
+ if(strstr.str().size() != narray )
+ {
+ std::cerr << "failed to write array to strstr" << std::endl;
+ return 1;
+ }
+
+ std::istringstream istr(" 10 20 str ");
+ std::string s;
+ int x;
+ if(istr >> x)
+ {
+ if(x != 10)
+ {
+ std::cerr << "x != 10" << std::endl;
+ return 1;
+ }
+ }
+ else
+ {
+ std::cerr << "Failed to read 10 from istr" << std::endl;
+ return 1;
+ }
+ if(istr >> x)
+ {
+ if(x != 20)
+ {
+ std::cerr << "x != 20" << std::endl;
+ return 1;
+ }
+ }
+ else
+ {
+ std::cerr << "Failed to read 20 from istr" << std::endl;
+ return 1;
+ }
+ if(istr >> s)
+ {
+ if(s != "str")
+ {
+ std::cerr << "s != \"str\"" << std::endl;
+ return 1;
+ }
+ }
+ else
+ {
+ std::cerr << "Failed to read str from istr" << std::endl;
+ return 1;
+ }
+ if(istr >> s)
+ {
+ std::cerr << "Able to read past end of stream" << std::endl;
+ return 1;
+ }
+ else
+ {
+ // Clear the failure.
+ istr.clear(istr.rdstate() & ~std::ios::eofbit);
+ istr.clear(istr.rdstate() & ~std::ios::failbit);
+ }
+ istr.str("30");
+ if(istr >> x)
+ {
+ if(x != 30)
+ {
+ std::cerr << "x != 30" << std::endl;
+ return 1;
+ }
+ }
+ else
+ {
+ std::cerr << "Failed to read 30 from istr" << std::endl;
+ return 1;
+ }
+
+ std::stringstream sstr;
+ sstr << "40 str2";
+ if(sstr >> x)
+ {
+ if(x != 40)
+ {
+ std::cerr << "x != 40" << std::endl;
+ return 1;
+ }
+ }
+ else
+ {
+ std::cerr << "Failed to read 40 from sstr" << std::endl;
+ return 1;
+ }
+ if(sstr >> s)
+ {
+ if(s != "str2")
+ {
+ std::cerr << "s != \"str2\"" << std::endl;
+ return 1;
+ }
+ }
+ else
+ {
+ std::cerr << "Failed to read str2 from sstr" << std::endl;
+ return 1;
+ }
+
+ // Just try to compile this.
+ if(x == 12345)
+ {
+ std::ifstream fin("/does_not_exist",
+ std::ios::in | std::ios::binary);
+ }
+
+ std::cout << "IOS tests passed" << std::endl;
+ return 0;
+}