// $Id: GenAncestorClasses.java 41 2010-04-03 20:04:12Z marcusvnac $ // Copyright (c) 1996-2006 The Regents of the University of California. All // Rights Reserved. Permission to use, copy, modify, and distribute this // software and its documentation without fee, and without a written // agreement is hereby granted, provided that the above copyright notice // and this paragraph appear in all copies. This software program and // documentation are copyrighted by The Regents of the University of // California. The software program and documentation are supplied "AS // IS", without any accompanying services from The Regents. The Regents // does not warrant that the operation of the program will be // uninterrupted or error-free. The end-user understands that the program // was developed for research purposes and is advised not to rely // exclusively on the program for any reason. IN NO EVENT SHALL THE // UNIVERSITY OF CALIFORNIA BE LIABLE TO ANY PARTY FOR DIRECT, INDIRECT, // SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, INCLUDING LOST PROFITS, // ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN IF // THE UNIVERSITY OF CALIFORNIA HAS BEEN ADVISED OF THE POSSIBILITY OF // SUCH DAMAGE. THE UNIVERSITY OF CALIFORNIA SPECIFICALLY DISCLAIMS ANY // WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF // MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE // PROVIDED HEREUNDER IS ON AN "AS IS" BASIS, AND THE UNIVERSITY OF // CALIFORNIA HAS NO OBLIGATIONS TO PROVIDE MAINTENANCE, SUPPORT, // UPDATES, ENHANCEMENTS, OR MODIFICATIONS. package org.argouml.uml; import java.util.Collection; import java.util.Collections; import java.util.Enumeration; import java.util.HashSet; import java.util.Set; import org.argouml.model.Model; import org.tigris.gef.util.ChildGenerator; /** Utility class to generate the base classes of a class. It * recursively moves up the class hierarchy. But it does that in a * safe way that will not hang in case of cyclic inheritance. */ public class GenAncestorClasses implements ChildGenerator { /* * @see org.tigris.gef.util.ChildGenerator#gen(java.lang.Object) */ public Enumeration gen(Object cls) { Set res = new HashSet(); if (Model.getFacade().isAGeneralizableElement(cls)) { accumulateAncestors(cls, res); } return Collections.enumeration(res); } /** * @param cls the class (in fact any GeneralizableElement will do) * @param accum the accumulated list of generalizations */ public void accumulateAncestors(Object cls, Collection accum) { Collection gens = Model.getFacade().getGeneralizations(cls); if (gens == null) { return; } for (Object g : gens) { Object ge = Model.getFacade().getGeneral(g); if (!accum.contains(ge)) { accum.add(ge); accumulateAncestors(cls, accum); } } } }