KSLog/src/commonMain/kotlin/KSLog.kt

82 lines
2.4 KiB
Kotlin
Raw Normal View History

2022-06-07 15:42:19 +00:00
package dev.inmo.kslog.common
enum class LogLevel {
2022-06-08 15:45:37 +00:00
DEBUG,
2022-06-07 15:42:19 +00:00
VERBOSE,
INFO,
WARNING,
ERROR,
ASSERT,
}
interface KSLog {
fun performLog(level: LogLevel, tag: String?, message: String, throwable: Throwable?)
2022-06-09 03:56:27 +00:00
fun performLog(level: LogLevel, message: String, throwable: Throwable?) = performLog(level, null, message, throwable)
fun performLog(
level: LogLevel,
tag: String?,
throwable: Throwable?,
messageBuilder: () -> String
) = performLog(level, tag, messageBuilder(), throwable)
suspend fun performLog(
level: LogLevel,
tag: String?,
throwable: Throwable?,
messageBuilder: suspend () -> String
) = performLog(level, tag, messageBuilder(), throwable)
2022-06-07 15:42:19 +00:00
companion object : KSLog {
private var defaultLogger: KSLog? = null
2022-06-07 15:52:42 +00:00
var default: KSLog
2022-06-07 15:42:19 +00:00
get() {
return defaultLogger ?: KSLog("app").also {
defaultLogger = it
}
}
set(value) {
defaultLogger = value
}
2022-06-07 15:52:42 +00:00
override fun performLog(level: LogLevel, tag: String?, message: String, throwable: Throwable?) = default.performLog(level, tag, message, throwable)
2022-06-07 15:42:19 +00:00
}
}
operator fun KSLog.invoke(performLogCallback: (level: LogLevel, tag: String?, message: String, throwable: Throwable?) -> Unit) = CallbackKSLog(performLogCallback)
expect fun KSLog(
2022-06-07 15:42:19 +00:00
defaultTag: String,
filter: MessageFilter = { _, _, _, _ -> true },
messageFormatter: MessageFormatter = defaultMessageFormatter
): KSLog
2022-06-07 15:42:19 +00:00
fun KSLog(
defaultTag: String,
levels: Iterable<LogLevel>,
messageFormatter: MessageFormatter = defaultMessageFormatter
2022-06-08 10:06:41 +00:00
): KSLog {
val levels = levels.toSet()
return KSLog (defaultTag, { l, _, _, _ ->
2022-06-08 10:06:41 +00:00
l in levels
}, messageFormatter)
2022-06-07 15:42:19 +00:00
}
2022-06-07 16:00:32 +00:00
2022-06-08 12:23:11 +00:00
fun KSLog(
2022-06-08 10:10:34 +00:00
defaultTag: String,
firstLevel: LogLevel,
secondLevel: LogLevel,
vararg otherLevels: LogLevel,
messageFormatter: MessageFormatter = defaultMessageFormatter,
): KSLog = KSLog(defaultTag, setOf(firstLevel, secondLevel, *otherLevels), messageFormatter)
2022-06-08 10:10:34 +00:00
2022-06-07 16:00:32 +00:00
fun KSLog(
defaultTag: String,
minLoggingLevel: LogLevel,
messageFormatter: MessageFormatter = defaultMessageFormatter,
): KSLog = KSLog (
defaultTag,
{ l, _, _, _ ->
minLoggingLevel.ordinal <= l.ordinal
},
messageFormatter
)