Refactor and reformat commands
This commit is contained in:
@@ -8,7 +8,7 @@ import io.dico.parcels2.util.hasAdminManage
|
|||||||
import org.bukkit.OfflinePlayer
|
import org.bukkit.OfflinePlayer
|
||||||
import org.bukkit.entity.Player
|
import org.bukkit.entity.Player
|
||||||
|
|
||||||
class ParcelAddCommands(plugin: ParcelsPlugin) : AbstractParcelCommands(plugin) {
|
class CommandsAddedStatus(plugin: ParcelsPlugin) : AbstractParcelCommands(plugin) {
|
||||||
|
|
||||||
@Cmd("allow", aliases = ["add", "permit"])
|
@Cmd("allow", aliases = ["add", "permit"])
|
||||||
@Desc("Allows a player to build on this parcel",
|
@Desc("Allows a player to build on this parcel",
|
||||||
@@ -0,0 +1,7 @@
|
|||||||
|
package io.dico.parcels2.command
|
||||||
|
|
||||||
|
import io.dico.parcels2.ParcelsPlugin
|
||||||
|
|
||||||
|
class CommandsAdmin(plugin: ParcelsPlugin) : AbstractParcelCommands(plugin) {
|
||||||
|
|
||||||
|
}
|
||||||
@@ -6,7 +6,7 @@ import io.dico.parcels2.ParcelsPlugin
|
|||||||
import org.bukkit.Bukkit
|
import org.bukkit.Bukkit
|
||||||
import org.bukkit.entity.Player
|
import org.bukkit.entity.Player
|
||||||
|
|
||||||
class DebugCommands(val plugin: ParcelsPlugin) {
|
class CommandsDebug(val plugin: ParcelsPlugin) {
|
||||||
|
|
||||||
@Cmd("reloadoptions")
|
@Cmd("reloadoptions")
|
||||||
fun reloadOptions() {
|
fun reloadOptions() {
|
||||||
@@ -13,7 +13,7 @@ import io.dico.parcels2.util.uuid
|
|||||||
import org.bukkit.entity.Player
|
import org.bukkit.entity.Player
|
||||||
|
|
||||||
//@Suppress("unused")
|
//@Suppress("unused")
|
||||||
class ParcelCommands(plugin: ParcelsPlugin) : AbstractParcelCommands(plugin) {
|
class CommandsGeneral(plugin: ParcelsPlugin) : AbstractParcelCommands(plugin) {
|
||||||
|
|
||||||
@Cmd("auto")
|
@Cmd("auto")
|
||||||
@Desc("Finds the unclaimed parcel nearest to origin,",
|
@Desc("Finds the unclaimed parcel nearest to origin,",
|
||||||
@@ -10,7 +10,7 @@ import io.dico.parcels2.ParcelsPlugin
|
|||||||
import org.bukkit.entity.Player
|
import org.bukkit.entity.Player
|
||||||
import kotlin.reflect.KMutableProperty
|
import kotlin.reflect.KMutableProperty
|
||||||
|
|
||||||
class ParcelOptionCommands(plugin: ParcelsPlugin) : AbstractParcelCommands(plugin) {
|
class CommandsParcelOptions(plugin: ParcelsPlugin) : AbstractParcelCommands(plugin) {
|
||||||
@Cmd("inputs")
|
@Cmd("inputs")
|
||||||
@Desc("Sets whether players who are not allowed to",
|
@Desc("Sets whether players who are not allowed to",
|
||||||
"build here can use levers, buttons,",
|
"build here can use levers, buttons,",
|
||||||
@@ -1,85 +0,0 @@
|
|||||||
package io.dico.parcels2.command
|
|
||||||
|
|
||||||
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.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
|
|
||||||
|
|
||||||
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)
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -1,7 +0,0 @@
|
|||||||
package io.dico.parcels2.command
|
|
||||||
|
|
||||||
import io.dico.parcels2.ParcelsPlugin
|
|
||||||
|
|
||||||
class ParcelAdminCommands(plugin: ParcelsPlugin) : AbstractParcelCommands(plugin) {
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -14,16 +14,16 @@ fun getParcelCommands(plugin: ParcelsPlugin): ICommandDispatcher {
|
|||||||
.addParameterType(true, ParcelHomeParameterType(plugin.worlds))
|
.addParameterType(true, ParcelHomeParameterType(plugin.worlds))
|
||||||
|
|
||||||
.group("parcel", "plot", "plots", "p")
|
.group("parcel", "plot", "plots", "p")
|
||||||
.registerCommands(ParcelCommands(plugin))
|
.registerCommands(CommandsGeneral(plugin))
|
||||||
.registerCommands(ParcelAddCommands(plugin))
|
.registerCommands(CommandsAddedStatus(plugin))
|
||||||
|
|
||||||
.group("option")
|
.group("option")
|
||||||
.apply { ParcelOptionCommands.setGroupDescription(this) }
|
.apply { CommandsParcelOptions.setGroupDescription(this) }
|
||||||
.registerCommands(ParcelOptionCommands(plugin))
|
.registerCommands(CommandsParcelOptions(plugin))
|
||||||
.parent()
|
.parent()
|
||||||
|
|
||||||
.group("admin", "a")
|
.group("admin", "a")
|
||||||
.registerCommands(ParcelAdminCommands(plugin))
|
.registerCommands(CommandsAdmin(plugin))
|
||||||
.parent()
|
.parent()
|
||||||
|
|
||||||
.putDebugCommands(plugin)
|
.putDebugCommands(plugin)
|
||||||
@@ -37,7 +37,7 @@ private fun CommandBuilder.putDebugCommands(plugin: ParcelsPlugin): CommandBuild
|
|||||||
if (!logger.isDebugEnabled) return this
|
if (!logger.isDebugEnabled) return this
|
||||||
//@formatter:off
|
//@formatter:off
|
||||||
return group("debug", "d")
|
return group("debug", "d")
|
||||||
.registerCommands(DebugCommands(plugin))
|
.registerCommands(CommandsDebug(plugin))
|
||||||
.parent()
|
.parent()
|
||||||
//@formatter:on
|
//@formatter:on
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,10 +3,14 @@ package io.dico.parcels2.command
|
|||||||
import io.dico.dicore.command.CommandException
|
import io.dico.dicore.command.CommandException
|
||||||
import io.dico.dicore.command.parameter.ArgumentBuffer
|
import io.dico.dicore.command.parameter.ArgumentBuffer
|
||||||
import io.dico.dicore.command.parameter.Parameter
|
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.dicore.command.parameter.type.ParameterType
|
||||||
import io.dico.parcels2.Parcel
|
import io.dico.parcels2.Parcel
|
||||||
import io.dico.parcels2.ParcelWorld
|
import io.dico.parcels2.ParcelWorld
|
||||||
import io.dico.parcels2.Worlds
|
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.command.CommandSender
|
||||||
import org.bukkit.entity.Player
|
import org.bukkit.entity.Player
|
||||||
|
|
||||||
@@ -44,3 +48,75 @@ class ParcelParameterType(val worlds: Worlds) : ParameterType<Parcel, Void>(Parc
|
|||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
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)
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|||||||
@@ -5,5 +5,4 @@ import io.dico.dicore.command.chat.AbstractChatController
|
|||||||
class ParcelsChatController : AbstractChatController() {
|
class ParcelsChatController : AbstractChatController() {
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
Reference in New Issue
Block a user