blob: 643ee3591b9b5bb5dc7c520cec17f58acff7f833 [file] [log] [blame]
// 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.actions;
import com.google.auto.value.AutoValue;
import com.google.common.annotations.VisibleForTesting;
import com.google.common.collect.ImmutableList;
import com.google.common.collect.ImmutableMap;
import com.google.devtools.build.lib.analysis.config.BuildConfigurationInfo;
import com.google.devtools.build.lib.analysis.platform.PlatformInfo;
import com.google.devtools.build.lib.cmdline.Label;
import com.google.devtools.build.lib.concurrent.ThreadSafety.Immutable;
import com.google.devtools.build.lib.packages.AspectDescriptor;
import com.google.devtools.build.lib.skyframe.serialization.autocodec.SerializationConstant;
import javax.annotation.Nullable;
import net.starlark.java.syntax.Location;
/**
* Contains metadata used for reporting the progress and status of an action.
*
* <p>Morally an action's owner is the RuleConfiguredTarget instance responsible for creating it,
* but to avoid storing heavyweight analysis objects in actions, and to avoid coupling between the
* analysis and actions packages, the RuleConfiguredTarget provides an instance of this class.
*/
@Immutable
public abstract class ActionOwner {
/** An action owner for special cases. Usage is strongly discouraged. */
@SerializationConstant
public static final ActionOwner SYSTEM_ACTION_OWNER =
createDummy(
/* label= */ null,
Location.BUILTIN,
/* targetKind= */ "empty target kind",
/* mnemonic= */ "system",
/* configurationChecksum= */ "system",
/* buildConfigurationEvent= */ null,
/* isToolConfiguration= */ false,
/* executionPlatform= */ null,
/* aspectDescriptors= */ ImmutableList.of(),
/* execProperties= */ ImmutableMap.of());
public static ActionOwner create(
@Nullable Label label,
Location location,
String targetKind,
BuildConfigurationInfo buildConfigurationValue,
@Nullable PlatformInfo executionPlatform,
ImmutableList<AspectDescriptor> aspectDescriptors,
ImmutableMap<String, String> execProperties) {
if (aspectDescriptors.isEmpty() && execProperties.isEmpty()) {
return LiteActionOwner.createInternal(
label, location, targetKind, buildConfigurationValue, executionPlatform);
} else {
return FullActionOwner.createInternal(
label,
location,
targetKind,
buildConfigurationValue,
executionPlatform,
aspectDescriptors,
execProperties);
}
}
@VisibleForTesting
public static ActionOwner createDummy(
@Nullable Label label,
Location location,
String targetKind,
String mnemonic,
String configurationChecksum,
@Nullable BuildConfigurationEvent buildConfigurationEvent,
boolean isToolConfiguration,
@Nullable PlatformInfo executionPlatform,
ImmutableList<AspectDescriptor> aspectDescriptors,
ImmutableMap<String, String> execProperties) {
return FullActionOwner.createInternal(
label,
location,
targetKind,
BuildConfigurationInfo.AutoBuildConfigurationInfo.create(
mnemonic, configurationChecksum, buildConfigurationEvent, isToolConfiguration),
executionPlatform,
aspectDescriptors,
execProperties);
}
/**
* Returns the label for this {@link ActionOwner}, or null if the {@link #SYSTEM_ACTION_OWNER}.
*/
@Nullable
public abstract Label getLabel();
/** Returns the location for this {@link ActionOwner}. */
public abstract Location getLocation();
/** Returns the target kind (rule class name) for this {@link ActionOwner}. */
public abstract String getTargetKind();
/** Returns {@link BuildConfigurationInfo} for this {@link ActionOwner}. */
public abstract BuildConfigurationInfo getBuildConfigurationInfo();
/** Returns the mnemonic for the configuration for this {@link ActionOwner}. */
public final String getMnemonic() {
return getBuildConfigurationInfo().getMnemonic();
}
/**
* Returns the short cache key for the configuration for this {@link ActionOwner}.
*
* <p>Special action owners that are not targets can return any string here. If the underlying
* configuration is null, this should return "null".
*/
public final String getConfigurationChecksum() {
return getBuildConfigurationInfo().checksum();
}
/**
* Return the {@link BuildConfigurationEvent} for this {@link ActionOwner}, if any, as it should
* be reported in the build event protocol.
*/
@Nullable
public final BuildConfigurationEvent getBuildConfigurationEvent() {
return getBuildConfigurationInfo().toBuildEvent();
}
/**
* Returns true when the {@link BuildConfigurationInfo} for this {@link ActionOwner} is a
* tool-related configuration.
*/
final boolean isBuildConfigurationForTool() {
return getBuildConfigurationInfo().isToolConfiguration();
}
/**
* Returns the {@link PlatformInfo} platform this action should be executed on. If the execution
* platform is {@code null}, then the host platform is assumed.
*/
@Nullable
public abstract PlatformInfo getExecutionPlatform();
public abstract ImmutableList<AspectDescriptor> getAspectDescriptors();
/** Returns a String to String map containing the execution properties of this action. */
@VisibleForTesting
public abstract ImmutableMap<String, String> getExecProperties();
/**
* Created when {@code aspectDescriptors} and {@code execProperties} are both empty.
*
* <p>{@link LiteActionOwner} is more likely to be created since both fields above are usually
* empty. This will save 8 bytes of memory for each {@link ActionOwner} instance compared to
* keeping both empty fields.
*/
@AutoValue
abstract static class LiteActionOwner extends ActionOwner {
static LiteActionOwner createInternal(
@Nullable Label label,
Location location,
String targetKind,
BuildConfigurationInfo buildConfigurationInfo,
@Nullable PlatformInfo executionPlatform) {
return new AutoValue_ActionOwner_LiteActionOwner(
label, location, targetKind, buildConfigurationInfo, executionPlatform);
}
@Override
public final ImmutableList<AspectDescriptor> getAspectDescriptors() {
return ImmutableList.of();
}
@Override
public final ImmutableMap<String, String> getExecProperties() {
return ImmutableMap.of();
}
}
/** Created when either {@code aspectDescriptors} or {@code execProperties} is not empty. */
@AutoValue
abstract static class FullActionOwner extends ActionOwner {
static FullActionOwner createInternal(
@Nullable Label label,
Location location,
String targetKind,
BuildConfigurationInfo buildConfigurationInfo,
@Nullable PlatformInfo executionPlatform,
ImmutableList<AspectDescriptor> aspectDescriptors,
ImmutableMap<String, String> execProperties) {
return new AutoValue_ActionOwner_FullActionOwner(
label,
location,
targetKind,
buildConfigurationInfo,
executionPlatform,
aspectDescriptors,
execProperties);
}
}
}