mirror of
https://github.com/CitizensDev/Citizens2.git
synced 2025-01-04 07:27:59 +01:00
Add -c flag to '/npc anchor --save anchor_name' to save location of the cursor.
This commit is contained in:
parent
b8878eda5d
commit
d6c6b3864f
@ -206,6 +206,16 @@ public class CommandContext {
|
|||||||
return location;
|
return location;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Location getSenderTargetBlockLocation() {
|
||||||
|
if (location != null || sender == null)
|
||||||
|
return location;
|
||||||
|
if (sender instanceof Player)
|
||||||
|
location = ((Player) sender).getTargetBlock(null, 50).getLocation();
|
||||||
|
else if (sender instanceof BlockCommandSender)
|
||||||
|
location = ((BlockCommandSender) sender).getBlock().getLocation();
|
||||||
|
return location;
|
||||||
|
}
|
||||||
|
|
||||||
public String[] getSlice(int index) {
|
public String[] getSlice(int index) {
|
||||||
String[] slice = new String[args.length - index];
|
String[] slice = new String[args.length - index];
|
||||||
System.arraycopy(args, index, slice, 0, args.length - index);
|
System.arraycopy(args, index, slice, 0, args.length - index);
|
||||||
|
@ -126,9 +126,9 @@ public class NPCCommands {
|
|||||||
|
|
||||||
@Command(
|
@Command(
|
||||||
aliases = { "npc" },
|
aliases = { "npc" },
|
||||||
usage = "anchor (--save [name]|--assume [name]|--remove [name]) (-a)",
|
usage = "anchor (--save [name]|--assume [name]|--remove [name]) (-a)(-c)",
|
||||||
desc = "Changes/Saves/Lists NPC's location anchor(s)",
|
desc = "Changes/Saves/Lists NPC's location anchor(s)",
|
||||||
flags = "a",
|
flags = "ac",
|
||||||
modifiers = { "anchor" },
|
modifiers = { "anchor" },
|
||||||
min = 1,
|
min = 1,
|
||||||
max = 2,
|
max = 2,
|
||||||
@ -143,10 +143,18 @@ public class NPCCommands {
|
|||||||
if (args.getSenderLocation() == null)
|
if (args.getSenderLocation() == null)
|
||||||
throw new ServerCommandException();
|
throw new ServerCommandException();
|
||||||
|
|
||||||
|
if (args.hasFlag('c')) {
|
||||||
|
if (trait.addAnchor(args.getFlag("save"), args.getSenderTargetBlockLocation())) {
|
||||||
|
Messaging.sendTr(sender, Messages.ANCHOR_ADDED);
|
||||||
|
} else
|
||||||
|
throw new CommandException(Messages.ANCHOR_ALREADY_EXISTS, args.getFlag("save"));
|
||||||
|
}
|
||||||
|
else {
|
||||||
if (trait.addAnchor(args.getFlag("save"), args.getSenderLocation())) {
|
if (trait.addAnchor(args.getFlag("save"), args.getSenderLocation())) {
|
||||||
Messaging.sendTr(sender, Messages.ANCHOR_ADDED);
|
Messaging.sendTr(sender, Messages.ANCHOR_ADDED);
|
||||||
} else
|
} else
|
||||||
throw new CommandException(Messages.ANCHOR_ALREADY_EXISTS, args.getFlag("save"));
|
throw new CommandException(Messages.ANCHOR_ALREADY_EXISTS, args.getFlag("save"));
|
||||||
|
}
|
||||||
} else if (args.hasValueFlag("assume")) {
|
} else if (args.hasValueFlag("assume")) {
|
||||||
if (args.getFlag("assume").isEmpty())
|
if (args.getFlag("assume").isEmpty())
|
||||||
throw new CommandException(Messages.INVALID_ANCHOR_NAME);
|
throw new CommandException(Messages.INVALID_ANCHOR_NAME);
|
||||||
|
Loading…
Reference in New Issue
Block a user