/*
* 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.TLongCollection;
import gnu.trove.iterator.TLongLongIterator;
import gnu.trove.map.hash.TLongLongHashMap;
import gnu.trove.set.TLongSet;
/**
* A simplistic map that supports a pair of integers for keys, using a trove long long hashmap in the backend.
*/
public class TIntPairLongHashMap {
private TLongLongHashMap map;
public TIntPairLongHashMap() {
map = new TLongLongHashMap(100);
}
public TIntPairLongHashMap(int capacity) {
map = new TLongLongHashMap(capacity);
}
public long put(int key1, int key2, long value) {
long key = (((long)key1)<<32) | (((long)key2) & 0xFFFFFFFFL);
return map.put(key, value);
}
public long 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(long 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 TLongLongIterator iterator() {
return map.iterator();
}
public TLongSet keySet() {
return map.keySet();
}
public long[] keys() {
return map.keys();
}
public long remove(int key1, int key2) {
long key = (((long)key1)<<32) | (((long)key2) & 0xFFFFFFFFL);
return map.remove(key);
}
public int size() {
return map.size();
}
public TLongCollection valueCollection() {
return map.valueCollection();
}
public long[] values() {
return map.values();
}
}