From 8b7e1f7020133e7a4601dd90fac0b459624df49e Mon Sep 17 00:00:00 2001 From: dankito Date: Sun, 6 Dec 2020 21:06:03 +0100 Subject: [PATCH] Implemented that on Android whole message gets logged (LogCat at maximum prints 4076 bytes per message) --- .../utils/multiplatform/log/Slf4jLogger.kt | 22 +++++++++++++++++-- 1 file changed, 20 insertions(+), 2 deletions(-) diff --git a/common/src/jvmMain/kotlin/net/dankito/utils/multiplatform/log/Slf4jLogger.kt b/common/src/jvmMain/kotlin/net/dankito/utils/multiplatform/log/Slf4jLogger.kt index 64f197bd..339929d7 100644 --- a/common/src/jvmMain/kotlin/net/dankito/utils/multiplatform/log/Slf4jLogger.kt +++ b/common/src/jvmMain/kotlin/net/dankito/utils/multiplatform/log/Slf4jLogger.kt @@ -1,7 +1,16 @@ package net.dankito.utils.multiplatform.log +import net.dankito.utils.multiplatform.os.OsHelper + + +open class Slf4jLogger(protected val slf4jLogger: org.slf4j.Logger, protected val osHelper: OsHelper = OsHelper()) : Logger { + + companion object { + + const val MaxLogCatMessageLength = 4 * 1024 + + } -open class Slf4jLogger(protected val slf4jLogger: org.slf4j.Logger) : Logger { override val name: String get() = slf4jLogger.name @@ -87,7 +96,16 @@ open class Slf4jLogger(protected val slf4jLogger: org.slf4j.Logger) : Logger { val args = determineArguments(exception, arguments) - logOnLevel(message, args) + if (osHelper.isRunningOnAndroid && message.length > MaxLogCatMessageLength) { + var index = 0 + // as LogCat only prints at maximum 4076 bytes per message, break up message in multiple strings + message.chunked(MaxLogCatMessageLength - 5).forEach { chunk -> // -5 to also log index + logOnLevel("[${index++}] $chunk", args) + } + } + else { + logOnLevel(message, args) + } } protected open fun determineArguments(exception: Throwable?, arguments: Array): Array {