summaryrefslogtreecommitdiffstats
path: root/libvncclient/zlib.c
diff options
context:
space:
mode:
authordscho <dscho>2005-05-23 19:26:12 +0000
committerdscho <dscho>2005-05-23 19:26:12 +0000
commit669b4c86855cc11a8904f4acb4039a14b91cbf6d (patch)
tree9575e388cfbac5bcdd63aa54ae053c465d93dc62 /libvncclient/zlib.c
parentdc1094f03c10c2d863a15f1d8638ea8742e42f32 (diff)
downloadlibtdevnc-669b4c86855cc11a8904f4acb4039a14b91cbf6d.tar.gz
libtdevnc-669b4c86855cc11a8904f4acb4039a14b91cbf6d.zip
make zlib and tight handling thread safe (static -> rfbClient)
Diffstat (limited to 'libvncclient/zlib.c')
-rw-r--r--libvncclient/zlib.c44
1 files changed, 22 insertions, 22 deletions
diff --git a/libvncclient/zlib.c b/libvncclient/zlib.c
index ec371be..2a32d1c 100644
--- a/libvncclient/zlib.c
+++ b/libvncclient/zlib.c
@@ -46,16 +46,16 @@ HandleZlibBPP (rfbClient* client, int rx, int ry, int rw, int rh)
* buffer, this buffer allocation should only happen once, on the
* first update.
*/
- if ( raw_buffer_size < (( rw * rh ) * ( BPP / 8 ))) {
+ if ( client->raw_buffer_size < (( rw * rh ) * ( BPP / 8 ))) {
- if ( raw_buffer != NULL ) {
+ if ( client->raw_buffer != NULL ) {
- free( raw_buffer );
+ free( client->raw_buffer );
}
- raw_buffer_size = (( rw * rh ) * ( BPP / 8 ));
- raw_buffer = (char*) malloc( raw_buffer_size );
+ client->raw_buffer_size = (( rw * rh ) * ( BPP / 8 ));
+ client->raw_buffer = (char*) malloc( client->raw_buffer_size );
}
@@ -65,26 +65,26 @@ HandleZlibBPP (rfbClient* client, int rx, int ry, int rw, int rh)
remaining = rfbClientSwap32IfLE(hdr.nBytes);
/* Need to initialize the decompressor state. */
- decompStream.next_in = ( Bytef * )client->buffer;
- decompStream.avail_in = 0;
- decompStream.next_out = ( Bytef * )raw_buffer;
- decompStream.avail_out = raw_buffer_size;
- decompStream.data_type = Z_BINARY;
+ client->decompStream.next_in = ( Bytef * )client->buffer;
+ client->decompStream.avail_in = 0;
+ client->decompStream.next_out = ( Bytef * )client->raw_buffer;
+ client->decompStream.avail_out = client->raw_buffer_size;
+ client->decompStream.data_type = Z_BINARY;
/* Initialize the decompression stream structures on the first invocation. */
- if ( decompStreamInited == FALSE ) {
+ if ( client->decompStreamInited == FALSE ) {
- inflateResult = inflateInit( &decompStream );
+ inflateResult = inflateInit( &client->decompStream );
if ( inflateResult != Z_OK ) {
rfbClientLog(
"inflateInit returned error: %d, msg: %s\n",
inflateResult,
- decompStream.msg);
+ client->decompStream.msg);
return FALSE;
}
- decompStreamInited = TRUE;
+ client->decompStreamInited = TRUE;
}
@@ -107,11 +107,11 @@ HandleZlibBPP (rfbClient* client, int rx, int ry, int rw, int rh)
if (!ReadFromRFBServer(client, client->buffer,toRead))
return FALSE;
- decompStream.next_in = ( Bytef * )client->buffer;
- decompStream.avail_in = toRead;
+ client->decompStream.next_in = ( Bytef * )client->buffer;
+ client->decompStream.avail_in = toRead;
/* Need to uncompress buffer full. */
- inflateResult = inflate( &decompStream, Z_SYNC_FLUSH );
+ inflateResult = inflate( &client->decompStream, Z_SYNC_FLUSH );
/* We never supply a dictionary for compression. */
if ( inflateResult == Z_NEED_DICT ) {
@@ -122,15 +122,15 @@ HandleZlibBPP (rfbClient* client, int rx, int ry, int rw, int rh)
rfbClientLog(
"zlib inflate returned error: %d, msg: %s\n",
inflateResult,
- decompStream.msg);
+ client->decompStream.msg);
return FALSE;
}
/* Result buffer allocated to be at least large enough. We should
* never run out of space!
*/
- if (( decompStream.avail_in > 0 ) &&
- ( decompStream.avail_out <= 0 )) {
+ if (( client->decompStream.avail_in > 0 ) &&
+ ( client->decompStream.avail_out <= 0 )) {
rfbClientLog("zlib inflate ran out of space!\n");
return FALSE;
}
@@ -142,14 +142,14 @@ HandleZlibBPP (rfbClient* client, int rx, int ry, int rw, int rh)
if ( inflateResult == Z_OK ) {
/* Put the uncompressed contents of the update on the screen. */
- CopyRectangle(client, raw_buffer, rx, ry, rw, rh);
+ CopyRectangle(client, client->raw_buffer, rx, ry, rw, rh);
}
else {
rfbClientLog(
"zlib inflate returned error: %d, msg: %s\n",
inflateResult,
- decompStream.msg);
+ client->decompStream.msg);
return FALSE;
}