--- /dev/null
+/*
+ * (C) Copyright 2016 Pantheon Technologies, s.r.o. and others.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.opendaylight.yangtools.triemap;
+
+import static com.google.common.base.Preconditions.checkNotNull;
+
+import java.util.AbstractSet;
+import java.util.Collection;
+
+/**
+ * Abstract base class for key set views of a TrieMap
+ *
+ * @author Robert Varga
+ *
+ * @param <K> the type of keys
+ */
+abstract class AbstractKeySet<K> extends AbstractSet<K> {
+ private final TrieMap<K, ?> map;
+
+ AbstractKeySet(final TrieMap<K, ?> map) {
+ this.map = checkNotNull(map);
+ }
+
+ final TrieMap<K, ?> map() {
+ return map;
+ }
+
+ @Override
+ public final boolean add(final K e) {
+ throw new UnsupportedOperationException();
+ }
+
+ @Override
+ public final boolean addAll(final Collection<? extends K> c) {
+ throw new UnsupportedOperationException();
+ }
+
+ @Override
+ public final boolean contains(final Object o) {
+ return map.containsKey(o);
+ }
+
+ @Override
+ public final boolean isEmpty() {
+ return map.isEmpty();
+ }
+
+ @Override
+ public final int size() {
+ return map.size();
+ }
+}
--- /dev/null
+/*
+ * (C) Copyright 2016 Pantheon Technologies, s.r.o. and others.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.opendaylight.yangtools.triemap;
+
+import static org.opendaylight.yangtools.triemap.ImmutableTrieMap.unsupported;
+
+import com.google.common.collect.Iterators;
+import java.util.Collection;
+import java.util.Iterator;
+import java.util.Map.Entry;
+
+/**
+ * An immutable view of a TrieMap's key set.
+ *
+ * @author Robert Varga
+ *
+ * @param <K> the type of keys
+ */
+final class ImmutableKeySet<K> extends AbstractKeySet<K> {
+ ImmutableKeySet(final TrieMap<K, ?> map) {
+ super(map);
+ }
+
+ @Override
+ public Iterator<K> iterator() {
+ return Iterators.transform(map().immutableIterator(), Entry::getKey);
+ }
+
+ @Override
+ public void clear() {
+ throw unsupported();
+ }
+
+ @Override
+ public boolean remove(final Object o) {
+ throw unsupported();
+ }
+ @Override
+ public boolean retainAll(final Collection<?> c) {
+ throw unsupported();
+ }
+
+ @Override
+ public boolean removeAll(final Collection<?> c) {
+ throw unsupported();
+ }
+}
return new ImmutableEntrySet<>(this);
}
+ @Override
+ ImmutableKeySet<K> createKeySet() {
+ return new ImmutableKeySet<>(this);
+ }
+
@Override
boolean isReadOnly() {
return true;
--- /dev/null
+/*
+ * (C) Copyright 2016 Pantheon Technologies, s.r.o. and others.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.opendaylight.yangtools.triemap;
+
+import java.util.Iterator;
+
+/**
+ * A mutable view of a TrieMap's key set.
+ *
+ * @author Robert Varga
+ *
+ * @param <K> the type of keys
+ */
+final class MutableKeySet<K> extends AbstractKeySet<K> {
+ MutableKeySet(final MutableTrieMap<K, ?> map) {
+ super(map);
+ }
+
+ @Override
+ public Iterator<K> iterator() {
+ final AbstractIterator<K, ?> itr = map().iterator();
+ return new Iterator<K>() {
+ @Override
+ public boolean hasNext() {
+ return itr.hasNext();
+ }
+
+ @Override
+ public K next() {
+ return itr.next().getKey();
+ }
+
+ @Override
+ public void remove() {
+ itr.remove();
+ }
+ };
+ }
+
+ @Override
+ public void clear() {
+ map().clear();
+ }
+
+ @Override
+ public boolean remove(final Object o) {
+ return map().remove(o) != null;
+ }
+}
return new MutableEntrySet<>(this);
}
+ @Override
+ MutableKeySet<K> createKeySet() {
+ return new MutableKeySet<>(this);
+ }
+
@Override
MutableIterator<K, V> iterator() {
return new MutableIterator<>(this);
private final Equivalence<? super K> equiv;
private AbstractEntrySet<K, V> entrySet;
+ private AbstractKeySet<K> keySet;
TrieMap(final Equivalence<? super K> equiv) {
this.equiv = equiv;
return ret;
}
+ @Override
+ public final Set<K> keySet() {
+ AbstractKeySet<K> ret = keySet;
+ if (ret == null) {
+ keySet = ret = createKeySet();
+ }
+ return ret;
+ }
+
@Override
public final V get(final Object key) {
@SuppressWarnings("unchecked")
abstract AbstractEntrySet<K, V> createEntrySet();
+ abstract AbstractKeySet<K> createKeySet();
+
abstract boolean isReadOnly();
abstract INode<K, V> RDCSS_READ_ROOT(boolean abort);