diff options
Diffstat (limited to 'src/main/kotlin/io/dico/parcels2/command/ParcelParameterTypes.kt')
-rw-r--r-- | src/main/kotlin/io/dico/parcels2/command/ParcelParameterTypes.kt | 86 |
1 files changed, 5 insertions, 81 deletions
diff --git a/src/main/kotlin/io/dico/parcels2/command/ParcelParameterTypes.kt b/src/main/kotlin/io/dico/parcels2/command/ParcelParameterTypes.kt index ab97023..de3cf64 100644 --- a/src/main/kotlin/io/dico/parcels2/command/ParcelParameterTypes.kt +++ b/src/main/kotlin/io/dico/parcels2/command/ParcelParameterTypes.kt @@ -3,14 +3,10 @@ package io.dico.parcels2.command import io.dico.dicore.command.CommandException import io.dico.dicore.command.parameter.ArgumentBuffer import io.dico.dicore.command.parameter.Parameter -import io.dico.dicore.command.parameter.type.ParameterConfig import io.dico.dicore.command.parameter.type.ParameterType import io.dico.parcels2.Parcel +import io.dico.parcels2.ParcelProvider import io.dico.parcels2.ParcelWorld -import io.dico.parcels2.Worlds -import io.dico.parcels2.util.isValid -import org.bukkit.Bukkit -import org.bukkit.OfflinePlayer import org.bukkit.command.CommandSender import org.bukkit.entity.Player @@ -18,7 +14,7 @@ fun invalidInput(parameter: Parameter<*, *>, message: String): Nothing { throw CommandException("invalid input for ${parameter.name}: $message") } -fun Worlds.getTargetWorld(input: String?, sender: CommandSender, parameter: Parameter<*, *>): ParcelWorld { +fun ParcelProvider.getTargetWorld(input: String?, sender: CommandSender, parameter: Parameter<*, *>): ParcelWorld { val worldName = input ?.takeUnless { it.isEmpty() } ?: (sender as? Player)?.world?.name @@ -28,14 +24,14 @@ fun Worlds.getTargetWorld(input: String?, sender: CommandSender, parameter: Para ?: invalidInput(parameter, "$worldName is not a parcel world") } -class ParcelParameterType(val worlds: Worlds) : ParameterType<Parcel, Void>(Parcel::class.java) { +class ParcelParameterType(val parcelProvider: ParcelProvider) : ParameterType<Parcel, Void>(Parcel::class.java) { val regex = Regex.fromLiteral("((.+)->)?([0-9]+):([0-9]+)") override fun parse(parameter: Parameter<Parcel, Void>, sender: CommandSender, buffer: ArgumentBuffer): Parcel { val matchResult = regex.matchEntire(buffer.next()) ?: invalidInput(parameter, "must match (w->)?a:b (/${regex.pattern}/)") - val world = worlds.getTargetWorld(matchResult.groupValues[2], sender, parameter) + val world = parcelProvider.getTargetWorld(matchResult.groupValues[2], sender, parameter) val x = matchResult.groupValues[3].toIntOrNull() ?: invalidInput(parameter, "couldn't parse int") @@ -43,80 +39,8 @@ class ParcelParameterType(val worlds: Worlds) : ParameterType<Parcel, Void>(Parc val z = matchResult.groupValues[4].toIntOrNull() ?: invalidInput(parameter, "couldn't parse int") - return world.parcelByID(x, z) + return world.getParcelById(x, z) ?: invalidInput(parameter, "parcel id is out of range") } } - - -class NamedParcelTarget(val world: ParcelWorld, val player: OfflinePlayer, val index: Int) - -@Target(AnnotationTarget.VALUE_PARAMETER) -@Retention(AnnotationRetention.RUNTIME) -annotation class NamedParcelDefault(val value: NamedParcelDefaultValue) - -enum class NamedParcelDefaultValue { - FIRST_OWNED, - NULL -} - -class NamedParcelTargetConfig : ParameterConfig<NamedParcelDefault, - NamedParcelDefaultValue>(NamedParcelDefault::class.java) { - - override fun toParameterInfo(annotation: NamedParcelDefault): NamedParcelDefaultValue { - return annotation.value - } -} - -class ParcelHomeParameterType(val worlds: Worlds) : ParameterType<NamedParcelTarget, - NamedParcelDefaultValue>(NamedParcelTarget::class.java, NamedParcelTargetConfig()) { - - val regex = Regex.fromLiteral("((.+)->)?(.+)|((.+):([0-9]+))") - - private fun requirePlayer(sender: CommandSender, parameter: Parameter<*, *>): Player { - if (sender !is Player) invalidInput(parameter, "console cannot omit the player name") - return sender - } - - @Suppress("UsePropertyAccessSyntax") - private fun getOfflinePlayer(input: String, parameter: Parameter<*, *>) = Bukkit.getOfflinePlayer(input) - ?.takeIf { it.isValid } - ?: invalidInput(parameter, "do not know who $input is") - - override fun parse(parameter: Parameter<NamedParcelTarget, NamedParcelDefaultValue>, - sender: CommandSender, buffer: ArgumentBuffer): NamedParcelTarget { - val matchResult = regex.matchEntire(buffer.next()) - ?: invalidInput(parameter, "must be a player, index, or player:index (/${regex.pattern}/)") - - val world = worlds.getTargetWorld(matchResult.groupValues[2], sender, parameter) - - matchResult.groupValues[3].takeUnless { it.isEmpty() }?.let { - // first group was matched, it's a player or an int - it.toIntOrNull()?.let { - requirePlayer(sender, parameter) - return NamedParcelTarget(world, sender as Player, it) - } - - return NamedParcelTarget(world, getOfflinePlayer(it, parameter), 0) - } - - val player = getOfflinePlayer(matchResult.groupValues[5], parameter) - val index = matchResult.groupValues[6].toIntOrNull() - ?: invalidInput(parameter, "couldn't parse int") - - return NamedParcelTarget(world, player, index) - } - - override fun getDefaultValue(parameter: Parameter<NamedParcelTarget, NamedParcelDefaultValue>, - sender: CommandSender, buffer: ArgumentBuffer): NamedParcelTarget? { - if (parameter.paramInfo == NamedParcelDefaultValue.NULL) { - return null - } - - val world = worlds.getTargetWorld(null, sender, parameter) - val player = requirePlayer(sender, parameter) - return NamedParcelTarget(world, player, 0) - } - -} |