Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kezong/fat-aar-android
A gradle plugin that merge dependencies into the final aar file works with AGP 3.+
https://github.com/kezong/fat-aar-android
aar android fat-aar fataar gradle-plugin merge-aar
Last synced: about 1 month ago
JSON representation
A gradle plugin that merge dependencies into the final aar file works with AGP 3.+
- Host: GitHub
- URL: https://github.com/kezong/fat-aar-android
- Owner: kezong
- License: mit
- Created: 2018-12-19T12:36:38.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2024-07-25T12:51:00.000Z (6 months ago)
- Last Synced: 2024-08-25T22:45:37.042Z (5 months ago)
- Topics: aar, android, fat-aar, fataar, gradle-plugin, merge-aar
- Language: Groovy
- Homepage:
- Size: 6.91 MB
- Stars: 3,112
- Watchers: 56
- Forks: 615
- Open Issues: 163
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome - fat-aar-android
README
# fat-aar-android
[![license](https://img.shields.io/badge/license-MIT-blue.svg)](https://github.com/kezong/fat-aar-android/blob/master/LICENSE)
[![Maven Central](https://maven-badges.herokuapp.com/maven-central/com.github.kezong/fat-aar/badge.svg)](https://maven-badges.herokuapp.com/maven-central/com.github.kezong/fat-aar)- [中文文档](./README_CN.md)
>**I am no longer engaged in research and development, so the project will not be updated and maintained.
**
>**You can try to use the following steps to reference the remote plugin. If it doesn't work on the new version of gradle, you can fork or download this project to modify it, the code of this project is not very complex.**
>
>**P.S. Hope Google can support this damn feature as soon as possible.**The solution of merging aar works with [AGP][3] `3.0` and higher. (Tested in AGP 3.0 - 7.1.0, and Gradle 4.9 - 7.3)
## Getting Started### Step 1: Add classpath
#### Add snippet below to your root build script file:
For Maven Central (The lastest release is available on [Maven Central](https://maven-badges.herokuapp.com/maven-central/com.github.kezong/fat-aar)):
```groovy
buildscript {
repositories {
mavenCentral()
}
dependencies {
classpath 'com.github.kezong:fat-aar:1.3.8'
}
}
```### Step 2: Add plugin
Add snippet below to the `build.gradle` of your main android library:
```groovy
apply plugin: 'com.kezong.fat-aar'
```### Step 3: Embed dependencies
Declare `embed` for the dependencies you want to merge in `build.gradle`.
The usage is similar to `implementation`, like this:
```groovy
dependencies {
implementation fileTree(dir: 'libs', include: '*.jar')
// java dependency
embed project(path: ':lib-java', configuration: 'default')
// aar dependency
embed project(path: ':lib-aar', configuration: 'default')
// aar dependency
embed project(path: ':lib-aar2', configuration: 'default')
// local full aar dependency, just build in flavor1
flavor1Embed project(path: ':lib-aar-local', configuration: 'default')
// local full aar dependency, just build in debug
debugEmbed(name: 'lib-aar-local2', ext: 'aar')
// remote jar dependency
embed 'com.google.guava:guava:20.0'
// remote aar dependency
embed 'com.facebook.fresco:fresco:1.12.0'
// don't want to embed in
implementation('androidx.appcompat:appcompat:1.2.0')
}
```### Transitive
#### Local Dependency
If you want to include local transitive dependencies in final artifact, you must add `embed` for transitive dependencies in your main library.For example, mainLib depend on subLib1, subLib1 depend on subLib2, If you want include all dependencies in the final artifact, you must add `embed` for subLib1 and subLib2 in mainLib `build.gradle`
#### Remote Dependency
If you want to inlcude all of the remote transitive dependencies which are in POM file, you need change the `transitive` value to true in your `build.gradle`, like this:
```groovy
fataar {
/**
* If transitive is true, local jar module and remote library's dependencies will be embed. (local aar module does not support)
* If transitive is false, just embed first level dependency
* Default value is false
* @since 1.3.0
*/
transitive = true
}
```
If you change the transitive value to true,and want to ignore a dependency in its POM file, you can add exclude keywords, like this:
```groovy
embed('com.facebook.fresco:fresco:1.11.0') {
// exclude all dependencies
transitive = false
// exclude any group or module
exclude(group:'com.facebook.soloader', module:'soloader')
}
```**More usage see [example](./example).**
## About AAR File
AAR is a file format for android library.
The file itself is a zip file that containing useful stuff in android.
See [anatomy of an aar file here][2].**support list for now:**
- [x] Flavors
- [x] AndroidManifest merge
- [x] Classes merge
- [x] Jar merge
- [x] Res merge
- [x] Assets merge
- [x] Jni libs merge
- [x] R.txt merge
- [x] R.class merge
- [x] DataBinding merge
- [x] Proguard merge
- [x] Kotlin module merge## Gradle Version Support
| Version | Gradle Plugin | Gradle |
| :--------: | :--------:|:-------:|
| 1.0.1 | 3.1.0 - 3.2.1 | 4.4 - 6.0 |
| 1.1.6 | 3.1.0 - 3.4.1 | 4.4 - 6.0 |
| 1.1.10| 3.0.0 - 3.4.1 | 4.1 - 6.0 |
| 1.2.6 | 3.0.0 - 3.5.0 | 4.1 - 6.0 |
| 1.2.8 | 3.0.0 - 3.5.9 | 4.1 - 6.8 |
| 1.2.11 - 1.2.14 | 3.0.0 - 3.6.9 | 4.1 - 6.8 |
| 1.2.15 - 1.2.16 | 3.0.0 - 4.0.2 | 4.1 - 6.8 |
| 1.2.17 | 3.0.0 - 4.0.2 | 4.9 - 6.8 |
| 1.2.18+ | 3.0.0 - 4.1.0 | 4.9 - 6.8 |
| 1.3.+ | 3.0.0 - 4.1.0 | 4.9 - 6.8 |
| 1.3.4 - 1.3.5 | 3.0.0 - 4.1.0 | 4.9+ |
| 1.3.6 | 3.0.0 - 4.2.0 | 4.9+ |
| 1.3.8 | 3.0.0+ | 4.9+ |The following link which version of Gradle is required for each version of the Android Gradle plugin. For the best performance, you should use the latest possible version of both Gradle and the plugin.
[Plugin version and Required Gradle version](https://developer.android.google.cn/studio/releases/gradle-plugin.html)
## Version Log
- [1.3.8]()
- Fix the issue that plugin cannot be used in jdk 1.8 [#371](https://github.com/kezong/fat-aar-android/issues/371)
- [1.3.7]()
- Fix productFlavor detection in embed submodules [#348](https://github.com/kezong/fat-aar-android/issues/348)
- Support missingDimensionStrategy without productFlavors in current project. [#343](https://github.com/kezong/fat-aar-android/issues/343)
- [1.3.6]()
- Support AGP 4.2.0 [#290](https://github.com/kezong/fat-aar-android/issues/290) [#304](https://github.com/kezong/fat-aar-android/issues/304)
- Copy 'navigation' along with other R.$ classes. [#296](https://github.com/kezong/fat-aar-android/issues/296)
- [1.3.5]()
- Fix the bug that jar cannot be merged in some case. [#255](https://github.com/kezong/fat-aar-android/issues/255) [#288](https://github.com/kezong/fat-aar-android/issues/288)
- Fix build error when use gradle 6.0-6.8. [#277](https://github.com/kezong/fat-aar-android/issues/277)
- [1.3.4]()
- Support Gradle 6.8 [#274](https://github.com/kezong/fat-aar-android/issues/274)
- [1.3.3]()
- Fix bug that "Can not find task bundleDebugAar". [#84](https://github.com/kezong/fat-aar-android/issues/84)
- Fix bug that crash when module can not resolve.
- Throw a runtime exception when manifest merge fail.
- [1.3.1]()
- Implement bytecode patching to process R class
- Support merge consumerProguardFiles
- Support merge *.kotlin_module, support kotlin top-level
- Support flavor missingDimensionStrategy
- Fix build error when flavor artifact renamed
- Fix Jar merge error when use AGP 3.0 - 3.1
- Fix AGP version not found in some cases
- [1.2.20]()
- Fix error that getName() in a null object. [#214](https://github.com/kezong/fat-aar-android/issues/214)
- Rename r-classes.jar with applicationId.
- [1.2.19]()
- Support embed aar that has no classes.jar [#157](https://github.com/kezong/fat-aar-android/issues/158)
- Support embed aar that has no AndroidManifest.xml [#206](https://github.com/kezong/fat-aar-android/issues/206)
- Fix bug that R.class not embed when publish to maven [#200](https://github.com/kezong/fat-aar-android/issues/200)
- [1.2.18]()
- Adapt gradle plugin 4.1.0 [#201](https://github.com/kezong/fat-aar-android/issues/201)
- [1.2.17]()
- Support databing merge [#25](https://github.com/kezong/fat-aar-android/issues/25) [#67](https://github.com/kezong/fat-aar-android/issues/67) [#142](https://github.com/kezong/fat-aar-android/issues/142)
- Use Gradle's configuration avoidance APIs [#195](https://github.com/kezong/fat-aar-android/issues/195)
- Support incremental build [#199](https://github.com/kezong/fat-aar-android/issues/199) [#185](https://github.com/kezong/fat-aar-android/issues/185)
- Fix wrong directory for aar's jar libs [#154](https://github.com/kezong/fat-aar-android/issues/154)
- [1.2.16]()
- Search for android build plugin version in full classpath [#172](https://github.com/kezong/fat-aar-android/issues/172)
- Fixed a bug where resources might not be found when build in gradle version 4.0 [#163](https://github.com/kezong/fat-aar-android/issues/163)
- [1.2.15]()
- adapt gradle plugin 4.0.0 [#147](https://github.com/kezong/fat-aar-android/issues/147)
- support that the module can be indexed in AS 4.0.0 [#148](https://github.com/kezong/fat-aar-android/issues/148)
- fix lint error [#152](https://github.com/kezong/fat-aar-android/issues/152)
- [1.2.12]()
- Added support for specific build type and product flavor dependencies, like debugEmbed or flavorEmbed. [#135](https://github.com/kezong/fat-aar-android/issues/135) [#137](https://github.com/kezong/fat-aar-android/issues/137)
- Fix some build warning
- [1.2.11]()
- Fix build variants error in gradle plugin 3.6.+ [#126](https://github.com/kezong/fat-aar-android/issues/126)
- Fix bug that remote recources symbol can not found in R.class when build with gradle plugin 3.6.0+
- [1.2.9]()
- adapt gradle plugin 3.6.1 [#120](https://github.com/kezong/fat-aar-android/issues/120)
- [1.2.8]()
- adapt gradle 6.0.0+ [#97](https://github.com/kezong/fat-aar-android/issues/97)
- [1.2.7]()
- Fix manifest merge bug in gradle 3.5.0 [#62](https://github.com/kezong/fat-aar-android/issues/62) [#65](https://github.com/kezong/fat-aar-android/issues/65)
- [1.2.6]()
- Adapt gradle plugin 3.5.0 [#53](https://github.com/kezong/fat-aar-android/issues/53) [#58](https://github.com/kezong/fat-aar-android/issues/58)
- [1.2.5]()
- Fix task name repeat error [#48](https://github.com/kezong/fat-aar-android/issues/48)
- If minifyEnabled, jar files would build into classes.jar
- [1.2.4]()
- Fix jni and assets can't embed in windows platform [#37](https://github.com/kezong/fat-aar-android/issues/37)
- [1.2.3]()
- Fix the problem that non-dependency R cannot be found [#11](https://github.com/kezong/fat-aar-android/issues/11) [#35](https://github.com/kezong/fat-aar-android/issues/35)
- No longer need to add `compileOnly` for dependencies
- Default value of transitive change to false
- [1.1.11]()
- Fixed a problem where gradle plugin version might have misjudged [#28](https://github.com/kezong/fat-aar-android/issues/28)
- Fixed LibraryManifestMerger.java build warning [#29](https://github.com/kezong/fat-aar-android/issues/29)
- Optimize the merging rules of resource、assets、jni... [#27](https://github.com/kezong/fat-aar-android/issues/27)
- [1.1.10]()
- Fixed jar merge bug when using gradle plugin 3.0.1 [#24](https://github.com/kezong/fat-aar-android/issues/24)
- Fixed rebuild(./gradlew clean assemble) error [#24](https://github.com/kezong/fat-aar-android/issues/24)
- [1.1.8]()
- Adapt new interface to avoid the warning [#10](https://github.com/kezong/fat-aar-android/issues/10)
- Optimize AndroidManifest merge rules [#21](https://github.com/kezong/fat-aar-android/issues/21) [#23](https://github.com/kezong/fat-aar-android/issues/23)
- [1.1.7]()
- Support embed R file when upload maven [#7](https://github.com/kezong/fat-aar-android/issues/7)
- [1.1.6]()
- Adapt gradle plugin 3.3.0, 3.4.0, 3.4.1. [#4](https://github.com/kezong/fat-aar-android/issues/4) [#9](https://github.com/kezong/fat-aar-android/issues/9)
- Adapt gradle 4.10.1, 5.0, 5.1, 5.1.1... [#8](https://github.com/kezong/fat-aar-android/issues/8)
- Support sub-module's Flavor
- Fix the problem that the class update of the sub-module is not timely
- [1.0.3]()
- Fix assets merge
- [1.0.1]()
- Support gradle plugin 3.1.0 - 3.2.1
- Support R class file merge## Known Defects or Issues
- **Application cannot directly rely on embedded project:** application cannot directly rely on your embedded project. It must rely on the AAR file compiled by your embedded project
- For debugging convenience, you can use `embed` in the main library project when you choose to package aar. When you need to run the app directly, you can use `implementation` or `api`- **Res merge conflicts.** If the library res folder and embedded dependencies res have the same res Id(mostly `string/app_name`). A duplicate resources build exception will be thrown. To avoid res conflicts:
- consider using a prefix to each res Id, both in library res and aar dependencies if possible.
- Adding `android.disableResourceValidation=true` to `gradle.properties` can do a trick to skip the exception.
- **Proguard**
- If `minifyEnabled` is set to true, classes not referenced in the project will be filtered according to Proguard rules during compile, resulting in ClassNotFound during app compile.
Most AAR is SDK that provide interfaces. It is recommended that you carefully comb Proguard files and add keep rules.## Thanks
- [android-fat-aar][1]
- [fat-aar-plugin][4][1]: https://github.com/adwiv/android-fat-aar
[2]: https://developer.android.com/studio/projects/android-library.html#aar-contents
[3]: https://developer.android.com/studio/releases/gradle-plugin.html
[4]: https://github.com/Vigi0303/fat-aar-plugin