diff options
author | Dico200 <dico.karssiens@gmail.com> | 2016-05-31 16:39:54 +0200 |
---|---|---|
committer | Dico200 <dico.karssiens@gmail.com> | 2016-05-31 16:39:54 +0200 |
commit | f0ada788bfecd00c2d467f46bbc442af9ed1ecca (patch) | |
tree | 396ef93160b83a93b68d0a6ac1bbe73c9e43d8ee | |
parent | 5d00af8cedae09b66a0569e03635a04b0b188a1e (diff) |
Made serversigns force its commands into the command map (to replace the java plugin ServerSigns its commands)
-rw-r--r-- | main.py | 2 | ||||
-rw-r--r-- | serversigns.py | 21 |
2 files changed, 21 insertions, 2 deletions
@@ -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()) |