/*
* This file is part of SpoutcraftPlugin.
*
* Copyright (c) 2011 SpoutcraftDev <http://spoutcraft.org//>
* SpoutcraftPlugin is licensed under the GNU Lesser General Public License.
*
* SpoutcraftPlugin 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 3 of the License, or
* (at your option) any later version.
*
* SpoutcraftPlugin 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 Lesser 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, see <http://www.gnu.org/licenses/>.
*/
package org.getspout.spoutapi.util.map;
import gnu.trove.TDoubleCollection;
import gnu.trove.iterator.TLongDoubleIterator;
import gnu.trove.map.hash.TLongDoubleHashMap;
import gnu.trove.set.TLongSet;
/**
* A simplistic map that supports a pair of integers for keys, using a trove long double hashmap in the backend.
*/
public class TIntPairDoubleHashMap {
private TLongDoubleHashMap map;
public TIntPairDoubleHashMap() {
map = new TLongDoubleHashMap(100);
}
public TIntPairDoubleHashMap(int capacity) {
map = new TLongDoubleHashMap(capacity);
}
public double put(int key1, int key2, double value) {
long key = (((long)key1)<<32) | (((long)key2) & 0xFFFFFFFFL);
return map.put(key, value);
}
public double get(int key1, int key2) {
long key = (((long)key1)<<32) | (((long)key2) & 0xFFFFFFFFL);
return map.get(key);
}
public boolean containsKey(int key1, int key2) {
long key = (((long)key1)<<32) | (((long)key2) & 0xFFFFFFFFL);
return map.containsKey(key);
}
public void clear() {
map.clear();
}
public boolean containsValue(double val) {
return map.containsValue(val);
}
public boolean increment(int key1, int key2) {
long key = (((long)key1)<<32) | (((long)key2) & 0xFFFFFFFFL);
return map.increment(key);
}
public boolean isEmpty() {
return map.isEmpty();
}
public TLongDoubleIterator iterator() {
return map.iterator();
}
public TLongSet keySet() {
return map.keySet();
}
public long[] keys() {
return map.keys();
}
public double remove(int key1, int key2) {
long key = (((long)key1)<<32) | (((long)key2) & 0xFFFFFFFFL);
return map.remove(key);
}
public int size() {
return map.size();
}
public TDoubleCollection valueCollection() {
return map.valueCollection();
}
public double[] values() {
return map.values();
}
}