mirror of
https://github.com/sheumann/VNCviewGS.git
synced 2025-01-27 23:33:41 +00:00
Have Marinetti return a new handle in ReadFixup.
This should be faster, as in DoReadTCP, and it simplifies the code a little. Also, check for returned data size of 0 in DoReadTCP. I don't think this should happen, but in case it did, the returned handle could be invalid.
This commit is contained in:
parent
e1288f7e1b
commit
aa15c60672
@ -307,13 +307,6 @@ BOOLEAN DoWaitingReadTCP(unsigned long dataLength) {
|
|||||||
/* Fix things when TCPIPReadTCP returns less data than it's supposed to */
|
/* Fix things when TCPIPReadTCP returns less data than it's supposed to */
|
||||||
static BOOLEAN ReadFixup (unsigned long requested, unsigned long returned) {
|
static BOOLEAN ReadFixup (unsigned long requested, unsigned long returned) {
|
||||||
static rrBuff theRRBuff;
|
static rrBuff theRRBuff;
|
||||||
static void **fixupBufferHndl = NULL;
|
|
||||||
|
|
||||||
if (fixupBufferHndl == NULL) {
|
|
||||||
fixupBufferHndl = NewHandle(requested-returned, userid(), 0, NULL);
|
|
||||||
if (toolerror())
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
SetHandleSize(requested, readBufferHndl);
|
SetHandleSize(requested, readBufferHndl);
|
||||||
if (toolerror())
|
if (toolerror())
|
||||||
@ -322,7 +315,7 @@ static BOOLEAN ReadFixup (unsigned long requested, unsigned long returned) {
|
|||||||
|
|
||||||
do {
|
do {
|
||||||
TCPIPPoll();
|
TCPIPPoll();
|
||||||
if ((tcperr = TCPIPReadTCP(hostIpid, buffTypeHandle, (Ref)fixupBufferHndl,
|
if ((tcperr = TCPIPReadTCP(hostIpid, buffTypeNewHandle, NULL,
|
||||||
requested-returned, &theRRBuff)) != tcperrOK)
|
requested-returned, &theRRBuff)) != tcperrOK)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
if (toolerror())
|
if (toolerror())
|
||||||
@ -331,11 +324,11 @@ static BOOLEAN ReadFixup (unsigned long requested, unsigned long returned) {
|
|||||||
if (theRRBuff.rrBuffCount == 0) /* To avoid infinite loops */
|
if (theRRBuff.rrBuffCount == 0) /* To avoid infinite loops */
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
HandToPtr(fixupBufferHndl, (char *)*readBufferHndl + returned,
|
HandToPtr(theRRBuff.rrBuffHandle, (char *)*readBufferHndl + returned,
|
||||||
theRRBuff.rrBuffCount);
|
theRRBuff.rrBuffCount);
|
||||||
|
|
||||||
returned += theRRBuff.rrBuffCount;
|
returned += theRRBuff.rrBuffCount;
|
||||||
|
|
||||||
|
DisposeHandle(theRRBuff.rrBuffHandle);
|
||||||
} while (returned < requested);
|
} while (returned < requested);
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
@ -365,6 +358,9 @@ BOOLEAN DoReadTCP (unsigned long dataLength) {
|
|||||||
return FALSE;
|
return FALSE;
|
||||||
if (toolerror())
|
if (toolerror())
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
if (theRRBuff.rrBuffCount == 0)
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
readBufferHndl = theRRBuff.rrBuffHandle;
|
readBufferHndl = theRRBuff.rrBuffHandle;
|
||||||
|
|
||||||
if (theRRBuff.rrBuffCount != dataLength)
|
if (theRRBuff.rrBuffCount != dataLength)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user