像 npm 一樣在 Andriod 專案中引入 Gradle 依賴

承香墨影發表於2017-10-12

/WechatIMG2.jpeg
/WechatIMG2.jpeg

一、前言

作為 Android 開發人員,有沒有羨慕過 node.js 的匯入三方庫的方式,node.js 社群為開發者準備了一個快速可靠的依賴管理庫。這樣的依賴管理庫,讓 node.js 匯入依賴庫,非常的方便,一行程式碼就搞定了,npm install <library>

為了搞定這個問題,一個國外的程式設計師 @cesarferreira 做了一個庫來支援這樣的功能 drone

Github 地址:

github.com/cesarferrei…

接下來我們來看看 drone 的使用和細節原理。

二、drone 的使用細節

2.1 什麼是 drone

drone 在 Android 專案中,實現了 npm 對 node.js 的功能。

它維護了 50 個常用的第三方依賴庫庫,差不多可以覆蓋 90% 我們常用的開源庫,例如:rxjava、Gson、Picasso、recyclelerview-v7 等。

當我們需要使用某個庫的時候,只需要一行命令,就可以將這個庫引入到我們工程的 build.gradledependencies 中。這個過程中,會預設為我們引入最新的版本,無需關心應該引入的三方庫的最新版本號。

算是 Android 下的一個非常好用的導包工具。

因為本身 drone 是使用 node.js 實現的,所以這裡需要 npm 的環境才可以安裝它,node.js 基本上就是無腦安裝,這裡預設你已經安裝了 node.js 的環境了。

安裝 drone 也非常的簡單,一行程式碼搞定。

npm install -g drone

安裝完成之後,我們就可以正常使用它了。

2.2 使用 drone

使用 drone 新增依賴庫,只需要通過 drone add 命令即可。

drone add creator/library module

drone add 需要指定庫的別名和需要匯入的 App Module。

/add3.gif
/add3.gif

可以看到,它會主動將我們需要庫查詢出來,插入到 build.gradle 的 dependencies 中。

drone 的支援的功能還有很多,增刪改查都是最正常的操作,其他操作可以檢視它的幫助文件。

/help.png
/help.png

drone 的使用還是非常方便簡單的,基本上看看幫助文件就可以搞定了,就不再展開說了。

三、drone 的原理

drone 的使用非常的簡單,不知道你有沒有好奇它是如何維護這些庫的。我們只是指定了一個庫的名稱,它就能立刻確定它最新的穩定版版本號。

接下來我們來繼續探索一下 drone 的原理,滿足好奇心。

/project-path.png
/project-path.png

首先看看 drone 的整個專案結構,它是完全使用 node.js 開發完成的,它所有支援的命令都被定義在 tasks 目錄下。

而 drone 的入口是 router.js ,所有的命令都需要通過 router.js 進行分發。

/routerjs.png
/routerjs.png

我們找一個最常用的命令 add 來看看它的具體細節。

/add-task.png
/add-task.png

可以看到,它首先使用 QuickSearch.search() 查詢我們輸入的庫的細節,然後使用 hive.getWithVersions() 查詢到我們需要的三方庫最新穩定版的版本號。最終使用 handleGradleDependencyInjection() 方法,將它輸入到我們指定 Module 的 build.gradle 的具體位置。

handleGradleDependencyInjection() 方法不用看,應該就是一個 io 操作,去寫 build.gradle 檔案。

先來看看 QuickSearch.search() 方法。

/quick-search.png
/quick-search.png

這裡通過 string-similarity 這個字串相似度比較庫,去查詢出我們需要引入的庫的細節,這些資訊,被配置在 constants.js 檔案中。

/constantsjs.png
/constantsjs.png

可以看到,這裡被另外一個 github 開源庫 drone-hive 所維護。

github.com/cesarferrei…

drone-hive 中,維護了比較常用的 50 個開源庫的資訊。

/hive-project-path.png
/hive-project-path.png

我們隨便找一個看看,這裡看看 airbnb/lottie-android。

/lottie-json.png
/lottie-json.png

可以看到,它維護了開源庫的各項資訊,而其中的 repository 指定了開源庫的型別,它最終可以用於區分我們使用什麼方式去獲取最新的版本號。

這個邏輯在 metadata.js 檔案中。

/getlastversion.png
/getlastversion.png

例如這裡檢視的 airbnb/lottie-android 就是通過 jitpack.io 進行查詢,當然 drone 是使用 jitpack.io 的查詢 Api 去查詢到最新的版本號,這裡不再展開細節看了。

/JitPackage.png
/JitPackage.png

四、小結

到這裡,我好奇的地方就得到了解決,在來回顧一下這些細節。

  1. drone 主要用於 Android 開源庫的管理。
  2. drone 可以自動操作 Gradle dependencies。
  3. drone 維護的 50+ 的開源庫,所有的資訊維護在另外一個庫中,drone-hive。
  4. drone-hive 維護了這些開源庫的資訊,在不同庫的 xxx/xxx.json 檔案中。
  5. 根據在 hive 中配置的 repository 型別,使用不同的方式,獲取穩定版版本號。
  6. 最終使用 io 操作,修改我們指定 Module 的 build.gradle 檔案。

今天在承香墨影公眾號的後臺,回覆『成長』。我會送你一些我整理的學習資料。

點贊或者分享吧~

相關文章