Android-library
プロジェクトのJarパッケージをリリースするにはどうすればよいですか?
classes.jarはbuild/bundles/release/classes.jar
の下にあり、これが正しいJarパッケージ(*.class
ファイルを含む)であることがわかりました。
ライブラリをAARではなくJARとしてリリースする公式の方法はありますか?
編集
MavenアーティファクトをリリースするためにGradleを使用していますが、AARパッケージとともにJARをリリースしたいと思います。したがって、署名、md5、マニフェストなどを含むJAR.
https://chris.banes.me/2013/08/27/pushing-aars-to-maven-central/ に基づく
apply plugin: 'maven'
apply plugin: 'signing'
configurations {
archives {
extendsFrom configurations.default
}
}
def sonatypeRepositoryUrl
if (isReleaseBuild()) {
println 'RELEASE BUILD'
sonatypeRepositoryUrl = "https://oss.sonatype.org/service/local/staging/deploy/maven2/"
} else {
println 'DEBUG BUILD'
sonatypeRepositoryUrl = "https://oss.sonatype.org/content/repositories/snapshots/"
}
if(!hasProperty('nexusPassword')) {
ext.set('nexusPassword', System.console().readPassword("\n\$ Type in password for Sonatype nexus account " + nexusUsername + ": "))
}
if(!signing.hasProperty('password')) {
ext.set('signing.password', System.console().readPassword("\n\$ Type in GPG key password: "))
}
afterEvaluate { project ->
uploadArchives {
repositories {
mavenDeployer {
beforeDeployment { MavenDeployment deployment -> signing.signPom(deployment) }
pom.artifactId = POM_ARTIFACT_ID
repository(url: sonatypeRepositoryUrl) {
authentication(userName: nexusUsername, password: nexusPassword)
}
pom.project {
name POM_NAME
packaging POM_PACKAGING
description POM_DESCRIPTION
url POM_URL
scm {
url POM_SCM_URL
connection POM_SCM_CONNECTION
developerConnection POM_SCM_DEV_CONNECTION
}
licenses {
license {
name POM_LICENCE_NAME
url POM_LICENCE_URL
distribution POM_LICENCE_DIST
}
}
developers {
developer {
id "loopj"
name "James Smith"
}
developer {
id "smarek"
name "Marek Sebera"
}
}
}
}
}
}
signing {
required { isReleaseBuild() && gradle.taskGraph.hasTask("uploadArchives") }
sign configurations.archives
}
task androidJavadocs(type: Javadoc) {
source = Android.sourceSets.main.Java.srcDirs
}
task androidJavadocsJar(type: Jar) {
classifier = 'javadoc'
from androidJavadocs.destinationDir
}
task androidSourcesJar(type: Jar) {
classifier = 'sources'
from Android.sourceSets.main.Java.srcDirs
}
artifacts {
archives androidSourcesJar
archives androidJavadocsJar
}
}
を使用して
task androidJar(type: Jar) {
from Android.sourceSets.main.Java.srcDirs
}
パッケージ化されるのはJavaファイルであり、コンパイルおよびリンクされていないAndroid sdk
Sonatype(またはローカルリポジトリ)への展開でアーティファクトをアップロードしようとはしていませんが、同じ問題に取り組むときに 数週間前 を思いついたのは次のとおりです。
Android.libraryVariants.all { variant ->
def name = variant.buildType.name
if (name.equals(com.Android.builder.core.BuilderConstants.DEBUG)) {
return; // Skip debug builds.
}
def task = project.tasks.create "jar${name.capitalize()}", Jar
task.dependsOn variant.javaCompile
task.from variant.javaCompile.destinationDir
artifacts.add('archives', task);
}
次に、次を実行します。
./gradlew jarRelease
Gradleを介してライブラリプロジェクトからjarを生成する別の方法は次のとおりです。
ライブラリのbuild.gradleで:
def jarName = 'someJarName.jar'
task clearJar(type: Delete) {
delete "${project.buildDir}/libs/" + jarName
}
task makeJar(type: Copy) {
from("${project.buildDir}/intermediates/bundles/release/")
into("${project.buildDir}/libs/")
include('classes.jar')
rename('classes.jar', jarName)
}
makeJar.dependsOn(clearJar, build)
ここで行っていることは、Android Gradleプラグインによって生成されたclasses.jarをコピーすることです。 。
次にmakeJar
タスクを実行すると、結果のjarはlibrary/build/libs/${jarName}
。jar
リリース用の構成に応じたクラスファイルがあります。難読化する場合、jar内のファイルは難読化されます。
前の回答が私のニーズに合わなかったという理由だけで、プロジェクトクラスとaar/jar依存関係を含むjarを生成するために、トリッキーなバージョンを共有しています。
// A tricky jar operation, we want to generate a jar files that contains only the required classes used.
// Dependencies are in jar and aar, so we need to open the aar to extract the classes and put all at the same level
// (aar is a Zip that contains classes.jar, the latter is a Zip that contains .class files)
task jar(type: Jar) {
from {
List<File> allFiles = new ArrayList<>();
configurations.compile.collect {
for (File f : zipTree(it).getFiles()) {
if (f.getName().equals("classes.jar")) {
allFiles.addAll(zipTree(f).getAt("asFileTrees").get(0).getDir())
}
}
}
allFiles.add(new File('build/intermediates/classes/release'))
allFiles // To return the result inside a lambda
}
archiveName( project.ext.appName + '.jar' )
}
これは、ビルドタイプ/フレーバーを管理しませんが、適応させることができます(フレーバーのないビルドタイプリリースでビルドしても構いません)。
よりスマートでエレガントなソリューションをお持ちの場合は、共有してください!