Skip to content

Commit

Permalink
Update Lint checks for Kotlin consumers
Browse files Browse the repository at this point in the history
  • Loading branch information
John Rodriguez committed Aug 8, 2021
1 parent b04d9ef commit 3b41c5d
Show file tree
Hide file tree
Showing 2 changed files with 494 additions and 68 deletions.
16 changes: 10 additions & 6 deletions timber-lint/src/main/java/timber/lint/WrongTimberUsageDetector.kt
Original file line number Diff line number Diff line change
Expand Up @@ -74,7 +74,10 @@ class WrongTimberUsageDetector : Detector(), UastScanner {
val methodName = node.methodName
val evaluator = context.evaluator

if ("format" == methodName && evaluator.isMemberInClass(method, "java.lang.String")) {
if ("format" == methodName &&
(evaluator.isMemberInClass(method, "java.lang.String") ||
evaluator.isMemberInClass(method, "kotlin.text.StringsKt__StringsJVMKt"))
) {
checkNestedStringFormat(context, node)
return
}
Expand Down Expand Up @@ -122,8 +125,9 @@ class WrongTimberUsageDetector : Detector(), UastScanner {
}
if (current.isMethodCall()) {
val psiMethod = (current as UCallExpression).resolve()
if (Pattern.matches(TIMBER_TREE_LOG_METHOD_REGEXP, psiMethod!!.name)
&& context.evaluator.isMemberInClass(psiMethod, "timber.log.Timber")
if (psiMethod != null &&
Pattern.matches(TIMBER_TREE_LOG_METHOD_REGEXP, psiMethod.name)
&& isTimberLogMethod(psiMethod, context.evaluator)
) {
context.report(
Incident(
Expand Down Expand Up @@ -616,15 +620,15 @@ class WrongTimberUsageDetector : Detector(), UastScanner {
3 -> {
val msg = arguments[1]
val throwable = arguments[2]
fixSource1 += "$methodName(${throwable.asSourceString()}, ${msg.asSourceString()})"
fixSource2 += "$methodName(${throwable.asSourceString()}, ${msg.asSourceString()})"
fixSource1 += "$methodName(${throwable.sourcePsi?.text}, ${msg.asSourceString()})"
fixSource2 += "$methodName(${throwable.sourcePsi?.text}, ${msg.asSourceString()})"
}
else -> {
throw IllegalStateException("android.util.Log overloads should have 2 or 3 arguments")
}
}

val logCallSource = logCall.asSourceString()
val logCallSource = logCall.uastParent!!.sourcePsi?.text
return fix().group()
.add(
fix().replace().text(logCallSource).shortenNames().reformat(true).with(fixSource1).build()
Expand Down
Loading

0 comments on commit 3b41c5d

Please sign in to comment.