我有一个 Gradle 构建脚本,它使用注释处理器 (Android Annotations) 生成代码。在我添加新的 Pro Flavor 之前,构建一直很好。我可以构建 Free 风格,但是当我构建 Pro 风格时,注释处理器没有运行。这会导致缺少代码并且构建失败。
这是我的脚本:
buildscript {
repositories {
maven { url 'http://repo1.maven.org/maven2' }
}
dependencies {
classpath 'com.android.tools.build:gradle:0.5.+'
}
}
apply plugin: 'android'
repositories {
mavenCentral()
maven {
url 'https://oss.sonatype.org/content/repositories/snapshots/'
}
}
ext.androidAnnotationsVersion = '3.0-SNAPSHOT';
configurations {
apt
}
dependencies {
compile files('libs/android-support-v13.jar')
compile fileTree(dir: 'libs', include: '*.jar')
apt "org.androidannotations:androidannotations:${androidAnnotationsVersion}"
compile "org.androidannotations:androidannotations-api:${androidAnnotationsVersion}"
}
android {
compileSdkVersion 17
buildToolsVersion "17.0.0"
defaultConfig {
minSdkVersion 7
targetSdkVersion 17
versionCode 29
versionName "2.0.3"
packageName "com.MyCompany.MyApp"
}
productFlavors {
free {
buildConfig "final public static boolean PRO_VERSION = false;"
}
pro {
packageName "com.MyCompany.MyApp.Pro"
versionName (versionName + ".Pro")
buildConfig "final public static boolean PRO_VERSION = true;"
}
}
buildTypes {
release {
buildConfig "final public static String BASE_URL = \"http://data.MyCompany.com/\";", \
"final public static String APP_NAME = \"com.MyCompany.MyApp\";"
}
debug {
buildConfig "final public static String BASE_URL = \"http://192.168.1.15/GDM/\";", \
"final public static String APP_NAME = \"com.MyCompany.MyApp\";"
}
}
}
def getSourceSetName(variant) {
return new File(variant.dirName).getName();
}
android.applicationVariants.all { variant ->
def aptOutputDir = project.file("build/source/apt")
def aptOutput = new File(aptOutputDir, variant.dirName)
println "****************************"
println "variant: ${variant.name}"
println "manifest: ${variant.processResources.manifestFile}"
println "aptOutput: ${aptOutput}"
println "****************************"
android.sourceSets[getSourceSetName(variant)].java.srcDirs+= aptOutput.getPath()
variant.javaCompile.options.compilerArgs += [
'-processorpath', configurations.apt.getAsPath(),
'-AandroidManifestFile=' + variant.processResources.manifestFile,
'-s', aptOutput
]
variant.javaCompile.source = variant.javaCompile.source.filter { p ->
return !p.getPath().startsWith(aptOutputDir.getPath())
}
variant.javaCompile.doFirst {
aptOutput.mkdirs()
}
}
构建免费变体时,注释处理器按照gradle输出中的以下指示运行:
Note: Starting AndroidAnnotations annotation processing
构建 Pro 变体时,注释处理器不运行,因此对生成代码的引用失败。
奇怪的是,我发现(真的是偶然地)如果我从脚本中删除 packageName "com.MyCompany.MyApp.Pro"
....注释处理器运行它将正确构建。我需要更新 Google Play 的包名称。
在 android studio 中查看时,您可以看到 apt(注释处理工具)显示 Pro 版本处于 Activity 状态,即使我有 FreeDebug build选择的变体。我不确定这是否表示存在问题,或者这是否只是 beta android studio(Android Studio 版本:0.2.13)的问题。因此,请对此持保留态度。
我是 gradle 构建系统的新手,但我认为我已经掌握了它的窍门。我一遍又一遍地查看脚本,但不明白为什么注释处理器没有为 pro 变体运行。除了使用 --info 和 --debug 参数运行包装器之外,我还不知道如何调试这些问题。
我已经使用 -info 和 -debug 运行 gradle wrapper 以获得扩展输出,但没有任何其他错误(或丢失的项目)直到它到达由缺少生成的代码引起的错误。所以这让我相信这只是一个事实,即 androidannotations 没有使用那个是根本问题的变体运行。 (也就是说,我不认为这是由上游的某些东西引起的错误,后来被误报了。不过我可能是错的)
我真的很茫然,现在已经坚持了 2 天。
最佳答案
我能够解决问题。在仔细查看 gradle 包装器的 -info 输出后,我发现 androidAnnotations 正在尝试运行。错误输出的顺序不正确,因为注释处理消息在引用不存在的代码(由于注释处理失败而不存在)导致的错误之后出现。
这是日志:
:MyCompany:compileProDebug
....\src\main\java\com\MyCompany\MyApp\Activities\activityMain.java:14: error: cannot find symbol
import com.MyCompany.MyApp.Notifications.NotificationSetupActivity_;
^
symbol: class NotificationSetupActivity_
location: package com.MyCompany.MyApp.Notifications
....\src\main\java\com\MyCompany\MyApp\Activities\activityMain.java:24: error: cannot find symbol
import com.MyCompany.MyApp.FantasyScores.ActivityScores_;
^
symbol: class ActivityScores_
location: package com.MyCompany.MyApp.Scores
....\src\main\java\com\MyCompany\MyApp\Activities\activityMain.java:32: error: cannot find symbol
import com.MyCompany.MyApp.Team.activityTeamSelect_;
^
symbol: class activityTeamSelect_
location: package com.MyCompany.MyApp.Team
Note: Starting AndroidAnnotations annotation processing
Note: AndroidManifest.xml file found: ....\build\manifests\pro\debug\AndroidManifest.xml
error: The generated com.MyCompany.MyAppPro.R class cannot be found
Note: Time measurements: [Whole Processing = 190 ms], [Extract Manifest = 129 ms], [Extract Annotations = 49 ms],
....\src\main\java\com\MyCompany\MyApp\Activities\activityMain.java:14: error: cannot find symbol
import com.MyCompany.MyApp.Notifications.NotificationSetupActivity_;
重要的几行是:
注意:启动AndroidAnnotations注解处理
注意:AndroidManifest.xml 文件找到:....\build\manifests\pro\debug\AndroidManifest.xml
错误:找不到生成的 com.MyCompany.MyAppPro.R 类
这些应该是错误日志中的第一个,因为注释处理器在完整编译步骤之前运行,但由于某种原因它们被深埋(可能是 androidannotations 处理器中的刷新问题??)
无论如何,找不到 com.MyCompany.MyAppPro.R
的第三行是关键。资源实际上在 com.MyCompany.MyApp.R
(无 Pro)中。经过一番挖掘,我发现了 this post这表明这是 AndroidAnnotations 的一个已知问题。
我能够通过将 '-AresourcePackageName=MyBasePackageName',
参数添加到构建脚本来解决该问题。 注意:这仅在您使用 3.0 快照时有效。最新发布的 AndroidAnnotations 版本不支持 -AresourcePackageName 选项。
添加参数后,所有变体都能正确构建。
构建脚本的 compilerArgs 部分现在如下所示:
variant.javaCompile.options.compilerArgs += [
'-processorpath', configurations.apt.getAsPath(),
'-AandroidManifestFile=' + variant.processResources.manifestFile,
'-AresourcePackageName=MyBasePackageName',
'-s', aptOutput
]
希望这能帮助其他人在将来避免这个问题。
关于android - Gradle + Annotations + Flavors = 不会运行注释处理器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19351168/