Add ExistingUserArgumentParser

This commit is contained in:
Him188 2020-08-26 12:04:56 +08:00
parent e2e922905b
commit e0f535e937
3 changed files with 64 additions and 5 deletions

View File

@ -15,6 +15,7 @@ import net.mamoe.mirai.console.internal.command.fuzzySearchMember
import net.mamoe.mirai.contact.Friend import net.mamoe.mirai.contact.Friend
import net.mamoe.mirai.contact.Group import net.mamoe.mirai.contact.Group
import net.mamoe.mirai.contact.Member import net.mamoe.mirai.contact.Member
import net.mamoe.mirai.contact.User
import net.mamoe.mirai.getFriendOrNull import net.mamoe.mirai.getFriendOrNull
import net.mamoe.mirai.getGroupOrNull import net.mamoe.mirai.getGroupOrNull
import net.mamoe.mirai.message.data.At import net.mamoe.mirai.message.data.At
@ -180,6 +181,57 @@ public object ExistingGroupArgumentParser : InternalCommandArgumentParserExtensi
} }
} }
public object ExistingUserArgumentParser : InternalCommandArgumentParserExtensions<User> {
private val syntax: String = """
- `botId.group.memberId`
- `botId.group.memberCard` (模糊搜索, 寻找最优匹配)
- `~` (指代指令调用人自己. 仅聊天环境下)
- `$` (随机成员. 仅聊天环境下)
- `botId.friendId
当只登录了一个 [Bot] , 无需上述 `botId` 参数即可
""".trimIndent()
override fun parse(raw: String, sender: CommandSender): User {
return parseImpl(sender, raw, ExistingMemberArgumentParser::parse, ExistingFriendArgumentParser::parse)
}
override fun parse(raw: SingleMessage, sender: CommandSender): User {
return parseImpl(sender, raw, ExistingMemberArgumentParser::parse, ExistingFriendArgumentParser::parse)
}
private fun <T> parseImpl(
sender: CommandSender,
raw: T,
parseFunction: (T, CommandSender) -> User,
parseFunction2: (T, CommandSender) -> User,
): User {
if (sender.inferGroup() != null) {
kotlin.runCatching {
return parseFunction(raw, sender)
}.recoverCatching {
return parseFunction2(raw, sender)
}.getOrElse {
illegalArgument("无法推断目标好友或群员. \n$syntax")
}
}
if (Bot.botInstancesSequence.count() == 1) {
kotlin.runCatching {
}.getOrElse {
illegalArgument("无法推断目标好友或群员. \n$syntax")
}
}
kotlin.runCatching {
return parseFunction2(raw, sender)
}.getOrElse {
illegalArgument("无法推断目标好友或群员. \n$syntax")
}
}
}
/** /**
* 解析任意一个群成员. * 解析任意一个群成员.
* *
@ -190,7 +242,7 @@ public object ExistingGroupArgumentParser : InternalCommandArgumentParserExtensi
* *
* 当只登录了一个 [Bot] , 无需上述 `botId` 参数即可 * 当只登录了一个 [Bot] , 无需上述 `botId` 参数即可
*/ */
public object ExistMemberArgumentParser : InternalCommandArgumentParserExtensions<Member> { public object ExistingMemberArgumentParser : InternalCommandArgumentParserExtensions<Member> {
private val syntax: String = """ private val syntax: String = """
- `botId.group.memberId` - `botId.group.memberId`
- `botId.group.memberCard` (模糊搜索, 寻找最优匹配) - `botId.group.memberCard` (模糊搜索, 寻找最优匹配)
@ -265,7 +317,9 @@ internal interface InternalCommandArgumentParserExtensions<T : Any> : CommandArg
fun CommandSender.inferBotOrFail(): Bot = (this as? BotAwareCommandSender)?.bot ?: illegalArgument("当前语境下无法推断目标群员") fun CommandSender.inferBotOrFail(): Bot = (this as? BotAwareCommandSender)?.bot ?: illegalArgument("当前语境下无法推断目标群员")
fun CommandSender.inferGroupOrFail(): Group = fun CommandSender.inferGroupOrFail(): Group =
(this as? GroupAwareCommandSender)?.group ?: illegalArgument("当前语境下无法推断目标群") inferGroup() ?: illegalArgument("当前语境下无法推断目标群")
fun CommandSender.inferGroup(): Group? = (this as? GroupAwareCommandSender)?.group
fun CommandSender.inferFriendOrFail(): Friend = fun CommandSender.inferFriendOrFail(): Friend =
(this as? FriendCommandSender)?.user ?: illegalArgument("当前语境下无法推断目标好友") (this as? FriendCommandSender)?.user ?: illegalArgument("当前语境下无法推断目标好友")

View File

@ -20,6 +20,7 @@ import net.mamoe.mirai.console.util.ConsoleExperimentalAPI
import net.mamoe.mirai.contact.Friend import net.mamoe.mirai.contact.Friend
import net.mamoe.mirai.contact.Group import net.mamoe.mirai.contact.Group
import net.mamoe.mirai.contact.Member import net.mamoe.mirai.contact.Member
import net.mamoe.mirai.contact.User
import kotlin.internal.LowPriorityInOverloadResolution import kotlin.internal.LowPriorityInOverloadResolution
import kotlin.reflect.KClass import kotlin.reflect.KClass
import kotlin.reflect.full.isSubclassOf import kotlin.reflect.full.isSubclassOf
@ -75,7 +76,8 @@ public interface CommandArgumentContext {
Double::class with DoubleArgumentParser Double::class with DoubleArgumentParser
Float::class with FloatArgumentParser Float::class with FloatArgumentParser
Member::class with ExistMemberArgumentParser User::class with ExistingUserArgumentParser
Member::class with ExistingMemberArgumentParser
Group::class with ExistingGroupArgumentParser Group::class with ExistingGroupArgumentParser
Friend::class with ExistingFriendArgumentParser Friend::class with ExistingFriendArgumentParser
Bot::class with ExistingBotArgumentParser Bot::class with ExistingBotArgumentParser
@ -137,7 +139,8 @@ public class SimpleCommandArgumentContext(
public val list: List<ParserPair<*>> public val list: List<ParserPair<*>>
) : CommandArgumentContext { ) : CommandArgumentContext {
override fun <T : Any> get(klass: KClass<out T>): CommandArgumentParser<T>? = override fun <T : Any> get(klass: KClass<out T>): CommandArgumentParser<T>? =
this.list.firstOrNull { klass.isSubclassOf(it.klass) }?.parser as CommandArgumentParser<T>? (this.list.firstOrNull { klass == it.klass }?.parser
?: this.list.firstOrNull { klass.isSubclassOf(it.klass) }?.parser) as CommandArgumentParser<T>?
override fun toList(): List<ParserPair<*>> = list override fun toList(): List<ParserPair<*>> = list
} }

View File

@ -19,6 +19,7 @@ import net.mamoe.mirai.console.command.SimpleCommand
import net.mamoe.mirai.contact.Friend import net.mamoe.mirai.contact.Friend
import net.mamoe.mirai.contact.Group import net.mamoe.mirai.contact.Group
import net.mamoe.mirai.contact.Member import net.mamoe.mirai.contact.Member
import net.mamoe.mirai.contact.User
import net.mamoe.mirai.message.data.SingleMessage import net.mamoe.mirai.message.data.SingleMessage
import net.mamoe.mirai.message.data.content import net.mamoe.mirai.message.data.content
import kotlin.contracts.InvocationKind import kotlin.contracts.InvocationKind
@ -43,7 +44,8 @@ import kotlin.contracts.contract
* - [Bot]: [ExistingBotArgumentParser] * - [Bot]: [ExistingBotArgumentParser]
* - [Friend]: [ExistingFriendArgumentParser] * - [Friend]: [ExistingFriendArgumentParser]
* - [Group]: [ExistingGroupArgumentParser] * - [Group]: [ExistingGroupArgumentParser]
* - [Member]: [ExistMemberArgumentParser] * - [Member]: [ExistingMemberArgumentParser]
* - [User]: [ExistingUserArgumentParser]
* *
* *
* @see SimpleCommand 简单指令 * @see SimpleCommand 简单指令