// 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.skylarkbuildapi.android; import com.google.devtools.build.lib.collect.nestedset.NestedSet; import com.google.devtools.build.lib.skylarkbuildapi.FileApi; import com.google.devtools.build.lib.skylarkbuildapi.ProviderApi; import com.google.devtools.build.lib.skylarkbuildapi.StructApi; import com.google.devtools.build.lib.skylarkinterface.Param; import com.google.devtools.build.lib.skylarkinterface.SkylarkCallable; import com.google.devtools.build.lib.skylarkinterface.SkylarkConstructor; import com.google.devtools.build.lib.skylarkinterface.SkylarkModule; import com.google.devtools.build.lib.skylarkinterface.SkylarkModuleCategory; import com.google.devtools.build.lib.syntax.EvalException; import com.google.devtools.build.lib.syntax.SkylarkNestedSet; /** * Configured targets implementing this provider can contribute Android IDL information to the * compilation. */ @SkylarkModule( name = "AndroidIdlInfo", doc = "Information about Android IDLs", category = SkylarkModuleCategory.PROVIDER) public interface AndroidIdlProviderApi extends StructApi { /** Name of this info object. */ public static final String NAME = "AndroidIdlInfo"; /** The set of IDL import roots need for compiling the IDL sources in the transitive closure. */ @SkylarkCallable( name = "transitive_idl_import_roots", structField = true, doc = "Returns a depset of strings of all the idl import roots.") NestedSet getTransitiveIdlImportRoots(); /** The IDL files in the transitive closure. */ @SkylarkCallable( name = "transitive_idl_imports", structField = true, doc = "Returns a depset of artifacts of all the idl imports.") NestedSet getTransitiveIdlImports(); /** The IDL jars in the transitive closure, both class and source jars. */ @SkylarkCallable( name = "transitive_idl_jars", structField = true, doc = "Returns a depset of artifacts of all the idl class and source jars.") NestedSet getTransitiveIdlJars(); /** The preprocessed IDL files in the transitive closure. */ @SkylarkCallable( name = "transitive_idl_preprocessed", structField = true, doc = "Returns a depset of artifacts of all the idl preprocessed files.") NestedSet getTransitiveIdlPreprocessed(); /** The provider implementing this can construct the AndroidIdlInfo provider. */ @SkylarkModule(name = "Provider", doc = "", documented = false) public interface Provider extends ProviderApi { @SkylarkCallable( name = NAME, doc = "The AndroidIdlInfo constructor.", parameters = { @Param( name = "transitive_idl_import_roots", doc = "A depset of strings of all the idl import roots in the transitive closure.", positional = true, named = false, type = SkylarkNestedSet.class, generic1 = String.class), @Param( name = "transitive_idl_imports", doc = "A depset of artifacts of all the idl imports in the transitive closure.", positional = true, named = false, type = SkylarkNestedSet.class, generic1 = FileApi.class), @Param( name = "transitive_idl_jars", doc = "A depset of artifacts of all the idl class and source jars in the " + "transitive closure.", positional = true, named = false, type = SkylarkNestedSet.class, generic1 = FileApi.class), @Param( name = "transitive_idl_preprocessed", doc = "A depset of artifacts of all the idl preprocessed files in the transitive " + "closure.", positional = true, named = false, type = SkylarkNestedSet.class, generic1 = FileApi.class), }, selfCall = true) @SkylarkConstructor(objectType = AndroidIdlProviderApi.class) AndroidIdlProviderApi createInfo( SkylarkNestedSet transitiveIdlImportRoots, SkylarkNestedSet transitiveIdlImports, SkylarkNestedSet transitiveIdlJars, SkylarkNestedSet transitiveIdlPreprocessed) throws EvalException; } }