mirror of
https://github.com/plexusorg/Plex-FAWE.git
synced 2024-12-23 17:57:38 +00:00
Added support for console commands to WorldEditPlugin.
This commit is contained in:
parent
3bec3c169c
commit
370ddeb9ff
@ -260,6 +260,10 @@ public abstract class CommandsManager<T> {
|
|||||||
return descs;
|
return descs;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Map<Method, Map<String, Method>> getMethods() {
|
||||||
|
return commands;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get a map from command name to help message. This is only for root commands.
|
* Get a map from command name to help message. This is only for root commands.
|
||||||
*
|
*
|
||||||
@ -437,9 +441,7 @@ public abstract class CommandsManager<T> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!hasPermission(method, player)) {
|
checkPermission(player, method);
|
||||||
throw new CommandPermissionsException();
|
|
||||||
}
|
|
||||||
|
|
||||||
int argsCount = args.length - 1 - level;
|
int argsCount = args.length - 1 - level;
|
||||||
|
|
||||||
@ -495,6 +497,12 @@ public abstract class CommandsManager<T> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected void checkPermission(T player, Method method) throws CommandException {
|
||||||
|
if (!hasPermission(method, player)) {
|
||||||
|
throw new CommandPermissionsException();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public void invokeMethod(Method parent, String[] args, T player, Method method,
|
public void invokeMethod(Method parent, String[] args, T player, Method method,
|
||||||
Object instance, Object[] methodArgs, int level) throws CommandException {
|
Object instance, Object[] methodArgs, int level) throws CommandException {
|
||||||
try {
|
try {
|
||||||
|
31
src/main/java/com/sk89q/minecraft/util/commands/Console.java
Normal file
31
src/main/java/com/sk89q/minecraft/util/commands/Console.java
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
// $Id$
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2010 sk89q <http://www.sk89q.com>
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.sk89q.minecraft.util.commands;
|
||||||
|
|
||||||
|
import java.lang.annotation.Retention;
|
||||||
|
import java.lang.annotation.RetentionPolicy;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This annotation indicates that a command can be used from the console.
|
||||||
|
*
|
||||||
|
* @author sk89q
|
||||||
|
*/
|
||||||
|
@Retention(RetentionPolicy.RUNTIME)
|
||||||
|
public @interface Console {
|
||||||
|
}
|
@ -640,7 +640,7 @@ public class LocalSession {
|
|||||||
|
|
||||||
// Create an edit session
|
// Create an edit session
|
||||||
EditSession editSession =
|
EditSession editSession =
|
||||||
new EditSession(player.getWorld(),
|
new EditSession(player.isPlayer() ? player.getWorld() : null,
|
||||||
getBlockChangeLimit(), blockBag);
|
getBlockChangeLimit(), blockBag);
|
||||||
editSession.setFastMode(fastMode);
|
editSession.setFastMode(fastMode);
|
||||||
editSession.setMask(mask);
|
editSession.setMask(mask);
|
||||||
|
@ -28,6 +28,7 @@ import java.lang.reflect.Method;
|
|||||||
import javax.script.ScriptException;
|
import javax.script.ScriptException;
|
||||||
|
|
||||||
import com.sk89q.minecraft.util.commands.*;
|
import com.sk89q.minecraft.util.commands.*;
|
||||||
|
import com.sk89q.minecraft.util.commands.Console;
|
||||||
|
|
||||||
import com.sk89q.util.StringUtil;
|
import com.sk89q.util.StringUtil;
|
||||||
import com.sk89q.worldedit.CuboidClipboard.FlipDirection;
|
import com.sk89q.worldedit.CuboidClipboard.FlipDirection;
|
||||||
@ -101,6 +102,15 @@ public class WorldEdit {
|
|||||||
this.config = config;
|
this.config = config;
|
||||||
|
|
||||||
commands = new CommandsManager<LocalPlayer>() {
|
commands = new CommandsManager<LocalPlayer>() {
|
||||||
|
@Override
|
||||||
|
protected void checkPermission(LocalPlayer player, Method method) throws CommandException {
|
||||||
|
if (!player.isPlayer() && !method.isAnnotationPresent(Console.class)) {
|
||||||
|
throw new UnhandledCommandException();
|
||||||
|
}
|
||||||
|
|
||||||
|
super.checkPermission(player, method);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean hasPermission(LocalPlayer player, String perm) {
|
public boolean hasPermission(LocalPlayer player, String perm) {
|
||||||
return player.hasPermission(perm);
|
return player.hasPermission(perm);
|
||||||
@ -120,9 +130,12 @@ public class WorldEdit {
|
|||||||
logMode = loggingAnnotation.value();
|
logMode = loggingAnnotation.value();
|
||||||
}
|
}
|
||||||
|
|
||||||
String msg = "WorldEdit: " + player.getName() + " (in \"" + player.getWorld().getName()
|
String msg = "WorldEdit: " + player.getName();
|
||||||
+ "\")" + ": " + StringUtil.joinString(args, " ");
|
if (player.isPlayer()) {
|
||||||
if (logMode != null) {
|
msg += " (in \"" + player.getWorld().getName() + "\")";
|
||||||
|
}
|
||||||
|
msg += ": " + StringUtil.joinString(args, " ");
|
||||||
|
if (logMode != null && player.isPlayer()) {
|
||||||
Vector position = player.getPosition();
|
Vector position = player.getPosition();
|
||||||
final LocalSession session = getSession(player);
|
final LocalSession session = getSession(player);
|
||||||
switch (logMode) {
|
switch (logMode) {
|
||||||
|
@ -0,0 +1,28 @@
|
|||||||
|
package com.sk89q.worldedit.bukkit;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import com.sk89q.minecraft.util.commands.Command;
|
||||||
|
import com.sk89q.minecraft.util.commands.CommandPermissions;
|
||||||
|
|
||||||
|
public class WorldEditCommand extends org.bukkit.command.Command {
|
||||||
|
|
||||||
|
public WorldEditCommand(Command command, CommandPermissions commandPermissions) {
|
||||||
|
super(command.aliases()[0]);
|
||||||
|
this.description = command.desc();
|
||||||
|
this.usageMessage = "/"+getName()+" "+command.usage();
|
||||||
|
|
||||||
|
List<String> aliases = new ArrayList<String>(Arrays.asList(command.aliases()));
|
||||||
|
aliases.remove(0);
|
||||||
|
this.setAliases(aliases);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean execute(CommandSender sender, String currentAlias, String[] args) {
|
||||||
|
// This method is never called.
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
@ -31,7 +31,6 @@ import java.util.zip.ZipEntry;
|
|||||||
import com.sk89q.util.yaml.YAMLProcessor;
|
import com.sk89q.util.yaml.YAMLProcessor;
|
||||||
import com.sk89q.wepif.PermissionsResolverManager;
|
import com.sk89q.wepif.PermissionsResolverManager;
|
||||||
import org.bukkit.World;
|
import org.bukkit.World;
|
||||||
import org.bukkit.command.Command;
|
|
||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.event.Event.Priority;
|
import org.bukkit.event.Event.Priority;
|
||||||
@ -222,15 +221,8 @@ public class WorldEditPlugin extends JavaPlugin {
|
|||||||
* Called on WorldEdit command.
|
* Called on WorldEdit command.
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public boolean onCommand(CommandSender sender, Command cmd,
|
public boolean onCommand(CommandSender sender, org.bukkit.command.Command cmd,
|
||||||
String commandLabel, String[] args) {
|
String commandLabel, String[] args) {
|
||||||
// Since WorldEdit is primarily made for use in-game, we're going
|
|
||||||
// to ignore the situation where the command sender is not a player.
|
|
||||||
if (!(sender instanceof Player)) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
Player player = (Player) sender;
|
|
||||||
|
|
||||||
// Add the command to the array because the underlying command handling
|
// Add the command to the array because the underlying command handling
|
||||||
// code of WorldEdit expects it
|
// code of WorldEdit expects it
|
||||||
@ -238,7 +230,7 @@ public class WorldEditPlugin extends JavaPlugin {
|
|||||||
System.arraycopy(args, 0, split, 1, args.length);
|
System.arraycopy(args, 0, split, 1, args.length);
|
||||||
split[0] = "/" + cmd.getName();
|
split[0] = "/" + cmd.getName();
|
||||||
|
|
||||||
controller.handleCommand(wrapPlayer(player), split);
|
controller.handleCommand(wrapCommandSender(sender), split);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user