/
EntityAI.java
99 lines (78 loc) · 2.51 KB
/
EntityAI.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
88
89
90
91
92
93
94
95
96
97
98
99
package net.aufdemrand.denizen.objects.properties.entity;
import net.aufdemrand.denizen.objects.dEntity;
import net.aufdemrand.denizen.utilities.entity.EntityMovement;
import net.aufdemrand.denizencore.objects.Element;
import net.aufdemrand.denizencore.objects.Mechanism;
import net.aufdemrand.denizencore.objects.dObject;
import net.aufdemrand.denizencore.objects.properties.Property;
import net.aufdemrand.denizencore.tags.Attribute;
public class EntityAI implements Property {
public static boolean describes(dObject entity) {
return entity instanceof dEntity
&& ((dEntity) entity).isLivingEntity();
}
public static EntityAI getFrom(dObject entity) {
if (!describes(entity)) {
return null;
}
else {
return new EntityAI((dEntity) entity);
}
}
///////////////////
// Instance Fields and Methods
/////////////
private EntityAI(dEntity ent) {
entity = ent;
}
dEntity entity;
/////////
// Property Methods
///////
@Override
public String getPropertyString() {
return String.valueOf(!EntityMovement.isAIDisabled(entity.getBukkitEntity()));
}
@Override
public String getPropertyId() {
return "has_ai";
}
///////////
// dObject Attributes
////////
@Override
public String getAttribute(Attribute attribute) {
if (attribute == null) {
return null;
}
// <--[tag]
// @attribute <e@entity.has_ai>
// @returns Element(Boolean)
// @group attributes
// @description
// Returns whether the entity uses the default Minecraft
// AI to roam and look around.
// -->
if (attribute.startsWith("has_ai")) {
return new Element(!EntityMovement.isAIDisabled(entity.getBukkitEntity()))
.getAttribute(attribute.fulfill(1));
}
return null;
}
@Override
public void adjust(Mechanism mechanism) {
// <--[mechanism]
// @object dEntity
// @name has_ai
// @input Element(Boolean)
// @description
// Sets whether this entity will use the default
// Minecraft AI to roam and look around.
// @tags
// <e@entity.has_ai>
// -->
if ((mechanism.matches("has_ai") || mechanism.matches("toggle_ai")) && mechanism.requireBoolean()) {
EntityMovement.toggleAI(entity.getBukkitEntity(), mechanism.getValue().asBoolean());
}
}
}