- 在终端经过Gradle命令执行Lint检查。
- 在编译时进行lint检查。
Android Studio中Project目录下有两个文件gradlew和gradlew.bat分别是在Mac/Linux系统和Windows系统上的Gradle命令工具。在Mac系统Project目录下执行./gradlew -p ${module_dir} lint命令,就能够执行对指定module按照Android Studio默认支持的扫描规则进行Lint检查。html
Gradle提供了名为lintOptions的插件对Lint扫描进行个性化配置。android
在${module_dir}/build.gradle文件android块内使用DSL对象lintOptions对Lint进行配置,配置项能够参考Android Plugin DSL Reference: LintOptions。git
android {
lintOptions {
// true--关闭lint报告的分析进度
quiet true
// true--错误发生后中止gradle构建
abortOnError false
// true--只报告error
ignoreWarnings true
// true--忽略有错误的文件的全/绝对路径(默认是true)
//absolutePaths true
// true--检查全部问题点,包含其余默认关闭项
checkAllWarnings true
// true--全部warning当作error
warningsAsErrors true
// 关闭指定问题检查
disable 'TypographyFractions','TypographyQuotes'
// 打开指定问题检查
enable 'RtlHardcoded','RtlCompat', 'RtlEnabled'
// 仅检查指定问题
check 'NewApi', 'InlinedApi'
// true--error输出文件不包含源码行号
noLines true
// true--显示错误的全部发生位置,不截取
showAll true
// 回退lint设置(默认规则)
lintConfig file("default-lint.xml")
// true--生成txt格式报告(默认false)
textReport true
// 重定向输出;能够是文件或'stdout'
textOutput 'stdout'
// true--生成XML格式报告
xmlReport false
// 指定xml报告文档(默认lint-results.xml)
xmlOutput file("lint-report.xml")
// true--生成HTML报告(带问题解释,源码位置,等)
htmlReport true
// html报告可选路径(构建器默认是lint-results.html )
htmlOutput file("lint-report.html")
// true--全部正式版构建执行规则生成崩溃的lint检查,若是有崩溃问题将中止构建
checkReleaseBuilds true
// 在发布版本编译时检查(即便不包含lint目标),指定问题的规则生成崩溃
fatal 'NewApi', 'InlineApi'
// 指定问题的规则生成错误
error 'Wakelock', 'TextViewEdits'
// 指定问题的规则生成警告
warning 'ResourceAsColor'
// 忽略指定问题的规则(同关闭检查)
ignore 'TypographyQuotes'
}
}
复制代码
下面前三条所涉及的配置项,后面跟的参数都是issue_id,这些ID值跟lint.xml文件中使用的ID是同一个集合。github
配置Gradle脚本可实现编译Android工程时执行Lint检查:好处是既能够尽早发现问题,又能够有强制性;缺点是对编译速度有必定的影响。api
编译Android工程执行的是assemble任务,让assemble依赖lint任务,便可在编译时执行Lint检查;同时配置LintOptions,发现Error级别问题时中断编译。app
android.applicationVariants.all { variant ->
variant.outputs.each { output ->
def lintTask = tasks["lint${variant.name.capitalize()}"]
output.assemble.dependsOn lintTask
}
}
复制代码
android.libraryVariants.all { variant ->
variant.outputs.each { output ->
def lintTask = tasks["lint${variant.name.capitalize()}"]
output.assemble.dependsOn lintTask
}
}
复制代码