blob: 0fc88ecfb0a1915ac2a2787acf5a86e772f33fe1 [file] [log] [blame]
// 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.devtools.build.lib.actions.Artifact;
import com.google.devtools.build.lib.analysis.config.transitions.StarlarkExposedRuleTransitionFactory;
import com.google.devtools.build.lib.rules.java.JavaCompilationArgsProvider;
import com.google.devtools.build.lib.rules.java.JavaInfo;
import com.google.devtools.build.lib.starlarkbuildapi.android.AndroidSplitTransitionApi;
import com.google.devtools.build.lib.starlarkbuildapi.android.AndroidStarlarkCommonApi;
/** Common utilities for Starlark rules related to Android. */
public class AndroidStarlarkCommon implements AndroidStarlarkCommonApi<Artifact, JavaInfo> {
@Override
public AndroidDeviceBrokerInfo createDeviceBrokerInfo(String deviceBrokerType) {
return new AndroidDeviceBrokerInfo(deviceBrokerType);
}
@Override
public String getSourceDirectoryRelativePathFromResource(Artifact resource) {
return AndroidCommon.getSourceDirectoryRelativePathFromResource(resource).toString();
}
@Override
public AndroidSplitTransitionApi getAndroidSplitTransition() {
return AndroidRuleClasses.ANDROID_SPLIT_TRANSITION;
}
@Override
public StarlarkExposedRuleTransitionFactory getAndroidPlatformsTransition() {
return new AndroidPlatformsTransition.AndroidPlatformsTransitionFactory();
}
/**
* TODO(b/14473160): Provides a Starlark compatibility layer for the sourceless deps bug. When a
* sourceless target is defined, the deps of the target are implicitly exported. Specifically only
* the {@link JavaCompilationArgsProvider} is propagated. This method takes the existing JavaInfo
* and produces a new one, only containing the {@link JavaCompilationArgsProvider} to be added to
* the exports field of the java_common.compile method. Remove this method once the bug has been
* fixed.
*/
@Override
public JavaInfo enableImplicitSourcelessDepsExportsCompatibility(
JavaInfo javaInfo, boolean neverlink) {
JavaCompilationArgsProvider.ClasspathType type =
neverlink
? JavaCompilationArgsProvider.ClasspathType.COMPILE_ONLY
: JavaCompilationArgsProvider.ClasspathType.BOTH;
return JavaInfo.Builder.create()
.setNeverlink(neverlink)
.addProvider(
JavaCompilationArgsProvider.class,
JavaCompilationArgsProvider.builder()
.addExports(javaInfo.getProvider(JavaCompilationArgsProvider.class), type)
.build())
.build();
}
}