對于開發(fā)者來說,總會有一些自己寫的東西,包括但不限于自定義View,自定義一些框架,有時我們開發(fā)中覺得很多大牛的東西很好用,他們一般都是托管到Github上,而他們的庫都是有一些倉庫來進行托管,最常用的就是maven跟jcenter了,但是對于國內(nèi)開發(fā)者來說,這兩個倉庫的下載速度真的是一言難盡,所以最近幾年出現(xiàn)了另外一個倉庫,JitPack。這個托管倉庫與Github銜接真的很棒,現(xiàn)在很多開源庫都是托管在這里了,下載速度也是很不錯的,下面介紹怎么將自己的開源庫托管到JitPack。
創(chuàng)建自己的開源庫并提交到Github
這里不多解釋了,相信看這篇文章的同學對Android開發(fā)很熟練了,所以自動跳過這一步了。
配置maven倉庫
這里說的配置maven倉庫,是指Github的倉庫插件,因為你需要通過Github來發(fā)布你的開源庫嘛,肯定需要他們的插件了,這里加入插件也很簡單,首先在你的項目根目錄下的build.gradle文件中添加:
buildscript {
repositories {
jcenter()
}
dependencies {
classpath 'com.android.tools.build:gradle:2.3.3'
// add github maven plugin
classpath 'com.github.dcendents:android-maven-gradle-plugin:1.5'
// NOTE: Do not place your application dependencies here; they belong
// in the individual module build.gradle files
}
}
這里我使用的是1.5版本的,因為我使用的gradle版本是3.3的,各個不同的版本使用的插件版本也不一樣,具體見這里。
配置好插件之后呢,還要配置一些東西,在你需要發(fā)布的library中的build.gradle文件中加入以下:
apply plugin: 'com.android.library'
// add these
apply plugin: 'com.github.dcendents.android-maven'
group='com.github.××××' // ××××代表你github名字
沒錯,這里就是運用插件的地方了。
這樣我們的配置就完成了。有的同學可能看到有的文章寫了要配置倉庫,像這樣:
allprojects {
repositories {
jcenter()
maven { url "https://jitpack.io" } // add this
}
}
其實這步不需要的,這步一般是驗證你的庫已經(jīng)托管成功了才會加,所以你可加可不加,在發(fā)布庫時是不需要加的。
配置好了之后,我們就可以提交代碼進行發(fā)布了嗎?不不不,有一重要的一步必須要執(zhí)行,那就是需要我們在根目錄下執(zhí)行
./gradlew install
如果你不執(zhí)行該命令,那么在JitPack上你的庫是編譯不過的,我開始沒執(zhí)行這句命令,一直發(fā)布不上去,查看了Log才發(fā)現(xiàn)。
Failed to notify ProjectEvaluationListener.afterEvaluate(), but primary configuration failure takes precedence.
java.lang.IllegalStateException: buildToolsVersion is not specified.
at com.google.common.base.Preconditions.checkState(Preconditions.java:173)
at com.android.build.gradle.BasePlugin.createAndroidTasks(BasePlugin.java:558)
at com.android.build.gradle.BasePlugin.lambda$null$4(BasePlugin.java:526)
at com.android.builder.profile.ThreadRecorder.record(ThreadRecorder.java:81)
at com.android.build.gradle.BasePlugin.lambda$createTasks$5(BasePlugin.java:522)
at org.gradle.internal.event.BroadcastDispatch$ActionInvocationHandler.dispatch(BroadcastDispatch.java:93)
at org.gradle.internal.event.BroadcastDispatch$ActionInvocationHandler.dispatch(BroadcastDispatch.java:82)
at org.gradle.internal.event.AbstractBroadcastDispatch.dispatch(AbstractBroadcastDispatch.java:44)
at org.gradle.internal.event.BroadcastDispatch.dispatch(BroadcastDispatch.java:79)
at org.gradle.internal.event.BroadcastDispatch.dispatch(BroadcastDispatch.java:30)
at org.gradle.internal.dispatch.ProxyDispatchAdapter$DispatchingInvocationHandler.invoke(ProxyDispatchAdapter.java:93)
at com.sun.proxy.$Proxy15.afterEvaluate(Unknown Source)
at org.gradle.configuration.project.LifecycleProjectEvaluator.notifyAfterEvaluate(LifecycleProjectEvaluator.java:82)
at org.gradle.configuration.project.LifecycleProjectEvaluator.doConfigure(LifecycleProjectEvaluator.java:76)
at org.gradle.configuration.project.LifecycleProjectEvaluator.access$000(LifecycleProjectEvaluator.java:33)
at org.gradle.configuration.project.LifecycleProjectEvaluator$1.execute(LifecycleProjectEvaluator.java:53)
at org.gradle.configuration.project.LifecycleProjectEvaluator$1.execute(LifecycleProjectEvaluator.java:50)
at org.gradle.internal.Transformers$4.transform(Transformers.java:169)
at org.gradle.internal.progress.DefaultBuildOperationExecutor.run(DefaultBuildOperationExecutor.java:106)
at org.gradle.internal.progress.DefaultBuildOperationExecutor.run(DefaultBuildOperationExecutor.java:61)
at org.gradle.configuration.project.LifecycleProjectEvaluator.evaluate(LifecycleProjectEvaluator.java:50)
at org.gradle.api.internal.project.DefaultProject.evaluate(DefaultProject.java:628)
at org.gradle.api.internal.project.DefaultProject.evaluate(DefaultProject.java:129)
at org.gradle.api.internal.project.DefaultProjectAccessListener.evaluateProjectAndDiscoverTasks(DefaultProjectAccessListener.java:32)
at org.gradle.api.internal.project.DefaultProjectAccessListener.beforeResolvingProjectDependency(DefaultProjectAccessListener.java:28)
at org.gradle.api.internal.artifacts.dependencies.DefaultProjectDependency.beforeResolved(DefaultProjectDependency.java:107)
...
FAILURE: Build failed with an exception.
* Where:
Build file '/home/jitpack/build/percentview/build.gradle' line: 2
* What went wrong:
A problem occurred evaluating project ':percentview'.
> Failed to apply plugin [id 'com.github.dcendents.android-maven']
> Could not create plugin of type 'AndroidMavenPlugin'.
> No service of type Factory<LoggingManagerInternal> available in ProjectScopeServices.
* Try:
Run with --stacktrace option to get the stack trace. Run with --info or --debug option to get more log output.
WARNING:
Gradle 'install' task not found. Please add the 'maven' or 'android-maven' plugin.
See the documentation and examples: https://jitpack.io/docs/
具體Log如上。
執(zhí)行命令后就可以直接提交代碼到Github了。
發(fā)布自己的開源庫
因為Github與JitPack對接很好,所以我們在Github上操作后JitPack也會同步,在提交代碼后我們需要Release我們的版本,操作也很簡單,
如下圖:
點擊上面四個選項中的releases即可,然后按照提示創(chuàng)建tag以及相關信息,保存。
查看使用自己的開源庫
當我們Release我們的開源庫之后,就可以登錄JitPack來查看開源庫的情況,比如查看我的開源庫情況:
這是我開源庫的編譯情況,在Log那欄,綠色代表編譯通過,紅色代表編譯失敗,然后點擊Get it會告訴你怎么使用:
這段你也可以復制到你的README.md中去,修改一下,這里JitPack還告訴怎么生成快捷鏈接的圖標,你也可以加入到你的README.md中去
到此,發(fā)布到自己的開源庫到JitPack就結束了,如果在發(fā)布過程中遇到問題可以使勁戳這里,這里才是最專業(yè)的!