// Copyright 2014 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.Supplier; import com.google.devtools.build.lib.concurrent.ThreadSafety; /** * Receiver to inform callers which values have been invalidated. Values may be invalidated and then * re-validated if they have been found not to be changed. */ @ThreadSafety.ThreadSafe public interface EvaluationProgressReceiver { /** * New state of the value entry after evaluation. */ enum EvaluationState { /** The value was successfully re-evaluated. */ BUILT, /** The value is clean or re-validated. */ CLEAN, } /** * New state of the value entry after invalidation. */ enum InvalidationState { /** The value is dirty, although it might get re-validated again. */ DIRTY, /** The value is dirty and got deleted, cannot get re-validated again. */ DELETED, } /** * Notifies that the node named by {@code key} has been invalidated. * *

{@code state} indicates the new state of the value. * *

May be called concurrently from multiple threads, possibly with the same {@code key}. */ void invalidated(SkyKey skyKey, InvalidationState state); /** * Notifies that {@code skyKey} is about to get queued for evaluation. * *

Note that we don't guarantee that it actually got enqueued or will, only that if * everything "goes well" (e.g. no interrupts happen) it will. * *

This guarantee is intentionally vague to encourage writing robust implementations. */ void enqueueing(SkyKey skyKey); /** * Notifies that {@code skyFunction.compute(skyKey, ...)} has just been called, for some * appropriate {@link SkyFunction} {@code skyFunction}. * *

Notably, this includes {@link SkyFunction#compute} calls due to Skyframe restarts. */ void computed(SkyKey skyKey, long elapsedTimeNanos); /** * Notifies that the node for {@code skyKey} has been evaluated. * *

{@code state} indicates the new state of the node. * *

If the value builder threw an error when building this node, then * {@code valueSupplier.get()} evaluates to null. */ void evaluated(SkyKey skyKey, Supplier valueSupplier, EvaluationState state); }