net.derquinse.common.collect.RegularImmutableHierarchy Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of derquinse-common-base Show documentation
Show all versions of derquinse-common-base Show documentation
Module containing support classes depending on Java SE 6, Guava 11 and Joda-Time 2.0
/*
* Copyright (C) the original author or authors.
*
* 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 net.derquinse.common.collect;
import static com.google.common.base.Preconditions.checkArgument;
import java.util.List;
import java.util.concurrent.ConcurrentMap;
import javax.annotation.Nullable;
import com.google.common.collect.ImmutableList;
import com.google.common.collect.ImmutableListMultimap;
import com.google.common.collect.ImmutableMap;
import com.google.common.collect.ImmutableSet;
import com.google.common.collect.MapMaker;
/**
* Implementation of {@link ImmutableHierarchy} with two or more levels.
* @author Andres Rodriguez
* @param Type of the elements in the hierarchy.
*/
final class RegularImmutableHierarchy extends ImmutableHierarchy {
private transient final ImmutableSet elements;
private final ImmutableList firstLevel;
private transient final ImmutableMap parents;
private final ImmutableListMultimap children;
/** Computed descendants. */
private transient final ConcurrentMap> descendants;
RegularImmutableHierarchy(ImmutableHierarchy.Builder builder) {
this.elements = ImmutableSet.copyOf(builder.getElements());
this.firstLevel = ImmutableList.copyOf(builder.getFirstLevel());
this.parents = ImmutableMap.copyOf(builder.getParents());
this.children = ImmutableListMultimap.copyOf(builder.getChildren());
// Incomplete integrity check
checkArgument(elements.size() == firstLevel.size() + children.size(), "Inconsistent hierarchy.");
this.descendants = new MapMaker().initialCapacity(this.elements.size()).makeMap();
}
@Override
public ImmutableSet elementSet() {
return elements;
}
/*
* (non-Javadoc)
* @see net.derquinse.common.collect.Hierarchy#getChildren(java.lang.Object)
*/
public List getChildren(@Nullable E element) {
if (element == null) {
return getFirstLevel();
}
checkMember(element);
return children.get(element);
}
/*
* (non-Javadoc)
* @see net.derquinse.common.collect.Hierarchy#getFirstLevel()
*/
public List getFirstLevel() {
return firstLevel;
}
/*
* (non-Javadoc)
* @see net.derquinse.common.collect.Hierarchy#getParent(java.lang.Object)
*/
public E getParent(E element) {
checkMember(element);
return parents.get(element);
}
/*
* (non-Javadoc)
* @see net.derquinse.common.collect.ImmutableHierarchy#getDescendants(java.lang.Object)
*/
ImmutableSet getMemberDescendants(E element) {
checkMember(element);
ImmutableSet set = descendants.get(element);
if (set != null) {
return set;
}
ImmutableSet.Builder b = ImmutableSet.builder();
for (E e : getChildren(element)) {
b.add(e);
b.addAll(getDescendants(e));
}
set = b.build();
descendants.put(element, set);
return set;
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy