diff options
author | 2016-07-07 19:11:40 +0000 | |
---|---|---|
committer | 2016-07-08 08:43:32 +0000 | |
commit | 3348513de992b5a3ab7d22dea9ad265d288c93b6 (patch) | |
tree | ee2ba837007aaba8d92999f722df6a9c241ba022 /src/main/java/com/google/devtools/build/lib/rules/android | |
parent | dda672424e15fd775b980ae22493b8c863bbfde3 (diff) |
More pieces of RClassGeneratorAction
Add the rclass_generator.sh, and fill in the
boiler-plate for mock tools, etc. Mostly cargo-
culting references to resources_processor.sh.
Rename earlier pieces to use RClassGenerator
prefix instead of AndroidResourceCompilation.
--
MOS_MIGRATED_REVID=126831848
Diffstat (limited to 'src/main/java/com/google/devtools/build/lib/rules/android')
-rw-r--r-- | src/main/java/com/google/devtools/build/lib/rules/android/AndroidRuleClasses.java | 1 | ||||
-rw-r--r-- | src/main/java/com/google/devtools/build/lib/rules/android/RClassGeneratorActionBuilder.java | 144 |
2 files changed, 145 insertions, 0 deletions
diff --git a/src/main/java/com/google/devtools/build/lib/rules/android/AndroidRuleClasses.java b/src/main/java/com/google/devtools/build/lib/rules/android/AndroidRuleClasses.java index 9be507bcfd..d779ce04b4 100644 --- a/src/main/java/com/google/devtools/build/lib/rules/android/AndroidRuleClasses.java +++ b/src/main/java/com/google/devtools/build/lib/rules/android/AndroidRuleClasses.java @@ -169,6 +169,7 @@ public final class AndroidRuleClasses { "//tools/android:incremental_split_stub_application"; public static final String DEFAULT_AAR_GENERATOR = "//tools/android:aar_generator"; public static final String DEFAULT_MANIFEST_MERGER = "//tools/android:manifest_merger"; + public static final String DEFAULT_RCLASS_GENERATOR = "//tools/android:rclass_generator"; public static final String DEFAULT_RESOURCES_PROCESSOR = "//tools/android:resources_processor"; public static final String DEFAULT_RESOURCE_SHRINKER = "//tools/android:resource_shrinker"; public static final String DEFAULT_SDK = "//tools/android:sdk"; diff --git a/src/main/java/com/google/devtools/build/lib/rules/android/RClassGeneratorActionBuilder.java b/src/main/java/com/google/devtools/build/lib/rules/android/RClassGeneratorActionBuilder.java new file mode 100644 index 0000000000..973966943b --- /dev/null +++ b/src/main/java/com/google/devtools/build/lib/rules/android/RClassGeneratorActionBuilder.java @@ -0,0 +1,144 @@ +// Copyright 2016 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.rules.android; + +import com.google.common.base.Function; +import com.google.common.collect.FluentIterable; +import com.google.common.collect.ImmutableList; +import com.google.common.collect.Iterables; +import com.google.devtools.build.lib.actions.Artifact; +import com.google.devtools.build.lib.actions.ParameterFile.ParameterFileType; +import com.google.devtools.build.lib.analysis.RuleConfiguredTarget.Mode; +import com.google.devtools.build.lib.analysis.RuleContext; +import com.google.devtools.build.lib.analysis.actions.CustomCommandLine; +import com.google.devtools.build.lib.analysis.actions.SpawnAction; +import com.google.devtools.build.lib.collect.nestedset.NestedSet; +import com.google.devtools.build.lib.collect.nestedset.NestedSetBuilder; +import com.google.devtools.build.lib.collect.nestedset.Order; +import com.google.devtools.build.lib.rules.android.AndroidResourcesProvider.ResourceContainer; + +import java.util.ArrayList; +import java.util.List; + +import javax.annotation.Nullable; + +/** + * Builds up the spawn action for $android_rclass_generator. + */ +public class RClassGeneratorActionBuilder { + + private final RuleContext ruleContext; + private ResourceContainer primary; + private ResourceDependencies dependencies; + + private Artifact classJarOut; + + private static final ContainerToArg DEPS_TO_ARG = new ContainerToArg(); + private static final ContainerToArtifacts DEPS_TO_ARTIFACTS = new ContainerToArtifacts(); + + /** + * @param ruleContext The RuleContext that is used to create a SpawnAction.Builder. + */ + public RClassGeneratorActionBuilder(RuleContext ruleContext) { + this.ruleContext = ruleContext; + } + + public RClassGeneratorActionBuilder withPrimary(ResourceContainer primary) { + this.primary = primary; + return this; + } + + public RClassGeneratorActionBuilder withDependencies(ResourceDependencies resourceDeps) { + this.dependencies = resourceDeps; + return this; + } + + public RClassGeneratorActionBuilder setClassJarOut(Artifact classJarOut) { + this.classJarOut = classJarOut; + return this; + } + + private static class ContainerToArg implements Function<ResourceContainer, String> { + + @Override + public String apply(ResourceContainer container) { + return (container.getRTxt() != null ? container.getRTxt().getExecPath() : "") + + ":" + + (container.getManifest() != null ? container.getManifest().getExecPath() : ""); + } + } + + private static class ContainerToArtifacts implements + Function<ResourceContainer, NestedSet<Artifact>> { + + @Override + public NestedSet<Artifact> apply(ResourceContainer container) { + NestedSetBuilder<Artifact> artifacts = NestedSetBuilder.naiveLinkOrder(); + addIfNotNull(container.getRTxt(), artifacts); + addIfNotNull(container.getManifest(), artifacts); + return artifacts.build(); + } + + private void addIfNotNull(@Nullable Artifact artifact, NestedSetBuilder<Artifact> artifacts) { + if (artifact != null) { + artifacts.add(artifact); + } + } + + } + + public void build() { + CustomCommandLine.Builder builder = new CustomCommandLine.Builder(); + NestedSetBuilder<Artifact> inputs = NestedSetBuilder.naiveLinkOrder(); + inputs.addAll(ruleContext.getExecutablePrerequisite("$android_rclass_generator", Mode.HOST) + .getRunfilesSupport() + .getRunfilesArtifactsWithoutMiddlemen()); + + List<Artifact> outs = new ArrayList<>(); + if (primary.getRTxt() != null) { + builder.addExecPath("--primaryRTxt", primary.getRTxt()); + inputs.add(primary.getRTxt()); + } + if (primary.getManifest() != null) { + builder.addExecPath("--primaryManifest", primary.getManifest()); + inputs.add(primary.getManifest()); + } + if (dependencies != null) { + Iterable<ResourceContainer> depResources = dependencies.getResources(); + if (depResources.iterator().hasNext()) { + builder.addJoinStrings("--libraries", ",", Iterables.transform(depResources, DEPS_TO_ARG)); + inputs.addTransitive(NestedSetBuilder.wrap( + Order.NAIVE_LINK_ORDER, + FluentIterable.from(depResources) + .transformAndConcat(DEPS_TO_ARTIFACTS))); + } + } + builder.addExecPath("--classJarOutput", classJarOut); + outs.add(classJarOut); + + // Create the spawn action. + SpawnAction.Builder spawnActionBuilder = new SpawnAction.Builder(); + ruleContext.registerAction( + spawnActionBuilder + .addTransitiveInputs(inputs.build()) + .addOutputs(ImmutableList.<Artifact>copyOf(outs)) + .useParameterFile(ParameterFileType.SHELL_QUOTED) + .setCommandLine(builder.build()) + .setExecutable( + ruleContext.getExecutablePrerequisite("$android_rclass_generator", Mode.HOST)) + .setProgressMessage("Generating R Classes: " + ruleContext.getLabel()) + .setMnemonic("RClassGenerator") + .build(ruleContext)); + } +} |