added wxStd{In,Out}putStream classes (closes #10637)

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@60483 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Vadim Zeitlin
2009-05-02 18:29:33 +00:00
parent 574be073c0
commit 72a7c55982
29 changed files with 1198 additions and 13 deletions

View File

@@ -1,6 +1,6 @@
# =========================================================================
# This makefile was generated by
# Bakefile 0.2.5 (http://www.bakefile.org)
# Bakefile 0.2.6 (http://www.bakefile.org)
# Do not modify, all changes will be overwritten!
# =========================================================================
@@ -14,6 +14,7 @@ INSTALL = @INSTALL@
EXEEXT = @EXEEXT@
WINDRES = @WINDRES@
SETFILE = @SETFILE@
ICC_PCH_USE_SWITCH = @ICC_PCH_USE_SWITCH@
BK_DEPS = @BK_DEPS@
BK_MAKE_PCH = @BK_MAKE_PCH@
srcdir = @srcdir@
@@ -100,6 +101,7 @@ TEST_OBJECTS = \
test_memstream.o \
test_socketstream.o \
test_sstream.o \
test_stdstream.o \
test_tempfile.o \
test_textstreamtest.o \
test_zlibstream.o \
@@ -174,7 +176,7 @@ PRINTFBENCH_ODEP = $(_____pch_testprec_printfbench_testprec_h_gch___depname)
@COND_PLATFORM_MAC_1@__test___mac_setfilecmd = \
@COND_PLATFORM_MAC_1@ $(SETFILE) -t APPL test$(EXEEXT)
@COND_GCC_PCH_1@__test_PCH_INC = -I./.pch/testprec_test
@COND_ICC_PCH_1@__test_PCH_INC = -use_pch \
@COND_ICC_PCH_1@__test_PCH_INC = $(ICC_PCH_USE_SWITCH) \
@COND_ICC_PCH_1@ ./.pch/testprec_test/testprec.h.gch
@COND_USE_PCH_1@_____pch_testprec_test_testprec_h_gch___depname \
@COND_USE_PCH_1@ = ./.pch/testprec_test/testprec.h.gch
@@ -207,7 +209,7 @@ PRINTFBENCH_ODEP = $(_____pch_testprec_printfbench_testprec_h_gch___depname)
@COND_TOOLKIT_COCOA@____test_gui_BUNDLE_TGT_REF_DEP = \
@COND_TOOLKIT_COCOA@ $(__test_gui_app_Contents_PkgInfo___depname)
@COND_GCC_PCH_1@__test_gui_PCH_INC = -I./.pch/testprec_test_gui
@COND_ICC_PCH_1@__test_gui_PCH_INC = -use_pch \
@COND_ICC_PCH_1@__test_gui_PCH_INC = $(ICC_PCH_USE_SWITCH) \
@COND_ICC_PCH_1@ ./.pch/testprec_test_gui/testprec.h.gch
@COND_USE_PCH_1@_____pch_testprec_test_gui_testprec_h_gch___depname \
@COND_USE_PCH_1@ = ./.pch/testprec_test_gui/testprec.h.gch
@@ -239,7 +241,8 @@ COND_MONOLITHIC_0___WXLIB_CORE_p = \
@COND_PLATFORM_MAC_1@__printfbench___mac_setfilecmd = \
@COND_PLATFORM_MAC_1@ $(SETFILE) -t APPL printfbench$(EXEEXT)
@COND_GCC_PCH_1@__printfbench_PCH_INC = -I./.pch/testprec_printfbench
@COND_ICC_PCH_1@__printfbench_PCH_INC = -use_pch \
@COND_ICC_PCH_1@__printfbench_PCH_INC = \
@COND_ICC_PCH_1@ $(ICC_PCH_USE_SWITCH) \
@COND_ICC_PCH_1@ ./.pch/testprec_printfbench/testprec.h.gch
@COND_USE_PCH_1@_____pch_testprec_printfbench_testprec_h_gch___depname \
@COND_USE_PCH_1@ = ./.pch/testprec_printfbench/testprec.h.gch
@@ -503,6 +506,9 @@ test_socketstream.o: $(srcdir)/streams/socketstream.cpp $(TEST_ODEP)
test_sstream.o: $(srcdir)/streams/sstream.cpp $(TEST_ODEP)
$(CXXC) -c -o $@ $(TEST_CXXFLAGS) $(srcdir)/streams/sstream.cpp
test_stdstream.o: $(srcdir)/streams/stdstream.cpp $(TEST_ODEP)
$(CXXC) -c -o $@ $(TEST_CXXFLAGS) $(srcdir)/streams/stdstream.cpp
test_tempfile.o: $(srcdir)/streams/tempfile.cpp $(TEST_ODEP)
$(CXXC) -c -o $@ $(TEST_CXXFLAGS) $(srcdir)/streams/tempfile.cpp

View File

@@ -85,6 +85,7 @@ TEST_OBJECTS = \
$(OBJS)\test_memstream.obj \
$(OBJS)\test_socketstream.obj \
$(OBJS)\test_sstream.obj \
$(OBJS)\test_stdstream.obj \
$(OBJS)\test_tempfile.obj \
$(OBJS)\test_textstreamtest.obj \
$(OBJS)\test_zlibstream.obj \
@@ -544,6 +545,9 @@ $(OBJS)\test_socketstream.obj: .\streams\socketstream.cpp
$(OBJS)\test_sstream.obj: .\streams\sstream.cpp
$(CXX) -q -c -P -o$@ $(TEST_CXXFLAGS) .\streams\sstream.cpp
$(OBJS)\test_stdstream.obj: .\streams\stdstream.cpp
$(CXX) -q -c -P -o$@ $(TEST_CXXFLAGS) .\streams\stdstream.cpp
$(OBJS)\test_tempfile.obj: .\streams\tempfile.cpp
$(CXX) -q -c -P -o$@ $(TEST_CXXFLAGS) .\streams\tempfile.cpp

View File

@@ -77,6 +77,7 @@ TEST_OBJECTS = \
$(OBJS)\test_memstream.o \
$(OBJS)\test_socketstream.o \
$(OBJS)\test_sstream.o \
$(OBJS)\test_stdstream.o \
$(OBJS)\test_tempfile.o \
$(OBJS)\test_textstreamtest.o \
$(OBJS)\test_zlibstream.o \
@@ -524,6 +525,9 @@ $(OBJS)\test_socketstream.o: ./streams/socketstream.cpp
$(OBJS)\test_sstream.o: ./streams/sstream.cpp
$(CXX) -c -o $@ $(TEST_CXXFLAGS) $(CPPDEPS) $<
$(OBJS)\test_stdstream.o: ./streams/stdstream.cpp
$(CXX) -c -o $@ $(TEST_CXXFLAGS) $(CPPDEPS) $<
$(OBJS)\test_tempfile.o: ./streams/tempfile.cpp
$(CXX) -c -o $@ $(TEST_CXXFLAGS) $(CPPDEPS) $<

View File

@@ -78,6 +78,7 @@ TEST_OBJECTS = \
$(OBJS)\test_memstream.obj \
$(OBJS)\test_socketstream.obj \
$(OBJS)\test_sstream.obj \
$(OBJS)\test_stdstream.obj \
$(OBJS)\test_tempfile.obj \
$(OBJS)\test_textstreamtest.obj \
$(OBJS)\test_zlibstream.obj \
@@ -629,6 +630,9 @@ $(OBJS)\test_socketstream.obj: .\streams\socketstream.cpp
$(OBJS)\test_sstream.obj: .\streams\sstream.cpp
$(CXX) /c /nologo /TP /Fo$@ $(TEST_CXXFLAGS) .\streams\sstream.cpp
$(OBJS)\test_stdstream.obj: .\streams\stdstream.cpp
$(CXX) /c /nologo /TP /Fo$@ $(TEST_CXXFLAGS) .\streams\stdstream.cpp
$(OBJS)\test_tempfile.obj: .\streams\tempfile.cpp
$(CXX) /c /nologo /TP /Fo$@ $(TEST_CXXFLAGS) .\streams\tempfile.cpp

View File

@@ -316,6 +316,7 @@ TEST_OBJECTS = &
$(OBJS)\test_memstream.obj &
$(OBJS)\test_socketstream.obj &
$(OBJS)\test_sstream.obj &
$(OBJS)\test_stdstream.obj &
$(OBJS)\test_tempfile.obj &
$(OBJS)\test_textstreamtest.obj &
$(OBJS)\test_zlibstream.obj &
@@ -585,6 +586,9 @@ $(OBJS)\test_socketstream.obj : .AUTODEPEND .\streams\socketstream.cpp
$(OBJS)\test_sstream.obj : .AUTODEPEND .\streams\sstream.cpp
$(CXX) -bt=nt -zq -fo=$^@ $(TEST_CXXFLAGS) $<
$(OBJS)\test_stdstream.obj : .AUTODEPEND .\streams\stdstream.cpp
$(CXX) -bt=nt -zq -fo=$^@ $(TEST_CXXFLAGS) $<
$(OBJS)\test_tempfile.obj : .AUTODEPEND .\streams\tempfile.cpp
$(CXX) -bt=nt -zq -fo=$^@ $(TEST_CXXFLAGS) $<

446
tests/streams/stdstream.cpp Normal file
View File

@@ -0,0 +1,446 @@
///////////////////////////////////////////////////////////////////////////////
// Name: tests/streams/stdstream.cpp
// Purpose: Test wxStdInputStreamBuffer/wxStdOutputStreamBuffer
// Author: Jonathan Liu <net147@gmail.com>
// RCS-ID: $Id$
// Copyright: (c) 2009 Jonathan Liu
// Licence: wxWidgets licence
///////////////////////////////////////////////////////////////////////////////
// For compilers that support precompilation, includes "wx/wx.h".
// and "wx/cppunit.h"
#include "testprec.h"
#ifdef __BORLANDC__
#pragma hdrstop
#endif
// for all others, include the necessary headers
#ifndef WX_PRECOMP
#include "wx/wx.h"
#endif
#if wxUSE_STD_IOSTREAM
#include "wx/stdstream.h"
#include <string.h>
#include "wx/mstream.h"
// when std::streamoff is simply long we don't need this as we already allow
// comparisons between int and long but we do need it otherwise -- and we don't
// have any way to detect it so for now just assume that all 64 bit builds use
// long as streamoff and if this is wrong we'll add a check to configure later
#if SIZEOF_SIZE_T != 8
WX_CPPUNIT_ALLOW_EQUALS_TO_INT(std::streamoff)
#endif
// ==========================================================================
// Definitions
// ==========================================================================
const int TEST_SIZE = 384;
// ==========================================================================
// Test class
// ==========================================================================
class StdStreamTestCase : public CppUnit::TestCase
{
public:
StdStreamTestCase();
private:
CPPUNIT_TEST_SUITE( StdStreamTestCase );
// Input buffer management and positioning
CPPUNIT_TEST( InputBuffer_pubsetbuf );
CPPUNIT_TEST( InputBuffer_pubseekoff );
CPPUNIT_TEST( InputBuffer_pubseekpos );
CPPUNIT_TEST( InputBuffer_pubsync );
// Input functions
CPPUNIT_TEST( InputBuffer_in_avail );
CPPUNIT_TEST( InputBuffer_snextc );
CPPUNIT_TEST( InputBuffer_sbumpc );
CPPUNIT_TEST( InputBuffer_sgetc );
CPPUNIT_TEST( InputBuffer_sgetn );
CPPUNIT_TEST( InputBuffer_sputbackc );
CPPUNIT_TEST( InputBuffer_sungetc );
// Output buffer management and positioning
CPPUNIT_TEST( OutputBuffer_pubsetbuf );
CPPUNIT_TEST( OutputBuffer_pubseekoff );
CPPUNIT_TEST( OutputBuffer_pubseekpos );
CPPUNIT_TEST( OutputBuffer_pubsync );
// Output functions
CPPUNIT_TEST( OutputBuffer_sputc );
CPPUNIT_TEST( OutputBuffer_sputn );
CPPUNIT_TEST_SUITE_END();
// Input buffer management and positioning
void InputBuffer_pubsetbuf();
void InputBuffer_pubseekoff();
void InputBuffer_pubseekpos();
void InputBuffer_pubsync();
// Input functions
void InputBuffer_in_avail();
void InputBuffer_snextc();
void InputBuffer_sbumpc();
void InputBuffer_sgetc();
void InputBuffer_sgetn();
void InputBuffer_sputbackc();
void InputBuffer_sungetc();
// Output buffer management and positioning
void OutputBuffer_pubsetbuf();
void OutputBuffer_pubseekoff();
void OutputBuffer_pubseekpos();
void OutputBuffer_pubsync();
// Output functions
void OutputBuffer_sputc();
void OutputBuffer_sputn();
char m_testData[TEST_SIZE];
DECLARE_NO_COPY_CLASS(StdStreamTestCase)
};
// register in the unnamed registry so that these tests are run by default
CPPUNIT_TEST_SUITE_REGISTRATION( StdStreamTestCase );
// also include in it's own registry so that these tests can be run alone
CPPUNIT_TEST_SUITE_NAMED_REGISTRATION( StdStreamTestCase,
"StdStreamTestCase" );
// ==========================================================================
// Implementation
// ==========================================================================
StdStreamTestCase::StdStreamTestCase()
{
for (int i = 0; i < TEST_SIZE; ++i)
m_testData[i] = (i & 0xFF);
}
// --------------------------------------------------------------------------
// Input buffer management and positioning
// --------------------------------------------------------------------------
void StdStreamTestCase::InputBuffer_pubsetbuf()
{
wxMemoryInputStream stream(m_testData, TEST_SIZE);
wxStdInputStreamBuffer buffer(stream);
char testBuffer[TEST_SIZE];
CPPUNIT_ASSERT(buffer.pubsetbuf(testBuffer, TEST_SIZE) == NULL);
}
void StdStreamTestCase::InputBuffer_pubseekoff()
{
const char *testData = "0123456789";
wxMemoryInputStream stream(testData, 10);
wxStdInputStreamBuffer buffer(stream);
CPPUNIT_ASSERT_EQUAL(2,
buffer.pubseekoff(2, std::ios_base::beg,
std::ios_base::in));
CPPUNIT_ASSERT_EQUAL(-1,
buffer.pubseekoff(2, std::ios_base::beg,
std::ios_base::out));
CPPUNIT_ASSERT_EQUAL(4,
buffer.pubseekoff(2, std::ios_base::cur));
CPPUNIT_ASSERT_EQUAL(-1,
buffer.pubseekoff(2, std::ios_base::cur,
std::ios_base::out));
CPPUNIT_ASSERT_EQUAL(8,
buffer.pubseekoff(-2, std::ios_base::end));
CPPUNIT_ASSERT_EQUAL(-1,
buffer.pubseekoff(-2, std::ios_base::end,
std::ios_base::out));
CPPUNIT_ASSERT_EQUAL(-1,
buffer.pubseekoff(3, std::ios_base::cur));
CPPUNIT_ASSERT_EQUAL(-1,
buffer.pubseekoff(3, std::ios_base::cur,
std::ios_base::out));
}
void StdStreamTestCase::InputBuffer_pubseekpos()
{
const char *testData = "0123456789";
wxMemoryInputStream stream(testData, 10);
wxStdInputStreamBuffer buffer(stream);
for (int i = 9; i >= 0; --i)
{
if (i % 2 == 0)
CPPUNIT_ASSERT_EQUAL(i, buffer.pubseekpos(i));
else
CPPUNIT_ASSERT_EQUAL(i, buffer.pubseekpos(i, std::ios_base::in));
CPPUNIT_ASSERT_EQUAL('0' + i, buffer.sgetc());
}
}
void StdStreamTestCase::InputBuffer_pubsync()
{
wxMemoryInputStream stream(m_testData, TEST_SIZE);
wxStdInputStreamBuffer buffer(stream);
CPPUNIT_ASSERT(buffer.pubsync() == 0);
}
// --------------------------------------------------------------------------
// Input functions
// --------------------------------------------------------------------------
void StdStreamTestCase::InputBuffer_in_avail()
{
wxMemoryInputStream stream(m_testData, TEST_SIZE);
wxStdInputStreamBuffer buffer(stream);
CPPUNIT_ASSERT(buffer.sgetc() != EOF);
CPPUNIT_ASSERT_EQUAL(TEST_SIZE, buffer.in_avail());
char data[TEST_SIZE / 2];
buffer.sgetn(data, TEST_SIZE / 2);
CPPUNIT_ASSERT_EQUAL(TEST_SIZE - TEST_SIZE / 2, buffer.in_avail());
}
void StdStreamTestCase::InputBuffer_snextc()
{
wxMemoryInputStream stream(m_testData, TEST_SIZE);
wxStdInputStreamBuffer buffer(stream);
CPPUNIT_ASSERT(buffer.sgetc() != EOF);
CPPUNIT_ASSERT_EQUAL(TEST_SIZE, buffer.in_avail());
char data[TEST_SIZE];
data[0] = buffer.sgetc();
for (int i = 1; i < TEST_SIZE; ++i)
data[i] = buffer.snextc();
CPPUNIT_ASSERT(memcmp(data, m_testData, TEST_SIZE) == 0);
CPPUNIT_ASSERT_EQUAL((int)(unsigned char) (m_testData[TEST_SIZE - 1]),
buffer.sbumpc());
CPPUNIT_ASSERT(buffer.sgetc() == EOF);
}
void StdStreamTestCase::InputBuffer_sbumpc()
{
wxMemoryInputStream stream(m_testData, TEST_SIZE);
wxStdInputStreamBuffer buffer(stream);
CPPUNIT_ASSERT(buffer.sgetc() != EOF);
CPPUNIT_ASSERT_EQUAL(TEST_SIZE, buffer.in_avail());
char data[TEST_SIZE];
for (int i = 0; i < TEST_SIZE; ++i)
data[i] = buffer.sbumpc();
CPPUNIT_ASSERT(memcmp(data, m_testData, TEST_SIZE) == 0);
CPPUNIT_ASSERT(buffer.sgetc() == EOF);
}
void StdStreamTestCase::InputBuffer_sgetc()
{
wxMemoryInputStream stream(m_testData, TEST_SIZE);
wxStdInputStreamBuffer buffer(stream);
CPPUNIT_ASSERT(buffer.sgetc() != EOF);
CPPUNIT_ASSERT_EQUAL(TEST_SIZE, buffer.in_avail());
char data[TEST_SIZE];
for (int i = 0; i < TEST_SIZE; ++i) {
data[i] = buffer.sgetc();
buffer.sbumpc();
}
CPPUNIT_ASSERT(memcmp(data, m_testData, TEST_SIZE) == 0);
CPPUNIT_ASSERT(buffer.sgetc() == EOF);
}
void StdStreamTestCase::InputBuffer_sgetn()
{
wxMemoryInputStream stream(m_testData, TEST_SIZE);
wxStdInputStreamBuffer buffer(stream);
CPPUNIT_ASSERT(buffer.sgetc() != EOF);
CPPUNIT_ASSERT_EQUAL(TEST_SIZE, buffer.in_avail());
char data[TEST_SIZE * 2];
std::streamsize read = buffer.sgetn(data, TEST_SIZE * 2);
CPPUNIT_ASSERT_EQUAL(TEST_SIZE, read);
CPPUNIT_ASSERT(memcmp(data, m_testData, TEST_SIZE) == 0);
CPPUNIT_ASSERT(buffer.sgetc() == EOF);
}
void StdStreamTestCase::InputBuffer_sputbackc()
{
wxMemoryInputStream stream(m_testData, TEST_SIZE);
wxStdInputStreamBuffer buffer(stream);
CPPUNIT_ASSERT(buffer.sgetc() != EOF);
CPPUNIT_ASSERT_EQUAL(TEST_SIZE, buffer.in_avail());
char data[TEST_SIZE];
std::streamsize read = buffer.sgetn(data, TEST_SIZE);
CPPUNIT_ASSERT_EQUAL(TEST_SIZE, read);
CPPUNIT_ASSERT(memcmp(data, m_testData, TEST_SIZE) == 0);
CPPUNIT_ASSERT(buffer.sgetc() == EOF);
char putBackChar = m_testData[TEST_SIZE - 1] + 147;
CPPUNIT_ASSERT_EQUAL((int) putBackChar, buffer.sputbackc(putBackChar));
CPPUNIT_ASSERT_EQUAL((int) putBackChar, buffer.sgetc());
CPPUNIT_ASSERT_EQUAL((int) putBackChar, buffer.sbumpc());
CPPUNIT_ASSERT(buffer.sgetc() == EOF);
}
void StdStreamTestCase::InputBuffer_sungetc()
{
wxMemoryInputStream stream(m_testData, TEST_SIZE);
wxStdInputStreamBuffer buffer(stream);
CPPUNIT_ASSERT(buffer.sgetc() != EOF);
CPPUNIT_ASSERT_EQUAL(TEST_SIZE, buffer.in_avail());
char data[TEST_SIZE];
std::streamsize read = buffer.sgetn(data, TEST_SIZE);
CPPUNIT_ASSERT_EQUAL(TEST_SIZE, read);
CPPUNIT_ASSERT(memcmp(data, m_testData, TEST_SIZE) == 0);
CPPUNIT_ASSERT(buffer.sgetc() == EOF);
CPPUNIT_ASSERT_EQUAL((int) m_testData[TEST_SIZE - 1], buffer.sungetc());
CPPUNIT_ASSERT_EQUAL((int) m_testData[TEST_SIZE - 1], buffer.sgetc());
CPPUNIT_ASSERT_EQUAL((int) m_testData[TEST_SIZE - 1], buffer.sbumpc());
CPPUNIT_ASSERT(buffer.sgetc() == EOF);
}
// --------------------------------------------------------------------------
// Output buffer management and positioning
// --------------------------------------------------------------------------
void StdStreamTestCase::OutputBuffer_pubsetbuf()
{
wxMemoryOutputStream stream;
wxStdOutputStreamBuffer buffer(stream);
char testBuffer[TEST_SIZE];
CPPUNIT_ASSERT(buffer.pubsetbuf(testBuffer, TEST_SIZE) == NULL);
}
void StdStreamTestCase::OutputBuffer_pubseekoff()
{
char testData[] = "0123456789";
wxMemoryOutputStream stream(testData, 10);
wxStdOutputStreamBuffer buffer(stream);
CPPUNIT_ASSERT_EQUAL(2,
buffer.pubseekoff(2, std::ios_base::beg,
std::ios_base::out));
CPPUNIT_ASSERT_EQUAL(-1,
buffer.pubseekoff(2, std::ios_base::beg,
std::ios_base::in));
CPPUNIT_ASSERT_EQUAL(4,
buffer.pubseekoff(2, std::ios_base::cur));
CPPUNIT_ASSERT_EQUAL(-1,
buffer.pubseekoff(2, std::ios_base::cur,
std::ios_base::in));
CPPUNIT_ASSERT_EQUAL(8,
buffer.pubseekoff(-2, std::ios_base::end));
CPPUNIT_ASSERT_EQUAL(-1,
buffer.pubseekoff(-2, std::ios_base::end,
std::ios_base::in));
CPPUNIT_ASSERT_EQUAL(-1,
buffer.pubseekoff(3, std::ios_base::cur));
CPPUNIT_ASSERT_EQUAL(-1,
buffer.pubseekoff(3, std::ios_base::cur,
std::ios_base::in));
}
void StdStreamTestCase::OutputBuffer_pubseekpos()
{
char testData[] = "0123456789";
wxMemoryOutputStream stream(testData, 10);
wxStdOutputStreamBuffer buffer(stream);
for (int i = 9; i >= 0; --i)
{
if (i % 2 == 0)
{
CPPUNIT_ASSERT_EQUAL(i, buffer.pubseekpos(i));
}
else
{
CPPUNIT_ASSERT_EQUAL(i,
buffer.pubseekpos(i, std::ios_base::out));
}
CPPUNIT_ASSERT_EQUAL('0' + (9 - i), buffer.sputc('0' + (9 - i)));
}
CPPUNIT_ASSERT(memcmp(testData, "9876543210", 10) == 0);
CPPUNIT_ASSERT_EQUAL(-1, buffer.pubseekpos(5, std::ios_base::in));
}
void StdStreamTestCase::OutputBuffer_pubsync()
{
wxMemoryOutputStream stream;
wxStdOutputStreamBuffer buffer(stream);
CPPUNIT_ASSERT(buffer.pubsync() == 0);
}
// --------------------------------------------------------------------------
// Output functions
// --------------------------------------------------------------------------
void StdStreamTestCase::OutputBuffer_sputc()
{
wxMemoryOutputStream stream;
wxStdOutputStreamBuffer buffer(stream);
for (int i = 0; i < TEST_SIZE; ++i)
buffer.sputc(m_testData[i]);
CPPUNIT_ASSERT_EQUAL(TEST_SIZE, stream.GetSize());
char result[TEST_SIZE];
stream.CopyTo(result, TEST_SIZE);
CPPUNIT_ASSERT(memcmp(result, m_testData, TEST_SIZE) == 0);
}
void StdStreamTestCase::OutputBuffer_sputn()
{
wxMemoryOutputStream stream;
wxStdOutputStreamBuffer buffer(stream);
buffer.sputn(m_testData, TEST_SIZE);
CPPUNIT_ASSERT_EQUAL(TEST_SIZE, stream.GetSize());
char result[TEST_SIZE];
stream.CopyTo(result, TEST_SIZE);
CPPUNIT_ASSERT(memcmp(result, m_testData, TEST_SIZE) == 0);
}
#endif // wxUSE_STD_IOSTREAM

View File

@@ -76,6 +76,7 @@
streams/memstream.cpp
streams/socketstream.cpp
streams/sstream.cpp
streams/stdstream.cpp
streams/tempfile.cpp
streams/textstreamtest.cpp
streams/zlibstream.cpp

View File

@@ -397,6 +397,10 @@ SOURCE=.\streams\sstream.cpp
# End Source File
# Begin Source File
SOURCE=.\streams\stdstream.cpp
# End Source File
# Begin Source File
SOURCE=.\strings\stdstrings.cpp
# End Source File
# Begin Source File

View File

@@ -725,6 +725,9 @@
<File
RelativePath=".\streams\sstream.cpp">
</File>
<File
RelativePath=".\streams\stdstream.cpp">
</File>
<File
RelativePath=".\strings\stdstrings.cpp">
</File>

View File

@@ -1043,6 +1043,10 @@
RelativePath=".\streams\sstream.cpp"
>
</File>
<File
RelativePath=".\streams\stdstream.cpp"
>
</File>
<File
RelativePath=".\strings\stdstrings.cpp"
>

View File

@@ -1015,6 +1015,10 @@
RelativePath=".\streams\sstream.cpp"
>
</File>
<File
RelativePath=".\streams\stdstream.cpp"
>
</File>
<File
RelativePath=".\strings\stdstrings.cpp"
>