Move CommandResolveResult.fold to extension, add CommandResolveResult.getOrElse

This commit is contained in:
Him188 2020-11-17 09:41:00 +08:00
parent 453d072cc7
commit 77f00d2d84
2 changed files with 27 additions and 17 deletions

View File

@ -32,20 +32,33 @@ public class CommandResolveResult private constructor(
public val failure: CommandExecuteResult.Failure? public val failure: CommandExecuteResult.Failure?
get() = value.safeCast() get() = value.safeCast()
public inline fun <R> fold( public constructor(call: ResolvedCommandCall?) : this(call as Any?)
public constructor(failure: CommandExecuteResult.Failure) : this(failure as Any)
}
@OptIn(ExperimentalCommandDescriptors::class)
public inline fun <R> CommandResolveResult.fold(
onSuccess: (ResolvedCommandCall?) -> R, onSuccess: (ResolvedCommandCall?) -> R,
onFailure: (CommandExecuteResult.Failure) -> R, onFailure: (CommandExecuteResult.Failure) -> R,
): R { ): R {
contract { contract {
callsInPlace(onSuccess, InvocationKind.AT_MOST_ONCE) callsInPlace(onSuccess, InvocationKind.AT_MOST_ONCE)
callsInPlace(onFailure, InvocationKind.AT_MOST_ONCE) callsInPlace(onFailure, InvocationKind.AT_MOST_ONCE)
} }
failure?.let(onFailure)?.let { return it } failure?.let(onFailure)?.let { return it }
return call.let(onSuccess) return call.let(onSuccess)
} }
public constructor(call: ResolvedCommandCall?) : this(call as Any?)
public constructor(failure: CommandExecuteResult.Failure) : this(failure as Any) @OptIn(ExperimentalCommandDescriptors::class)
public inline fun CommandResolveResult.getOrElse(
onFailure: (CommandExecuteResult.Failure) -> ResolvedCommandCall,
): ResolvedCommandCall {
contract {
callsInPlace(onFailure, InvocationKind.AT_MOST_ONCE)
}
failure?.let(onFailure)?.let { return it }
return call!!
} }
/** /**

View File

@ -193,11 +193,8 @@ internal suspend fun executeCommandImpl(
} }
val resolved = call val resolved = call
.resolve().fold( .resolve()
onSuccess = { it }, .getOrElse { return it }
onFailure = { return it }
)
.ifNull { return CommandExecuteResult.UnresolvedCommand(call) }
.let { raw -> .let { raw ->
raw.intercepted() raw.intercepted()
.getOrElse { return CommandExecuteResult.Intercepted(call, raw, null, it) } .getOrElse { return CommandExecuteResult.Intercepted(call, raw, null, it) }