commit 3a582245998c624fecb218573d4ccf0ad834a53a Author: Simon Hardt Date: Sun Mar 20 23:46:03 2022 +0100 init diff --git a/minecart/pom.xml b/minecart/pom.xml new file mode 100644 index 0000000..a5eefc4 --- /dev/null +++ b/minecart/pom.xml @@ -0,0 +1,136 @@ + + + + 4.0.0 + + plugin.minecraft + minecart + 1.0-SNAPSHOT + + minecart + + http://www.example.com + + + UTF-8 + 1.8 + 1.8 + + + + + + + papermc + https://papermc.io/repo/repository/maven-public/ + + + + + + + + + + junit + junit + 4.11 + test + + + + + + + io.papermc.paper + paper-api + 1.18.2-R0.1-SNAPSHOT + provided + + + + + + org.bukkit + bukkit + 1.15.2-R0.1-SNAPSHOT + provided + + + + + + + + ${project.basedir}/src/main/java/plugin/minecraft + + + ${project.basedir}/src/main/resources + + plugin.yml + + + + + + + + + + maven-clean-plugin + 3.1.0 + + + + maven-resources-plugin + 3.0.2 + + + maven-compiler-plugin + 3.8.0 + + 17 + + + + maven-surefire-plugin + 2.22.1 + + + maven-jar-plugin + 3.0.2 + + + maven-install-plugin + 2.5.2 + + + maven-deploy-plugin + 2.8.2 + + + + maven-site-plugin + 3.7.1 + + + maven-project-info-reports-plugin + 3.0.0 + + + + + diff --git a/minecart/src/main/java/plugin/minecraft/Main.java b/minecart/src/main/java/plugin/minecraft/Main.java new file mode 100644 index 0000000..475dc86 --- /dev/null +++ b/minecart/src/main/java/plugin/minecraft/Main.java @@ -0,0 +1,25 @@ +package plugin.minecraft; + +import org.bukkit.plugin.java.JavaPlugin; + +/** + * Hello world! + * + */ +public class Main extends JavaPlugin { + @Override + public void onEnable() { + getLogger().info("Hello, SpigotMC! sadae"); + + getServer().getPluginManager().registerEvents(new MinecartMove(this), this); + + } + + public void test() { + } + + @Override + public void onDisable() { + getLogger().info("See you again, SpigotMC!"); + } +} diff --git a/minecart/src/main/java/plugin/minecraft/MinecartMove.java b/minecart/src/main/java/plugin/minecraft/MinecartMove.java new file mode 100644 index 0000000..18a3e86 --- /dev/null +++ b/minecart/src/main/java/plugin/minecraft/MinecartMove.java @@ -0,0 +1,92 @@ +package plugin.minecraft; + +import org.bukkit.Bukkit; +import org.bukkit.entity.EntityType; +import org.bukkit.event.EventHandler; +import org.bukkit.event.Listener; +import org.bukkit.event.vehicle.VehicleCreateEvent; +import org.bukkit.event.vehicle.VehicleMoveEvent; +import org.bukkit.event.world.ChunkLoadEvent; +import org.bukkit.plugin.Plugin; +import org.bukkit.util.Vector; + +public class MinecartMove implements Listener { + + private Plugin plugin; + + MinecartMove(Plugin p) { + plugin = p; + } + + @EventHandler + public void onVehicleCreate(VehicleCreateEvent ev) { + ev.getVehicle().setVelocity(new Vector(1.0, 0.0, 0.0)); + + if (ev.getVehicle().getType() == EntityType.MINECART_CHEST) { + Bukkit.getLogger().info(String.format("Minecart %d %s", ev.getVehicle().getChunk().getX(), + ev.getVehicle().getChunk().getX())); + } + } + + @EventHandler + void onVehicleMove(VehicleMoveEvent ev) { + var vehicle = ev.getVehicle(); + if (vehicle.getType() == EntityType.MINECART_CHEST) { + var x = vehicle.getChunk().getX(); + var z = vehicle.getChunk().getZ(); + + var world = vehicle.getWorld(); + + var vel = vehicle.getVelocity(); + + // plugin.getLogger().info(String.format("Current %d %d", x, z)); + + var chunk = vehicle.getChunk(); + if (!chunk.getPluginChunkTickets().contains(plugin)) { + plugin.getLogger().info(String.format("Loading %d %d", x, z)); + chunk.addPluginChunkTicket(plugin); + } + + var last_x = x; + var last_z = z; + var next_x = x; + var next_z = z; + + if (vel.getX() > 0) { + last_x -= 2; + next_x += 1; + } else if (vel.getX() < 0) { + last_x += 2; + next_x -= 1; + } + + if (vel.getZ() > 0) { + last_z -= 2; + next_z += 1; + } else if (vel.getZ() < 0) { + last_z += 2; + next_z -= 1; + } + + if (world.getPluginChunkTickets(next_x, next_z).contains(plugin)) { + plugin.getLogger().info(String.format("Loading %d %d", next_x, next_z)); + world.addPluginChunkTicket(next_x, next_z, plugin); + } + + if (last_x != x || last_z != z) { + if (world.getPluginChunkTickets(last_x, last_z).contains(plugin)) { + plugin.getLogger().info(String.format("Removing Ticket %d %d", last_x, last_z)); + world.removePluginChunkTicket(last_x, last_z, plugin); + + } + } + + } + } + + @EventHandler + public void onChunkLoad(ChunkLoadEvent ev) { + plugin.getLogger().info(String.format("Chunk Loaded %d %d Chunk Count: %d", ev.getChunk().getX(), + ev.getChunk().getZ(), ev.getWorld().getChunkCount())); + } +} diff --git a/minecart/src/main/resources/plugin.yml b/minecart/src/main/resources/plugin.yml new file mode 100644 index 0000000..3ae67cf --- /dev/null +++ b/minecart/src/main/resources/plugin.yml @@ -0,0 +1,4 @@ +main: plugin.minecraft.Main +name: minecart +version: "0.1" +api-version: "1.18" diff --git a/minecart/src/test/java/plugin/minecraft/AppTest.java b/minecart/src/test/java/plugin/minecraft/AppTest.java new file mode 100644 index 0000000..1051532 --- /dev/null +++ b/minecart/src/test/java/plugin/minecraft/AppTest.java @@ -0,0 +1,20 @@ +package plugin.minecraft; + +import static org.junit.Assert.assertTrue; + +import org.junit.Test; + +/** + * Unit test for simple App. + */ +public class AppTest +{ + /** + * Rigorous Test :-) + */ + @Test + public void shouldAnswerWithTrue() + { + assertTrue( true ); + } +}