【Android Gradle 插件】Android Studio 工程 Gradle 构建流程 ② ( settin
一、settings.gradle 构建脚本分析1、Maven 长途堆栈配置
pluginManagement 脚本块 ,
[*]用于 配置 Gradle 插件的 Maven 堆栈 ,
[*]配置的是 构建过程 中 , 使用的堆栈 ;
dependencyResolutionManagement 脚本块 ,
[*]用于 配置 依靠 的 Maven 堆栈 ,
[*]配置的是 工程 或 模块 下的依靠使用的堆栈 ;
在 dependencyResolutionManagement 脚本块 中 定义的 repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS) 代码的寄义是 解析依靠时 , 只能使用本脚本块中的 Maven 堆栈 , 不能使用 Module 子项目中的依靠 ;
repositoriesMode 模式有两种 :
[*]RepositoriesMode.PREFER_PROJECT : 解析依靠库时 , 优先使用当地堆栈 , 当地堆栈没有该依靠 , 则使用长途堆栈 ;
[*]RepositoriesMode.FAIL_ON_PROJECT_REPOS : 解析依靠库时 , 强行使用长途堆栈 , 不管当地堆栈有没有该依靠库 ;
参考之前的 【Android Gradle 插件】Android 依靠管理 ② ( 为工程配置依靠堆栈 | 为工程构建添加依靠堆栈 | classpath 引入依靠库 | 配置依靠堆栈 ) 博客中的配置 ,
[*]pluginManagement 脚本块中的 repositories 配置 , 对应之前的 buildscript 中的 repositories 配置 ;
[*]dependencyResolutionManagement 脚本块中的 repositories 配置 , 对应之前的 allprojects 中的 repositories 配置 ;
https://img-blog.csdnimg.cn/850f72aed53945e0a15c48c743bec835.png
2、目次配置
settings.gradle 构建脚本中的目次设置 :
[*]rootProject.name 用于指定工程根目次 , 在该目次下有一个 build.gradle 构建脚本 , 声明后会自动实行该构建脚本 ;
rootProject.name = "LiveDataDemo"
[*]include 用于指定子项目 , 在子项目中也有一个 build.gradle 构建脚本 , 声明后会自动实行该构建脚本 ;
include ':app'
3、完备代码示例
完备代码示例 :
pluginManagement {
repositories {
gradlePluginPortal()
google()
mavenCentral()
}
}
dependencyResolutionManagement {
repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
repositories {
google()
mavenCentral()
}
}
rootProject.name = "LiveDataDemo"
include ':app'
二、根目次下 build.gradle 构建脚本分析
根目次下 build.gradle 构建脚本如下 :
// Top-level build file where you can add configuration options common to all sub-projects/modules.
plugins {
id 'com.android.application' version '7.3.1' apply false
id 'com.android.library' version '7.3.1' apply false
id 'org.jetbrains.kotlin.android' version '1.7.20' apply false
}
在 plugins 中使用
id 'com.android.application' version '7.3.1' apply false
配置 Gradle 插件 , 下面分析每个配置的寄义 :
[*]引入 com.android.application 插件 ,
[*]version '7.3.1' 说明引入插件的版本号 ,
[*]apply false 表示当前不会马上引用该插件 , 在 Module 子项目 中使用到该插件时 , 才气正式应用 ;
在此处 主要是为了说明 Gradle 插件的版本 , 没有其它寄义 ;
如 : 在 Module 子项目中 , 有如下配置 :
plugins {
id 'com.android.application'
id 'org.jetbrains.kotlin.android'
}
则会立刻应用 com.android.application 和 org.jetbrains.kotlin.android Gradle 插件 , 此处就不会有插件版本了 ;
在之前的 build.gradle 配置 中 , 在 " buildscript / dependencies / classpath " 中 , 配置 Android Gradle 插件版本 是 4.2.1 , 也就是
[*]com.android.application
[*]com.android.library
插件 的 版本 ;
buildscript {
repositories {
google()
jcenter()
}
dependencies {
classpath 'com.android.tools.build:gradle:4.2.1'
}
}
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页:
[1]