Skip to content

Commit

Permalink
Add the missing sdk toolchain type attribute to `android_tools_defaul…
Browse files Browse the repository at this point in the history
…ts_jar`.

PiperOrigin-RevId: 563816464
Change-Id: I3316a20462f8ac16cb4dcc95e8768405ea8a4be8
  • Loading branch information
katre authored and copybara-github committed Sep 8, 2023
1 parent ea40cb1 commit 3f728e4
Show file tree
Hide file tree
Showing 3 changed files with 44 additions and 13 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,7 @@
import com.google.devtools.build.lib.bazel.rules.android.BazelAndroidLocalTestRule;
import com.google.devtools.build.lib.bazel.rules.android.BazelAndroidSdkRule;
import com.google.devtools.build.lib.bazel.rules.android.BazelAndroidSemantics;
import com.google.devtools.build.lib.bazel.rules.android.BazelAndroidToolsDefaultsJar;
import com.google.devtools.build.lib.bazel.rules.android.BazelAndroidToolsDefaultsJarRule;
import com.google.devtools.build.lib.bazel.rules.android.BazelDexArchiveAspect;
import com.google.devtools.build.lib.bazel.rules.android.BazelSdkToolchainRule;
import com.google.devtools.build.lib.bazel.rules.java.proto.BazelJavaLiteProtoLibraryRule;
Expand Down Expand Up @@ -93,7 +93,7 @@
import com.google.devtools.build.lib.rules.android.AndroidProguardInfo;
import com.google.devtools.build.lib.rules.android.AndroidResourcesInfo;
import com.google.devtools.build.lib.rules.android.AndroidRuleClasses;
import com.google.devtools.build.lib.rules.android.AndroidRuleClasses.AndroidToolsDefaultsJarRule;
import com.google.devtools.build.lib.rules.android.AndroidRuleClasses.AndroidBaseToolsDefaultsJarRule;
import com.google.devtools.build.lib.rules.android.AndroidSdkBaseRule;
import com.google.devtools.build.lib.rules.android.AndroidSdkProvider;
import com.google.devtools.build.lib.rules.android.AndroidStarlarkCommon;
Expand Down Expand Up @@ -388,8 +388,8 @@ public void init(ConfiguredRuleClassProvider.Builder builder) {

builder.addRuleDefinition(new AndroidSdkBaseRule());
builder.addRuleDefinition(new BazelAndroidSdkRule());
builder.addRuleDefinition(
new AndroidToolsDefaultsJarRule(BazelAndroidToolsDefaultsJar.class));
builder.addRuleDefinition(new AndroidBaseToolsDefaultsJarRule());
builder.addRuleDefinition(new BazelAndroidToolsDefaultsJarRule());
builder.addRuleDefinition(new AndroidRuleClasses.AndroidBaseRule());
builder.addRuleDefinition(new AndroidRuleClasses.AndroidResourceSupportRule());
builder.addRuleDefinition(
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
// Copyright 2023 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.bazel.rules.android;

import com.google.devtools.build.lib.analysis.RuleDefinition;
import com.google.devtools.build.lib.analysis.RuleDefinitionEnvironment;
import com.google.devtools.build.lib.packages.RuleClass;
import com.google.devtools.build.lib.rules.android.AndroidRuleClasses;

/** Rule class definition for {@code android_tools_defaults_jar}. */
public class BazelAndroidToolsDefaultsJarRule implements RuleDefinition {
@Override
public RuleClass build(RuleClass.Builder builder, RuleDefinitionEnvironment environment) {
return builder.build();
}

@Override
public Metadata getMetadata() {
return RuleDefinition.Metadata.builder()
.name("android_tools_defaults_jar")
.ancestors(
AndroidRuleClasses.AndroidBaseToolsDefaultsJarRule.class, BazelSdkToolchainRule.class)
.factoryClass(BazelAndroidToolsDefaultsJar.class)
.build();
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -975,13 +975,7 @@ public static List<String> getValidValues() {
}

/** Definition of the {@code android_tools_defaults_jar} rule. */
public static final class AndroidToolsDefaultsJarRule implements RuleDefinition {

private final Class<? extends AndroidToolsDefaultsJar> factoryClass;

public AndroidToolsDefaultsJarRule(Class<? extends AndroidToolsDefaultsJar> factoryClass) {
this.factoryClass = factoryClass;
}
public static final class AndroidBaseToolsDefaultsJarRule implements RuleDefinition {

@Override
public RuleClass build(RuleClass.Builder builder, RuleDefinitionEnvironment environment) {
Expand All @@ -997,9 +991,9 @@ public RuleClass build(RuleClass.Builder builder, RuleDefinitionEnvironment envi
@Override
public Metadata getMetadata() {
return Metadata.builder()
.name("android_tools_defaults_jar")
.name("$android_base_tools_defaults_jar")
.type(RuleClassType.ABSTRACT)
.ancestors(BaseRuleClasses.NativeBuildRule.class)
.factoryClass(factoryClass)
.build();
}
}
Expand Down

0 comments on commit 3f728e4

Please sign in to comment.