From 01fc3f4c32bf549ec28036f2b1d6ea4e157b7242 Mon Sep 17 00:00:00 2001 From: Him188 Date: Thu, 30 Apr 2020 11:46:38 +0800 Subject: [PATCH] Use `suspendCancellableCoroutine`, improve performance --- .../controller/MiraiGraphicalUIController.kt | 20 ++++++++----------- 1 file changed, 8 insertions(+), 12 deletions(-) diff --git a/mirai-console-graphical/src/main/kotlin/net/mamoe/mirai/console/graphical/controller/MiraiGraphicalUIController.kt b/mirai-console-graphical/src/main/kotlin/net/mamoe/mirai/console/graphical/controller/MiraiGraphicalUIController.kt index 4fced2c38..173a7a8c0 100644 --- a/mirai-console-graphical/src/main/kotlin/net/mamoe/mirai/console/graphical/controller/MiraiGraphicalUIController.kt +++ b/mirai-console-graphical/src/main/kotlin/net/mamoe/mirai/console/graphical/controller/MiraiGraphicalUIController.kt @@ -6,6 +6,7 @@ import javafx.stage.Modality import javafx.stage.StageStyle import kotlinx.coroutines.delay import kotlinx.coroutines.isActive +import kotlinx.coroutines.suspendCancellableCoroutine import net.mamoe.mirai.Bot import net.mamoe.mirai.console.command.CommandManager import net.mamoe.mirai.console.command.CommandManager.runCommand @@ -16,12 +17,13 @@ import net.mamoe.mirai.console.graphical.view.dialog.InputDialog import net.mamoe.mirai.console.graphical.view.dialog.VerificationCodeFragment import net.mamoe.mirai.console.plugins.PluginManager import net.mamoe.mirai.console.utils.MiraiConsoleUI -import net.mamoe.mirai.network.WrongPasswordException +import net.mamoe.mirai.network.CustomLoginFailedException import net.mamoe.mirai.utils.LoginSolver import net.mamoe.mirai.utils.SimpleLogger.LogPriority import tornadofx.* import java.text.SimpleDateFormat import java.util.* +import kotlin.coroutines.resume class MiraiGraphicalUIController : Controller(), MiraiConsoleUI { @@ -105,18 +107,12 @@ class MiraiGraphicalUIController : Controller(), MiraiConsoleUI { } } - override suspend fun requestInput(hint: String): String { - var ret: String? = null - - // UI必须在UI线程执行,requestInput在协程种被调用 - Platform.runLater { - ret = InputDialog(hint).open() + override suspend fun requestInput(hint: String): String = + suspendCancellableCoroutine { + Platform.runLater { + it.resume(InputDialog(hint).open()) + } } - while (ret == null) { - delay(1000) - } - return ret!! - } override fun pushBotAdminStatus(identity: Long, admins: List) = Platform.runLater { cache[identity]?.admins?.setAll(admins)