Mercurial > hg > Applications > TreeVNC
view src/main/java/com/glavsoft/rfb/protocol/SenderTask.java @ 326:1d4d5055a288
add error message, add assure stream close.
author | oc |
---|---|
date | Sun, 01 Feb 2015 15:30:17 +0900 |
parents | e21ef8f60f7a |
children | 1f86df6504b7 |
line wrap: on
line source
// Copyright (C) 2010, 2011, 2012, 2013 GlavSoft LLC. // All rights reserved. // //------------------------------------------------------------------------- // This file is part of the TightVNC software. Please visit our Web site: // // http://www.tightvnc.com/ // // This program is free software; you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation; either version 2 of the License, or // (at your option) any later version. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License along // with this program; if not, write to the Free Software Foundation, Inc., // 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. //------------------------------------------------------------------------- // package com.glavsoft.rfb.protocol; import com.glavsoft.exceptions.TransportException; import com.glavsoft.rfb.client.ClientToServerMessage; import com.glavsoft.transport.Writer; import java.io.PrintWriter; import java.io.StringWriter; import java.util.logging.Logger; public class SenderTask implements Runnable { private final MessageQueue queue; private final Writer writer; private final ProtocolContext protocolContext; private volatile boolean isRunning = false; /** * Create sender task * Task runs as thread, receive messages from queue and sends them to writer. * When no messages appears in queue longer than timeout period, sends FramebufferUpdate * request * @param messageQueue queue to poll messages * @param writer writer to send messages out * @param protocolContext protocol */ public SenderTask(MessageQueue messageQueue, Writer writer, ProtocolContext protocolContext) { this.queue = messageQueue; this.writer = writer; this.protocolContext = protocolContext; } @Override public void run() { isRunning = true; while (isRunning) { ClientToServerMessage message; try { message = queue.get(); if (message != null) { message.send(writer); } } catch (InterruptedException e) { System.out.println("cannot get ClientToServerMessage."); } catch (TransportException e) { System.out.println("cannot send ClientToServerMessage."); Logger.getLogger(getClass().getName()).severe("Close session: " + e.getMessage()); if (isRunning) { protocolContext.cleanUpSession("Connection closed"); } stopTask(); } catch (Throwable te) { System.out.println("throwable when ClientToServerMessage send or get"); StringWriter sw = new StringWriter(); PrintWriter pw = new PrintWriter(sw); te.printStackTrace(pw); if (isRunning) { protocolContext.cleanUpSession(te.getMessage() + "\n" + sw.toString()); } stopTask(); } } } public void stopTask() { isRunning = false; } }