2021-01-29 10:23:18 +08:00
|
|
|
/*
|
|
|
|
* Copyright 2019-2021 Mamoe Technologies and contributors.
|
|
|
|
*
|
|
|
|
* 此源代码的使用受 GNU AFFERO GENERAL PUBLIC LICENSE version 3 许可证的约束, 可以在以下链接找到该许可证.
|
|
|
|
* Use of this source code is governed by the GNU AGPLv3 license that can be found through the following link.
|
|
|
|
*
|
|
|
|
* https://github.com/mamoe/mirai/blob/master/LICENSE
|
|
|
|
*/
|
|
|
|
|
2020-11-29 15:05:39 +08:00
|
|
|
package net.mamoe.mirai.console.intellij.diagnostics
|
|
|
|
|
|
|
|
import net.mamoe.mirai.console.compiler.common.diagnostics.MiraiConsoleErrors.ILLEGAL_COMMAND_DECLARATION_RECEIVER
|
|
|
|
import net.mamoe.mirai.console.compiler.common.resolve.COMMAND_SENDER_FQ_NAME
|
|
|
|
import net.mamoe.mirai.console.intellij.resolve.hasSuperType
|
2021-01-29 12:43:42 +08:00
|
|
|
import net.mamoe.mirai.console.intellij.resolve.isCompositeCommandSubCommand
|
|
|
|
import net.mamoe.mirai.console.intellij.resolve.isSimpleCommandHandler
|
2020-11-29 15:05:39 +08:00
|
|
|
import org.jetbrains.kotlin.descriptors.DeclarationDescriptor
|
|
|
|
import org.jetbrains.kotlin.diagnostics.Diagnostic
|
|
|
|
import org.jetbrains.kotlin.psi.KtDeclaration
|
|
|
|
import org.jetbrains.kotlin.psi.KtNamedFunction
|
|
|
|
import org.jetbrains.kotlin.resolve.checkers.DeclarationChecker
|
|
|
|
import org.jetbrains.kotlin.resolve.checkers.DeclarationCheckerContext
|
|
|
|
|
|
|
|
class CommandDeclarationChecker : DeclarationChecker {
|
|
|
|
override fun check(declaration: KtDeclaration, descriptor: DeclarationDescriptor, context: DeclarationCheckerContext) {
|
|
|
|
if (declaration !is KtNamedFunction) return
|
|
|
|
|
2021-01-29 12:43:42 +08:00
|
|
|
// exclusive checks or return
|
|
|
|
when {
|
|
|
|
declaration.isSimpleCommandHandler() -> {
|
|
|
|
}
|
|
|
|
|
|
|
|
declaration.isCompositeCommandSubCommand() -> {
|
|
|
|
}
|
|
|
|
else -> return
|
|
|
|
}
|
2020-11-29 15:05:39 +08:00
|
|
|
|
|
|
|
// common checks
|
|
|
|
checkCommandReceiverParameter(declaration)?.let { context.report(it) }
|
|
|
|
}
|
|
|
|
|
|
|
|
companion object {
|
|
|
|
fun checkCommandReceiverParameter(declaration: KtNamedFunction): Diagnostic? {
|
|
|
|
val receiverTypeRef = declaration.receiverTypeReference ?: return null // no receiver, accept.
|
|
|
|
val receiver = receiverTypeRef.resolveReferencedType() ?: return null // unresolved type
|
|
|
|
if (!receiver.hasSuperType(COMMAND_SENDER_FQ_NAME)) {
|
|
|
|
return ILLEGAL_COMMAND_DECLARATION_RECEIVER.on(receiverTypeRef)
|
|
|
|
}
|
|
|
|
|
|
|
|
return null
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|