annotate src/ZlibInStream.java @ 4:60a87e277536

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