From 4a695fc19b6c2191cba9ed1a1e95dfd16e216d3f Mon Sep 17 00:00:00 2001 From: Jay Freeman Date: Thu, 13 Oct 2011 04:12:18 +0000 Subject: Upgrade to 0.9.8.1 of libvncserver, and fix a stupid bug in their code. git-svn-id: http://svn.telesphoreo.org/trunk@761 514c082c-b64e-11dc-b46d-3d985efe055d --- data/libvncserver/LibVNCServer-0.9.8.1.tar.gz | Bin 0 -> 1238171 bytes data/libvncserver/LibVNCServer-0.9.8.tar.gz | Bin 1240804 -> 0 bytes data/libvncserver/_metadata/version | 2 +- data/libvncserver/clsockrace.diff | 48 ++++++++++++++++++++++++++ 4 files changed, 49 insertions(+), 1 deletion(-) create mode 100644 data/libvncserver/LibVNCServer-0.9.8.1.tar.gz delete mode 100644 data/libvncserver/LibVNCServer-0.9.8.tar.gz create mode 100644 data/libvncserver/clsockrace.diff (limited to 'data/libvncserver') diff --git a/data/libvncserver/LibVNCServer-0.9.8.1.tar.gz b/data/libvncserver/LibVNCServer-0.9.8.1.tar.gz new file mode 100644 index 000000000..aad3ad8d8 Binary files /dev/null and b/data/libvncserver/LibVNCServer-0.9.8.1.tar.gz differ diff --git a/data/libvncserver/LibVNCServer-0.9.8.tar.gz b/data/libvncserver/LibVNCServer-0.9.8.tar.gz deleted file mode 100644 index 789014637..000000000 Binary files a/data/libvncserver/LibVNCServer-0.9.8.tar.gz and /dev/null differ diff --git a/data/libvncserver/_metadata/version b/data/libvncserver/_metadata/version index e3e180701..b5343984c 100644 --- a/data/libvncserver/_metadata/version +++ b/data/libvncserver/_metadata/version @@ -1 +1 @@ -0.9.8 +0.9.8.1 diff --git a/data/libvncserver/clsockrace.diff b/data/libvncserver/clsockrace.diff new file mode 100644 index 000000000..56b41e38e --- /dev/null +++ b/data/libvncserver/clsockrace.diff @@ -0,0 +1,48 @@ +diff -ru LibVNCServer-0.9.8.1/libvncserver/main.c LibVNCServer-0.9.8.1+iPhone/libvncserver/main.c +--- LibVNCServer-0.9.8.1/libvncserver/main.c 2011-10-12 16:52:18.000000000 +0000 ++++ LibVNCServer-0.9.8.1+iPhone/libvncserver/main.c 2011-10-13 04:09:56.000000000 +0000 +@@ -517,24 +517,26 @@ + struct timeval tv; + int n; + +- if (cl->sock == -1) { ++ int sock = cl->sock; ++ ++ if (sock == -1) { + /* Client has disconnected. */ + break; + } + + FD_ZERO(&rfds); +- FD_SET(cl->sock, &rfds); ++ FD_SET(sock, &rfds); + FD_ZERO(&efds); +- FD_SET(cl->sock, &efds); ++ FD_SET(sock, &efds); + + /* Are we transferring a file in the background? */ + FD_ZERO(&wfds); + if ((cl->fileTransfer.fd!=-1) && (cl->fileTransfer.sending==1)) +- FD_SET(cl->sock, &wfds); ++ FD_SET(sock, &wfds); + + tv.tv_sec = 60; /* 1 minute */ + tv.tv_usec = 0; +- n = select(cl->sock + 1, &rfds, &wfds, &efds, &tv); ++ n = select(sock + 1, &rfds, &wfds, &efds, &tv); + if (n < 0) { + rfbLogPerror("ReadExact: select"); + break; +@@ -546,10 +548,10 @@ + } + + /* We have some space on the transmit queue, send some data */ +- if (FD_ISSET(cl->sock, &wfds)) ++ if (FD_ISSET(sock, &wfds)) + rfbSendFileTransferChunk(cl); + +- if (FD_ISSET(cl->sock, &rfds) || FD_ISSET(cl->sock, &efds)) ++ if (FD_ISSET(sock, &rfds) || FD_ISSET(cl->sock, &efds)) + rfbProcessClientMessage(cl); + } + -- cgit v1.2.3