Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
COOS - Connected Objects Operating System (www.connectedobjects.org). Copyright (C) 2009 Telenor ASA and Tellu AS. All rights reserved. DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. This library is free software: you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation, either version 3 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 Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with this program. If not, see <http://www.gnu.org/licenses/>. You may also contact one of the following for additional information: Telenor ASA, Snaroyveien 30, N-1331 Fornebu, Norway (www.telenor.no) Tellu AS, Hagalokkveien 13, N-1383 Asker, Norway (www.tellu.no)
 
 package org.coos.messaging.cldc.transport;
 
 
 import java.io.*;
Created by IntelliJ IDEA. User: Knut Eilif
 
 public class TCPTransport extends DefaultProcessor implements TransportService {
 
 	protected String hostName;
 	protected int hostPort;
 	protected SocketConnection socket;
 	protected Reader reader;
 	protected Writer writer;
 	protected Vector mailbox = new Vector();
 	// private static final Log logger = LogFactory.getLog(TCPTransport.class);
 	protected boolean running = true;
 	protected Channel channel;
 
 	public TCPTransport() {
 	}
 
 	public TCPTransport(String hostIPint hostPort) {
 		this. = hostIP;
 		this. = hostPort;
 	}
 
 		this. = socket;
 	}
 
 	}
 
 	public void setChainedProcessor(Processor transportProcessor) {
 		this. = transportProcessor;
 	}
 
 	public Reader getReader() {
 		return ;
 	}
 
 	public Writer getWriter() {
 		return ;
 	}
 
 	public void processMessage(Message msgthrows ProcessorException {
 		String priStr = msg.getHeader(.);
 		if (priStr != null) {
 			int pri = Integer.parseInt(priStr);
 			int idx = 0;
 
 			for (int i = 0; i < .size(); i++) {
 				Message message = (Message.elementAt(i);
 				String pr = message.getHeader(.);
 				if (pr != null) {
 					int p = Integer.parseInt(pr);
 					if (pri < p) {
 						.insertElementAt(msgidx);
 						synchronized (this) {
 							this.notify();
 						}
 						break;
 					}
				}
				idx++;
			}
else {
			synchronized (this) {
				this.notify();
			}
		}
	}
	public void start() throws Exception {
		 = true;
		if ( != null) {
			// Socket already exist, Start reader and writer
			 = new Reader();
			 = new Writer();
			return;
		}
		// socket does not exist, must be established before starting reader and
		// writer
		if ( == null) {
			 = (String.get("host");
		}
		if ( == 0 && .get("port") != null) {
			 = Integer.parseInt((String.get("port"));
		}
		// logger.info("Establishing transport to " + hostName + ":" +
		// hostPort);
		Thread t = new Thread(new Runnable() {
			public void run() {
				if ( == null) {
					boolean connecting = true;
					while (connecting && ) {
						try {
							 = (SocketConnection) Connector.open("socket://" +  + ":" + );
							connecting = false;
catch (IOException e) {
							String retryStr = (String.get("retry");
							if (retryStr == null || retryStr.equals("true")) {
								// logger.info("Establishing transport to " +
								// hostName + ":" + hostPort +
								// " failed. Retrying in 10 sec.");
								try {
									Thread.sleep(10000);
catch (InterruptedException e1) {
								}
else {
								connecting = false;
							}
						}
					}
					if () {
						// logger.info("Transport from " +
						// socket.getLocalSocketAddress() + " to " +
						// socket.getRemoteSocketAddress() + " established.");
					}
				}
				 = new Reader();
				 = new Writer();
			}
		});
		t.start();
	}
	public void stop() throws Exception {
		// logger.info("Closing transport: " + hostName + ":" + hostPort);
		 = false;
		if ( != null) {
		}
		if ( != null) {
		}
		if ( != null) {
		}
		 = null;
	}
	public int getQueueSize() {
		return .size();
	}
	public void setChannel(Channel channel) {
		this. = channel;
	}
	class Reader implements Runnable {
		boolean running = true;
		Reader() {
			 = new Thread(this);
			// logger.info("Reader started on :" +
			// socket.getLocalSocketAddress());
		}
		public void stop() {
			 = false;
		}
		public void run() {
			try {
				// is = socket.getInputStream();
				while () {
					Message msg = null;
					try {
						msg = new DefaultMessage(din);
catch (EOFException e) {
						// logger.info("Connection closing EOF");
						 = false;
catch (Exception e) {
						// logger.fatal("Error in Message deserialization. Aborting");
						 = false;
					}
				}
				if ( != null) {
				}
catch (IOException e) {
			}
		}
	}
	class Writer implements Runnable {
		boolean running = true;
		Writer() {
			 = new Thread(this);
			// logger.info("Writer started on :" +
			// socket.getLocalSocketAddress());
		}
		public void stop() {
			 = false;
		}
		public void run() {
			try {
				// os = socket.getOutputStream();
				while () {
					if (.isEmpty()) {
						synchronized (TCPTransport.this) {
							try {
catch (InterruptedException e) {
								if (!)
									return;
							}
						}
else {
						// Message msg = mailbox.remove(0);
						try {
catch (Exception e) {
							// logger.fatal("Error in Message writing. Aborting");
							 = false;
						}
					}
				}
				if ( != null) {
				}
catch (IOException e) {
			}
		}
	}
New to GrepCode? Check out our FAQ X