00001 /* 00002 * (c) copyright 2008, Technische Universitaet Graz and Technische Universitaet Wien 00003 * 00004 * This file is part of jdiagengine. 00005 * 00006 * jdiagengine is free software: you can redistribute it and/or modify 00007 * it under the terms of the GNU General Public License as published by 00008 * the Free Software Foundation, either version 3 of the License, or 00009 * (at your option) any later version. 00010 * 00011 * jdiagengine is distributed in the hope that it will be useful, 00012 * but WITHOUT ANY WARRANTY; without even the implied warranty of 00013 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00014 * GNU General Public License for more details. 00015 * You should have received a copy of the GNU General Public License 00016 * along with jdiagengine. If not, see <http://www.gnu.org/licenses/>. 00017 * 00018 * Authors: Joerg Weber, Franz Wotawa 00019 * Contact: jweber@ist.tugraz.at (preferred), or fwotawa@ist.tugraz.at 00020 * 00021 */ 00022 00023 00024 package dfengine; 00025 00026 import java.util.*; 00027 00028 import utils.*; 00029 00030 00031 00032 public class ConflictSets { 00033 00034 protected ArrayList csets = new ArrayList(); 00035 00036 public void add(ConflictSet cs) { 00037 assert(cs.size() > 0); 00038 00039 cs.subst(Mode.MODE_AB, Mode.MODE_IF); // normalization: AB -> IF 00040 csets.add(cs); 00041 } 00042 00043 public Iterator iterator() { 00044 return csets.iterator(); 00045 } 00046 00047 public ConflictSet conflictsWith(ModeAssignment ma) { 00048 Iterator itCS = csets.iterator(); 00049 while (itCS.hasNext()) { 00050 ConflictSet cs = (ConflictSet)itCS.next(); 00051 if (cs.conflictsWith(ma)) return cs; 00052 } 00053 00054 return null; 00055 } 00056 00057 }