android 我可以在我的java库上使用Timber Logger吗?

6ljaweal  于 2022-12-25  发布在  Android
关注(0)|答案(4)|浏览(270)

我将Timber依赖项添加到Java核心库模块build.gradle文件中:

implementation 'com.jakewharton.timber:timber:4.6.0'

虽然在Gradle同步时没有给予错误,但我无法在Core Library中看到或使用Timber类。

jxct1oxe

jxct1oxe1#

Timber依赖于android.util.Log,因此无法在纯Java模块中使用。
有人提议将库与Android分离,但库的创建者决定反对。https://github.com/JakeWharton/timber/pull/63
Timber的5.0.0-SNAPSHOT版本现在通过使用jdk工件支持在Java模块中使用。

<dependency>
  <groupId>com.jakewharton.timber</groupId>
  <artifactId>timber-jdk</artifactId>
  <version>5.0.0-SNAPSHOT</version>
</dependency>
5lhxktic

5lhxktic2#

如果有人在多模块Android项目中寻找Timber(无Android依赖),请使用timber-jdk,如下所示。
在项目的build.gradle文件中。

allprojects {
    repositories {
        maven { url 'https://oss.sonatype.org/content/repositories/snapshots/' }
    }
}

在单个模块build.gradle文件中(例如:域或远程模块)

implementation "com.jakewharton.timber:timber-jdk:5.0.0-SNAPSHOT"

有了这个,你应该能够实现Timber而不依赖android框架

vfwfrxfs

vfwfrxfs3#

如果您有多模块项目,您可以在纯Java/Kotlin中使用Timber,只涉及一点点抽象,没有外部库。
Kotlin和Koin的示例:

在pureKotlin模块中创建一个大的冒名顶替者Timber.kt:

interface ILogger {
    fun d(message: String)
    fun e(message: String)
    fun e(throwable: Throwable, message: String)
    fun i(message: String)
}

object Timber: ILogger, KoinComponent {

    private val logger: ILogger by inject()

    override fun d(message: String) = logger.d(message)
    override fun e(message: String) = logger.e(message)
    override fun e(throwable: Throwable, message: String) = logger.e(throwable, message)
    override fun i(message: String) = logger.i(message)
}

在应用模块中创建TimberLogger.kt:

import timber.log.Timber

class TimberLogger : ILogger {

    override fun d(message: String) = Timber.d(message) // this is real timber this time
    override fun e(message: String) = Timber.e(message)
    override fun e(throwable: Throwable, message: String) = Timber.e(throwable, message)
    override fun i(message: String) = Timber.i(message)
}

在应用模块中,将TimberLogger实现注入到您的假Timber中:

val appModule = module {

    single<ILogger> { TimberLogger() }
}

现在您可以从任何地方静态地调用Timber.d(“message”)。
如果你有2个以上的纯模块可以使用Timber,可以考虑创建Utils模块,并将其包含在其余模块中,这样它就可以在任何地方使用。

epfja78i

epfja78i4#

尝试Arbor:KotlinMultiplatform的类似木材的日志记录实现。
https://github.com/ToxicBakery/Arbor

相关问题