水军大提督 发表于 2024-7-24 08:14:16

【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]
查看完整版本: 【Android Gradle 插件】Android Studio 工程 Gradle 构建流程 ② ( settin