Mercurial > hg > graal-jvmci-8
view c1x4hotspotsrc/HotSpotVM/src/com/sun/hotspot/c1x/InvocationSocket.java @ 1435:20a3896518ac
Initial adjustments to make C1X4HotSpot compile and run with latest Maxine version.
author | Thomas Wuerthinger <wuerthinger@ssw.jku.at> |
---|---|
date | Fri, 22 Oct 2010 17:31:38 +0200 |
parents | 760213a60e8b |
children | 9e5e83ca2259 |
line wrap: on
line source
/* * Copyright (c) 2010 Sun Microsystems, Inc. All rights reserved. * * Sun Microsystems, Inc. has intellectual property rights relating to technology embodied in the product that is * described in this document. In particular, and without limitation, these intellectual property rights may include one * or more of the U.S. patents listed at http://www.sun.com/patents and one or more additional patents or pending patent * applications in the U.S. and in other countries. * * U.S. Government Rights - Commercial software. Government users are subject to the Sun Microsystems, Inc. standard * license agreement and applicable provisions of the FAR and its supplements. * * Use is subject to license terms. Sun, Sun Microsystems, the Sun logo, Java and Solaris are trademarks or registered * trademarks of Sun Microsystems, Inc. in the U.S. and other countries. All SPARC trademarks are used under license and * are trademarks or registered trademarks of SPARC International, Inc. in the U.S. and other countries. * * UNIX is a registered trademark in the U.S. and other countries, exclusively licensed through X/Open Company, Ltd. */ package com.sun.hotspot.c1x; import java.io.*; import java.lang.reflect.*; import com.sun.hotspot.c1x.logging.*; /** * A java.lang.reflect proxy that communicates over a socket connection. * * Calling a method sends the method name and the parameters through the socket. Afterwards this class waits for a result. * While waiting for a result three types of objects can arrive through the socket: a method invocation, a method result or an exception. * Method invocation can thus be recursive. * * @author Lukas Stadler */ public class InvocationSocket implements InvocationHandler { private final ObjectOutputStream output; private final ObjectInputStream input; private Object delegate; public InvocationSocket(ObjectOutputStream output, ObjectInputStream input) { this.output = output; this.input = input; } public void setDelegate(Object delegate) { this.delegate = delegate; } private static class Invocation implements Serializable { public String methodName; public Object[] args; public Invocation(String methodName, Object[] args) { this.methodName = methodName; this.args = args; } } private static class Result implements Serializable { public Object result; public Result(Object result) { this.result = result; } } @Override public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { try { Logger.startScope("invoking remote " + method.getName()); output.writeObject(new Invocation(method.getName(), args)); output.flush(); return waitForResult(); } catch (Throwable t) { t.printStackTrace(); throw t; } finally { Logger.endScope(""); } } public Object waitForResult() throws IOException, ClassNotFoundException { while (true) { Object in = input.readObject(); if (in instanceof Result) return ((Result) in).result; if (in instanceof RuntimeException) throw (RuntimeException) in; if (in instanceof Throwable) throw new RuntimeException((Throwable) in); Invocation invoke = (Invocation) in; Method method = null; for (Method m : delegate.getClass().getDeclaredMethods()) { if (invoke.methodName.equals(m.getName())) { method = m; break; } } if (method == null) { Exception e = new UnsupportedOperationException("unknown method " + invoke.methodName); e.printStackTrace(); output.writeObject(e); output.flush(); } else { Object result; try { Logger.startScope("invoking local " + invoke.methodName); if (invoke.args == null) { result = method.invoke(delegate); } else { result = method.invoke(delegate, invoke.args); } result = new Result(result); } catch (IllegalArgumentException e) { System.out.println("error while invoking " + invoke.methodName); e.getCause().printStackTrace(); result = e.getCause(); } catch (InvocationTargetException e) { System.out.println("error while invoking " + invoke.methodName); e.getCause().printStackTrace(); result = e.getCause(); } catch (IllegalAccessException e) { System.out.println("error while invoking " + invoke.methodName); e.getCause().printStackTrace(); result = e.getCause(); } finally { Logger.endScope(""); } output.writeObject(result); output.flush(); } } } }