【Android Gradle 插件】Android Studio 工程 Gradle 构建流程 ② ( settin ...

打印 上一主题 下一主题

主题 815|帖子 815|积分 2445

一、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 配置 ;


2、目次配置


settings.gradle 构建脚本中的目次设置 :


  • rootProject.name 用于指定工程根目次 , 在该目次下有一个 build.gradle 构建脚本 , 声明后会自动实行该构建脚本 ;
  1.         rootProject.name = "LiveDataDemo"
复制代码


  • include 用于指定子项目 , 在子项目中也有一个 build.gradle 构建脚本 , 声明后会自动实行该构建脚本 ;
  1.         include ':app'
复制代码

3、完备代码示例


完备代码示例 :
  1. pluginManagement {
  2.     repositories {
  3.         gradlePluginPortal()
  4.         google()
  5.         mavenCentral()
  6.     }
  7. }
  8. dependencyResolutionManagement {
  9.     repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
  10.     repositories {
  11.         google()
  12.         mavenCentral()
  13.     }
  14. }
  15. rootProject.name = "LiveDataDemo"
  16. include ':app'
复制代码




二、根目次下 build.gradle 构建脚本分析



根目次下 build.gradle 构建脚本如下 :
  1. // Top-level build file where you can add configuration options common to all sub-projects/modules.
  2. plugins {
  3.     id 'com.android.application' version '7.3.1' apply false
  4.     id 'com.android.library' version '7.3.1' apply false
  5.     id 'org.jetbrains.kotlin.android' version '1.7.20' apply false
  6. }
复制代码
在 plugins 中使用
  1. id 'com.android.application' version '7.3.1' apply false
复制代码
配置 Gradle 插件 , 下面分析每个配置的寄义 :


  • 引入 com.android.application 插件 ,
  • version '7.3.1' 说明引入插件的版本号 ,
  • apply false 表示当前不会马上引用该插件 , 在 Module 子项目 中使用到该插件时 , 才气正式应用 ;
在此处 主要是为了说明 Gradle 插件的版本 , 没有其它寄义 ;

如 : 在 Module 子项目中 , 有如下配置 :
  1. plugins {
  2.     id 'com.android.application'
  3.     id 'org.jetbrains.kotlin.android'
  4. }
复制代码
则会立刻应用 com.android.application 和 org.jetbrains.kotlin.android Gradle 插件 , 此处就不会有插件版本了 ;

在之前的 build.gradle 配置 中 , 在 " buildscript / dependencies / classpath " 中 , 配置 Android Gradle 插件版本 是 4.2.1 , 也就是


  • com.android.application
  • com.android.library
插件 的 版本 ;
  1. buildscript {
  2.     repositories {
  3.         google()
  4.         jcenter()
  5.     }
  6.     dependencies {
  7.         classpath 'com.android.tools.build:gradle:4.2.1'
  8.     }
  9. }
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

水军大提督

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表