blob: cdb3ab83ac51151d1b6beca95af33c54ea52c5e4 [file] [log] [blame]
// Copyright 2022 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.auto.value.AutoValue;
/**
* Encapsulates the two versions relevant to a {@link NodeEntry}: when it was last evaluated, and
* when its value last changed.
*/
public interface NodeVersion {
/**
* Returns the last version at which a node's value changed.
*
* <p>In {@link NodeEntry#setValue} it may be determined that the value being set is the same as
* the already-stored value. In that case, the last changed version will remain the same.
*/
Version lastChanged();
/**
* Returns the last version a {@link NodeEntry} was evaluated at, even if it re-evaluated to the
* same value.
*
* <p>When a child signals a node with the last version it was changed at in {@link
* NodeEntry#signalDep}, the node need not re-evaluate if the child's version is {@link
* Version#atMost} this version, even if {@link #lastChanged} is lower.
*/
Version lastEvaluated();
static NodeVersion of(Version lastChanged, Version lastEvaluated) {
if (lastChanged.equals(lastEvaluated)) {
return lastChanged;
}
return new AutoValue_NodeVersion_ChangePruned(lastChanged, lastEvaluated);
}
/**
* Basic implementation of {@link NodeVersion} for the case where {@link #lastChanged} and {@link
* #lastEvaluated} are different versions.
*/
@AutoValue
abstract class ChangePruned implements NodeVersion {}
}