Main Page   Packages   Class Hierarchy   Alphabetical List   Compound List   File List   Compound Members  

HashSet.java

00001 package ca.mcgill.sable.util;
00002 
00003 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
00004  * SableUtil, a clean room implementation of the Collection API.     *
00005  * Copyright (C) 1997, 1998 Raja Vallee-Rai (kor@sable.mcgill.ca).   *
00006  * All rights reserved.                                              *
00007  *                                                                   *
00008  * This work was done as a project of the Sable Research Group,      *
00009  * School of Computer Science, McGill University, Canada             *
00010  * (http://www.sable.mcgill.ca/).  It is understood that any         *
00011  * modification not identified as such is not covered by the         *
00012  * preceding statement.                                              *
00013  *                                                                   *
00014  * This work is free software; you can redistribute it and/or        *
00015  * modify it under the terms of the GNU Library General Public       *
00016  * License as published by the Free Software Foundation; either      *
00017  * version 2 of the License, or (at your option) any later version.  *
00018  *                                                                   *
00019  * This work is distributed in the hope that it will be useful,      *
00020  * but WITHOUT ANY WARRANTY; without even the implied warranty of    *
00021  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU *
00022  * Library General Public License for more details.                  *
00023  *                                                                   *
00024  * You should have received a copy of the GNU Library General Public *
00025  * License along with this library; if not, write to the             *
00026  * Free Software Foundation, Inc., 59 Temple Place - Suite 330,      *
00027  * Boston, MA  02111-1307, USA.                                      *
00028  *                                                                   *
00029  * To submit a bug report, send a comment, or get the latest news on *
00030  * this project and other Sable Research Group projects, please      *
00031  * visit the web site: http://www.sable.mcgill.ca/                   *
00032  * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
00033 
00034 /*
00035  Reference Version
00036  -----------------
00037  This is the latest official version on which this file is based.
00038  The reference version is: $SableUtilVersion: 1.11 $
00039 
00040  Change History
00041  --------------
00042  A) Notes:
00043 
00044  Please use the following template.  Most recent changes should
00045  appear at the top of the list.
00046 
00047  - Modified on [date (March 1, 1900)] by [name]. [(*) if appropriate]
00048    [description of modification].
00049 
00050  Any Modification flagged with "(*)" was done as a project of the
00051  Sable Research Group, School of Computer Science,
00052  McGill University, Canada (http://www.sable.mcgill.ca/).
00053 
00054  You should add your copyright, using the following template, at
00055  the top of this file, along with other copyrights.
00056 
00057  *                                                                   *
00058  * Modifications by [name] are                                       *
00059  * Copyright (C) [year(s)] [your name (or company)].  All rights     *
00060  * reserved.                                                         *
00061  *                                                                   *
00062 
00063  B) Changes:
00064 
00065  - Modified on July 21, 1998 by Raja Vallee-Rai (kor@sable.mcgill.ca). (*)
00066    Using HashMap.
00067 
00068  - Modified on June 15, 1998 by Raja Vallee-Rai (kor@sable.mcgill.ca). (*)
00069    First release of this file.
00070 
00071 */
00072 
00073 /**
00074  * Provides an implementation of the Set object using java.util.Hashtable.
00075  *
00076  * @author: Raja Vallee-Rai
00077  */
00078 
00079 public class HashSet extends AbstractSet
00080 {
00081     HashMap table;
00082 
00083     public HashSet()
00084     {
00085         table = new HashMap();
00086     }
00087     /**
00088      * Create a set which contains the given elements.
00089      */
00090 
00091     public HashSet(Object[] elements)
00092     {
00093         table = new HashMap();
00094 
00095         for(int i = 0; i < elements.length; i++)
00096             add(elements[i]);
00097     }
00098       public HashSet(int cap)
00099     {
00100         table = new HashMap(cap);
00101     }
00102     public HashSet(int cap, float load)
00103     {
00104         table = new HashMap(cap, load);
00105     }
00106     public boolean add(Object obj)
00107     {
00108         if(!table.containsKey(obj))
00109         {
00110             table.put(obj, obj);
00111             return true;
00112         }
00113         else
00114             return false;
00115     }
00116     public void clear()
00117     {
00118         table.clear();
00119     }
00120     public boolean contains(Object obj)
00121     {
00122         return table.containsKey(obj);
00123     }
00124     public boolean isEmpty()
00125     {
00126         return table.isEmpty();
00127     }
00128     public Iterator iterator()
00129     {
00130         return table.values().iterator();
00131     }
00132     public boolean remove(Object obj)
00133     {
00134         if(!table.containsKey(obj))
00135         {
00136             return false;
00137         }
00138         else {
00139             table.remove(obj);
00140             return true;
00141         }
00142     }
00143     public int size()
00144     {
00145         return table.size();
00146     }
00147 }

Generated at Thu Feb 7 06:46:10 2002 for Bandera by doxygen1.2.10 written by Dimitri van Heesch, © 1997-2001