前言
為了精簡(jiǎn)目前底層的基礎(chǔ)組件庫(kù), 拆分出必要依賴項(xiàng)目(有一定精簡(jiǎn))和完全的依賴項(xiàng)目,
第一想法是在library上構(gòu)建變種(Variant)版本, 一次發(fā)布所有的變種,在研究了一些相關(guān)的資料后,
最后完美解決
基礎(chǔ)部署到maven倉(cāng)庫(kù)
我們可以通過(guò)gradle部署到遠(yuǎn)程或者本地的maven倉(cāng)庫(kù),
首先添加maven插件, 然后我們通過(guò)updaloadArchives任務(wù)自動(dòng)生成POM文件, 并打包部署到指定的倉(cāng)庫(kù)中
apply plugin: 'maven' // 添加maven插件
uploadArchives {
repositories {
mavenDeployer {
repository(url: "maven倉(cāng)庫(kù)地址")
}
}
}
當(dāng)然我們也可以通過(guò)authentication來(lái)添加服務(wù)器的認(rèn)證信息, 也可以定義快照(snapshot)倉(cāng)庫(kù)
apply plugin: 'maven' // 添加maven插件
uploadArchives {
repositories {
mavenDeployer {
repository(url: "maven倉(cāng)庫(kù)地址"){
authentication(userName: "yourUserName", password: "yourPsw")
}
snapshotRepository(url: "maven snapshot倉(cāng)庫(kù)地址"){
authentication(userName: "yourUserName", password: "yourPsw")
}
}
}
POM文件的自定義
我們可以針對(duì)POM做自定義處理, 最常見的就是設(shè)置版本號(hào)等等
apply plugin: 'maven' // 添加maven插件
uploadArchives {
repositories {
mavenDeployer {
repository(url: "maven倉(cāng)庫(kù)地址")
}
pom.groupId = "com.maven.test"
pom.artifactId = "myLibrary"
pom.version = "1.0.0"
pom.packaging = "aar"
}
}
針對(duì)上面的設(shè)置, 我們依賴引用的就應(yīng)該是
implementation "com.maven.test:myLibrary:1.0.0"
Maven默認(rèn)每個(gè)項(xiàng)目只會(huì)處理一個(gè)artifact, 當(dāng)我們library沒有設(shè)置productFlavor和buildType時(shí), 默認(rèn)上傳的是release的variant.
當(dāng)我們兩個(gè)variant代碼不同, 依賴不同時(shí), 需要生產(chǎn)不同的POM進(jìn)行上傳,這種情況下我們需要顯示聲明每個(gè)artifact, 并針對(duì)每個(gè)POM進(jìn)行自定義上傳.
在這方面我們可以分別參考MavenDeployer和MavenPom開放的API
// 上略
mavenDeployer {
repository(url: "倉(cāng)庫(kù)地址")
android.libraryVariants.all {variant->
def isFlavor = !variant.flavorName.isEmpty()
def _name = "${variant.name}"
// 生成多個(gè)pom
addFilter(_name){artifact, file->
true
}
// 對(duì)應(yīng)pom屬性設(shè)置
pom(_name).artifactId = project.archivesBaseName + "-" + _name
pom(_name).version = "1.0.0"
pom(_name).groupId = "com.maven.test"
pom(_name).packaging = 'aar'
// 自定義pom的依賴集
pom(_name).withXml{
def root = asNode()
def depsNode = root["dependencies"][0] ?: root.appendNode("dependencies")
def addDep = {
if (it.group == null) return // Avoid empty dependency nodes
def dependencyNode = depsNode.appendNode('dependency')
dependencyNode.appendNode('groupId', it.group)
dependencyNode.appendNode('artifactId', it.name)
dependencyNode.appendNode('version', it.version)
if (it.hasProperty('optional') && it.optional) {
dependencyNode.appendNode('optional', 'true')
}
}
// 添加基本依賴
configurations.api.allDependencies.each addDep
configurations.implementation.allDependencies.each addDep
// 添加特殊依賴
if (isFlavor) {
configurations["${_name}Implementation"].allDependencies.each addDep
def flavorName = variant.flavorName
configurations["${flavorName}Implementation"].allDependencies.each addDep
configurations["${_name}Api"].allDependencies.each addDep
configurations["${flavorName}Api"].allDependencies.each addDep
}
}
}
}
相關(guān)demo可以看這里
依賴對(duì)應(yīng)的組件庫(kù)
在成功發(fā)布后, 我們倉(cāng)庫(kù)內(nèi)容應(yīng)該如下圖

假設(shè)我們的flavor分別為full和simple,當(dāng)我們?nèi)ヒ蕾嚨臅r(shí)候, 就可以通過(guò)
fullReleaseImplementation "com.maven.test:libraryNameFullRelease:1.0.0"
fullDebugImplementation "com.maven.test:libraryNameFullDebug:1.0.0"
simpleReleaseImplementation "com.maven.test:libraryNameSimpleRelease:1.0.0"