summaryrefslogtreewikicommitdiff
path: root/core/src/command/map/set/Bounds.kt
diff options
context:
space:
mode:
authorFreya Murphy <freya@freyacat.org>2026-03-26 23:15:33 -0400
committerFreya Murphy <freya@freyacat.org>2026-03-27 23:09:23 -0400
commitf8322cd21cde68a72b05efbad3a05b8e67c0bdd0 (patch)
treed7e60bc8fedadc8fa7ae725571cad1f398eaf6dc /core/src/command/map/set/Bounds.kt
downloadkenshinshideandseek2-f8322cd21cde68a72b05efbad3a05b8e67c0bdd0.tar.gz
kenshinshideandseek2-f8322cd21cde68a72b05efbad3a05b8e67c0bdd0.tar.bz2
kenshinshideandseek2-f8322cd21cde68a72b05efbad3a05b8e67c0bdd0.zip
initial
Diffstat (limited to 'core/src/command/map/set/Bounds.kt')
-rw-r--r--core/src/command/map/set/Bounds.kt57
1 files changed, 57 insertions, 0 deletions
diff --git a/core/src/command/map/set/Bounds.kt b/core/src/command/map/set/Bounds.kt
new file mode 100644
index 0000000..7c13802
--- /dev/null
+++ b/core/src/command/map/set/Bounds.kt
@@ -0,0 +1,57 @@
+package cat.freya.khs.command.map.set
+
+import cat.freya.khs.Khs
+import cat.freya.khs.command.util.Command
+import cat.freya.khs.config.BoundConfig
+import cat.freya.khs.player.Player
+import cat.freya.khs.runChecks
+
+class KhsMapSetBounds : Command {
+ override val label = "bounds"
+ override val usage = listOf("map")
+ override val description = "Sets the map bounds for a map"
+
+ override fun execute(plugin: Khs, player: Player, args: List<String>) {
+ val (name) = args
+ runChecks(plugin, player) {
+ mapExists(name)
+ inMapWorld(name)
+ gameNotInProgress()
+ }
+
+ var map = plugin.maps.get(name) ?: return
+ val config = map.config.bounds
+
+ val pos = player.location.position
+ val num: Int
+
+ if (config.min == null || config.max != null) {
+ config.min = BoundConfig(pos.x, pos.z)
+ config.max == null
+ num = 1
+ } else {
+ val minX = minOf(config.min?.x ?: 0.0, pos.x)
+ val minZ = minOf(config.min?.z ?: 0.0, pos.z)
+ val maxX = maxOf(config.min?.x ?: 0.0, pos.x)
+ val maxZ = maxOf(config.min?.z ?: 0.0, pos.z)
+ config.min = BoundConfig(minX, minZ)
+ config.max = BoundConfig(maxX, maxZ)
+ num = 2
+ }
+
+ runChecks(plugin, player) {
+ // note this is not error, only warn
+ spawnsInRange(map)
+ }
+
+ map.reloadConfig()
+ plugin.saveConfig()
+ player.message(plugin.locale.prefix.default + plugin.locale.map.set.bounds.with(num))
+ }
+
+ override fun autoComplete(plugin: Khs, parameter: String, typed: String): List<String> =
+ when (parameter) {
+ "map" -> plugin.maps.keys.filter { it.startsWith(typed) }
+ else -> listOf()
+ }
+}