com.simbot.component.mirai.logger.SimbotBotMiraiLogger.kt Maven / Gradle / Ivy
/*
*
* * Copyright (c) 2020. ForteScarlet All rights reserved.
* * Project component-mirai
* * File SimbotBotMiraiLogger.kt
* *
* * You can contact the author through the following channels:
* * github https://github.com/ForteScarlet
* * gitee https://gitee.com/ForteScarlet
* * email [email protected]
* * QQ 1149159218
* *
* * The Mirai code is copyrighted by mamoe-mirai
* * you can see mirai at https://github.com/mamoe/mirai
* *
* *
*
*/
package com.simbot.component.mirai.logger
import com.forte.plusutils.consoleplus.console.Colors
import com.forte.plusutils.consoleplus.console.colors.FontColorTypes
import com.forte.qqrobot.log.QQLog
import net.mamoe.mirai.Bot
import net.mamoe.mirai.utils.MiraiLoggerPlatformBase
/**
* 通过bot参数在日志中输出不同的bot账号
* 可能会导致日志过长.
* @author ForteScarlet
* 2020/8/11
*/
class SimbotBotMiraiLogger(private val bot: Bot) : MiraiLoggerPlatformBase() {
/**
* 日志的标记. 在 Mirai 中, identity 可为
* - "Bot"
* - "BotNetworkHandler"
* 等.
*
* 它只用于帮助调试或统计. 十分建议清晰定义 identity
*/
override val identity: String = "Mirai-${
Colors.builder()
.add(bot.id.toString(), FontColorTypes.DARK_GREEN)
.build()
}"
/**
* 颜色标记
*/
private val identityColor: String = Colors.builder()
.add("[", FontColorTypes.BLUE)
.add(identity, FontColorTypes.DARK_GREEN)
.add("]", FontColorTypes.BLUE)
.build().toString()
private val verboseColor: String = Colors.builder()
.add("[", FontColorTypes.BLUE)
.add("V/B", FontColorTypes.YELLOW)
.add("]", FontColorTypes.BLUE)
.build().toString()
override fun debug0(message: String?, e: Throwable?) {
QQLog.debug("{0}", e, "$identityColor $message")
}
override fun error0(message: String?, e: Throwable?) {
QQLog.error("{0}", e, " $identityColor $message")
}
override fun info0(message: String?, e: Throwable?) {
QQLog.info("{0}", e, " $identityColor $message")
}
override fun verbose0(message: String?, e: Throwable?) {
QQLog.debug("{0}", e, "$identityColor $verboseColor $message")
}
override fun warning0(message: String?, e: Throwable?) {
QQLog.warning("{0}", e, " $identityColor $message")
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy