/
EntityCombustsScriptEvent.java
119 lines (109 loc) · 4.39 KB
/
EntityCombustsScriptEvent.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
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
package com.denizenscript.denizen.events.entity;
import com.denizenscript.denizen.objects.EntityTag;
import com.denizenscript.denizen.objects.LocationTag;
import com.denizenscript.denizen.utilities.implementation.BukkitScriptEntryData;
import com.denizenscript.denizen.events.BukkitScriptEvent;
import com.denizenscript.denizencore.objects.core.DurationTag;
import com.denizenscript.denizencore.objects.core.ElementTag;
import com.denizenscript.denizencore.objects.ObjectTag;
import com.denizenscript.denizencore.scripts.ScriptEntryData;
import org.bukkit.block.Block;
import org.bukkit.event.EventHandler;
import org.bukkit.event.Listener;
import org.bukkit.event.entity.EntityCombustByBlockEvent;
import org.bukkit.event.entity.EntityCombustByEntityEvent;
import org.bukkit.event.entity.EntityCombustEvent;
public class EntityCombustsScriptEvent extends BukkitScriptEvent implements Listener {
// <--[event]
// @Events
// <entity> combusts
//
// @Group Entity
//
// @Location true
//
// @Cancellable true
//
// @Triggers when an entity catches fire.
//
// @Context
// <context.entity> returns the entity that caught fire.
// <context.duration> returns the length of the burn.
// <context.source> returns the EntityTag or LocationTag that caused the fire, if any. NOTE: Currently, if the source is a LocationTag, the tag will return a null. It is expected that this will be fixed by Spigot in the future.
// <context.source_type> returns the type of the source, which can be: ENTITY, LOCATION, NONE.
//
// @Determine
// DurationTag set the burn duration.
//
// @Player when the entity that catches fire is a player.
//
// @NPC when the entity that catches fire is an NPC.
//
// -->
public EntityCombustsScriptEvent() {
registerCouldMatcher("<entity> combusts");
}
public EntityTag entity;
public EntityCombustEvent event;
@Override
public boolean matches(ScriptPath path) {
if (!path.tryArgObject(0, entity)) {
return false;
}
if (!runInCheck(path, entity.getLocation())) {
return false;
}
return super.matches(path);
}
@Override
public boolean applyDetermination(ScriptPath path, ObjectTag determinationObj) {
if (determinationObj instanceof ElementTag && ((ElementTag) determinationObj).isInt()) {
event.setDuration(((ElementTag) determinationObj).asInt());
return true;
}
else if (DurationTag.matches(determinationObj.toString())) {
event.setDuration(DurationTag.valueOf(determinationObj.toString(), getTagContext(path)).getTicksAsInt());
return true;
}
return super.applyDetermination(path, determinationObj);
}
@Override
public ScriptEntryData getScriptEntryData() {
return new BukkitScriptEntryData(entity);
}
@Override
public ObjectTag getContext(String name) {
switch (name) {
case "entity":
return entity.getDenizenObject();
case "duration":
return new DurationTag(event.getDuration());
case "source":
if (event instanceof EntityCombustByEntityEvent) {
return new EntityTag(((EntityCombustByEntityEvent) event).getCombuster()).getDenizenObject();
}
else if (event instanceof EntityCombustByBlockEvent) {
Block combuster = ((EntityCombustByBlockEvent) event).getCombuster();
if (combuster != null) {
return new LocationTag(combuster.getLocation());
}
}
break;
case "source_type":
if (event instanceof EntityCombustByEntityEvent) {
return new ElementTag("ENTITY");
}
else if (event instanceof EntityCombustByBlockEvent) {
return new ElementTag("LOCATION");
}
return new ElementTag("NONE");
}
return super.getContext(name);
}
@EventHandler
public void onEntityCombusts(EntityCombustEvent event) {
entity = new EntityTag(event.getEntity());
this.event = event;
fire(event);
}
}