aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/main/java/com/google/devtools/build/lib/rules
diff options
context:
space:
mode:
authorGravatar Googler <noreply@google.com>2018-07-17 18:35:36 -0700
committerGravatar Copybara-Service <copybara-piper@google.com>2018-07-17 18:37:22 -0700
commit6b5205b000fe391faf12f84ed4f2e9ea38ae81ff (patch)
tree077b068f74df373bb635435b924af7f003e9ca08 /src/main/java/com/google/devtools/build/lib/rules
parentf309ad3be36363070e87eef0ee04b12f4956d601 (diff)
Expose AndroidFeatureFlagSetProvider to Skylark
RELNOTES: None PiperOrigin-RevId: 205011761
Diffstat (limited to 'src/main/java/com/google/devtools/build/lib/rules')
-rw-r--r--src/main/java/com/google/devtools/build/lib/rules/android/AndroidBinary.java3
-rw-r--r--src/main/java/com/google/devtools/build/lib/rules/android/AndroidFeatureFlagSetProvider.java53
2 files changed, 46 insertions, 10 deletions
diff --git a/src/main/java/com/google/devtools/build/lib/rules/android/AndroidBinary.java b/src/main/java/com/google/devtools/build/lib/rules/android/AndroidBinary.java
index 869267d318..cd4833c4be 100644
--- a/src/main/java/com/google/devtools/build/lib/rules/android/AndroidBinary.java
+++ b/src/main/java/com/google/devtools/build/lib/rules/android/AndroidBinary.java
@@ -658,8 +658,7 @@ public abstract class AndroidBinary implements RuleConfiguredTargetFactory {
applicationManifest.getManifest(),
AndroidCommon.getApkDebugSigningKey(ruleContext)))
.addNativeDeclaredProvider(new AndroidPreDexJarProvider(jarToDex))
- .addProvider(
- AndroidFeatureFlagSetProvider.class,
+ .addNativeDeclaredProvider(
AndroidFeatureFlagSetProvider.create(
AndroidFeatureFlagSetProvider.getAndValidateFlagMapFromRuleContext(ruleContext)))
.addOutputGroup("android_deploy_info", deployInfo);
diff --git a/src/main/java/com/google/devtools/build/lib/rules/android/AndroidFeatureFlagSetProvider.java b/src/main/java/com/google/devtools/build/lib/rules/android/AndroidFeatureFlagSetProvider.java
index 3746a85c8d..dae015df42 100644
--- a/src/main/java/com/google/devtools/build/lib/rules/android/AndroidFeatureFlagSetProvider.java
+++ b/src/main/java/com/google/devtools/build/lib/rules/android/AndroidFeatureFlagSetProvider.java
@@ -14,22 +14,25 @@
package com.google.devtools.build.lib.rules.android;
-import com.google.auto.value.AutoValue;
import com.google.common.base.Optional;
import com.google.common.collect.ImmutableMap;
import com.google.devtools.build.lib.analysis.AliasProvider;
import com.google.devtools.build.lib.analysis.RuleContext;
import com.google.devtools.build.lib.analysis.RuleDefinitionEnvironment;
import com.google.devtools.build.lib.analysis.TransitiveInfoCollection;
-import com.google.devtools.build.lib.analysis.TransitiveInfoProvider;
import com.google.devtools.build.lib.analysis.configuredtargets.RuleConfiguredTarget.Mode;
import com.google.devtools.build.lib.cmdline.Label;
import com.google.devtools.build.lib.concurrent.ThreadSafety.Immutable;
import com.google.devtools.build.lib.packages.Attribute;
import com.google.devtools.build.lib.packages.BuildType;
+import com.google.devtools.build.lib.packages.BuiltinProvider;
+import com.google.devtools.build.lib.packages.NativeInfo;
import com.google.devtools.build.lib.packages.NonconfigurableAttributeMapper;
import com.google.devtools.build.lib.packages.RuleClass.ConfiguredTargetFactory.RuleErrorException;
import com.google.devtools.build.lib.rules.config.ConfigFeatureFlag;
+import com.google.devtools.build.lib.skylarkbuildapi.android.AndroidFeatureFlagSetProviderApi;
+import com.google.devtools.build.lib.syntax.EvalException;
+import com.google.devtools.build.lib.syntax.SkylarkDict;
import java.util.Map;
/**
@@ -40,18 +43,25 @@ import java.util.Map;
* of the android_test will be compiled with different flags from the android_binary code which runs
* in the same Android virtual machine, which may cause compatibility issues at runtime.
*/
-@AutoValue
@Immutable
-public abstract class AndroidFeatureFlagSetProvider implements TransitiveInfoProvider {
+public final class AndroidFeatureFlagSetProvider extends NativeInfo
+ implements AndroidFeatureFlagSetProviderApi {
+
+ public static final String PROVIDER_NAME = "AndroidFeatureFlagSetProvider";
+ public static final Provider PROVIDER = new Provider();
/** The name of the attribute used by Android rules to set config_feature_flags. */
public static final String FEATURE_FLAG_ATTR = "feature_flags";
- AndroidFeatureFlagSetProvider() {}
+ private final Optional<ImmutableMap<Label, String>> flags;
+
+ AndroidFeatureFlagSetProvider(Optional<? extends Map<Label, String>> flags) {
+ super(PROVIDER);
+ this.flags = flags.transform(ImmutableMap::copyOf);
+ }
- /** Creates a new AndroidFeatureFlagSetProvider with the given flags. */
public static AndroidFeatureFlagSetProvider create(Optional<? extends Map<Label, String>> flags) {
- return new AutoValue_AndroidFeatureFlagSetProvider(flags.transform(ImmutableMap::copyOf));
+ return new AndroidFeatureFlagSetProvider(flags.transform(ImmutableMap::copyOf));
}
/**
@@ -123,5 +133,32 @@ public abstract class AndroidFeatureFlagSetProvider implements TransitiveInfoPro
|| (targetFlags.isPresent() && targetFlags.get().equals(depFlags.get()));
}
- public abstract Optional<ImmutableMap<Label, String>> getFlags();
+ public Optional<ImmutableMap<Label, String>> getFlags() {
+ return flags;
+ }
+
+ @Override
+ public ImmutableMap<Label, String> getFlagMap() {
+ return flags.or(ImmutableMap.of());
+ }
+
+ /** Provider class for {@link AndroidFeatureFlagSetProvider} objects. */
+ public static class Provider extends BuiltinProvider<AndroidFeatureFlagSetProvider>
+ implements AndroidFeatureFlagSetProviderApi.Provider {
+ private Provider() {
+ super(PROVIDER_NAME, AndroidFeatureFlagSetProvider.class);
+ }
+
+ public String getName() {
+ return PROVIDER_NAME;
+ }
+
+ @Override
+ public AndroidFeatureFlagSetProvider create(SkylarkDict<Label, String> flags)
+ throws EvalException {
+ return new AndroidFeatureFlagSetProvider(
+ Optional.of(
+ SkylarkDict.castSkylarkDictOrNoneToDict(flags, Label.class, String.class, "flags")));
+ }
+ }
}