传递式.aar依赖项

时间:2018-07-12 16:53:38

标签: android android-studio gradle aar

我正在创建一个依赖于另一个.aar文件的.aar模块。

我将依存关系添加到我的gradle文件中的项目中,如下所示:

debugApi(group: 'com.mydomain.mylib', name: 'anotherlib-debug', version: '1.0', ext: 'aar') {
    transitive=true
}
releaseApi(group: 'com.mydomain.mylib', name: 'anotherlib-release', version: '1.0', ext: 'aar') {
    transitive=true
}

transitive=true似乎不起作用,因为当我构建.aar文件时,不包括依赖项。

我有2个问题:

1。如何包含依赖项.aar文件,以便它们内置到我的模块.aar文件中?

2。是否可以构建模块.aar文件,以便在任何项目使用它的情况下都不会暴露依赖项.aar api?。也就是说,我想防止在项目中使用我的模块的人直接从依赖项.aar文件访问api。我只想让他们使用我创建的用于包装或使用依赖项的api。

2 个答案:

答案 0 :(得分:0)

AAR不管理依赖项; maven这样做(通常通过AAR旁的pom.xml文件)。您需要检查这些AAR的构建过程,以确保它们正确生成和部署pom文件。

对于第二个问题,如果将debugApi替换为debugImplementation,gradle的行为将是这样。如果您想将此扩展到使用该模块的任何人,那么这基本上是不可能的,因为他们仍然可以直接依赖于依赖项。

或者(也许这是您首先要问的问题),可以将库代码和依赖项编译成没有依赖项的“胖” AAR,并有效地隐藏其外部依赖项。请注意,如果您在使用代码时也直接依赖相同的依赖项,则可能会遇到类路径问题,因此请当心。 Android本身不支持此功能,但是有些插件可以提供帮助,例如https://github.com/adwiv/android-fat-aar

答案 1 :(得分:0)

  1. transitive=true不利于包括从属aar。
  2. aar只能单独使用,这意味着如果没有正确编写的自定义gradle插件,则无法将多个aar合并为一个fat-aar。
  3. Android gradle multiproject dependency resolution上有一些讨论,可能与您的讨论有关 问题。
相关问题