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.body.ft.servers.util; 00032 00033 import java.io.IOException; 00034 import java.rmi.RemoteException; 00035 00036 import org.objectweb.proactive.core.body.UniversalBody; 00037 import org.objectweb.proactive.core.body.ft.internalmsg.Killer; 00038 import org.objectweb.proactive.core.body.ft.servers.FTServer; 00039 00040 00046 public class KillerJob implements ActiveQueueJob { 00047 private FTServer server; 00048 private UniversalBody toKill; 00049 private long toWait; 00050 00054 public KillerJob(FTServer server, UniversalBody toKill, long toWait) { 00055 this.server = server; 00056 this.toKill = toKill; 00057 this.toWait = toWait; 00058 } 00059 00063 public void doTheJob() { 00064 try { 00065 // wait before killing 00066 Thread.sleep(toWait); 00067 toKill.receiveFTMessage(new Killer()); 00068 } catch (IOException e) { 00069 //nothing 00070 } catch (InterruptedException e) { 00071 // TODO Auto-generated catch block 00072 e.printStackTrace(); 00073 } 00074 try { 00075 this.server.forceDetection(); 00076 } catch (RemoteException e1) { 00077 e1.printStackTrace(); 00078 } 00079 } 00080 }
 1.5.1
 1.5.1