summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDico200 <dico.karssiens@gmail.com>2016-05-31 16:39:54 +0200
committerDico200 <dico.karssiens@gmail.com>2016-05-31 16:39:54 +0200
commitf0ada788bfecd00c2d467f46bbc442af9ed1ecca (patch)
tree396ef93160b83a93b68d0a6ac1bbe73c9e43d8ee
parent5d00af8cedae09b66a0569e03635a04b0b188a1e (diff)
Made serversigns force its commands into the command map (to replace the java plugin ServerSigns its commands)
-rw-r--r--main.py2
-rw-r--r--serversigns.py21
2 files changed, 21 insertions, 2 deletions
diff --git a/main.py b/main.py
index ffea209..1b9e3f4 100644
--- a/main.py
+++ b/main.py
@@ -24,7 +24,7 @@ def on_enable():
if "imbusy" in shared["modules"]:
shared["modules"]["imbusy"].replace_ess_commands()
if "serversigns" in shared["modules"]:
- shared["modules"]["serversigns"].check_all_signs()
+ shared["modules"]["serversigns"].check_all_signs_and_force_commands()
info("RedstonerUtils enabled!")
diff --git a/serversigns.py b/serversigns.py
index c5238e1..d680acb 100644
--- a/serversigns.py
+++ b/serversigns.py
@@ -335,7 +335,26 @@ def can_build2(player, block):
return not event.isCancelled()
-def check_all_signs():
+def check_all_signs_and_force_commands():
for loc in signs:
if server.getWorld(loc[0]).getBlockAt(loc[1], loc[2], loc[3]).getType() not in (Material.WALL_SIGN, Material.SIGN_POST):
del signs[loc]
+
+ try:
+ map_field = server.getPluginManager().getClass().getDeclaredField("commandMap")
+ map_field.setAccessible(True)
+ command_map = map_field.get(server.getPluginManager())
+
+ commands_field = command_map.getClass().getDeclaredField("knownCommands")
+ commands_field.setAccessible(True)
+ map = commands_field.get(command_map)
+
+ rsutils_cmd = map.get("redstonerutils:serversigns")
+ info(str(rsutils_cmd))
+ map.put("svs", rsutils_cmd)
+ map.put("serversigns", rsutils_cmd)
+ map.put("signsmsg", rsutils_cmd)
+
+ except:
+ error("[Serversigns] failed to force commands")
+ error(trace())