Archived
0
This commit is contained in:
Dico
2018-09-23 21:34:48 +01:00
parent b05e424ef4
commit e0bf8249bd
6 changed files with 95 additions and 35 deletions

View File

@@ -5,50 +5,51 @@ import io.dico.dicore.command.ICommandAddress
import io.dico.dicore.command.ICommandDispatcher
import io.dico.dicore.command.registration.reflect.ReflectiveRegistration
import io.dico.parcels2.ParcelsPlugin
import io.dico.parcels2.logger
import java.util.LinkedList
import java.util.Queue
@Suppress("UsePropertyAccessSyntax")
fun getParcelCommands(plugin: ParcelsPlugin): ICommandDispatcher {
//@formatter:off
return CommandBuilder()
.setChatController(ParcelsChatController())
.addParameterType(false, ParcelParameterType(plugin.parcelProvider))
.addParameterType(true, ParcelTarget.PType(plugin.parcelProvider))
fun getParcelCommands(plugin: ParcelsPlugin): ICommandDispatcher =
with(CommandBuilder()) {
setChatController(ParcelsChatController())
addParameterType(false, ParcelParameterType(plugin.parcelProvider))
addParameterType(false, ProfileParameterType())
addParameterType(true, ParcelTarget.PType(plugin.parcelProvider))
.group("parcel", "plot", "plots", "p")
.addRequiredPermission("parcels.command")
.registerCommands(CommandsGeneral(plugin))
.registerCommands(CommandsAddedStatusLocal(plugin))
group("parcel", "plot", "plots", "p") {
addRequiredPermission("parcels.command")
registerCommands(CommandsGeneral(plugin))
registerCommands(CommandsAddedStatusLocal(plugin))
.group("option", "opt", "o")
.apply { CommandsParcelOptions.setGroupDescription(this) }
.registerCommands(CommandsParcelOptions(plugin))
.parent()
group("option", "opt", "o") {
CommandsParcelOptions.setGroupDescription(this)
registerCommands(CommandsParcelOptions(plugin))
}
.group("global", "g")
.registerCommands(CommandsAddedStatusGlobal(plugin))
.parent()
group("global", "g") {
registerCommands(CommandsAddedStatusGlobal(plugin))
}
.group("admin", "a")
.registerCommands(CommandsAdmin(plugin))
.parent()
group("admin", "a") {
registerCommands(CommandsAdmin(plugin))
}
.putDebugCommands(plugin)
if (!logger.isDebugEnabled) return@group
.parent()
.generateHelpAndSyntaxCommands()
.getDispatcher()
//@formatter:on
}
group("debug", "d") {
registerCommands(CommandsDebug(plugin))
}
}
private fun CommandBuilder.putDebugCommands(plugin: ParcelsPlugin): CommandBuilder {
//if (!logger.isDebugEnabled) return this
//@formatter:off
return group("debug", "d")
.registerCommands(CommandsDebug(plugin))
.parent()
//@formatter:on
generateHelpAndSyntaxCommands()
getDispatcher()
}
inline fun CommandBuilder.group(name: String, vararg aliases: String, config: CommandBuilder.() -> Unit) {
group(name, *aliases)
config()
parent()
}
private fun CommandBuilder.generateHelpAndSyntaxCommands(): CommandBuilder {

View File

@@ -7,6 +7,7 @@ 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.PlayerProfile
import org.bukkit.command.CommandSender
import org.bukkit.entity.Player
@@ -44,3 +45,12 @@ class ParcelParameterType(val parcelProvider: ParcelProvider) : ParameterType<Pa
}
}
class ProfileParameterType : ParameterType<PlayerProfile, Void>(PlayerProfile::class.java) {
override fun parse(parameter: Parameter<PlayerProfile, Void>, sender: CommandSender, buffer: ArgumentBuffer): PlayerProfile {
val input = buffer.next()
return PlayerProfile.byName(input, allowReal = true, allowFake = true)
}
}

View File

@@ -170,7 +170,7 @@ class ParcelListeners(
if (ppa.isNullOr { hasBlockVisitors }) event.isCancelled = true
}
private val bedTypes = EnumSet.copyOf(getMaterialsWithWoodTypePrefix("BED").toList())
private val bedTypes = EnumSet.copyOf(getMaterialsWithWoolColorPrefix("BED").toList())
/*
* Prevents players from placing liquids, using flint and steel, changing redstone components,
* using inputs (unless allowed by the plot),