// Copyright 2017 The Bazel Authors. All rights reserved. // // 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 com.google.devtools.build.skyframe; import com.google.common.base.MoreObjects; import com.google.common.collect.Iterators; import java.util.Arrays; import java.util.Collection; import java.util.Iterator; /** * Result of {@link EvaluableGraph#analyzeDepsDoneness}: Equivalent to an {@code * Optional<Collection<SkyKey>>} but without the overhead of the wrapper {@code Optional}. */ public class DepsReport implements Collection<SkyKey> { public static final DepsReport NO_INFORMATION = new DepsReport(-1, null); private final int size; /** Note that this array may have trailing null elements past {@link #size}. */ private final SkyKey[] arr; private DepsReport(int size, SkyKey[] arr) { this.size = size; this.arr = arr; } boolean hasInformation() { return arr != null; } @Override public int size() { return size; } @Override public boolean isEmpty() { return size == 0; } @Override public Iterator<SkyKey> iterator() { return Iterators.limit(Iterators.forArray(arr), size); } private UnsupportedOperationException throwUnsupported() { throw new UnsupportedOperationException(this.toString()); } @Override public boolean contains(Object o) { throw throwUnsupported(); } @Override public Object[] toArray() { throw throwUnsupported(); } @Override public <T> T[] toArray(T[] a) { throw throwUnsupported(); } @Override public boolean add(SkyKey skyKey) { throw throwUnsupported(); } @Override public boolean remove(Object o) { throw throwUnsupported(); } @Override public boolean containsAll(Collection<?> c) { throw throwUnsupported(); } @Override public boolean addAll(Collection<? extends SkyKey> c) { throw throwUnsupported(); } @Override public boolean removeAll(Collection<?> c) { throw throwUnsupported(); } @Override public boolean retainAll(Collection<?> c) { throw throwUnsupported(); } @Override public void clear() { throw throwUnsupported(); } @Override public String toString() { return MoreObjects.toStringHelper(this) .add("size", size) .add("arr", Arrays.toString(arr)) .toString(); } /** Builder for {@link DepsReport}. */ public static class Builder { private int size = 0; private final SkyKey[] arr; public Builder(int maxSize) { arr = new SkyKey[maxSize]; } public void add(SkyKey key) { if (size >= arr.length) { throw new IllegalStateException("Too many adds: " + key + ", " + this); } arr[size] = key; size++; } public DepsReport build() { return new DepsReport(size, arr); } @Override public String toString() { return MoreObjects.toStringHelper(this) .add("size", size) .add("arr", Arrays.toString(arr)) .toString(); } } }