1 /*BEGIN_COPYRIGHT_BLOCK 2 * 3 * This file is part of DrJava. Download the current version of this project from http://www.drjava.org/ 4 * or http://sourceforge.net/projects/drjava/ 5 * 6 * DrJava Open Source License 7 * 8 * Copyright (C) 2001-2005 JavaPLT group at Rice University (javaplt@rice.edu). All rights reserved. 9 * 10 * Developed by: Java Programming Languages Team, Rice University, http://www.cs.rice.edu/~javaplt/ 11 * 12 * Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated 13 * documentation files (the "Software"), to deal with the Software without restriction, including without limitation 14 * the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and 15 * to permit persons to whom the Software is furnished to do so, subject to the following conditions: 16 * 17 * - Redistributions of source code must retain the above copyright notice, this list of conditions and the 18 * following disclaimers. 19 * - Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the 20 * following disclaimers in the documentation and/or other materials provided with the distribution. 21 * - Neither the names of DrJava, the JavaPLT, Rice University, nor the names of its contributors may be used to 22 * endorse or promote products derived from this Software without specific prior written permission. 23 * - Products derived from this software may not be called "DrJava" nor use the term "DrJava" as part of their 24 * names without prior written permission from the JavaPLT group. For permission, write to javaplt@rice.edu. 25 * 26 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO 27 * THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 28 * CONTRIBUTORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF 29 * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS 30 * WITH THE SOFTWARE. 31 * 32 END_COPYRIGHT_BLOCK*/ 33 34 35 package edu.rice.cs.util.newjvm; 36 37 import java.rmi.*; 38 39 /** The remote interface for a slave JVM. All instances must also provide a no-arg constructor, which is reflectively 40 * invoked in {@link SlaveJVMRunner}. 41 * @version $Id: SlaveRemote.java 3218 2005-05-26 20:08:20Z rcartwright $ 42 */ 43 public interface SlaveRemote extends Remote { 44 /** Quits the slave JVM. */ 45 public void quit() throws RemoteException; 46 47 /** This method is called when the slave JVM is initialized. 48 * @param master The remote link to the master JVM. Note that the implementation of the slave class will have to 49 * downcast this reference to the correct master remote interface. Also note that because of the GJ erasure 50 * semantics, this can't have the type it, which is MasterRemote<YourSlaveInterface>. Luckily it doesn't matter 51 * much here to use the erased type. 52 */ 53 public void start(MasterRemote master) throws RemoteException; 54 } 55