mirror of
https://github.com/EngineHub/WorldEdit.git
synced 2025-01-12 12:25:03 +08:00
Alowed performing undos from other player sessions, if they exist.
This commit is contained in:
parent
a3186c2ce4
commit
02d8acfa81
@ -631,4 +631,10 @@ public boolean equals(Object other) {
|
|||||||
public int hashCode() {
|
public int hashCode() {
|
||||||
return getName().hashCode();
|
return getName().hashCode();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void checkPermission(String permission) throws WorldEditPermissionException {
|
||||||
|
if (!hasPermission(permission)) {
|
||||||
|
throw new WorldEditPermissionException();
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -174,6 +174,16 @@ public void invokeMethod(Method parent, String[] args,
|
|||||||
commands.register(UtilityCommands.class);
|
commands.register(UtilityCommands.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Gets the LocalSession for a player name if it exists
|
||||||
|
*
|
||||||
|
* @param player
|
||||||
|
* @return The session for the player, if it exists
|
||||||
|
*/
|
||||||
|
public LocalSession getSession(String player) {
|
||||||
|
return sessions.get(player);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the WorldEdit session for a player.
|
* Gets the WorldEdit session for a player.
|
||||||
*
|
*
|
||||||
|
@ -0,0 +1,10 @@
|
|||||||
|
package com.sk89q.worldedit;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author zml2008
|
||||||
|
*/
|
||||||
|
public class WorldEditPermissionException extends WorldEditException {
|
||||||
|
public WorldEditPermissionException() {
|
||||||
|
super("You don't have permission to do this.");
|
||||||
|
}
|
||||||
|
}
|
@ -32,10 +32,10 @@
|
|||||||
public class HistoryCommands {
|
public class HistoryCommands {
|
||||||
@Command(
|
@Command(
|
||||||
aliases = {"/undo", "undo"},
|
aliases = {"/undo", "undo"},
|
||||||
usage = "[times]",
|
usage = "[times] [player]",
|
||||||
desc = "Undoes the last action",
|
desc = "Undoes the last action",
|
||||||
min = 0,
|
min = 0,
|
||||||
max = 1
|
max = 2
|
||||||
)
|
)
|
||||||
@CommandPermissions({"worldedit.history.undo"})
|
@CommandPermissions({"worldedit.history.undo"})
|
||||||
public static void undo(CommandContext args, WorldEdit we,
|
public static void undo(CommandContext args, WorldEdit we,
|
||||||
@ -43,9 +43,19 @@ public static void undo(CommandContext args, WorldEdit we,
|
|||||||
throws WorldEditException {
|
throws WorldEditException {
|
||||||
|
|
||||||
int times = Math.max(1, args.getInteger(0, 1));
|
int times = Math.max(1, args.getInteger(0, 1));
|
||||||
|
|
||||||
for (int i = 0; i < times; ++i) {
|
for (int i = 0; i < times; ++i) {
|
||||||
EditSession undone = session.undo(session.getBlockBag(player));
|
EditSession undone;
|
||||||
|
if (args.argsLength() < 2) {
|
||||||
|
undone = session.undo(session.getBlockBag(player));
|
||||||
|
} else {
|
||||||
|
player.checkPermission("worldedit.history.undo.other");
|
||||||
|
LocalSession sess = we.getSession(args.getString(1));
|
||||||
|
if (sess == null){
|
||||||
|
player.printError("Unable to find session for " + args.getString(1));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
undone = sess.undo(session.getBlockBag(player));
|
||||||
|
}
|
||||||
if (undone != null) {
|
if (undone != null) {
|
||||||
player.print("Undo successful.");
|
player.print("Undo successful.");
|
||||||
we.flushBlockBag(player, undone);
|
we.flushBlockBag(player, undone);
|
||||||
@ -58,10 +68,10 @@ public static void undo(CommandContext args, WorldEdit we,
|
|||||||
|
|
||||||
@Command(
|
@Command(
|
||||||
aliases = {"/redo", "redo"},
|
aliases = {"/redo", "redo"},
|
||||||
usage = "[times]",
|
usage = "[times] [player]",
|
||||||
desc = "Redoes the last action (from history)",
|
desc = "Redoes the last action (from history)",
|
||||||
min = 0,
|
min = 0,
|
||||||
max = 1
|
max = 2
|
||||||
)
|
)
|
||||||
@CommandPermissions({"worldedit.history.redo"})
|
@CommandPermissions({"worldedit.history.redo"})
|
||||||
public static void redo(CommandContext args, WorldEdit we,
|
public static void redo(CommandContext args, WorldEdit we,
|
||||||
@ -71,7 +81,18 @@ public static void redo(CommandContext args, WorldEdit we,
|
|||||||
int times = Math.max(1, args.getInteger(0, 1));
|
int times = Math.max(1, args.getInteger(0, 1));
|
||||||
|
|
||||||
for (int i = 0; i < times; ++i) {
|
for (int i = 0; i < times; ++i) {
|
||||||
EditSession redone = session.redo(session.getBlockBag(player));
|
EditSession redone;
|
||||||
|
if (args.argsLength() < 2) {
|
||||||
|
redone = session.redo(session.getBlockBag(player));
|
||||||
|
} else {
|
||||||
|
player.checkPermission("worldedit.history.redo.other");
|
||||||
|
LocalSession sess = we.getSession(args.getString(1));
|
||||||
|
if (sess == null){
|
||||||
|
player.printError("Unable to find session for " + args.getString(1));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
redone = sess.redo(session.getBlockBag(player));
|
||||||
|
}
|
||||||
if (redone != null) {
|
if (redone != null) {
|
||||||
player.print("Redo successful.");
|
player.print("Redo successful.");
|
||||||
we.flushBlockBag(player, redone);
|
we.flushBlockBag(player, redone);
|
||||||
|
Loading…
Reference in New Issue
Block a user