org.sirix.index.art.KeySet Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of sirix-core Show documentation
Show all versions of sirix-core Show documentation
SirixDB is a hybrid on-disk and in-memory document oriented, versioned database system. It has a lightweight buffer manager, stores everything in a huge persistent and durable tree and allows efficient reconstruction of every revision. Furthermore, SirixDB implements change tracking, diffing and supports time travel queries.
package org.sirix.index.art;
import java.util.*;
// implementation simply relays/delegates calls to backing map's methods
final class KeySet extends AbstractSet implements NavigableSet {
private final NavigableMap map;
KeySet(NavigableMap map) {
this.map = map;
}
// this KeySet can only be created either on ART or on one of it's subMaps
@Override
@SuppressWarnings("unchecked")
public Iterator iterator() {
if (map instanceof AdaptiveRadixTree)
return ((AdaptiveRadixTree) map).keyIterator();
else
return ((NavigableSubMap) map).keyIterator();
}
// this KeySet can only be created either on ART or on one of it's subMaps
@Override
@SuppressWarnings("unchecked")
public Iterator descendingIterator() {
if (map instanceof AdaptiveRadixTree)
return ((AdaptiveRadixTree) map).descendingKeyIterator();
else
return ((NavigableSubMap) map).descendingKeyIterator();
}
@Override
public int size() {
return map.size();
}
@Override
public boolean isEmpty() {
return map.isEmpty();
}
@Override
public boolean contains(Object o) {
return map.containsKey(o);
}
@Override
public void clear() {
map.clear();
}
@Override
public E lower(E e) {
return map.lowerKey(e);
}
@Override
public E floor(E e) {
return map.floorKey(e);
}
@Override
public E ceiling(E e) {
return map.ceilingKey(e);
}
@Override
public E higher(E e) {
return map.higherKey(e);
}
@Override
public E first() {
return map.firstKey();
}
@Override
public E last() {
return map.lastKey();
}
@Override
public Comparator super E> comparator() {
return map.comparator();
}
@Override
public E pollFirst() {
Map.Entry e = map.pollFirstEntry();
return (e == null) ? null : e.getKey();
}
@Override
public E pollLast() {
Map.Entry e = map.pollLastEntry();
return (e == null) ? null : e.getKey();
}
@Override
public boolean remove(Object o) {
int oldSize = size();
map.remove(o);
return size() != oldSize;
}
@Override
public NavigableSet subSet(E fromElement, boolean fromInclusive,
E toElement, boolean toInclusive) {
return new KeySet<>(map.subMap(fromElement, fromInclusive,
toElement, toInclusive));
}
@Override
public NavigableSet headSet(E toElement, boolean inclusive) {
return new KeySet<>(map.headMap(toElement, inclusive));
}
@Override
public NavigableSet tailSet(E fromElement, boolean inclusive) {
return new KeySet<>(map.tailMap(fromElement, inclusive));
}
@Override
public SortedSet subSet(E fromElement, E toElement) {
return subSet(fromElement, true, toElement, false);
}
@Override
public SortedSet headSet(E toElement) {
return headSet(toElement, false);
}
@Override
public SortedSet tailSet(E fromElement) {
return tailSet(fromElement, true);
}
@Override
public NavigableSet descendingSet() {
return new KeySet<>(map.descendingMap());
}
// TODO: implement Spliterator
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy