annotate src/myVncClient/ZlibInStream.java @ 17:f9ecb0315303

add package
author e085711
date Sun, 24 Apr 2011 16:55:29 +0900
parents src/ZlibInStream.java@bdb8d7c7d4d1
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
17
f9ecb0315303 add package
e085711
parents: 5
diff changeset
1 package myVncClient;
0
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
2 /* Copyright (C) 2002-2005 RealVNC Ltd. All Rights Reserved.
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
3 *
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
4 * This is free software; you can redistribute it and/or modify
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
5 * it under the terms of the GNU General Public License as published by
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
6 * the Free Software Foundation; either version 2 of the License, or
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
7 * (at your option) any later version.
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
8 *
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
9 * This software is distributed in the hope that it will be useful,
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
12 * GNU General Public License for more details.
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
13 *
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
14 * You should have received a copy of the GNU General Public License
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
15 * along with this software; if not, write to the Free Software
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
16 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
17 * USA.
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
18 */
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
19
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
20 //
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
21 // A ZlibInStream reads from a zlib.io.InputStream
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
22 //
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
23
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
24 public class ZlibInStream extends InStream {
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
25
4
e085711
parents: 2
diff changeset
26 static final int defaultBufSize = 16384;
0
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
27
4
e085711
parents: 2
diff changeset
28 public ZlibInStream(int bufSize_) {
e085711
parents: 2
diff changeset
29 bufSize = bufSize_;
e085711
parents: 2
diff changeset
30 b = new byte[bufSize];
e085711
parents: 2
diff changeset
31 ptr = end = ptrOffset = 0;
e085711
parents: 2
diff changeset
32 inflater = new java.util.zip.Inflater();
e085711
parents: 2
diff changeset
33 }
0
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
34
4
e085711
parents: 2
diff changeset
35 public ZlibInStream() {
e085711
parents: 2
diff changeset
36 this(defaultBufSize);
e085711
parents: 2
diff changeset
37 }
0
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
38
4
e085711
parents: 2
diff changeset
39 public void setUnderlying(InStream is, int bytesIn_) {
e085711
parents: 2
diff changeset
40 underlying = is;
e085711
parents: 2
diff changeset
41 bytesIn = bytesIn_;
e085711
parents: 2
diff changeset
42 ptr = end = 0;
e085711
parents: 2
diff changeset
43 }
0
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
44
4
e085711
parents: 2
diff changeset
45 public void reset() throws Exception {
e085711
parents: 2
diff changeset
46 ptr = end = 0;
e085711
parents: 2
diff changeset
47 if (underlying == null)
e085711
parents: 2
diff changeset
48 return;
0
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
49
4
e085711
parents: 2
diff changeset
50 while (bytesIn > 0) {
e085711
parents: 2
diff changeset
51 decompress();
e085711
parents: 2
diff changeset
52 end = 0; // throw away any data
e085711
parents: 2
diff changeset
53 }
e085711
parents: 2
diff changeset
54 underlying = null;
e085711
parents: 2
diff changeset
55 }
0
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
56
4
e085711
parents: 2
diff changeset
57 public int pos() {
e085711
parents: 2
diff changeset
58 return ptrOffset + ptr;
e085711
parents: 2
diff changeset
59 }
0
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
60
4
e085711
parents: 2
diff changeset
61 protected int overrun(int itemSize, int nItems) throws Exception {
e085711
parents: 2
diff changeset
62 if (itemSize > bufSize)
e085711
parents: 2
diff changeset
63 throw new Exception("ZlibInStream overrun: max itemSize exceeded");
e085711
parents: 2
diff changeset
64 if (underlying == null)
e085711
parents: 2
diff changeset
65 throw new Exception("ZlibInStream overrun: no underlying stream");
0
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
66
4
e085711
parents: 2
diff changeset
67 if (end - ptr != 0)
e085711
parents: 2
diff changeset
68 System.arraycopy(b, ptr, b, 0, end - ptr);
0
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
69
4
e085711
parents: 2
diff changeset
70 ptrOffset += ptr;
e085711
parents: 2
diff changeset
71 end -= ptr;
e085711
parents: 2
diff changeset
72 ptr = 0;
0
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
73
4
e085711
parents: 2
diff changeset
74 while (end < itemSize) {
e085711
parents: 2
diff changeset
75 decompress();
e085711
parents: 2
diff changeset
76 }
0
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
77
4
e085711
parents: 2
diff changeset
78 if (itemSize * nItems > end)
e085711
parents: 2
diff changeset
79 nItems = end / itemSize;
0
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
80
4
e085711
parents: 2
diff changeset
81 return nItems;
e085711
parents: 2
diff changeset
82 }
e085711
parents: 2
diff changeset
83
e085711
parents: 2
diff changeset
84 // decompress() calls the decompressor once. Note that this won't
e085711
parents: 2
diff changeset
85 // necessarily generate any output data - it may just consume some input
e085711
parents: 2
diff changeset
86 // data. Returns false if wait is false and we would block on the underlying
e085711
parents: 2
diff changeset
87 // stream.
0
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
88
4
e085711
parents: 2
diff changeset
89 private void decompress() throws Exception {
e085711
parents: 2
diff changeset
90 try {
e085711
parents: 2
diff changeset
91 underlying.check(1);
e085711
parents: 2
diff changeset
92 int avail_in = underlying.getend() - underlying.getptr();
e085711
parents: 2
diff changeset
93 if (avail_in > bytesIn)
e085711
parents: 2
diff changeset
94 avail_in = bytesIn;
e085711
parents: 2
diff changeset
95
e085711
parents: 2
diff changeset
96 if (inflater.needsInput()) {
e085711
parents: 2
diff changeset
97 inflater.setInput(underlying.getbuf(), underlying.getptr(),
e085711
parents: 2
diff changeset
98 avail_in);
e085711
parents: 2
diff changeset
99 }
e085711
parents: 2
diff changeset
100 int n = inflater.inflate(b, end, bufSize - end);
e085711
parents: 2
diff changeset
101 end += n;
e085711
parents: 2
diff changeset
102 if (inflater.needsInput()) {
e085711
parents: 2
diff changeset
103 bytesIn -= avail_in;
e085711
parents: 2
diff changeset
104 underlying.setptr(underlying.getptr() + avail_in);
e085711
parents: 2
diff changeset
105 }
e085711
parents: 2
diff changeset
106 } catch (java.util.zip.DataFormatException e) {
e085711
parents: 2
diff changeset
107 throw new Exception("ZlibInStream: inflate failed");
e085711
parents: 2
diff changeset
108 }
e085711
parents: 2
diff changeset
109 }
0
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
110
4
e085711
parents: 2
diff changeset
111 private InStream underlying;
e085711
parents: 2
diff changeset
112 private int bufSize;
5
bdb8d7c7d4d1 update version0.1
e085711
parents: 4
diff changeset
113 private int ptrOffset;
4
e085711
parents: 2
diff changeset
114 private java.util.zip.Inflater inflater;
e085711
parents: 2
diff changeset
115 private int bytesIn;
0
e04119c40b9b upload all file of tighVNCClient
e085711
parents:
diff changeset
116 }