|  | // 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(); | 
|  | } | 
|  | } | 
|  | } |