| package org.eclipse.jem.internal.proxy.remote; |
| /******************************************************************************* |
| * Copyright (c) 2001, 2003 IBM Corporation and others. |
| * All rights reserved. This program and the accompanying materials |
| * are made available under the terms of the Common Public License v1.0 |
| * which accompanies this distribution, and is available at |
| * http://www.eclipse.org/legal/cpl-v10.html |
| * |
| * Contributors: |
| * IBM Corporation - initial API and implementation |
| *******************************************************************************/ |
| /* |
| * $RCSfile: REMConnection.java,v $ |
| * $Revision: 1.1 $ $Date: 2003/10/27 17:22:23 $ |
| */ |
| |
| |
| import java.io.*; |
| import java.net.Socket; |
| |
| import org.eclipse.core.runtime.IStatus; |
| import org.eclipse.core.runtime.Status; |
| import org.eclipse.jem.internal.proxy.core.ProxyPlugin; |
| import org.eclipse.jem.internal.proxy.common.CommandException; |
| import org.eclipse.jem.internal.proxy.common.remote.CommandErrorException; |
| import org.eclipse.jem.internal.proxy.common.remote.Commands; |
| import org.eclipse.jem.internal.proxy.common.remote.Commands.GetClassIDReturn; |
| import org.eclipse.jem.internal.proxy.common.remote.Commands.GetClassReturn; |
| /** |
| * The default implementation of the connection. |
| * |
| * It uses the property "proxyvm.bufsize" to determine the buffer size to use. If not specified, it uses the system default |
| */ |
| public class REMConnection implements IREMConnection { |
| protected Socket fSocket = null; |
| protected DataInputStream in = null; |
| protected DataOutputStream out = null; |
| private static final int TIME_OUT = 1000 * 60; // Wait up to one minute before timeout. |
| |
| public REMConnection(Socket socket, boolean noTimeouts) { |
| try { |
| fSocket = socket; |
| fSocket.setSoLinger(true, 10); // Wait 10 seconds if necessary for the final stuff to go out after closing. |
| if (!noTimeouts) |
| fSocket.setSoTimeout(TIME_OUT); // Timeout period |
| Integer bufSize = Integer.getInteger("proxyvm.bufsize"); //$NON-NLS-1$ |
| if (bufSize == null) |
| bufSize = new Integer(16000); |
| // try { |
| // fSocket.setReceiveBufferSize(bufSize.intValue()); |
| // fSocket.setSendBufferSize(bufSize.intValue()); |
| // } catch (SocketException e) { |
| // } |
| // if (fSocket.getSendBufferSize() >= bufSize.intValue()) |
| // out = new DataOutputStream(fSocket.getOutputStream()); // It took the hint, no need to add another buffer on top. |
| // else |
| out = new DataOutputStream(new BufferedOutputStream(fSocket.getOutputStream(), bufSize.intValue())); // It didn't take the hint, so we will buffer it. |
| // if (fSocket.getReceiveBufferSize() >= bufSize.intValue()) |
| // in = new DataInputStream(fSocket.getInputStream()); // It took the hint, no need to add another buffer on top. |
| // else |
| in = new DataInputStream(new BufferedInputStream(fSocket.getInputStream(), bufSize.intValue())); // It didn't take the hint, so we will buffer it. |
| } catch (IOException e) { |
| ProxyPlugin.getPlugin().getMsgLogger().log(new Status(IStatus.ERROR, ProxyPlugin.getPlugin().getDescriptor().getUniqueIdentifier(), 0, "", e)); |
| |
| if (out != null) |
| try { |
| out.close(); |
| } catch (IOException e2) { |
| } |
| if (in != null) |
| try { |
| in.close(); |
| } catch (IOException e3) { |
| } |
| try { |
| fSocket.close(); |
| } catch (IOException e4) { |
| } |
| fSocket = null; |
| in = null; |
| out = null; |
| } |
| } |
| |
| /** |
| * Did this construct correctly. |
| * This is needed because an exception could be thrown in the ctor and |
| * that's not a good thing to do. |
| */ |
| public boolean isConnected() { |
| return fSocket != null; |
| } |
| |
| /** |
| * Terminate the server. |
| */ |
| public void terminateServer() { |
| if (isConnected()) { |
| try { |
| Commands.sendTerminateCommand(out); |
| } catch (IOException e) { |
| } |
| close(); |
| } |
| } |
| |
| /** |
| * Close the connection. |
| */ |
| public void close() { |
| if (isConnected()) { |
| try { |
| Commands.sendQuitCommand(out); |
| } catch (IOException e) { |
| } finally { |
| try { |
| out.close(); |
| } catch (IOException e2) { |
| } |
| try { |
| in.close(); |
| } catch (IOException e3) { |
| } |
| try { |
| fSocket.close(); |
| } catch (IOException e4) { |
| } |
| } |
| fSocket = null; |
| in = null; |
| out = null; |
| } |
| } |
| |
| |
| /** |
| * Return the class information. |
| */ |
| public GetClassReturn getClass(String className) throws CommandException { |
| if (isConnected()) |
| try { |
| // It's simple, just pass onto Commands. |
| return Commands.sendGetClassCommand(out, in, className); |
| } catch (CommandErrorException e) { |
| if (e.getErrorCode() != Commands.GET_CLASS_NOT_FOUND) |
| throw e; // Not class not found, send it on |
| } |
| return null; // Not found, so return null |
| } |
| |
| |
| /** |
| * Return the class information given an ID. |
| */ |
| public GetClassIDReturn getClassFromID(int classID) throws CommandException { |
| if (isConnected()) { |
| // It's simple, just pass onto Commands. |
| return Commands.sendGetClassFromIDCommand(out, in, classID); |
| } |
| return null; // Not found, so return null |
| } |
| |
| /** |
| * Get the object data from an id. |
| */ |
| public void getObjectData(int classID, Commands.ValueObject valueReturn) throws CommandException { |
| if (isConnected()) { |
| // Just pass onto Commands. |
| Commands.sendGetObjectData(out, in, classID, valueReturn); |
| } else |
| valueReturn.set(); // Set it to null since we aren't connected. |
| } |
| |
| /** |
| * Get a new instance using an init string |
| */ |
| public void getNewInstance(int classID, String initString, Commands.ValueObject newInstance) throws CommandException { |
| if (isConnected()) { |
| // Just pass onto Commands. |
| Commands.sendNewInstance(out, in, classID, initString, newInstance); |
| } else |
| newInstance.set(); // Set it to null since we aren't connected. |
| } |
| |
| /** |
| * Release the id. |
| */ |
| public void releaseID(int id){ |
| if (isConnected()) |
| try { |
| // Just pass onto Commands. |
| Commands.releaseObjectCommand(out, id); |
| } catch (IOException e) { |
| // Don't care it didn't work |
| } |
| } |
| |
| /** |
| * Invoke the method call |
| */ |
| public void invokeMethod(int methodID, Commands.ValueObject invokeOn, Commands.ValueObject parms, Commands.ValueObject returnValue) throws CommandException { |
| if (isConnected()) { |
| // It's simple, just pass onto Commands. |
| Commands.sendInvokeMethodCommand(out, in, methodID, invokeOn, parms, returnValue); |
| } |
| } |
| } |