annotate src/main/java/com/glavsoft/rfb/protocol/ReceiverTask.java @ 17:61d95bdc2bdb

change Alice PUT API new Version
author sugi
date Sun, 02 Nov 2014 18:26:41 +0900
parents 3c0f262384dc
children 80b4d7efba08
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
daa24f8a557b TightVNC original
YU
parents:
diff changeset
1 // Copyright (C) 2010, 2011, 2012, 2013 GlavSoft LLC.
daa24f8a557b TightVNC original
YU
parents:
diff changeset
2 // All rights reserved.
daa24f8a557b TightVNC original
YU
parents:
diff changeset
3 //
daa24f8a557b TightVNC original
YU
parents:
diff changeset
4 //-------------------------------------------------------------------------
daa24f8a557b TightVNC original
YU
parents:
diff changeset
5 // This file is part of the TightVNC software. Please visit our Web site:
daa24f8a557b TightVNC original
YU
parents:
diff changeset
6 //
daa24f8a557b TightVNC original
YU
parents:
diff changeset
7 // http://www.tightvnc.com/
daa24f8a557b TightVNC original
YU
parents:
diff changeset
8 //
daa24f8a557b TightVNC original
YU
parents:
diff changeset
9 // This program is free software; you can redistribute it and/or modify
daa24f8a557b TightVNC original
YU
parents:
diff changeset
10 // it under the terms of the GNU General Public License as published by
daa24f8a557b TightVNC original
YU
parents:
diff changeset
11 // the Free Software Foundation; either version 2 of the License, or
daa24f8a557b TightVNC original
YU
parents:
diff changeset
12 // (at your option) any later version.
daa24f8a557b TightVNC original
YU
parents:
diff changeset
13 //
daa24f8a557b TightVNC original
YU
parents:
diff changeset
14 // This program is distributed in the hope that it will be useful,
daa24f8a557b TightVNC original
YU
parents:
diff changeset
15 // but WITHOUT ANY WARRANTY; without even the implied warranty of
daa24f8a557b TightVNC original
YU
parents:
diff changeset
16 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
daa24f8a557b TightVNC original
YU
parents:
diff changeset
17 // GNU General Public License for more details.
daa24f8a557b TightVNC original
YU
parents:
diff changeset
18 //
daa24f8a557b TightVNC original
YU
parents:
diff changeset
19 // You should have received a copy of the GNU General Public License along
daa24f8a557b TightVNC original
YU
parents:
diff changeset
20 // with this program; if not, write to the Free Software Foundation, Inc.,
daa24f8a557b TightVNC original
YU
parents:
diff changeset
21 // 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
daa24f8a557b TightVNC original
YU
parents:
diff changeset
22 //-------------------------------------------------------------------------
daa24f8a557b TightVNC original
YU
parents:
diff changeset
23 //
daa24f8a557b TightVNC original
YU
parents:
diff changeset
24
daa24f8a557b TightVNC original
YU
parents:
diff changeset
25 package com.glavsoft.rfb.protocol;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
26
9
3c0f262384dc send EncodingType.DESKTOP_SIZE AliceVNCMessage
YU
parents: 0
diff changeset
27 import alice.datasegment.DataSegment;
3c0f262384dc send EncodingType.DESKTOP_SIZE AliceVNCMessage
YU
parents: 0
diff changeset
28
0
daa24f8a557b TightVNC original
YU
parents:
diff changeset
29 import com.glavsoft.drawing.Renderer;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
30 import com.glavsoft.exceptions.CommonException;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
31 import com.glavsoft.exceptions.ProtocolException;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
32 import com.glavsoft.exceptions.TransportException;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
33 import com.glavsoft.rfb.ClipboardController;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
34 import com.glavsoft.rfb.IRepaintController;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
35 import com.glavsoft.rfb.client.FramebufferUpdateRequestMessage;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
36 import com.glavsoft.rfb.client.SetPixelFormatMessage;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
37 import com.glavsoft.rfb.encoding.EncodingType;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
38 import com.glavsoft.rfb.encoding.PixelFormat;
9
3c0f262384dc send EncodingType.DESKTOP_SIZE AliceVNCMessage
YU
parents: 0
diff changeset
39 import com.glavsoft.rfb.encoding.decoder.AliceVNCMessage;
0
daa24f8a557b TightVNC original
YU
parents:
diff changeset
40 import com.glavsoft.rfb.encoding.decoder.Decoder;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
41 import com.glavsoft.rfb.encoding.decoder.DecodersContainer;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
42 import com.glavsoft.rfb.encoding.decoder.FramebufferUpdateRectangle;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
43 import com.glavsoft.rfb.encoding.decoder.RichCursorDecoder;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
44 import com.glavsoft.transport.Reader;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
45
daa24f8a557b TightVNC original
YU
parents:
diff changeset
46 import java.io.PrintWriter;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
47 import java.io.StringWriter;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
48 import java.util.logging.Logger;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
49
daa24f8a557b TightVNC original
YU
parents:
diff changeset
50 public class ReceiverTask implements Runnable {
daa24f8a557b TightVNC original
YU
parents:
diff changeset
51 private static final byte FRAMEBUFFER_UPDATE = 0;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
52 private static final byte SET_COLOR_MAP_ENTRIES = 1;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
53 private static final byte BELL = 2;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
54 private static final byte SERVER_CUT_TEXT = 3;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
55
daa24f8a557b TightVNC original
YU
parents:
diff changeset
56
daa24f8a557b TightVNC original
YU
parents:
diff changeset
57 private static Logger logger = Logger.getLogger("com.glavsoft.rfb.protocol.ReceiverTask");
daa24f8a557b TightVNC original
YU
parents:
diff changeset
58 private final Reader reader;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
59 private volatile boolean isRunning = false;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
60 private Renderer renderer;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
61 private final IRepaintController repaintController;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
62 private final ClipboardController clipboardController;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
63 private final DecodersContainer decoders;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
64 private FramebufferUpdateRequestMessage fullscreenFbUpdateIncrementalRequest;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
65 private final ProtocolContext context;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
66 private PixelFormat pixelFormat;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
67 private boolean needSendPixelFormat;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
68
daa24f8a557b TightVNC original
YU
parents:
diff changeset
69 public ReceiverTask(Reader reader,
daa24f8a557b TightVNC original
YU
parents:
diff changeset
70 IRepaintController repaintController, ClipboardController clipboardController,
daa24f8a557b TightVNC original
YU
parents:
diff changeset
71 DecodersContainer decoders, ProtocolContext context) {
daa24f8a557b TightVNC original
YU
parents:
diff changeset
72 this.reader = reader;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
73 this.repaintController = repaintController;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
74 this.clipboardController = clipboardController;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
75 this.context = context;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
76 this.decoders = decoders;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
77 renderer = repaintController.createRenderer(reader, context.getFbWidth(), context.getFbHeight(),
daa24f8a557b TightVNC original
YU
parents:
diff changeset
78 context.getPixelFormat());
daa24f8a557b TightVNC original
YU
parents:
diff changeset
79 fullscreenFbUpdateIncrementalRequest =
daa24f8a557b TightVNC original
YU
parents:
diff changeset
80 new FramebufferUpdateRequestMessage(0, 0, context.getFbWidth(), context.getFbHeight(), true);
daa24f8a557b TightVNC original
YU
parents:
diff changeset
81 }
daa24f8a557b TightVNC original
YU
parents:
diff changeset
82
daa24f8a557b TightVNC original
YU
parents:
diff changeset
83 @Override
daa24f8a557b TightVNC original
YU
parents:
diff changeset
84 public void run() {
daa24f8a557b TightVNC original
YU
parents:
diff changeset
85 isRunning = true;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
86 while (isRunning) {
daa24f8a557b TightVNC original
YU
parents:
diff changeset
87 try {
daa24f8a557b TightVNC original
YU
parents:
diff changeset
88 byte messageId = reader.readByte();
daa24f8a557b TightVNC original
YU
parents:
diff changeset
89 switch (messageId) {
daa24f8a557b TightVNC original
YU
parents:
diff changeset
90 case FRAMEBUFFER_UPDATE:
daa24f8a557b TightVNC original
YU
parents:
diff changeset
91 // logger.fine("Server message: FramebufferUpdate (0)");
daa24f8a557b TightVNC original
YU
parents:
diff changeset
92 framebufferUpdateMessage();
daa24f8a557b TightVNC original
YU
parents:
diff changeset
93 break;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
94 case SET_COLOR_MAP_ENTRIES:
daa24f8a557b TightVNC original
YU
parents:
diff changeset
95 logger.severe("Server message SetColorMapEntries is not implemented. Skip.");
daa24f8a557b TightVNC original
YU
parents:
diff changeset
96 setColorMapEntries();
daa24f8a557b TightVNC original
YU
parents:
diff changeset
97 break;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
98 case BELL:
daa24f8a557b TightVNC original
YU
parents:
diff changeset
99 logger.fine("Server message: Bell");
daa24f8a557b TightVNC original
YU
parents:
diff changeset
100 System.out.print("\0007");
daa24f8a557b TightVNC original
YU
parents:
diff changeset
101 System.out.flush();
daa24f8a557b TightVNC original
YU
parents:
diff changeset
102 break;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
103 case SERVER_CUT_TEXT:
daa24f8a557b TightVNC original
YU
parents:
diff changeset
104 logger.fine("Server message: CutText (3)");
daa24f8a557b TightVNC original
YU
parents:
diff changeset
105 serverCutText();
daa24f8a557b TightVNC original
YU
parents:
diff changeset
106 break;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
107 default:
daa24f8a557b TightVNC original
YU
parents:
diff changeset
108 logger.severe("Unsupported server message. Id = " + messageId);
daa24f8a557b TightVNC original
YU
parents:
diff changeset
109 }
daa24f8a557b TightVNC original
YU
parents:
diff changeset
110 } catch (TransportException e) {
daa24f8a557b TightVNC original
YU
parents:
diff changeset
111 if (isRunning) {
daa24f8a557b TightVNC original
YU
parents:
diff changeset
112 logger.severe("Close session: " + e.getMessage());
daa24f8a557b TightVNC original
YU
parents:
diff changeset
113 context.cleanUpSession("Connection closed.");
daa24f8a557b TightVNC original
YU
parents:
diff changeset
114 }
daa24f8a557b TightVNC original
YU
parents:
diff changeset
115 stopTask();
daa24f8a557b TightVNC original
YU
parents:
diff changeset
116 } catch (ProtocolException e) {
daa24f8a557b TightVNC original
YU
parents:
diff changeset
117 logger.severe(e.getMessage());
daa24f8a557b TightVNC original
YU
parents:
diff changeset
118 if (isRunning) {
daa24f8a557b TightVNC original
YU
parents:
diff changeset
119 context.cleanUpSession(e.getMessage() + "\nConnection closed.");
daa24f8a557b TightVNC original
YU
parents:
diff changeset
120 }
daa24f8a557b TightVNC original
YU
parents:
diff changeset
121 stopTask();
daa24f8a557b TightVNC original
YU
parents:
diff changeset
122 } catch (CommonException e) {
daa24f8a557b TightVNC original
YU
parents:
diff changeset
123 logger.severe(e.getMessage());
daa24f8a557b TightVNC original
YU
parents:
diff changeset
124 if (isRunning) {
daa24f8a557b TightVNC original
YU
parents:
diff changeset
125 context.cleanUpSession("Connection closed..");
daa24f8a557b TightVNC original
YU
parents:
diff changeset
126 }
daa24f8a557b TightVNC original
YU
parents:
diff changeset
127 stopTask();
daa24f8a557b TightVNC original
YU
parents:
diff changeset
128 } catch (Throwable te) {
daa24f8a557b TightVNC original
YU
parents:
diff changeset
129 StringWriter sw = new StringWriter();
daa24f8a557b TightVNC original
YU
parents:
diff changeset
130 PrintWriter pw = new PrintWriter(sw);
daa24f8a557b TightVNC original
YU
parents:
diff changeset
131 te.printStackTrace(pw);
daa24f8a557b TightVNC original
YU
parents:
diff changeset
132 if (isRunning) {
daa24f8a557b TightVNC original
YU
parents:
diff changeset
133 context.cleanUpSession(te.getMessage() + "\n" + sw.toString());
daa24f8a557b TightVNC original
YU
parents:
diff changeset
134 }
daa24f8a557b TightVNC original
YU
parents:
diff changeset
135 stopTask();
daa24f8a557b TightVNC original
YU
parents:
diff changeset
136 }
daa24f8a557b TightVNC original
YU
parents:
diff changeset
137 }
daa24f8a557b TightVNC original
YU
parents:
diff changeset
138 }
daa24f8a557b TightVNC original
YU
parents:
diff changeset
139
daa24f8a557b TightVNC original
YU
parents:
diff changeset
140 private void setColorMapEntries() throws TransportException {
daa24f8a557b TightVNC original
YU
parents:
diff changeset
141 reader.readByte(); // padding
daa24f8a557b TightVNC original
YU
parents:
diff changeset
142 reader.readUInt16(); // first color index
daa24f8a557b TightVNC original
YU
parents:
diff changeset
143 int length = reader.readUInt16();
daa24f8a557b TightVNC original
YU
parents:
diff changeset
144 while (length-- > 0) {
daa24f8a557b TightVNC original
YU
parents:
diff changeset
145 reader.readUInt16(); // R
daa24f8a557b TightVNC original
YU
parents:
diff changeset
146 reader.readUInt16(); // G
daa24f8a557b TightVNC original
YU
parents:
diff changeset
147 reader.readUInt16(); // B
daa24f8a557b TightVNC original
YU
parents:
diff changeset
148 }
daa24f8a557b TightVNC original
YU
parents:
diff changeset
149 }
daa24f8a557b TightVNC original
YU
parents:
diff changeset
150
daa24f8a557b TightVNC original
YU
parents:
diff changeset
151 private void serverCutText() throws TransportException {
daa24f8a557b TightVNC original
YU
parents:
diff changeset
152 reader.readByte(); // padding
daa24f8a557b TightVNC original
YU
parents:
diff changeset
153 reader.readInt16(); // padding
daa24f8a557b TightVNC original
YU
parents:
diff changeset
154 int length = reader.readInt32() & Integer.MAX_VALUE;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
155 clipboardController.updateSystemClipboard(reader.readBytes(length));
daa24f8a557b TightVNC original
YU
parents:
diff changeset
156 }
daa24f8a557b TightVNC original
YU
parents:
diff changeset
157
daa24f8a557b TightVNC original
YU
parents:
diff changeset
158 public void framebufferUpdateMessage() throws CommonException {
daa24f8a557b TightVNC original
YU
parents:
diff changeset
159 reader.readByte(); // padding
daa24f8a557b TightVNC original
YU
parents:
diff changeset
160 int numberOfRectangles = reader.readUInt16();
daa24f8a557b TightVNC original
YU
parents:
diff changeset
161 while (numberOfRectangles-- > 0) {
daa24f8a557b TightVNC original
YU
parents:
diff changeset
162 FramebufferUpdateRectangle rect = new FramebufferUpdateRectangle();
daa24f8a557b TightVNC original
YU
parents:
diff changeset
163 rect.fill(reader);
daa24f8a557b TightVNC original
YU
parents:
diff changeset
164
daa24f8a557b TightVNC original
YU
parents:
diff changeset
165 Decoder decoder = decoders.getDecoderByType(rect.getEncodingType());
daa24f8a557b TightVNC original
YU
parents:
diff changeset
166 logger.finest(rect.toString() + (0 == numberOfRectangles ? "\n---" : ""));
daa24f8a557b TightVNC original
YU
parents:
diff changeset
167 if (decoder != null) {
daa24f8a557b TightVNC original
YU
parents:
diff changeset
168 decoder.decode(reader, renderer, rect);
daa24f8a557b TightVNC original
YU
parents:
diff changeset
169 repaintController.repaintBitmap(rect);
daa24f8a557b TightVNC original
YU
parents:
diff changeset
170 } else if (rect.getEncodingType() == EncodingType.RICH_CURSOR) {
daa24f8a557b TightVNC original
YU
parents:
diff changeset
171 RichCursorDecoder.getInstance().decode(reader, renderer, rect);
daa24f8a557b TightVNC original
YU
parents:
diff changeset
172 repaintController.repaintCursor();
daa24f8a557b TightVNC original
YU
parents:
diff changeset
173 } else if (rect.getEncodingType() == EncodingType.CURSOR_POS) {
daa24f8a557b TightVNC original
YU
parents:
diff changeset
174 renderer.decodeCursorPosition(rect);
daa24f8a557b TightVNC original
YU
parents:
diff changeset
175 repaintController.repaintCursor();
daa24f8a557b TightVNC original
YU
parents:
diff changeset
176 } else if (rect.getEncodingType() == EncodingType.DESKTOP_SIZE) {
daa24f8a557b TightVNC original
YU
parents:
diff changeset
177 fullscreenFbUpdateIncrementalRequest =
daa24f8a557b TightVNC original
YU
parents:
diff changeset
178 new FramebufferUpdateRequestMessage(0, 0, rect.width, rect.height, true);
daa24f8a557b TightVNC original
YU
parents:
diff changeset
179 synchronized (renderer.getLock()) {
daa24f8a557b TightVNC original
YU
parents:
diff changeset
180 renderer = repaintController.createRenderer(reader, rect.width, rect.height,
daa24f8a557b TightVNC original
YU
parents:
diff changeset
181 context.getPixelFormat());
daa24f8a557b TightVNC original
YU
parents:
diff changeset
182 }
9
3c0f262384dc send EncodingType.DESKTOP_SIZE AliceVNCMessage
YU
parents: 0
diff changeset
183 AliceVNCMessage message = new AliceVNCMessage();
3c0f262384dc send EncodingType.DESKTOP_SIZE AliceVNCMessage
YU
parents: 0
diff changeset
184 message.setRectangle(rect);
3c0f262384dc send EncodingType.DESKTOP_SIZE AliceVNCMessage
YU
parents: 0
diff changeset
185 message.setPixelFormat(context.getPixelFormat());
17
61d95bdc2bdb change Alice PUT API new Version
sugi
parents: 9
diff changeset
186 DataSegment.getLocal().put("aliceVNCMessage", message, null);
9
3c0f262384dc send EncodingType.DESKTOP_SIZE AliceVNCMessage
YU
parents: 0
diff changeset
187
0
daa24f8a557b TightVNC original
YU
parents:
diff changeset
188 context.sendMessage(new FramebufferUpdateRequestMessage(0, 0, rect.width, rect.height, false));
daa24f8a557b TightVNC original
YU
parents:
diff changeset
189 // repaintController.repaintCursor();
daa24f8a557b TightVNC original
YU
parents:
diff changeset
190 } else
daa24f8a557b TightVNC original
YU
parents:
diff changeset
191 throw new CommonException("Unprocessed encoding: " + rect.toString());
daa24f8a557b TightVNC original
YU
parents:
diff changeset
192 }
daa24f8a557b TightVNC original
YU
parents:
diff changeset
193 synchronized (this) {
daa24f8a557b TightVNC original
YU
parents:
diff changeset
194 if (needSendPixelFormat) {
daa24f8a557b TightVNC original
YU
parents:
diff changeset
195 needSendPixelFormat = false;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
196 context.setPixelFormat(pixelFormat);
daa24f8a557b TightVNC original
YU
parents:
diff changeset
197 context.sendMessage(new SetPixelFormatMessage(pixelFormat));
daa24f8a557b TightVNC original
YU
parents:
diff changeset
198 logger.fine("sent: "+pixelFormat);
daa24f8a557b TightVNC original
YU
parents:
diff changeset
199 context.sendRefreshMessage();
daa24f8a557b TightVNC original
YU
parents:
diff changeset
200 logger.fine("sent: nonincremental fb update");
daa24f8a557b TightVNC original
YU
parents:
diff changeset
201 } else {
daa24f8a557b TightVNC original
YU
parents:
diff changeset
202 context.sendMessage(fullscreenFbUpdateIncrementalRequest);
daa24f8a557b TightVNC original
YU
parents:
diff changeset
203 }
daa24f8a557b TightVNC original
YU
parents:
diff changeset
204 }
daa24f8a557b TightVNC original
YU
parents:
diff changeset
205 }
daa24f8a557b TightVNC original
YU
parents:
diff changeset
206
daa24f8a557b TightVNC original
YU
parents:
diff changeset
207 public synchronized void queueUpdatePixelFormat(PixelFormat pf) {
daa24f8a557b TightVNC original
YU
parents:
diff changeset
208 pixelFormat = pf;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
209 needSendPixelFormat = true;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
210 // context.sendMessage(new FramebufferUpdateRequestMessage(0, 0, 1, 1, false));
daa24f8a557b TightVNC original
YU
parents:
diff changeset
211 }
daa24f8a557b TightVNC original
YU
parents:
diff changeset
212
daa24f8a557b TightVNC original
YU
parents:
diff changeset
213 public void stopTask() {
daa24f8a557b TightVNC original
YU
parents:
diff changeset
214 isRunning = false;
daa24f8a557b TightVNC original
YU
parents:
diff changeset
215 }
daa24f8a557b TightVNC original
YU
parents:
diff changeset
216
daa24f8a557b TightVNC original
YU
parents:
diff changeset
217 }