/
MythicSignalCommand.java
87 lines (80 loc) · 3.59 KB
/
MythicSignalCommand.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
package com.denizenscript.depenizen.bukkit.commands.mythicmobs;
import com.denizenscript.denizen.objects.EntityTag;
import com.denizenscript.denizencore.exceptions.InvalidArgumentsException;
import com.denizenscript.denizencore.objects.Argument;
import com.denizenscript.denizencore.objects.core.ElementTag;
import com.denizenscript.denizencore.objects.core.ListTag;
import com.denizenscript.denizencore.scripts.ScriptEntry;
import com.denizenscript.denizencore.scripts.commands.AbstractCommand;
import com.denizenscript.denizencore.utilities.debugging.Debug;
import com.denizenscript.depenizen.bukkit.objects.mythicmobs.MythicMobsMobTag;
import io.lumine.xikage.mythicmobs.adapters.bukkit.BukkitAdapter;
import java.util.List;
public class MythicSignalCommand extends AbstractCommand {
public MythicSignalCommand() {
setName("mythicsignal");
setSyntax("mythicsignal [<mythicmob>|...] [<signal>] [source:<entity>]");
setRequiredArguments(3, 3);
}
// <--[command]
// @Name MythicSignal
// @Syntax mythicsignal [<mythicmob>|...] [<signal>] [source:<entity>]
// @Group Depenizen
// @Plugin Depenizen, MythicMobs
// @Required 3
// @Maximum 3
// @Short Sends a signal trigger to the target MythicMobs.
//
// @Description
// This allows you to send a signal trigger to multiple MythicMobs.
// If those mobs have any triggers configured for that signal, they will fire.
// You must specify an entity that acts as the sender.
// NOTE: signals are case sensitive.
//
// @Usage
// Used to trigger the player's target's signal "attack".
// - mythicsignal <player.target.mythicmob> attack source:<player>
//
// -->
@Override
public void parseArgs(ScriptEntry scriptEntry) throws InvalidArgumentsException {
for (Argument arg : scriptEntry) {
if (!scriptEntry.hasObject("targets")
&& arg.matchesArgumentList(MythicMobsMobTag.class)) {
scriptEntry.addObject("targets", arg.asType(ListTag.class).filter(MythicMobsMobTag.class, scriptEntry));
}
else if (!scriptEntry.hasObject("source")
&& arg.matchesPrefix("source")
&& arg.matchesArgumentType(EntityTag.class)) {
scriptEntry.addObject("source", arg.asType(EntityTag.class));
}
else if (!scriptEntry.hasObject("signal")) {
scriptEntry.addObject("signal", arg.asType(ElementTag.class));
}
else {
arg.reportUnhandled();
}
}
if (!scriptEntry.hasObject("targets")) {
throw new InvalidArgumentsException("Must specify MythicMobs to send the signal to.");
}
if (!scriptEntry.hasObject("signal")) {
throw new InvalidArgumentsException("Must specify a signal to send.");
}
if (!scriptEntry.hasObject("source")) {
throw new InvalidArgumentsException("Must specify a source entity.");
}
}
@Override
public void execute(ScriptEntry scriptEntry) {
EntityTag source = scriptEntry.getObjectTag("source");
List<MythicMobsMobTag> targets = (List<MythicMobsMobTag>) scriptEntry.getObject("targets");
ElementTag signal = scriptEntry.getElement("signal");
if (scriptEntry.dbCallShouldDebug()) {
Debug.report(scriptEntry, getName(), db("mythicmobs", targets), signal, source);
}
for (MythicMobsMobTag mob : targets) {
mob.getMob().signalMob(BukkitAdapter.adapt(source.getBukkitEntity()), signal.asString());
}
}
}