Skip to content

Commit

Permalink
Rewrote "portal created" in ScriptEvent format.
Browse files Browse the repository at this point in the history
Removed imports that weren't needed from EntityCreatedPortal.
  • Loading branch information
Talamar1 committed Jun 30, 2015
1 parent ed08ebe commit 4e2ee18
Show file tree
Hide file tree
Showing 4 changed files with 110 additions and 43 deletions.
1 change: 1 addition & 0 deletions src/main/java/net/aufdemrand/denizen/Denizen.java
Expand Up @@ -650,6 +650,7 @@ public void onEnable() {
ScriptEvent.registerScriptEvent(new PlayerTakesFromFurnaceScriptEvent());
ScriptEvent.registerScriptEvent(new PlayerUsesPortalScriptEvent());
ScriptEvent.registerScriptEvent(new PlayerWalkScriptEvent());
ScriptEvent.registerScriptEvent(new PortalCreateScriptEvent());
ScriptEvent.registerScriptEvent(new ProjectileLaunchedScriptEvent());
ScriptEvent.registerScriptEvent(new PotionSplashScriptEvent());
ScriptEvent.registerScriptEvent(new RedstoneScriptEvent());
Expand Down
Expand Up @@ -14,9 +14,7 @@
import org.bukkit.event.Listener;
import org.bukkit.event.entity.EntityCreatePortalEvent;

import java.util.Arrays;
import java.util.HashMap;
import java.util.List;

public class EntityCreatePortalScriptEvent extends BukkitScriptEvent implements Listener {

Expand Down
@@ -0,0 +1,109 @@
package net.aufdemrand.denizen.events.world;


import net.aufdemrand.denizen.objects.dLocation;
import net.aufdemrand.denizen.objects.dWorld;
import net.aufdemrand.denizen.utilities.DenizenAPI;
import net.aufdemrand.denizencore.events.ScriptEvent;
import net.aufdemrand.denizencore.objects.Element;
import net.aufdemrand.denizencore.objects.dList;
import net.aufdemrand.denizencore.objects.dObject;
import net.aufdemrand.denizencore.scripts.containers.ScriptContainer;
import net.aufdemrand.denizencore.utilities.CoreUtilities;
import org.bukkit.Bukkit;
import org.bukkit.block.Block;
import org.bukkit.event.EventHandler;
import org.bukkit.event.Listener;
import org.bukkit.event.world.PortalCreateEvent;

import java.util.HashMap;

public class PortalCreateScriptEvent extends ScriptEvent implements Listener {

// <--[event]
// @Events
// portal created (in <world>) (because <reason>)
//
// @Cancellable true
//
// @Triggers when a portal is created in a world.
//
// @Context
// <context.world> returns the dWorld the portal was created in.
// <context.reason> returns an Element of the reason the portal was created. (FIRE or OBC_DESTINATION)
// <context.list> returns a dList of all the blocks that will become portal blocks.
//
// -->

public PortalCreateScriptEvent() {
instance = this;
}

public static PortalCreateScriptEvent instance;
public dWorld world;
public Element reason;
public dList list;
public PortalCreateEvent event;

@Override
public boolean couldMatch(ScriptContainer scriptContainer, String s) {
return CoreUtilities.toLowerCase(s).startsWith("portal created");
}

@Override
public boolean matches(ScriptContainer scriptContainer, String s) {
String lower = CoreUtilities.toLowerCase(s);
String wCheck = CoreUtilities.getXthArg(3,lower);
if (wCheck.length() > 0 && !wCheck.equals("world") && !wCheck.equals(CoreUtilities.toLowerCase(world.getName()))) {
return false;
}
String rCheck = CoreUtilities.getXthArg(2,lower).equals("because") ? CoreUtilities.getXthArg(3,lower):CoreUtilities.getXthArg(5,lower);
if (rCheck.length() > 0 && !rCheck.equals(CoreUtilities.toLowerCase(reason.asString()))) {
return false;
}
return true;
}

@Override
public String getName() {
return "PortalCreate";
}

@Override
public void init() {
Bukkit.getServer().getPluginManager().registerEvents(this, DenizenAPI.getCurrentInstance());
}

@Override
public void destroy() {
PortalCreateEvent.getHandlerList().unregister(this);
}

@Override
public boolean applyDetermination(ScriptContainer container, String determination) {
return super.applyDetermination(container, determination);
}

@Override
public HashMap<String, dObject> getContext() {
HashMap<String, dObject> context = super.getContext();
context.put("world", world);
context.put("reason", reason);
context.put("list", list);
return context;
}

@EventHandler
public void onPortalCreate(PortalCreateEvent event) {
world = new dWorld(event.getWorld());
reason = new Element(event.getReason().toString());
list = new dList();
for (Block block : event.getBlocks()) {
list.add(new dLocation(block.getLocation()).identify());
}
this.event = event;
cancelled = event.isCancelled();
fire();
event.setCancelled(cancelled);
}
}
Expand Up @@ -2088,47 +2088,6 @@ public void weatherChange(WeatherChangeEvent event) {
// WORLD EVENTS
/////////////////

// <--[event]
// @Events
// portal created (in <world>) (because <reason>)
//
// @Triggers when a portal is created in a world.
// @Context
// <context.world> returns the dWorld the portal was created in.
// <context.reason> returns an Element of the reason the portal was created. (FIRE or OBC_DESTINATION)
// <context.list> returns a dList of all the blocks that will become portal blocks.
//
// @Determine
// "CANCELLED" to stop the portal from being created.
//
// -->
@EventHandler
public void portalCreate(PortalCreateEvent event) {

Map<String, dObject> context = new HashMap<String, dObject>();
dWorld world = new dWorld(event.getWorld());
String reason = event.getReason().name();

context.put("world", world);
context.put("reason", new Element(reason));

dList list = new dList();
for (Block block : event.getBlocks()) {
list.add(new dLocation(block.getLocation()).identify());
}
context.put("blocks", list);

String determination = doEvents(Arrays.asList
("portal created",
"portal created because " + reason,
"portal created in " + world.identifySimple(),
"portal created in " + world.identifySimple() + " because " + reason),
null, null, context, true);

if (determination.toUpperCase().startsWith("CANCELLED"))
event.setCancelled(true);
}

// <--[event]
// @Events
// structure grows (naturally/from bonemeal) (in <world>)
Expand Down

0 comments on commit 4e2ee18

Please sign in to comment.