BuildConfig.VersionCode更新到AGP 3.2.0后未反映实际的versionCode

时间:2018-09-25 16:13:07

标签: android gradle android-gradle

更新为AGP(Android Gradle插件)3.2.0后,我们无法直接在versionCode上设置mergedFlavor。如果这样做,我们会收到以下有用警告:

versionCode cannot be set on a mergedFlavor directly.
versionCodeOverride can instead be set for variant outputs using the following syntax:
android {
    applicationVariants.all { variant ->
        variant.outputs.each { output ->
            output.versionCodeOverride = 40805
        }
    }
}

此更改之后,除了一件小事情,其他所有东西都可以正常工作。自动生成的BuildConfig.VERSION_CODE不能反映output.versionCodeOverride = 40805中的版本代码。

在AGP 3.2.0之前,我们可以通过以下方式动态设置versionCode:

applicationVariants.all { v ->
        v.mergedFlavor.versionCode = 40805 // 40805 is hardcoded as an example but it is archived dynamically.
    }

并且版本代码反映在BuildConfig.VERSION_CODE中(这非常方便),我想使用AGP 3.2.0将其存档。

我知道我可以通过为此创建自定义构建配置字段来解决此问题,例如variant.buildConfigField('int', 'OVERRIDDEN_VERSION_CODE', "${versionCodeOverride}"),这将生成带有我覆盖的versionCode的BuildConfig.OVERRIDDEN_VERSION_CODE。通过设置versionCodemergedFlavor.versionCode = 40805来存档与使用AGP 3.2.0版以下版本时的存档相同,但是我不喜欢这种解决方法。

有什么方法可以使output.versionCodeOverride = 40805反映在自动生成的BuildConfig.VERSION_CODE中?

PS:如果我们直接将versionCode设置为特定的风味,它将按预期工作,但这不是我想知道的:)

更新

发现了一个类似的问题(使用案例得到了很好的描述),考虑到我们的讨论,我可以给出一个更好的答案here

2 个答案:

答案 0 :(得分:2)

那里的指示顺序很重要...

String versionName = version.versionName
int versionCode = version.versionCode

android {
    applicationVariants.all { variant ->

        // to be removed here:
        // variant.mergedFlavor.versionCode = versionCode

        variant.outputs.each { output ->

            // and to be added here:
            output.versionNameOverride = versionName
            output.versionCodeOverride = versionCode
        }
    }
}

Build multiple APKs的文档在“配置版本控制”下对其进行了解释。

原因不是构建工具3.2.0,而是Gradle 4.6。

答案 1 :(得分:2)

回顾一下,问题不在于根本没有应用版本代码替代,而是BuildConfig.VERSION_CODE没有选择替代值。

此问题已在官方问题跟踪器中标记为预期的行为:https://issuetracker.google.com/issues/37008496

其中一条评论解释了原因,并建议以一种口味而不是versionCode来定义defaultConfig

  

如果我们为每个输出创建一个不同的buildconfig.java,那么我们还需要为每个拆分运行javac / proguard / jacoco / dex,并且我们会失去构建[时间]上的改进。

     

如果这对您很重要,则不要使用拆分,而要使用口味,但是我们会大大减少构建时间。

如果您不想更改当前的设置,则可能需要从清单中读取版本代码。您只需要一个上下文:

val versionCode = context.packageManager.getPackageInfo(context.packageName, 0).versionCode

您应该缓存该值,因为获取包信息不是一件容易的事。

版本名称也是如此。