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.exceptions.proxy; 00032 00033 import java.util.Iterator; 00034 00035 import org.objectweb.proactive.core.exceptions.NonFunctionalException; 00036 import org.objectweb.proactive.core.exceptions.manager.NFEListener; 00037 import org.objectweb.proactive.core.group.ExceptionInGroup; 00038 import org.objectweb.proactive.core.group.ExceptionListException; 00039 import org.objectweb.proactive.core.group.ProxyForGroup; 00040 00041 00042 class AutomaticPurgeGroup implements NFEListener { 00043 public boolean handleNFE(NonFunctionalException nfe) { 00044 Iterator exceptions; 00045 ProxyForGroup group; 00046 ExceptionListException exceptionList; 00047 00048 try { 00049 FailedGroupRendezVousException fgrve = (FailedGroupRendezVousException) nfe; 00050 exceptionList = (ExceptionListException) fgrve.getCause(); 00051 group = fgrve.getGroup(); 00052 } catch (ClassCastException cce) { 00053 return false; 00054 } 00055 00056 synchronized (exceptionList) { 00057 exceptions = exceptionList.iterator(); 00058 00059 while (exceptions.hasNext()) { 00060 ExceptionInGroup eig = (ExceptionInGroup) exceptions.next(); 00061 group.remove(eig.getObject()); 00062 } 00063 } 00064 00065 return true; 00066 } 00067 } 00068 00069 00070 public class FailedGroupRendezVousException extends ProxyNonFunctionalException { 00071 public static final AutomaticPurgeGroup AUTO_GROUP_PURGE = new AutomaticPurgeGroup(); 00072 private ProxyForGroup group; 00073 00074 public FailedGroupRendezVousException(String message, 00075 ExceptionListException e, ProxyForGroup group) { 00076 super(message, e); 00077 this.group = group; 00078 } 00079 00080 public ProxyForGroup getGroup() { 00081 return group; 00082 } 00083 }