From fb82d8236ddf0a1386f1e619c1ed300bc6830fdb Mon Sep 17 00:00:00 2001 From: Him188 Date: Tue, 17 Nov 2020 08:36:49 +0800 Subject: [PATCH] Add assertionError --- backend/mirai-console/src/internal/util/CommonUtils.kt | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/backend/mirai-console/src/internal/util/CommonUtils.kt b/backend/mirai-console/src/internal/util/CommonUtils.kt index aca7b0d7d..a28170631 100644 --- a/backend/mirai-console/src/internal/util/CommonUtils.kt +++ b/backend/mirai-console/src/internal/util/CommonUtils.kt @@ -7,12 +7,14 @@ * https://github.com/mamoe/mirai/blob/master/LICENSE */ -@file:JvmName("CommonUtils") +@file:JvmName("CommonUtils") // maintain binary compatibility package net.mamoe.mirai.console.internal.util import io.github.karlatemp.caller.StackFrame import net.mamoe.mirai.console.internal.plugin.BuiltInJvmPluginLoaderImpl +import kotlin.contracts.InvocationKind +import kotlin.contracts.contract internal inline fun runIgnoreException(block: () -> R): R? { try { @@ -38,3 +40,9 @@ internal fun StackFrame.findLoader(): ClassLoader? { BuiltInJvmPluginLoaderImpl.classLoaders.firstOrNull { it.findClass(className, true) != null } }.getOrNull() } + +@PublishedApi +internal inline fun assertionError(message: () -> String): Nothing { + contract { callsInPlace(message, InvocationKind.EXACTLY_ONCE) } + throw AssertionError(message()) +} \ No newline at end of file