-
-
Notifications
You must be signed in to change notification settings - Fork 103
/
VehicleCollidesEntityScriptEvent.java
124 lines (108 loc) · 3.91 KB
/
VehicleCollidesEntityScriptEvent.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
120
121
122
123
124
package com.denizenscript.denizen.events.entity;
import com.denizenscript.denizen.objects.EntityTag;
import com.denizenscript.denizen.utilities.implementation.BukkitScriptEntryData;
import com.denizenscript.denizen.events.BukkitScriptEvent;
import com.denizenscript.denizencore.objects.Argument;
import com.denizenscript.denizencore.objects.core.ElementTag;
import com.denizenscript.denizencore.objects.ObjectTag;
import com.denizenscript.denizencore.scripts.ScriptEntryData;
import org.bukkit.event.EventHandler;
import org.bukkit.event.Listener;
import org.bukkit.event.vehicle.VehicleEntityCollisionEvent;
public class VehicleCollidesEntityScriptEvent extends BukkitScriptEvent implements Listener {
// <--[event]
// @Events
// vehicle collides with entity
// vehicle collides with <entity>
// <vehicle> collides with entity
// <vehicle> collides with <entity>
//
// @Regex ^on [^\s]+ collides with [^\s]+$
//
// @Switch in:<area> to only process the event if it occurred within a specified area.
//
// @Cancellable true
//
// @Triggers when a vehicle collides with an entity.
//
// @Context
// <context.vehicle> returns the EntityTag of the vehicle.
// <context.entity> returns the EntityTag of the entity the vehicle has collided with.
// <context.pickup> returns whether the vehicle can pick up the entity.
//
// @Determine
// "PICKUP:TRUE" to allow the vehicle to pick up the entity.
// "PICKUP:FALSE" to stop the vehicle from picking up the entity.
//
// @Player when a vehicle collides with a player.
//
// @NPC when a vehicle collides with an NPC.
//
// -->
public VehicleCollidesEntityScriptEvent() {
instance = this;
}
public static VehicleCollidesEntityScriptEvent instance;
public EntityTag vehicle;
public EntityTag entity;
private Boolean pickup_cancel;
public VehicleEntityCollisionEvent event;
@Override
public boolean couldMatch(ScriptPath path) {
return path.eventLower.contains("collides with");
}
@Override
public boolean matches(ScriptPath path) {
if (!tryEntity(vehicle, path.eventArgLowerAt(0))) {
return false;
}
if (!tryEntity(entity, path.eventArgLowerAt(3))) {
return false;
}
if (!runInCheck(path, vehicle.getLocation())) {
return false;
}
return super.matches(path);
}
@Override
public String getName() {
return "VehicleCollidesEntity";
}
@Override
public boolean applyDetermination(ScriptPath path, ObjectTag determinationObj) {
if (determinationObj instanceof ElementTag) {
Argument arg = Argument.valueOf(determinationObj.toString());
if (arg.matchesPrefix("pickup")) {
pickup_cancel = !arg.asElement().asBoolean();
return true;
}
}
return super.applyDetermination(path, determinationObj);
}
@Override
public ScriptEntryData getScriptEntryData() {
return new BukkitScriptEntryData(entity);
}
@Override
public ObjectTag getContext(String name) {
if (name.equals("vehicle")) {
return vehicle;
}
else if (name.equals("entity")) {
return entity;
}
else if (name.equals("pickup")) {
return new ElementTag(!pickup_cancel);
}
return super.getContext(name);
}
@EventHandler
public void onVehicleCollidesEntity(VehicleEntityCollisionEvent event) {
entity = new EntityTag(event.getEntity());
vehicle = new EntityTag(event.getVehicle());
pickup_cancel = event.isPickupCancelled();
this.event = event;
fire(event);
event.setPickupCancelled(pickup_cancel);
}
}