00001 /* 00002 * ################################################################ 00003 * 00004 * ProActive: The Java(TM) library for Parallel, Distributed, 00005 * Concurrent computing with Security and Mobility 00006 * 00007 * Copyright (C) 1997-2007 INRIA/University of Nice-Sophia Antipolis 00008 * Contact: proactive@objectweb.org 00009 * 00010 * This library is free software; you can redistribute it and/or 00011 * modify it under the terms of the GNU Lesser General Public 00012 * License as published by the Free Software Foundation; either 00013 * version 2.1 of the License, or any later version. 00014 * 00015 * This library is distributed in the hope that it will be useful, 00016 * but WITHOUT ANY WARRANTY; without even the implied warranty of 00017 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00018 * Lesser General Public License for more details. 00019 * 00020 * You should have received a copy of the GNU Lesser General Public 00021 * License along with this library; if not, write to the Free Software 00022 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 00023 * USA 00024 * 00025 * Initial developer(s): The ProActive Team 00026 * http://www.inria.fr/oasis/ProActive/contacts.html 00027 * Contributor(s): 00028 * 00029 * ################################################################ 00030 */ 00031 package org.objectweb.proactive.core.process.rocks; 00032 00033 import org.objectweb.proactive.core.process.AbstractExternalProcessDecorator; 00034 import org.objectweb.proactive.core.process.ExternalProcess; 00035 import org.objectweb.proactive.core.process.UniversalProcess; 00036 00037 00038 public class ClusterForkProcess extends AbstractExternalProcessDecorator { 00039 final protected String DEFAULT_COMMAND = "cluster-fork"; 00040 00041 public ClusterForkProcess() { 00042 super(); 00043 command_path = DEFAULT_COMMAND; 00044 hostname = null; 00045 } 00046 00047 public ClusterForkProcess(ExternalProcess _targetProcess) { 00048 super(_targetProcess); 00049 command_path = DEFAULT_COMMAND; 00050 hostname = null; 00051 } 00052 00053 /* ==== AbstractExternalProcessDecorator ==== */ 00054 protected String internalBuildCommand() { 00055 if (logger.isDebugEnabled()) { 00056 logger.debug("cluster-fork command is " + command_path); 00057 } 00058 return command_path + " --bg "; 00059 } 00060 00061 public UniversalProcess getFinalProcess() { 00062 checkStarted(); 00063 return targetProcess; 00064 } 00065 00066 public int getNodeNumber() { 00067 return UNKNOWN_NODE_NUMBER; 00068 } 00069 00070 public String getProcessId() { 00071 return "clusterfork_" + targetProcess.getProcessId(); 00072 } 00073 }