微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

timber lint:ClassNotFound:com / android / tools / lint / detector / api / Detector $JavaPsiScanner

Timber(V 4.5.0)lint检查仅通过Gradle工作(但不是通过lint命令,也不是在Android Studio版本2.3 Beta2中).

摘要

当我直接在命令行上运行lint时,我收到一个错误.

lint --show TimberArgCount

Could not load custom rule jar file /home/tmtron/.android/lint/timber-lint.jar
java.lang.NoClassDefFoundError: com/android/tools/lint/detector/api/Detector$JavaPsiScanner

但是当我通过gradle调用它时它可以工作:

./gradlew lint

MainActivity.java:15: Error: Wrong argument count,format string %s.%s requires 2 but format call supplies 1 [TimberArgCount]
        Timber.d("%s.%s","onCreate");
        ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

详细说明

我在GitHub上做了一个小样本项目:TimberLintTest

基本上我这样做了:

>在Android Studio中创建了一个简单的Android项目
>添加了木材
>为lint错误激活stdout输出

android {
    lintOptions {
        textReport是的
        textoutput“stdout”
    }
}

MainActivity中,我使用了一个错误的日志语句,如下所示:

Timber.d("%s.%s","onCreate");

当我从命令行通过Gradle-wrapper执行lint时,它按预期工作 – 剥离输出

MainActivity.java:15: Error: Wrong argument count,"onCreate");
        ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

但是这些检查在Android Studio中不起作用,也不能直接启动lint.
互联网上的一些消息来源表明我们必须将lint.jar文件复制到〜/ .android / lint.我为lint.jar(来自timber-4.5.0)做了那个并将它重命名为timber-lint.jar,所以我最终得到了这个文件

~/.android/lint/timber-lint.jar

所以问题是找不到这个JavaPsiScanner接口.

我检查了Timber源代码,它取决于lint-api-25.0.2,其中Detector包含这个内部接口.但是在我的本地SDK代码(Android / Sdk / tools / lib / lint-api.jar)中,这个内部类不存在(我猜这是lint命令行工具和Android Studio使用的).

所以我认为这只是一个版本不匹配.但我不知道如何解决这个问题.
我怎么能确定,我目前的android工具有哪个版本的lint-api.jar?

启动sdk管理器时,它显示Android SDK Tools版本为25.2.5(我已更新到最新版本).那么这是lint-api.jar的版本(或者是SDK平台工具,SDK构建工具,……)?

解决方法

作为一种解决方法,我们可以告诉gradle在编译后始终运行lint检查.然后,在Android Studio中按Build – Make Project后,也将执行lint检查,这解决了我原来的问题.

Gradle详细信息在this SO-answer.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐