aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/main/java/com/google/devtools/build/lib/analysis/skylark/SkylarkConfigurationField.java
diff options
context:
space:
mode:
authorGravatar cparsons <cparsons@google.com>2017-11-04 01:00:59 +0100
committerGravatar Damien Martin-Guillerez <dmarting@google.com>2017-11-06 20:20:21 +0100
commitcaceacd984a3f86b623ea726f4df36bd81998d25 (patch)
treefe7ec2dbd11dfdb10abc2994335c34972c26b77b /src/main/java/com/google/devtools/build/lib/analysis/skylark/SkylarkConfigurationField.java
parente8d32b7c922f65539b74357711d5ad6b70934115 (diff)
Expose late-bound-attributes to Skylark.
RELNOTES: Late-bound attributes are exposed to skylark. This is a new API (`configuration_field()`) to depend on certain configuration-defined targets from skylark rules. PiperOrigin-RevId: 174534104
Diffstat (limited to 'src/main/java/com/google/devtools/build/lib/analysis/skylark/SkylarkConfigurationField.java')
-rw-r--r--src/main/java/com/google/devtools/build/lib/analysis/skylark/SkylarkConfigurationField.java71
1 files changed, 71 insertions, 0 deletions
diff --git a/src/main/java/com/google/devtools/build/lib/analysis/skylark/SkylarkConfigurationField.java b/src/main/java/com/google/devtools/build/lib/analysis/skylark/SkylarkConfigurationField.java
new file mode 100644
index 0000000000..153751c318
--- /dev/null
+++ b/src/main/java/com/google/devtools/build/lib/analysis/skylark/SkylarkConfigurationField.java
@@ -0,0 +1,71 @@
+// Copyright 2017 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.analysis.skylark;
+
+import java.lang.annotation.ElementType;
+import java.lang.annotation.Retention;
+import java.lang.annotation.RetentionPolicy;
+import java.lang.annotation.Target;
+
+/**
+ * A marker interface for Java methods of Skylark-exposed configuration fragments which denote
+ * Skylark "configuration fields": late-bound attribute defaults that depend on configuration.
+ *
+ * <p>Methods annotated with this annotation have a few constraints:
+ * <ul>
+ * <li>The annotated method must be on a configuration fragment exposed to skylark.</li>
+ * <li>The method must have return type Label.</li>
+ * <li>The method must be public.</li>
+ * <li>The method must have zero arguments.</li>
+ * <li>The method must not throw exceptions.</li>
+ * </ul>
+ */
+// TODO(b/68817606): Verify the above constraints using annotation processing.
+@Target({ElementType.METHOD})
+@Retention(RetentionPolicy.RUNTIME)
+public @interface SkylarkConfigurationField {
+
+ /**
+ * Name of the configuration field, as exposed to Skylark.
+ */
+ String name();
+
+ /**
+ * The default label associated with this field, corresponding to the value of this configuration
+ * field with default command line flags.
+ *
+ * <p>If the default label is under the tools repository, omit the tools repository prefix
+ * from this default, but set {@link #defaultInToolRepository} to true.</p>
+ */
+ String defaultLabel();
+
+ /**
+ * Whether the default label as defined in {@link #defaultLabel} should be prefixed with
+ * the tools repository.
+ */
+ boolean defaultInToolRepository() default false;
+
+ /**
+ * The documentation text in Skylark. It can contain HTML tags for special formatting.
+ *
+ * <p>It is allowed to be empty only if {@link #documented()} is false.
+ */
+ String doc() default "";
+
+ /**
+ * If true, the function will appear in the Skylark documentation. Set this to false if the
+ * function is experimental or an overloading and doesn't need to be documented.
+ */
+ boolean documented() default true;
+}