]> gerrit.simantics Code Review - simantics/platform.git/blobdiff - bundles/org.simantics.scenegraph/src/gnu/trove/TIntHash.java
Migrated source code from Simantics SVN
[simantics/platform.git] / bundles / org.simantics.scenegraph / src / gnu / trove / TIntHash.java
diff --git a/bundles/org.simantics.scenegraph/src/gnu/trove/TIntHash.java b/bundles/org.simantics.scenegraph/src/gnu/trove/TIntHash.java
new file mode 100644 (file)
index 0000000..4720f0a
--- /dev/null
@@ -0,0 +1,285 @@
+///////////////////////////////////////////////////////////////////////////////
+// Copyright (c) 2001, Eric D. Friedman All Rights Reserved.
+//
+// This library is free software; you can redistribute it and/or
+// modify it under the terms of the GNU Lesser General Public
+// License as published by the Free Software Foundation; either
+// version 2.1 of the License, or (at your option) any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU Lesser General Public
+// License along with this program; if not, write to the Free Software
+// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
+///////////////////////////////////////////////////////////////////////////////
+
+package gnu.trove;
+
+//////////////////////////////////////////////////
+// THIS IS A GENERATED CLASS. DO NOT HAND EDIT! //
+//////////////////////////////////////////////////
+
+
+/**
+ * An open addressed hashing implementation for int primitives.
+ *
+ * Created: Sun Nov  4 08:56:06 2001
+ *
+ * @author Eric D. Friedman
+ * @version $Id: PHash.template,v 1.2 2007/06/29 22:39:46 robeden Exp $
+ */
+
+abstract public class TIntHash extends TPrimitiveHash implements TIntHashingStrategy {
+
+    /** the set of ints */
+    protected transient int[] _set;
+
+    /** strategy used to hash values in this collection */
+    protected TIntHashingStrategy _hashingStrategy;
+
+    /**
+     * Creates a new <code>TIntHash</code> instance with the default
+     * capacity and load factor.
+     */
+    public TIntHash() {
+        super();
+        this._hashingStrategy = this;
+    }
+
+    /**
+     * Creates a new <code>TIntHash</code> instance whose capacity
+     * is the next highest prime above <tt>initialCapacity + 1</tt>
+     * unless that value is already prime.
+     *
+     * @param initialCapacity an <code>int</code> value
+     */
+    public TIntHash(int initialCapacity) {
+        super(initialCapacity);
+        this._hashingStrategy = this;
+    }
+
+    /**
+     * Creates a new <code>TIntHash</code> instance with a prime
+     * value at or near the specified capacity and load factor.
+     *
+     * @param initialCapacity used to find a prime capacity for the table.
+     * @param loadFactor used to calculate the threshold over which
+     * rehashing takes place.
+     */
+    public TIntHash(int initialCapacity, float loadFactor) {
+        super(initialCapacity, loadFactor);
+        this._hashingStrategy = this;
+    }
+
+    /**
+     * Creates a new <code>TIntHash</code> instance with the default
+     * capacity and load factor.
+     * @param strategy used to compute hash codes and to compare keys.
+     */
+    public TIntHash(TIntHashingStrategy strategy) {
+        super();
+        this._hashingStrategy = strategy;
+    }
+
+    /**
+     * Creates a new <code>TIntHash</code> instance whose capacity
+     * is the next highest prime above <tt>initialCapacity + 1</tt>
+     * unless that value is already prime.
+     *
+     * @param initialCapacity an <code>int</code> value
+     * @param strategy used to compute hash codes and to compare keys.
+     */
+    public TIntHash(int initialCapacity, TIntHashingStrategy strategy) {
+        super(initialCapacity);
+        this._hashingStrategy = strategy;
+    }
+
+    /**
+     * Creates a new <code>TIntHash</code> instance with a prime
+     * value at or near the specified capacity and load factor.
+     *
+     * @param initialCapacity used to find a prime capacity for the table.
+     * @param loadFactor used to calculate the threshold over which
+     * rehashing takes place.
+     * @param strategy used to compute hash codes and to compare keys.
+     */
+    public TIntHash(int initialCapacity, float loadFactor, TIntHashingStrategy strategy) {
+        super(initialCapacity, loadFactor);
+        this._hashingStrategy = strategy;
+    }
+
+    /**
+     * @return a deep clone of this collection
+     */
+    public Object clone() {
+        TIntHash h = (TIntHash)super.clone();
+        h._set = (int[])this._set.clone();
+        return h;
+    }
+
+    /**
+     * initializes the hashtable to a prime capacity which is at least
+     * <tt>initialCapacity + 1</tt>.
+     *
+     * @param initialCapacity an <code>int</code> value
+     * @return the actual capacity chosen
+     */
+    protected int setUp(int initialCapacity) {
+        int capacity;
+
+        capacity = super.setUp(initialCapacity);
+        _set = new int[capacity];
+        return capacity;
+    }
+
+    /**
+     * Searches the set for <tt>val</tt>
+     *
+     * @param val an <code>int</code> value
+     * @return a <code>boolean</code> value
+     */
+    public boolean contains(int val) {
+        return index(val) >= 0;
+    }
+
+    /**
+     * Executes <tt>procedure</tt> for each element in the set.
+     *
+     * @param procedure a <code>TObjectProcedure</code> value
+     * @return false if the loop over the set terminated because
+     * the procedure returned false for some value.
+     */
+    public boolean forEach(TIntProcedure procedure) {
+        byte[] states = _states;
+        int[] set = _set;
+        for (int i = set.length; i-- > 0;) {
+            if (states[i] == FULL && ! procedure.execute(set[i])) {
+                return false;
+            }
+        }
+        return true;
+    }
+
+    /**
+     * Releases the element currently stored at <tt>index</tt>.
+     *
+     * @param index an <code>int</code> value
+     */
+    protected void removeAt(int index) {
+        _set[index] = (int)0;
+        super.removeAt(index);
+    }
+
+    /**
+     * Locates the index of <tt>val</tt>.
+     *
+     * @param val an <code>int</code> value
+     * @return the index of <tt>val</tt> or -1 if it isn't in the set.
+     */
+    protected int index(int val) {
+        int hash, probe, index, length;
+
+        final byte[] states = _states;
+        final int[] set = _set;
+        length = states.length;
+        hash = _hashingStrategy.computeHashCode(val) & 0x7fffffff;
+        index = hash % length;
+
+        if (states[index] != FREE &&
+            (states[index] == REMOVED || set[index] != val)) {
+            // see Knuth, p. 529
+            probe = 1 + (hash % (length - 2));
+
+            do {
+                index -= probe;
+                if (index < 0) {
+                    index += length;
+                }
+            } while (states[index] != FREE &&
+                     (states[index] == REMOVED || set[index] != val));
+        }
+
+        return states[index] == FREE ? -1 : index;
+    }
+
+    /**
+     * Locates the index at which <tt>val</tt> can be inserted.  if
+     * there is already a value equal()ing <tt>val</tt> in the set,
+     * returns that value as a negative integer.
+     *
+     * @param val an <code>int</code> value
+     * @return an <code>int</code> value
+     */
+    protected int insertionIndex(int val) {
+        int hash, probe, index, length;
+
+        final byte[] states = _states;
+        final int[] set = _set;
+        length = states.length;
+        hash = _hashingStrategy.computeHashCode(val) & 0x7fffffff;
+        index = hash % length;
+
+        if (states[index] == FREE) {
+            return index;       // empty, all done
+        } else if (states[index] == FULL && set[index] == val) {
+            return -index -1;   // already stored
+        } else {                // already FULL or REMOVED, must probe
+            // compute the double hash
+            probe = 1 + (hash % (length - 2));
+
+            // if the slot we landed on is FULL (but not removed), probe
+            // until we find an empty slot, a REMOVED slot, or an element
+            // equal to the one we are trying to insert.
+            // finding an empty slot means that the value is not present
+            // and that we should use that slot as the insertion point;
+            // finding a REMOVED slot means that we need to keep searching,
+            // however we want to remember the offset of that REMOVED slot
+            // so we can reuse it in case a "new" insertion (i.e. not an update)
+            // is possible.
+            // finding a matching value means that we've found that our desired
+            // key is already in the table
+
+            if (states[index] != REMOVED) {
+                               // starting at the natural offset, probe until we find an
+                               // offset that isn't full.
+                               do {
+                                       index -= probe;
+                                       if (index < 0) {
+                                               index += length;
+                                       }
+                               } while (states[index] == FULL && set[index] != val);
+            }
+
+            // if the index we found was removed: continue probing until we
+            // locate a free location or an element which equal()s the
+            // one we have.
+            if (states[index] == REMOVED) {
+                int firstRemoved = index;
+                while (states[index] != FREE &&
+                       (states[index] == REMOVED || set[index] != val)) {
+                    index -= probe;
+                    if (index < 0) {
+                        index += length;
+                    }
+                }
+                return states[index] == FULL ? -index -1 : firstRemoved;
+            }
+            // if it's full, the key is already stored
+            return states[index] == FULL ? -index -1 : index;
+        }
+    }
+
+    /**
+     * Default implementation of TIntHashingStrategy:
+     * delegates hashing to HashFunctions.hash(int).
+     *
+     * @param val the value to hash
+     * @return the hashcode.
+     */
+    public final int computeHashCode(int val) {
+        return HashFunctions.hash(val);
+    }
+} // TIntHash