|  | // 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; | 
|  |  | 
|  | 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.skylarkinterface.SkylarkValue; | 
|  | import com.google.devtools.build.lib.syntax.EvalException; | 
|  | import com.google.devtools.build.lib.syntax.SkylarkDict; | 
|  | import com.google.devtools.build.lib.syntax.SkylarkList; | 
|  | import com.google.devtools.build.lib.syntax.SkylarkNestedSet; | 
|  | import java.io.IOException; | 
|  |  | 
|  | /** Interface for actions in Skylark. */ | 
|  | @SkylarkModule( | 
|  | name = "Action", | 
|  | category = SkylarkModuleCategory.BUILTIN, | 
|  | doc = | 
|  | "An action created during rule analysis." | 
|  | + "<p>This object is visible for the purpose of testing, and may be obtained from an " | 
|  | + "<a href=\"globals.html#Actions\">Actions</a> provider. It is normally not necessary " | 
|  | + "to access <code>Action</code> objects or their fields within a rule's " | 
|  | + "implementation function. You may instead want to see the " | 
|  | + "<a href='../rules.$DOC_EXT#actions'>Rules page</a> for a general discussion of how " | 
|  | + "to use actions when defining custom rules, or the <a href='actions.html'>API " | 
|  | + "reference</a> for creating actions." | 
|  | + "<p>Some fields of this object are only applicable for certain kinds of actions. " | 
|  | + "Fields that are inapplicable are set to <code>None</code>.") | 
|  | public interface ActionApi extends SkylarkValue { | 
|  |  | 
|  | @SkylarkCallable( | 
|  | name = "mnemonic", | 
|  | structField = true, | 
|  | doc = "The mnemonic for this action." | 
|  | ) | 
|  | public abstract String getMnemonic(); | 
|  |  | 
|  | @SkylarkCallable( | 
|  | name = "inputs", | 
|  | doc = "A set of the input files of this action.", | 
|  | structField = true) | 
|  | public SkylarkNestedSet getSkylarkInputs(); | 
|  |  | 
|  | @SkylarkCallable( | 
|  | name = "outputs", | 
|  | doc = "A set of the output files of this action.", | 
|  | structField = true) | 
|  | public SkylarkNestedSet getSkylarkOutputs(); | 
|  |  | 
|  | @SkylarkCallable( | 
|  | name = "argv", | 
|  | doc = | 
|  | "For actions created by <a href=\"actions.html#run\">ctx.actions.run()</a> " | 
|  | + "or <a href=\"actions.html#run_shell\">ctx.actions.run_shell()</a>  an immutable " | 
|  | + "list of the arguments for the command line to be executed. Note that " | 
|  | + "for shell actions the first two arguments will be the shell path " | 
|  | + "and <code>\"-c\"</code>.", | 
|  | structField = true, | 
|  | allowReturnNones = true | 
|  | ) | 
|  | public SkylarkList<String> getSkylarkArgv() throws EvalException; | 
|  |  | 
|  | @SkylarkCallable( | 
|  | name = "content", | 
|  | doc = | 
|  | "For actions created by <a href=\"actions.html#write\">ctx.actions.write()</a> or " | 
|  | + "<a href=\"actions.html#expand_template\">ctx.actions.expand_template()</a>," | 
|  | + " the contents of the file to be written.", | 
|  | structField = true, | 
|  | allowReturnNones = true) | 
|  | public String getSkylarkContent() throws IOException; | 
|  |  | 
|  | @SkylarkCallable( | 
|  | name = "substitutions", | 
|  | doc = | 
|  | "For actions created by " | 
|  | + "<a href=\"actions.html#expand_template\">ctx.actions.expand_template()</a>," | 
|  | + " an immutable dict holding the substitution mapping.", | 
|  | structField = true, | 
|  | allowReturnNones = true) | 
|  | public SkylarkDict<String, String> getSkylarkSubstitutions(); | 
|  |  | 
|  | @SkylarkCallable( | 
|  | name = "env", | 
|  | structField = true, | 
|  | doc = | 
|  | "The 'fixed' environment variables for this action. This includes only environment " | 
|  | + "settings which are explicitly set by the action definition, and thus omits settings " | 
|  | + "which are only pre-set in the execution environment.") | 
|  | public SkylarkDict<String, String> getEnv(); | 
|  | } |