From cf0e312b59e1c0afb4996188afafc8835eec191d Mon Sep 17 00:00:00 2001 From: Brian Hinz Date: Thu, 5 Apr 2012 03:37:50 +0000 Subject: adds experimental support for SSH tunneling to the Java client. Has not been tested with large desktop sizes yet. CMakeLists.txt needs some rework. git-svn-id: svn://svn.code.sf.net/p/tigervnc/code/trunk@4882 3789f03b-4d11-0410-bbf8-ca57d06f2519 --- java/com/tigervnc/network/TcpListener.java | 2 +- java/com/tigervnc/network/TcpSocket.java | 34 ++++++++++++------------------ 2 files changed, 15 insertions(+), 21 deletions(-) (limited to 'java/com/tigervnc/network') diff --git a/java/com/tigervnc/network/TcpListener.java b/java/com/tigervnc/network/TcpListener.java index 4cc8c0da..cb0a69aa 100644 --- a/java/com/tigervnc/network/TcpListener.java +++ b/java/com/tigervnc/network/TcpListener.java @@ -100,7 +100,7 @@ public class TcpListener extends SocketListener { // Accept an incoming connection try { - if (selector.select() > 0) { + if (selector.select(0) > 0) { Set keys = selector.selectedKeys(); Iterator iter = keys.iterator(); while (iter.hasNext()) { diff --git a/java/com/tigervnc/network/TcpSocket.java b/java/com/tigervnc/network/TcpSocket.java index 9277dd14..1d127f50 100644 --- a/java/com/tigervnc/network/TcpSocket.java +++ b/java/com/tigervnc/network/TcpSocket.java @@ -171,29 +171,23 @@ public class TcpSocket extends Socket { return ((InetSocketAddress)((SocketDescriptor)getFd()).socket().getRemoteSocketAddress()).getPort(); } + /* Tunnelling support. */ + public static int findFreeTcpPort() { + java.net.ServerSocket sock; + int port; + try { + sock = new java.net.ServerSocket(0); + port = sock.getLocalPort(); + sock.close(); + } catch (java.io.IOException e) { + throw new SocketException("unable to create socket: "+e.toString()); + } + return port; + } + private boolean closeFd; static LogWriter vlog = new LogWriter("TcpSocket"); } -/* Tunnelling support. */ -/* -public int findFreeTcpPort() { - int sock; - - if ((sock = socket(AF_INET, SOCK_STREAM, 0)) < 0) - throw SocketException("unable to create socket", errorNumber); - - int port = 0; - if (bind (sock, (struct sockaddr *)&addr, sizeof (addr)) < 0) - throw SocketException("unable to find free port", errorNumber); - - socklen_t n = sizeof(addr); - if (getsockname (sock, (struct sockaddr *)&addr, &n) < 0) - throw SocketException("unable to get port number", errorNumber); - - closesocket(sock); - return ntohs(addr.sin_port); -} -*/ -- cgit v1.2.3