a) unget a buffer (AAABBB)
b) read some data (AAA)
c) unget a second buffer (CCC)
it works OK now (you will get CCCBBB, instead of
CCCAAABBB as before)
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@4870
c3d73ce0-8a6f-49c7-b76d-
6d57e0e08775
char *wxInputStream::AllocSpaceWBack(size_t needed_size)
{
char *temp_b;
char *wxInputStream::AllocSpaceWBack(size_t needed_size)
{
char *temp_b;
- old_size = m_wbacksize;
- m_wbacksize += needed_size;
+ /* get number of bytes left from previous wback buffer */
+ toget = m_wbacksize - m_wbackcur;
- if (!m_wback)
- temp_b = (char *)malloc(m_wbacksize);
- else
- temp_b = (char *)realloc(m_wback, m_wbacksize);
+ /* allocate a buffer large enough to hold prev + new data */
+ temp_b = (char *) malloc(needed_size + toget);
+ return NULL;
+
+ /* copy previous data (and free old buffer) if needed */
+ if (m_wback)
+ {
+ memmove(temp_b + needed_size, m_wback + m_wbackcur, toget);
+ free(m_wback);
+ }
+
+ /* done */
+ m_wbackcur = 0;
+ m_wbacksize = needed_size + toget;
- memmove(m_wback+needed_size, m_wback, old_size);
-
- return (char *)(m_wback);
+ return (char *) m_wback;
}
size_t wxInputStream::GetWBack(char *buf, size_t bsize)
}
size_t wxInputStream::GetWBack(char *buf, size_t bsize)
size -= retsize;
buf += retsize;
size -= retsize;
buf += retsize;
+ // GRG: shouldn't we also add retsize to m_lastcount here?
m_lastcount = OnSysRead(buf, size);
return *this;
}
m_lastcount = OnSysRead(buf, size);
return *this;
}