因此,从 Gradle 和 Android Studio 诞生之初起,我就一直在使用它们。然而,我发现自己用头撞墙的次数有时远远超过了它的价值:(。
我花了一天半的时间试图解决我目前的困境。
在我工作的地方,我们使用很多共享库项目。这意味着与 Gradle 的本机假设不同,我的项目并非全部嵌套在一个父项目下。 (但这不是我的问题)我已经开始工作了。
当我们的项目完成并准备就绪后,我们被要求为当前项目基础设施创建一个 SDK 供外部使用。现在,在旧的 IntelliJ 中,我只需生成一些 JavaDoc 并创建一个包含所有依赖项的 Artifact,然后创建另一个不包含依赖项 jar 的 Artifact,并尊重地命名它们。
然而,在 Gradle 中这似乎非常困难,甚至可能不受支持,而且我找不到其他人在经过 10 多个小时的 Google 搜索和反复试验后做到了这一点,我最终决定制作一个演示项目来准确展示我正在做什么以及我正在努力实现什么目标。
我需要做一些事情。
- 生成一个包含所有模块依赖代码和依赖 Jar 文件的 Jar 文件
- 生成一个包含所有模块依赖代码和零个依赖 Jar 文件的 Jar 文件
- 生成一个 AAR 文件,其中包括所有模块依赖代码和依赖 Jar 文件以及用于启动我们的 Activity 的资源(如果他们想要使用它)。
- 生成一个 AAR 文件,其中包括所有模块依赖项代码和零 Jar 文件以及用于启动我们的 Activity 的资源(如果他们想要使用它)。
所以这就是我的问题。每个模块在使用(类型:Jar)运行任务时仅生成其自己的代码。我设法让依赖的 Jar 文件编译一次,但是没有常规的源代码,但我从来没有能够将模块的源代码包含在 Jar 文件中,这是我现在最大的障碍。
以下是我已尝试但尚未完成这项简单任务的任务列表。
evaluationDependsOn(':dependencyModule')
task myJar(type: Jar){
appendix = 'myJar'
from android.sourceSets.main.allSource.files
}
task uberJar (type: Jar){
from(configurations.compile.collect { it.isDirectory() ? it : zipTree(it) }) {
exclude "META-INF/*.SF"
exclude "META-INF/*.DSA"
exclude "META-INF/*.RSA"
}
}
task fatJar(type: Jar, dependsOn: 'compileJava') {
from {
sourceSets.main.output.classesDir
}
// Add all dependencies except for android.jar to the fat jar
from {
configurations.compile.findAll {
it.getName() != 'android.jar'
}.collect {
it.isDirectory() ? it : zipTree(it)
}
}
archiveName = 'fatJar.jar'
}
task jarFat(type: Jar) {
appendix = "fat"
from android.sourceSets.main.java
from { configurations.compile.collect { it.isDirectory() ? it : zipTree(it) } }
}
task sourcesJar(type: Jar) {
from android.sourceSets.main.allSource
classifier = 'sources'
}
task clearJar(type: Delete) {
delete 'build/libs/myCompiledLibrary.jar'
}
task makeJar(type: Copy) {
from('build/bundles/release/')
into('build/libs/')
include('classes.jar')
rename ('classes.jar', 'myCompiledLibrary.jar')
}
makeJar.dependsOn(clearJar, build)
task jar(type: Jar) {
from android.sourceSets.main.allJava
}
task deployJar(type: Jar, dependsOn: jar) {
baseName = project.name + '-deploy'
deps = configurations.runtime + configurations.archives.allArtifactFiles
depClasses = { deps.collect { it.isDirectory() ? it : zipTree(it) } }
from(depClasses) {
exclude 'META-INF/MANIFEST.MF'
}
}
task modelJar(type: Jar) {
from sourceSets.main.output
}
task jarWithDependency(type: Jar){
from android.sourceSets.main.classesDir
from {configurations.compile.collect {zipTree(it)}}
}
task androidJavadocs(type: Javadoc) {
source = android.sourceSets.main.allJava
}
目前还没有什么能完全完成这项工作。任何帮助将不胜感激!!
预先感谢您花时间查看此内容。
如果有人想要的话,我有完整功能的示例项目,但我没有看到在这里上传的选项,所以是我构建的演示项目的链接。它很小而且很容易跟随。基本上每个项目一个类或方法。
演示项目 https://www.dropbox.com/s/f06njpjzzm3den0/HELP.zip