git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@44872
c3d73ce0-8a6f-49c7-b76d-
6d57e0e08775
- Added wxGridUpdateLocker helper class (Evgeniy Tarassov)
- Support wxGRID_AUTOSIZE in wxGrid::SetRow/ColLabelSize() (Evgeniy Tarassov)
- Added wxMemoryInputStream(wxInputStream&) ctor (Stas Sergeev)
- Added wxGridUpdateLocker helper class (Evgeniy Tarassov)
- Support wxGRID_AUTOSIZE in wxGrid::SetRow/ColLabelSize() (Evgeniy Tarassov)
- Added wxMemoryInputStream(wxInputStream&) ctor (Stas Sergeev)
+- Implemented wxMemoryInputStream::CanRead()
virtual wxFileOffset GetLength() const { return m_length; }
virtual bool IsSeekable() const { return true; }
virtual wxFileOffset GetLength() const { return m_length; }
virtual bool IsSeekable() const { return true; }
+ virtual char Peek();
+ virtual bool CanRead() const;
wxStreamBuffer *GetInputStreamBuffer() const { return m_i_streambuf; }
wxStreamBuffer *GetInputStreamBuffer() const { return m_i_streambuf; }
m_length = stream.LastRead();
}
m_length = stream.LastRead();
}
+bool wxMemoryInputStream::CanRead() const
+{
+ return m_i_streambuf->GetIntPosition() != m_length;
+}
+
wxMemoryInputStream::~wxMemoryInputStream()
{
delete m_i_streambuf;
wxMemoryInputStream::~wxMemoryInputStream()
{
delete m_i_streambuf;
:m_pCleanup(value)
{}
~CleanupHelper()
:m_pCleanup(value)
{}
~CleanupHelper()
m_pCleanup->DeleteInStream();
m_pCleanup->DeleteOutStream();
}
m_pCleanup->DeleteInStream();
m_pCleanup->DeleteOutStream();
}
// Prevent mem leaks!
delete m_pCurrentIn;
delete m_pCurrentOut;
// Prevent mem leaks!
delete m_pCurrentIn;
delete m_pCurrentOut;
// Note: the input stream should at least be of min size +10!
// Note: the input stream should at least be of min size +10!
(void)stream_in.Read(buf, 10);
CPPUNIT_ASSERT(!stream_in.Eof());
(void)stream_in.Read(buf, 10);
CPPUNIT_ASSERT(!stream_in.Eof());
CPPUNIT_ASSERT(stream_in.Eof());
}
CPPUNIT_ASSERT(stream_in.Eof());
}
- // Test and see what happens to the EOF when we
+ // Test and see what happens to the EOF when we
// read after EOF was encountered.
void Input_Eof()
{
// read after EOF was encountered.
void Input_Eof()
{
}
// Check EOF stream state.
}
// Check EOF stream state.
- CPPUNIT_ASSERT_MESSAGE("EOF is not EOF?", stream_in.Eof());
+ CPPUNIT_ASSERT_MESSAGE("EOF is not EOF?", stream_in.Eof());
// Ok we found the end, lets see if we can go past it.
for (size_t i = 0; i < 100; i++)
// Ok we found the end, lets see if we can go past it.
for (size_t i = 0; i < 100; i++)
CPPUNIT_ASSERT(stream_in.LastRead() == 1);
}
CPPUNIT_ASSERT(stream_in.LastRead() == 1);
}
+ void Input_CanRead()
+ {
+ CleanupHelper cleanup(this);
+ TStreamIn &stream_in = CreateInStream();
+
+ CPPUNIT_ASSERT( stream_in.CanRead() );
+
+ // read the entire contents
+ (void)stream_in.Read(CreateOutStream());
+
+ CPPUNIT_ASSERT( !stream_in.CanRead() );
+ }
+
// Just try to perform a SeekI() on the input stream.
void Input_SeekI()
{
// Just try to perform a SeekI() on the input stream.
void Input_SeekI()
{
CPPUNIT_ASSERT(stream_in.TellI() == pos);
}
}
CPPUNIT_ASSERT(stream_in.TellI() == pos);
}
}
// Just try to perform a Peek() on the input stream.
void Input_Peek()
{
// Just try to perform a Peek() on the input stream.
void Input_Peek()
{
CleanupHelper cleanup(this);
TStreamIn &stream_in = CreateInStream();
CPPUNIT_ASSERT(!stream_in.Eof());
CleanupHelper cleanup(this);
TStreamIn &stream_in = CreateInStream();
CPPUNIT_ASSERT(!stream_in.Eof());
const char *ungetstr = "test";
size_t ungetsize = stream_in.Ungetch(ungetstr, strlen(ungetstr) + 1);
if (ungetsize != 0)
const char *ungetstr = "test";
size_t ungetsize = stream_in.Ungetch(ungetstr, strlen(ungetstr) + 1);
if (ungetsize != 0)
{
CleanupHelper cleanup(this);
TStreamOut &stream_out = CreateOutStream();
{
CleanupHelper cleanup(this);
TStreamOut &stream_out = CreateOutStream();
// First put some data in the stream, so it is not empty.
char *buf = "1234567890";
(void)stream_out.Write(buf, 10);
// First put some data in the stream, so it is not empty.
char *buf = "1234567890";
(void)stream_out.Write(buf, 10);
// First put some extra data in the stream, so it's not empty.
char *buf = "1234567890";
(void)stream_out.Write(buf, 10);
// First put some extra data in the stream, so it's not empty.
char *buf = "1234567890";
(void)stream_out.Write(buf, 10);
off_t pos = stream_out.SeekO(5, wxFromStart);
CPPUNIT_ASSERT(stream_out.TellO() == pos);
(void)stream_out.PutC('1');
off_t pos = stream_out.SeekO(5, wxFromStart);
CPPUNIT_ASSERT(stream_out.TellO() == pos);
(void)stream_out.PutC('1');
protected:
// Some tests can be configured... here you can find the config settings
protected:
// Some tests can be configured... here you can find the config settings
- bool m_bSimpleTellITest; // if true, no SeekI will be used by the TellI test.
+ bool m_bSimpleTellITest; // if true, no SeekI will be used by the TellI test.
- bool m_bSimpleTellOTest; // if true, no SeekO will be used by the TellI test.
+ bool m_bSimpleTellOTest; // if true, no SeekO will be used by the TellI test.
// Default false.
bool m_bSeekInvalidBeyondEnd; // if true a SeekI|O beyond the end of the stream should return wxInvalidOffset
// Default true.
// Default false.
bool m_bSeekInvalidBeyondEnd; // if true a SeekI|O beyond the end of the stream should return wxInvalidOffset
// Default true.
// Default true.
protected:
TStreamIn &CreateInStream()
// Default true.
protected:
TStreamIn &CreateInStream()
if (m_pCurrentIn)
{
wxFAIL_MSG(_T("Error in test case, the previouse input stream needs to be delete first!"));
if (m_pCurrentIn)
{
wxFAIL_MSG(_T("Error in test case, the previouse input stream needs to be delete first!"));
return *m_pCurrentIn;
}
TStreamOut &CreateOutStream()
return *m_pCurrentIn;
}
TStreamOut &CreateOutStream()
if (m_pCurrentOut)
{
wxFAIL_MSG(_T("Error in test case, the previouse output stream needs to be delete first!"));
if (m_pCurrentOut)
{
wxFAIL_MSG(_T("Error in test case, the previouse output stream needs to be delete first!"));
wxASSERT(m_pCurrentOut != NULL);
return *m_pCurrentOut;
}
wxASSERT(m_pCurrentOut != NULL);
return *m_pCurrentOut;
}
void DeleteInStream()
{
if (m_pCurrentIn == NULL)
void DeleteInStream()
{
if (m_pCurrentIn == NULL)
DoDeleteInStream();
}
void DeleteOutStream()
DoDeleteInStream();
}
void DeleteOutStream()
if (m_pCurrentOut == NULL)
return;
if (m_pCurrentOut == NULL)
return;
CPPUNIT_ASSERT(m_pCurrentOut->Close());
CPPUNIT_ASSERT(m_pCurrentOut->Close());
delete m_pCurrentOut;
m_pCurrentOut = NULL;
// Incase something extra needs to be done.
delete m_pCurrentOut;
m_pCurrentOut = NULL;
// Incase something extra needs to be done.
CPPUNIT_TEST(Input_Read);
CPPUNIT_TEST(Input_Eof);
CPPUNIT_TEST(Input_LastRead);
CPPUNIT_TEST(Input_Read);
CPPUNIT_TEST(Input_Eof);
CPPUNIT_TEST(Input_LastRead);
+ CPPUNIT_TEST(Input_CanRead);
CPPUNIT_TEST(Input_SeekI);
CPPUNIT_TEST(Input_TellI);
CPPUNIT_TEST(Input_Peek);
CPPUNIT_TEST(Input_SeekI);
CPPUNIT_TEST(Input_TellI);
CPPUNIT_TEST(Input_Peek);
CPPUNIT_TEST(Input_Read);
CPPUNIT_TEST(Input_Eof);
CPPUNIT_TEST(Input_LastRead);
CPPUNIT_TEST(Input_Read);
CPPUNIT_TEST(Input_Eof);
CPPUNIT_TEST(Input_LastRead);
+ CPPUNIT_TEST(Input_CanRead);
CPPUNIT_TEST(Input_SeekI);
CPPUNIT_TEST(Input_TellI);
CPPUNIT_TEST(Input_Peek);
CPPUNIT_TEST(Input_SeekI);
CPPUNIT_TEST(Input_TellI);
CPPUNIT_TEST(Input_Peek);
CPPUNIT_TEST(Input_Read);
CPPUNIT_TEST(Input_Eof);
CPPUNIT_TEST(Input_LastRead);
CPPUNIT_TEST(Input_Read);
CPPUNIT_TEST(Input_Eof);
CPPUNIT_TEST(Input_LastRead);
+ CPPUNIT_TEST(Input_CanRead);
CPPUNIT_TEST(Input_SeekI);
CPPUNIT_TEST(Input_TellI);
CPPUNIT_TEST(Input_Peek);
CPPUNIT_TEST(Input_SeekI);
CPPUNIT_TEST(Input_TellI);
CPPUNIT_TEST(Input_Peek);
CPPUNIT_TEST(Input_Read);
CPPUNIT_TEST(Input_Eof);
CPPUNIT_TEST(Input_LastRead);
CPPUNIT_TEST(Input_Read);
CPPUNIT_TEST(Input_Eof);
CPPUNIT_TEST(Input_LastRead);
+ CPPUNIT_TEST(Input_CanRead);
CPPUNIT_TEST(Input_SeekI);
CPPUNIT_TEST(Input_TellI);
CPPUNIT_TEST(Input_Peek);
CPPUNIT_TEST(Input_SeekI);
CPPUNIT_TEST(Input_TellI);
CPPUNIT_TEST(Input_Peek);
CPPUNIT_TEST(Input_Read);
CPPUNIT_TEST(Input_Eof);
CPPUNIT_TEST(Input_LastRead);
CPPUNIT_TEST(Input_Read);
CPPUNIT_TEST(Input_Eof);
CPPUNIT_TEST(Input_LastRead);
+ CPPUNIT_TEST(Input_CanRead);
CPPUNIT_TEST_FAIL(Input_SeekI);
CPPUNIT_TEST(Input_TellI);
CPPUNIT_TEST(Input_Peek);
CPPUNIT_TEST_FAIL(Input_SeekI);
CPPUNIT_TEST(Input_TellI);
CPPUNIT_TEST(Input_Peek);