blob: cc89c85c219a28b31f2983c42c80d2294b9b11f0 [file] [log] [blame]
// Copyright 2018 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.skylarkbuildapi.platform;
import com.google.devtools.build.lib.cmdline.Label;
import com.google.devtools.build.lib.skylarkbuildapi.StructApi;
import com.google.devtools.build.lib.skylarkinterface.SkylarkCallable;
import com.google.devtools.build.lib.skylarkinterface.SkylarkModule;
import com.google.devtools.build.lib.skylarkinterface.SkylarkModuleCategory;
import com.google.devtools.build.lib.syntax.StarlarkSemantics.FlagIdentifier;
/** Info object representing data about a specific platform. */
@SkylarkModule(
name = "PlatformInfo",
doc =
"Provides access to data about a specific platform. "
+ PlatformInfoApi.EXPERIMENTAL_WARNING,
category = SkylarkModuleCategory.PROVIDER)
public interface PlatformInfoApi<
ConstraintSettingInfoT extends ConstraintSettingInfoApi,
ConstraintValueInfoT extends ConstraintValueInfoApi>
extends StructApi {
static final String EXPERIMENTAL_WARNING =
"<i>Note: This API is experimental and may change at any time. It is disabled by default, "
+ "but may be enabled with <code>--experimental_platform_api</code></i>";
@SkylarkCallable(
name = "label",
doc = "The label of the target that created this platform.",
structField = true,
enableOnlyWithFlag = FlagIdentifier.EXPERIMENTAL_PLATFORM_API)
Label label();
@SkylarkCallable(
name = "constraints",
doc =
"The <a href=\"ConstraintValueInfo.html\">ConstraintValueInfo</a> instances that define "
+ "this platform.",
structField = true,
enableOnlyWithFlag = FlagIdentifier.EXPERIMENTAL_PLATFORM_API)
ConstraintCollectionApi<ConstraintSettingInfoT, ConstraintValueInfoT> constraints();
@SkylarkCallable(
name = "remoteExecutionProperties",
doc = "Properties that are available for the use of remote execution.",
structField = true,
enableOnlyWithFlag = FlagIdentifier.EXPERIMENTAL_PLATFORM_API)
String remoteExecutionProperties();
}