org.jetbrains.kotlin.kapt3.util.MessageCollectorBackedKaptLogger.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of kotlin-annotation-processing-embeddable Show documentation
Show all versions of kotlin-annotation-processing-embeddable Show documentation
Annotation Processor for Kotlin (for using with embeddable compiler)
/*
* Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.
* Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.
*/
package org.jetbrains.kotlin.kapt3.util
import org.jetbrains.kotlin.base.kapt3.KaptFlag
import org.jetbrains.kotlin.base.kapt3.KaptFlags
import org.jetbrains.kotlin.cli.common.messages.CompilerMessageSeverity
import org.jetbrains.kotlin.cli.common.messages.CompilerMessageSeverity.*
import org.jetbrains.kotlin.cli.common.messages.MessageCollector
import org.jetbrains.kotlin.cli.common.messages.MessageRenderer.PLAIN_FULL_PATHS
import org.jetbrains.kotlin.cli.common.messages.PrintingMessageCollector
import org.jetbrains.kotlin.kapt3.base.util.KaptLogger
import java.io.PrintWriter
import java.io.StringWriter
class MessageCollectorBackedKaptLogger(
override val isVerbose: Boolean,
isInfoAsWarnings: Boolean,
val messageCollector: MessageCollector = defaultMessageCollector(isVerbose)
) : KaptLogger {
constructor(flags: KaptFlags, messageCollector: MessageCollector = defaultMessageCollector(flags[KaptFlag.VERBOSE]))
: this(flags[KaptFlag.VERBOSE], flags[KaptFlag.INFO_AS_WARNINGS], messageCollector)
private companion object {
const val PREFIX = "[kapt] "
fun defaultMessageCollector(isVerbose: Boolean) = PrintingMessageCollector(System.err, PLAIN_FULL_PATHS, isVerbose)
}
override val errorWriter = makeWriter(ERROR)
override val warnWriter = makeWriter(STRONG_WARNING)
override val infoWriter = makeWriter(if (isInfoAsWarnings) WARNING else INFO)
override fun info(message: String) {
if (isVerbose) {
messageCollector.report(INFO, PREFIX + message)
}
}
override fun warn(message: String) {
messageCollector.report(WARNING, PREFIX + message)
}
override fun error(message: String) {
messageCollector.report(ERROR, PREFIX + message)
}
override fun exception(e: Throwable) {
val stacktrace = run {
val writer = StringWriter()
e.printStackTrace(PrintWriter(writer))
writer.toString()
}
messageCollector.report(ERROR, PREFIX + "An exception occurred: " + stacktrace)
}
private fun makeWriter(severity: CompilerMessageSeverity): PrintWriter {
return PrintWriter(MessageCollectorBackedWriter(messageCollector, severity))
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy