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;
    }

}