Skip to content

Commit

Permalink
Implements new GameModeAddon API.
Browse files Browse the repository at this point in the history
  • Loading branch information
tastybento committed Dec 25, 2018
1 parent 1cc0552 commit 2a6ba24
Show file tree
Hide file tree
Showing 9 changed files with 60 additions and 125 deletions.
2 changes: 1 addition & 1 deletion pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -91,7 +91,7 @@
<dependency>
<groupId>world.bentobox</groupId>
<artifactId>bentobox</artifactId>
<version>0.12.0-SNAPSHOT</version>
<version>1.0-SNAPSHOT</version>
<scope>provided</scope>
</dependency>
</dependencies>
Expand Down
72 changes: 51 additions & 21 deletions src/main/java/world/bentobox/acidisland/AcidIsland.java
Original file line number Diff line number Diff line change
@@ -1,37 +1,41 @@
package world.bentobox.acidisland;

import org.bukkit.World;
import org.bukkit.WorldCreator;
import org.bukkit.WorldType;
import org.bukkit.plugin.PluginManager;

import world.bentobox.acidisland.commands.AcidCommand;
import world.bentobox.acidisland.commands.AiCommand;
import world.bentobox.acidisland.listeners.AcidEffect;
import world.bentobox.acidisland.listeners.LavaCheck;
import world.bentobox.acidisland.world.AcidIslandWorld;
import world.bentobox.acidisland.world.AcidTask;
import world.bentobox.bentobox.api.addons.Addon;
import world.bentobox.acidisland.world.ChunkGeneratorWorld;
import world.bentobox.bentobox.api.addons.GameModeAddon;
import world.bentobox.bentobox.api.configuration.Config;
import world.bentobox.bentobox.api.configuration.WorldSettings;

/**
* Add-on to BentoBox that enables AcidIsland
* @author tastybento
*
*/
public class AcidIsland extends Addon {
public class AcidIsland extends GameModeAddon {

private static AcidIsland addon;
private AISettings settings;
private AcidIslandWorld aiw;
private AcidTask acidTask;

private static final String NETHER = "_nether";
private static final String THE_END = "_the_end";


@Override
public void onLoad() {
addon = this;
saveDefaultConfig();
// Load settings
settings = new Config<>(this, AISettings.class).loadConfigObject();
// Create worlds
aiw = new AcidIslandWorld(this);
}

@Override
Expand Down Expand Up @@ -61,21 +65,6 @@ public AISettings getSettings() {
return settings;
}

/**
* @return the aiw
*/
public AcidIslandWorld getAiw() {
return aiw;
}

/**
* Convenience method to obtain the AcidIsland overworld
* @return Island World
*/
public World getIslandWorld() {
return aiw.getOverWorld();
}

@Override
public void log(String string) {
getPlugin().log(string);
Expand All @@ -85,4 +74,45 @@ public static AcidIsland getInstance() {
return addon;
}

@Override
public void createWorlds() {
String worldName = settings.getWorldName();
if (getServer().getWorld(worldName) == null) {
getLogger().info("Creating AcidIsland...");
}
// Create the world if it does not exist
islandWorld = WorldCreator.name(worldName).type(WorldType.FLAT).environment(World.Environment.NORMAL).generator(new ChunkGeneratorWorld(addon))
.createWorld();

// Make the nether if it does not exist
if (settings.isNetherGenerate()) {
if (getServer().getWorld(worldName + NETHER) == null) {
log("Creating AcidIsland's Nether...");
}
if (!settings.isNetherIslands()) {
netherWorld = WorldCreator.name(worldName + NETHER).type(WorldType.NORMAL).environment(World.Environment.NETHER).createWorld();
} else {
netherWorld = WorldCreator.name(worldName + NETHER).type(WorldType.FLAT).generator(new ChunkGeneratorWorld(addon))
.environment(World.Environment.NETHER).createWorld();
}
}
// Make the end if it does not exist
if (settings.isEndGenerate()) {
if (getServer().getWorld(worldName + THE_END) == null) {
log("Creating AcidIsland's End World...");
}
if (!settings.isEndIslands()) {
endWorld = WorldCreator.name(worldName + THE_END).type(WorldType.NORMAL).environment(World.Environment.THE_END).createWorld();
} else {
endWorld = WorldCreator.name(worldName + THE_END).type(WorldType.FLAT).generator(new ChunkGeneratorWorld(addon))
.environment(World.Environment.THE_END).createWorld();
}
}
}

@Override
public WorldSettings getWorldSettings() {
return settings;
}

}
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@

import java.util.List;

import world.bentobox.acidisland.AcidIsland;
import world.bentobox.bentobox.api.addons.Addon;
import world.bentobox.bentobox.api.commands.CompositeCommand;
import world.bentobox.bentobox.api.commands.admin.AdminClearresetsCommand;
Expand Down Expand Up @@ -36,7 +35,6 @@ public void setup() {
setOnlyPlayer(false);
setParametersHelp("commands.admin.help.parameters");
setDescription("commands.admin.help.description");
setWorld(((AcidIsland)getAddon()).getIslandWorld());
new AdminVersionCommand(this);
new AdminTeleportCommand(this, "tp");
new AdminTeleportCommand(this, "tpnether");
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@
import java.util.ArrayList;
import java.util.List;

import world.bentobox.acidisland.AcidIsland;
import world.bentobox.bentobox.api.addons.Addon;
import world.bentobox.bentobox.api.commands.CompositeCommand;
import world.bentobox.bentobox.api.commands.island.IslandBanCommand;
Expand Down Expand Up @@ -39,8 +38,6 @@ public void setup() {
setOnlyPlayer(true);
// Permission
setPermission("island");
// Set up world
setWorld(((AcidIsland)getAddon()).getIslandWorld());
// Set up subcommands
new IslandAboutCommand(this);
new IslandCreateCommand(this);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -67,7 +67,7 @@ public void onPlayerDeath(PlayerDeathEvent e) {
public void onSeaBounce(PlayerMoveEvent e) {
Player player = e.getPlayer();
if (!player.getGameMode().equals(GameMode.CREATIVE) && !player.getGameMode().equals(GameMode.SPECTATOR)
&& player.getWorld().equals(addon.getIslandWorld()) && player.getLocation().getBlockY() < 1) {
&& player.getWorld().equals(addon.getOverWorld()) && player.getLocation().getBlockY() < 1) {
player.setVelocity(new Vector(player.getVelocity().getX(), 1D, player.getVelocity().getZ()));
}
}
Expand All @@ -81,7 +81,7 @@ public void onPlayerMove(PlayerMoveEvent e) {
|| player.getGameMode().equals(GameMode.CREATIVE)
|| player.getGameMode().equals(GameMode.SPECTATOR)
|| addon.getPlayers().isInTeleport(player.getUniqueId())
|| !Util.sameWorld(addon.getIslandWorld(), player.getWorld())
|| !Util.sameWorld(addon.getOverWorld(), player.getWorld())
|| (!player.isOp() && player.hasPermission("acidisland.mod.noburn"))
|| (!player.isOp() && player.hasPermission("admin.noburn"))
|| (player.isOp() && !addon.getSettings().isAcidDamageOp())) {
Expand Down Expand Up @@ -349,7 +349,7 @@ private static double getDamageReduced(Player player) {
*/
@EventHandler(priority = EventPriority.NORMAL)
public void onWeatherChange(final WeatherChangeEvent e) {
if (e.getWorld().equals(addon.getIslandWorld())) {
if (e.getWorld().equals(addon.getOverWorld())) {
this.isRaining = e.toWeatherState();
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ public LavaCheck(AcidIsland addon) {
@EventHandler(priority = EventPriority.LOWEST, ignoreCancelled = true)
public void onCleanstoneGen(BlockFromToEvent e) {
// Only do this in AcidIsland over world
if (!e.getBlock().getWorld().equals(addon.getIslandWorld()) || addon.getSettings().getAcidDamage() <= 0
if (!e.getBlock().getWorld().equals(addon.getOverWorld()) || addon.getSettings().getAcidDamage() <= 0
// TODO: backward compatibility hack
|| !(e.getToBlock().getType().name().equals("WATER"))) {
return;
Expand Down
90 changes: 0 additions & 90 deletions src/main/java/world/bentobox/acidisland/world/AcidIslandWorld.java

This file was deleted.

6 changes: 3 additions & 3 deletions src/main/java/world/bentobox/acidisland/world/AcidTask.java
Original file line number Diff line number Diff line change
Expand Up @@ -55,13 +55,13 @@ private void burnEntities() {
}

private Stream<Entity> getEntityStream() {
Stream<Entity> entityStream = addon.getIslandWorld().getEntities().stream();
Stream<Entity> entityStream = addon.getOverWorld().getEntities().stream();
// Nether and end
if (addon.getSettings().isNetherGenerate() && addon.getSettings().isNetherIslands()) {
entityStream = Stream.concat(entityStream, addon.getAiw().getNetherWorld().getEntities().stream());
entityStream = Stream.concat(entityStream, addon.getNetherWorld().getEntities().stream());
}
if (addon.getSettings().isEndGenerate() && addon.getSettings().isEndIslands()) {
entityStream = Stream.concat(entityStream, addon.getAiw().getEndWorld().getEntities().stream());
entityStream = Stream.concat(entityStream, addon.getEndWorld().getEntities().stream());
}
return entityStream;
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@
* @author tastybento
*
*/
class ChunkGeneratorWorld extends ChunkGenerator {
public class ChunkGeneratorWorld extends ChunkGenerator {

private final AcidIsland addon;
private final Random rand = new Random();
Expand Down

0 comments on commit 2a6ba24

Please sign in to comment.