X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=src%2Fedu%2Fberkeley%2Fsbp%2Futil%2FFastSet.java;h=88475e238b5163dce100ad973f74bcea85c94657;hb=8ed318cb9c9f27861adf519522cbe9d95f094dab;hp=b94613e7a92cb63a8ac83b7ae5413a0c59ddf3e3;hpb=f33c05adc5aa3dd324c5352cdbd6f4b55359acad;p=sbp.git diff --git a/src/edu/berkeley/sbp/util/FastSet.java b/src/edu/berkeley/sbp/util/FastSet.java index b94613e..88475e2 100644 --- a/src/edu/berkeley/sbp/util/FastSet.java +++ b/src/edu/berkeley/sbp/util/FastSet.java @@ -1,7 +1,9 @@ +// Copyright 2006 all rights reserved; see LICENSE file for BSD-style license + package edu.berkeley.sbp.util; import java.util.*; -public /*final*/ class FastSet implements Iterator, Iterable { +public /*final*/ class FastSet implements Iterator, Iterable, Visitable { public static final int INITIAL_SIZE = 8; @@ -28,6 +30,25 @@ public /*final*/ class FastSet implements Iterator, Iterable { for(T t : s) array[size++] = t; } + public void remove(T t) { + if (only != null) { + if (only==t) only=null; + return; + } + boolean found = false; + for(int j=0; j void visit(Invokable ivbc, B b) { + if (only!=null) ivbc.invoke(only, b); + else for(int j=0; j