Java tutorial
// 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.lib.skyframe; import com.google.common.annotations.VisibleForTesting; import com.google.common.collect.ImmutableList; import com.google.common.collect.Iterables; import com.google.devtools.build.lib.actions.ActionAnalysisMetadata; import com.google.devtools.build.lib.actions.Artifact; import com.google.devtools.build.lib.analysis.ConfiguredTarget; import com.google.devtools.build.lib.analysis.config.BuildConfiguration; import com.google.devtools.build.lib.cmdline.Label; import com.google.devtools.build.lib.collect.nestedset.NestedSet; import com.google.devtools.build.lib.concurrent.ThreadSafety.Immutable; import com.google.devtools.build.lib.concurrent.ThreadSafety.ThreadSafe; import com.google.devtools.build.lib.packages.Package; import com.google.devtools.build.lib.util.Preconditions; import com.google.devtools.build.skyframe.SkyKey; import java.util.Map; import javax.annotation.Nullable; /** * A configured target in the context of a Skyframe graph. */ @Immutable @ThreadSafe @VisibleForTesting public final class ConfiguredTargetValue extends ActionLookupValue { // These variables are only non-final because they may be clear()ed to save memory. They are null // only after they are cleared. @Nullable private ConfiguredTarget configuredTarget; private final NestedSet<Package> transitivePackages; ConfiguredTargetValue(ConfiguredTarget configuredTarget, Map<Artifact, ActionAnalysisMetadata> generatingActionMap, NestedSet<Package> transitivePackages) { super(generatingActionMap); this.configuredTarget = configuredTarget; this.transitivePackages = transitivePackages; } @VisibleForTesting public ConfiguredTarget getConfiguredTarget() { Preconditions.checkNotNull(configuredTarget); return configuredTarget; } @VisibleForTesting public Iterable<ActionAnalysisMetadata> getActions() { Preconditions.checkNotNull(configuredTarget); return generatingActionMap.values(); } public NestedSet<Package> getTransitivePackages() { return transitivePackages; } /** * Clears configured target data from this value, leaving only the artifact->generating action * map. * * <p>Should only be used when user specifies --discard_analysis_cache. Must be called at most * once per value, after which {@link #getConfiguredTarget} and {@link #getActions} cannot be * called. */ public void clear() { Preconditions.checkNotNull(configuredTarget); configuredTarget = null; } @VisibleForTesting public static SkyKey key(Label label, BuildConfiguration configuration) { return key(new ConfiguredTargetKey(label, configuration)); } static ImmutableList<SkyKey> keys(Iterable<ConfiguredTargetKey> lacs) { ImmutableList.Builder<SkyKey> keys = ImmutableList.builder(); for (ConfiguredTargetKey lac : lacs) { keys.add(key(lac)); } return keys.build(); } /** * Returns a label of ConfiguredTargetValue. */ @ThreadSafe static Label extractLabel(SkyKey value) { Object valueName = value.argument(); Preconditions.checkState(valueName instanceof ConfiguredTargetKey, valueName); return ((ConfiguredTargetKey) valueName).getLabel(); } @Override public String toString() { return "ConfiguredTargetValue: " + configuredTarget + ", actions: " + (configuredTarget == null ? null : Iterables.toString(getActions())); } }