mirror of
https://github.com/plexusorg/Plex-FAWE.git
synced 2025-01-10 17:57:37 +00:00
Moved WorldEdit to use Bukkit's command registration.
This commit is contained in:
parent
9f25c1906d
commit
5b200092ba
254
plugin.yml
254
plugin.yml
@ -1,3 +1,255 @@
|
|||||||
name: WorldEdit
|
name: WorldEdit
|
||||||
main: com.sk89q.worldedit.bukkit.WorldEditPlugin
|
main: com.sk89q.worldedit.bukkit.WorldEditPlugin
|
||||||
version: "WEVERSIONMACRO"
|
version: "WEVERSIONMACRO"
|
||||||
|
commands:
|
||||||
|
/limit:
|
||||||
|
description: See documentation
|
||||||
|
usage: /<command> <num>
|
||||||
|
toggleplace:
|
||||||
|
description: Toggle placing at pos #1
|
||||||
|
usage: /<command>
|
||||||
|
|
||||||
|
/undo:
|
||||||
|
description: Undo
|
||||||
|
usage: /<command>
|
||||||
|
/redo:
|
||||||
|
description: Redo
|
||||||
|
usage: /<command>
|
||||||
|
clearhistory:
|
||||||
|
description: Clear history
|
||||||
|
usage: /<command>
|
||||||
|
|
||||||
|
/pos1:
|
||||||
|
description: Set editing position #1
|
||||||
|
usage: /<command>
|
||||||
|
/pos2:
|
||||||
|
description: Set editing position #2
|
||||||
|
usage: /<command>
|
||||||
|
/hpos1:
|
||||||
|
description: Trace editing position #1
|
||||||
|
usage: /<command>
|
||||||
|
/hpos2:
|
||||||
|
description: Trace editing position #2
|
||||||
|
usage: /<command>
|
||||||
|
/chunk:
|
||||||
|
description: Select the chunk that you are in
|
||||||
|
usage: /<command>
|
||||||
|
/wand:
|
||||||
|
description: Gives you the edit wand
|
||||||
|
usage: /<command>
|
||||||
|
toggleeditwand:
|
||||||
|
description: Toggles edit wand selection
|
||||||
|
usage: /<command>
|
||||||
|
/expand:
|
||||||
|
description: Expands the selection
|
||||||
|
usage: /<command> <num> [direction]
|
||||||
|
/contract:
|
||||||
|
description: Contracts the selection
|
||||||
|
usage: /<command> <num> [direction]
|
||||||
|
/shift:
|
||||||
|
description: Shift the selection
|
||||||
|
usage: /<command> <num> [direction]
|
||||||
|
/size:
|
||||||
|
description: Get size of selected region
|
||||||
|
usage: /<command>
|
||||||
|
/count:
|
||||||
|
description: Count the number of blocks in the region
|
||||||
|
usage: /<command> <ids>
|
||||||
|
/distr:
|
||||||
|
description: Get the top block distribution
|
||||||
|
usage: /<command>
|
||||||
|
|
||||||
|
/set:
|
||||||
|
description: Set all blocks inside region
|
||||||
|
usage: /<command> <id>
|
||||||
|
/replace:
|
||||||
|
description: Replace all existing blocks inside region
|
||||||
|
usage: /<command> [from-id] [to-id]
|
||||||
|
/overlay:
|
||||||
|
description: Overlay the area one layer
|
||||||
|
usage: /<command> <id>
|
||||||
|
/walls:
|
||||||
|
description: Build walls
|
||||||
|
usage: /<command> <id>
|
||||||
|
/outline:
|
||||||
|
description: Outline the region with blocks
|
||||||
|
usage: /<command> <id>
|
||||||
|
/move:
|
||||||
|
description: Move the selection
|
||||||
|
usage: /<command> [count] [dir] [leave-id]
|
||||||
|
/stack:
|
||||||
|
description: Stacks the selection
|
||||||
|
usage: /<command> [count] [dir]
|
||||||
|
/smooth:
|
||||||
|
description: Smooth an area's heightmap
|
||||||
|
usage: /<command> [iterations]
|
||||||
|
|
||||||
|
/copy:
|
||||||
|
description: Copies the currently selected region
|
||||||
|
usage: /<command>
|
||||||
|
/cut:
|
||||||
|
description: Cuts the currently selected region
|
||||||
|
usage: /<command>
|
||||||
|
/paste:
|
||||||
|
description: Pastes the clipboard
|
||||||
|
usage: /<command> <at-origin?>
|
||||||
|
/rotate:
|
||||||
|
description: Rotate the clipboard
|
||||||
|
usage: /<command> <angle>
|
||||||
|
/flip:
|
||||||
|
description: Flip the clipboard
|
||||||
|
usage: /<command> [dir]
|
||||||
|
/load:
|
||||||
|
description: Load .schematic into clipboard
|
||||||
|
usage: /<command> <filename>
|
||||||
|
/save:
|
||||||
|
description: Save clipboard to .schematic
|
||||||
|
usage: /<command> <filename>
|
||||||
|
clearclipboard:
|
||||||
|
description: Clear clipboard
|
||||||
|
usage: /<command>
|
||||||
|
|
||||||
|
/hcyl:
|
||||||
|
description: Create a vertical hollow cylinder
|
||||||
|
usage: /<command> <id> <radius> [height]
|
||||||
|
/cyl:
|
||||||
|
description: Create a vertical cylinder
|
||||||
|
usage: /<command> <id> <radius> [height]
|
||||||
|
/sphere:
|
||||||
|
description: Create a sphere
|
||||||
|
usage: /<command> <id> <radius> [raised?]
|
||||||
|
/hsphere:
|
||||||
|
description: Create a hollow sphere
|
||||||
|
usage: /<command> <id> <radius> [raised?]
|
||||||
|
forestgen:
|
||||||
|
description: Make Notch tree forest
|
||||||
|
usage: /<command> [size] [density]
|
||||||
|
pinegen:
|
||||||
|
description: Make an ugly pine tree forest
|
||||||
|
usage: /<command> [size] [density]
|
||||||
|
pumpkins:
|
||||||
|
description: Make a pumpkin forest
|
||||||
|
usage: /<command> [size]
|
||||||
|
|
||||||
|
/fill:
|
||||||
|
description: Fill a hole
|
||||||
|
usage: /<command> <id> <radius> [depth]
|
||||||
|
/fillr:
|
||||||
|
description: Fill a hole fully recursively
|
||||||
|
usage: /<command> <id> <radius>
|
||||||
|
fixwater:
|
||||||
|
description: Level nearby pools of water
|
||||||
|
usage: /<command> <radius>
|
||||||
|
fixlava:
|
||||||
|
description: Level nearby pools of lava
|
||||||
|
usage: /<command> <radius>
|
||||||
|
/drain:
|
||||||
|
description: Drain nearby water/lava pools
|
||||||
|
usage: /<command> <radius>
|
||||||
|
removeabove:
|
||||||
|
description: Remove blocks above head
|
||||||
|
usage: /<command> [size] [height]
|
||||||
|
removebelow:
|
||||||
|
description: Remove blocks below position
|
||||||
|
usage: /<command> [size] [height]
|
||||||
|
removenear:
|
||||||
|
description: Remove blocks near you
|
||||||
|
usage: /<command> [id] [size]
|
||||||
|
replacenear:
|
||||||
|
description: Replace all existing blocks nearby
|
||||||
|
usage: /<command> <size> <from-id> <to-id>
|
||||||
|
snow:
|
||||||
|
description: Simulate snow cover
|
||||||
|
usage: /<command> <radius>
|
||||||
|
thaw:
|
||||||
|
description: Unthaw/remove snow
|
||||||
|
usage: /<command> <radius>
|
||||||
|
butcher:
|
||||||
|
description: Kill nearby mobs
|
||||||
|
usage: /<command> [radius]
|
||||||
|
ex:
|
||||||
|
description: Extinguish fires
|
||||||
|
usage: /<command> [size]
|
||||||
|
|
||||||
|
chunkinfo:
|
||||||
|
description: Get the filename of the chunk that you are in
|
||||||
|
usage: /<command>
|
||||||
|
listchunks:
|
||||||
|
description: Print a list of used chunks
|
||||||
|
usage: /<command>
|
||||||
|
delchunks:
|
||||||
|
description: Generate a shell script to delete chunks
|
||||||
|
usage: /<command>
|
||||||
|
|
||||||
|
unstuck:
|
||||||
|
description: Go up to the first free spot
|
||||||
|
usage: /<command>
|
||||||
|
ascend:
|
||||||
|
description: Go up one level
|
||||||
|
usage: /<command>
|
||||||
|
descend:
|
||||||
|
description: Go down one level
|
||||||
|
usage: /<command>
|
||||||
|
jumpto:
|
||||||
|
description: Jump to the block that you are looking at
|
||||||
|
usage: /<command>
|
||||||
|
thru:
|
||||||
|
description: Go through the wall that you are looking at
|
||||||
|
usage: /<command>
|
||||||
|
ceil:
|
||||||
|
description: Get to the ceiling
|
||||||
|
usage: /<command> [clearence]
|
||||||
|
up:
|
||||||
|
description: Go up some distance
|
||||||
|
usage: /<command> <distance>
|
||||||
|
|
||||||
|
listsnapshots:
|
||||||
|
description: List the 5 newest snapshots
|
||||||
|
usage: /<command> [num]
|
||||||
|
/use:
|
||||||
|
description: Use a particular snapshot
|
||||||
|
usage: /<command> <snapshot-id>
|
||||||
|
/restore:
|
||||||
|
description: Restore a particular snapshot
|
||||||
|
usage: /<command> [snapshot-id]
|
||||||
|
|
||||||
|
/:
|
||||||
|
description: Toggles super pick axe.
|
||||||
|
usage: /<command>
|
||||||
|
single:
|
||||||
|
description: Switch to single block super pickaxe mode
|
||||||
|
usage: /<command>
|
||||||
|
area:
|
||||||
|
description: Switch to area super pickaxe mode
|
||||||
|
usage: /<command> <range>
|
||||||
|
recur:
|
||||||
|
description: Switch to recursive super pickaxe mode
|
||||||
|
usage: /<command> <range>
|
||||||
|
none:
|
||||||
|
description: Switch to no tool
|
||||||
|
usage: /<command>
|
||||||
|
info:
|
||||||
|
description: Switch to the info tool
|
||||||
|
usage: /<command>
|
||||||
|
tree:
|
||||||
|
description: Switch to the tree tool
|
||||||
|
usage: /<command>
|
||||||
|
pinetree:
|
||||||
|
description: Switch to the pine tree tool
|
||||||
|
usage: /<command>
|
||||||
|
bigtree:
|
||||||
|
description: Switch to the big tree tool
|
||||||
|
usage: /<command>
|
||||||
|
repl:
|
||||||
|
description: Switch to the block replacer tool
|
||||||
|
usage: /<command> <id>
|
||||||
|
brush:
|
||||||
|
description: Switch to the sphere brush tool
|
||||||
|
usage: /<command> <id> [radius] [no-replace?]
|
||||||
|
reloadwe:
|
||||||
|
description: Switch to the replacing sphere brush tool
|
||||||
|
usage: /<command> <id> [radius]
|
||||||
|
|
||||||
|
reloadwe:
|
||||||
|
description: Reload WorldEdit's configuration
|
||||||
|
usage: /<command>
|
@ -60,20 +60,6 @@ public class WorldEditPlayerListener extends PlayerListener {
|
|||||||
public void onPlayerCommand(PlayerChatEvent event) {
|
public void onPlayerCommand(PlayerChatEvent event) {
|
||||||
String[] split = event.getMessage().split(" ");
|
String[] split = event.getMessage().split(" ");
|
||||||
|
|
||||||
if (split[0].equalsIgnoreCase("/reloadwe")
|
|
||||||
&& plugin.hasPermission(event.getPlayer(), "/reloadwe")) {
|
|
||||||
try {
|
|
||||||
plugin.loadConfiguration();
|
|
||||||
event.getPlayer().sendMessage("WorldEdit configuration reloaded.");
|
|
||||||
} catch (Throwable t) {
|
|
||||||
event.getPlayer().sendMessage("Error while reloading: "
|
|
||||||
+ t.getMessage());
|
|
||||||
}
|
|
||||||
|
|
||||||
event.setCancelled(true);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (plugin.controller.handleCommand(wrapPlayer(event.getPlayer()), split)) {
|
if (plugin.controller.handleCommand(wrapPlayer(event.getPlayer()), split)) {
|
||||||
event.setCancelled(true);
|
event.setCancelled(true);
|
||||||
}
|
}
|
||||||
|
@ -25,6 +25,7 @@ import java.io.IOException;
|
|||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.util.logging.Logger;
|
import java.util.logging.Logger;
|
||||||
import org.bukkit.Server;
|
import org.bukkit.Server;
|
||||||
|
import org.bukkit.command.Command;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.event.Event.Priority;
|
import org.bukkit.event.Event.Priority;
|
||||||
import org.bukkit.event.Event;
|
import org.bukkit.event.Event;
|
||||||
@ -89,10 +90,10 @@ public class WorldEditPlugin extends JavaPlugin {
|
|||||||
private void registerEvents() {
|
private void registerEvents() {
|
||||||
getServer().getPluginManager().registerEvent(Event.Type.PLAYER_QUIT,
|
getServer().getPluginManager().registerEvent(Event.Type.PLAYER_QUIT,
|
||||||
playerListener, Priority.Normal, this);
|
playerListener, Priority.Normal, this);
|
||||||
getServer().getPluginManager().registerEvent(Event.Type.PLAYER_COMMAND,
|
|
||||||
playerListener, Priority.Normal, this);
|
|
||||||
getServer().getPluginManager().registerEvent(Event.Type.PLAYER_ITEM,
|
getServer().getPluginManager().registerEvent(Event.Type.PLAYER_ITEM,
|
||||||
playerListener, Priority.Normal, this);
|
playerListener, Priority.Normal, this);
|
||||||
|
getServer().getPluginManager().registerEvent(Event.Type.PLAYER_COMMAND,
|
||||||
|
playerListener, Priority.Normal, this);
|
||||||
getServer().getPluginManager().registerEvent(Event.Type.BLOCK_DAMAGED,
|
getServer().getPluginManager().registerEvent(Event.Type.BLOCK_DAMAGED,
|
||||||
blockListener, Priority.Normal, this);
|
blockListener, Priority.Normal, this);
|
||||||
getServer().getPluginManager().registerEvent(Event.Type.BLOCK_RIGHTCLICKED,
|
getServer().getPluginManager().registerEvent(Event.Type.BLOCK_RIGHTCLICKED,
|
||||||
@ -143,6 +144,27 @@ public class WorldEditPlugin extends JavaPlugin {
|
|||||||
perms.load();
|
perms.load();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean onCommand(Player player, Command cmd, String commandLabel, String[] args) {
|
||||||
|
if (cmd.getName().equalsIgnoreCase("reloadwe")
|
||||||
|
&& hasPermission(player, "reloadwe")) {
|
||||||
|
try {
|
||||||
|
loadConfiguration();
|
||||||
|
player.sendMessage("WorldEdit configuration reloaded.");
|
||||||
|
} catch (Throwable t) {
|
||||||
|
player.sendMessage("Error while reloading: "
|
||||||
|
+ t.getMessage());
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
String[] split = new String[args.length + 1];
|
||||||
|
System.arraycopy(args, 0, split, 1, args.length);
|
||||||
|
split[0] = "/" + cmd.getName();
|
||||||
|
|
||||||
|
return controller.handleCommand(wrapPlayer(player), split);
|
||||||
|
}
|
||||||
|
|
||||||
String[] getGroups(Player player) {
|
String[] getGroups(Player player) {
|
||||||
return perms.getGroups(player.getName());
|
return perms.getGroups(player.getName());
|
||||||
}
|
}
|
||||||
@ -155,6 +177,10 @@ public class WorldEditPlugin extends JavaPlugin {
|
|||||||
return player.isOp() || perms.hasPermission(player.getName(), perm);
|
return player.isOp() || perms.hasPermission(player.getName(), perm);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
BukkitPlayer wrapPlayer(Player player) {
|
||||||
|
return new BukkitPlayer(this, this.server, player);
|
||||||
|
}
|
||||||
|
|
||||||
public WorldEditAPI getAPI() {
|
public WorldEditAPI getAPI() {
|
||||||
return api;
|
return api;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user