blob: 3de4fca081a1264094bcf7bf9d25dadbf928e66a [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.lib.starlarkbuildapi;
import com.google.devtools.build.docgen.annot.DocCategory;
import com.google.devtools.build.docgen.annot.StarlarkConstructor;
import com.google.devtools.build.lib.starlarkbuildapi.core.ProviderApi;
import com.google.devtools.build.lib.starlarkbuildapi.core.StructApi;
import java.util.List;
import java.util.Map;
import net.starlark.java.annot.Param;
import net.starlark.java.annot.ParamType;
import net.starlark.java.annot.StarlarkBuiltin;
import net.starlark.java.annot.StarlarkMethod;
import net.starlark.java.eval.Dict;
import net.starlark.java.eval.EvalException;
import net.starlark.java.eval.Sequence;
/**
* Provider containing any additional environment variables for use when running executables, either
* in test actions or when executed via the run command.
*/
@StarlarkBuiltin(
name = "RunEnvironmentInfo",
category = DocCategory.PROVIDER,
doc =
"A provider that can be returned from executable rules to control the environment in"
+ " which their executable is executed.")
public interface RunEnvironmentInfoApi extends StructApi {
@StarlarkMethod(
name = "environment",
doc =
"A map of string keys and values that represent environment variables and their values."
+ " These will be made available when the target that returns this provider is"
+ " executed, either as a test or via the run command.",
structField = true)
Map<String, String> getEnvironment();
@StarlarkMethod(
name = "inherited_environment",
doc =
"A sequence of names of environment variables. These variables are made available with"
+ " their current value taken from the shell environment when the target that returns"
+ " this provider is executed, either as a test or via the run command. If a variable"
+ " is contained in both <code>environment</code> and"
+ " <code>inherited_environment</code>, the value inherited from the shell"
+ " environment will take precedence if set.",
structField = true)
List<String> getInheritedEnvironment();
/** Provider for {@link RunEnvironmentInfoApi}. */
@StarlarkBuiltin(name = "Provider", category = DocCategory.PROVIDER, documented = false, doc = "")
interface RunEnvironmentInfoApiProvider extends ProviderApi {
@StarlarkMethod(
name = "RunEnvironmentInfo",
doc = "",
documented = false,
parameters = {
@Param(
name = "environment",
defaultValue = "{}",
named = true,
positional = true,
doc =
"A map of string keys and values that represent environment variables and their"
+ " values. These will be made available when the target that returns this"
+ " provider is executed, either as a test or via the run command."),
@Param(
name = "inherited_environment",
allowedTypes = {@ParamType(type = Sequence.class, generic1 = String.class)},
defaultValue = "[]",
named = true,
positional = true,
doc =
"A sequence of names of environment variables. These variables are made "
+ " available with their current value taken from the shell environment"
+ " when the target that returns this provider is executed, either as a"
+ " test or via the run command. If a variable is contained in both <code>"
+ "environment</code> and <code>inherited_environment</code>, the value"
+ " inherited from the shell environment will take precedence if set.")
},
selfCall = true)
@StarlarkConstructor
RunEnvironmentInfoApi constructor(
Dict<?, ?> environment, // <String, String> expected
Sequence<?> inheritedEnvironment /* <String> expected */)
throws EvalException;
}
}