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 }