Fixed issues with ropes
This commit is contained in:
parent
144f9cdaf1
commit
c712ad1775
5 changed files with 120 additions and 22 deletions
|
@ -3,12 +3,14 @@ package nl.SBDeveloper.V10Lift.API.Objects;
|
||||||
import lombok.Getter;
|
import lombok.Getter;
|
||||||
import lombok.Setter;
|
import lombok.Setter;
|
||||||
import org.bukkit.Material;
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.block.BlockFace;
|
||||||
|
|
||||||
import java.lang.reflect.Field;
|
import java.lang.reflect.Field;
|
||||||
|
|
||||||
@Getter @Setter
|
@Getter @Setter
|
||||||
public class LiftRope {
|
public class LiftRope {
|
||||||
private final Material type;
|
private final Material type;
|
||||||
|
private final BlockFace face;
|
||||||
private final String world;
|
private final String world;
|
||||||
private final int x;
|
private final int x;
|
||||||
private final int minY;
|
private final int minY;
|
||||||
|
@ -16,8 +18,9 @@ public class LiftRope {
|
||||||
private final int z;
|
private final int z;
|
||||||
private int currently;
|
private int currently;
|
||||||
|
|
||||||
public LiftRope(Material type, String world, int x, int minY, int maxY, int z) {
|
public LiftRope(Material type, BlockFace face, String world, int x, int minY, int maxY, int z) {
|
||||||
this.type = type;
|
this.type = type;
|
||||||
|
this.face = face;
|
||||||
this.world = world;
|
this.world = world;
|
||||||
this.x = x;
|
this.x = x;
|
||||||
this.minY = minY;
|
this.minY = minY;
|
||||||
|
|
|
@ -12,7 +12,6 @@ import org.bukkit.block.Block;
|
||||||
import org.bukkit.block.BlockState;
|
import org.bukkit.block.BlockState;
|
||||||
import org.bukkit.block.Chest;
|
import org.bukkit.block.Chest;
|
||||||
import org.bukkit.block.Sign;
|
import org.bukkit.block.Sign;
|
||||||
import org.bukkit.block.data.Directional;
|
|
||||||
import org.bukkit.entity.Entity;
|
import org.bukkit.entity.Entity;
|
||||||
import org.bukkit.inventory.Inventory;
|
import org.bukkit.inventory.Inventory;
|
||||||
import org.bukkit.inventory.ItemStack;
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
@ -72,6 +71,7 @@ public class MoveLift implements Runnable {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (lift.getQueue().isEmpty() || lift.isOffline()) {
|
if (lift.getQueue().isEmpty() || lift.isOffline()) {
|
||||||
|
lift.setQueue(null);
|
||||||
stopMe();
|
stopMe();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -96,6 +96,19 @@ public class MoveLift implements Runnable {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
lb = lift.getBlocks().last();
|
||||||
|
world = Bukkit.getWorld(lb.getWorld());
|
||||||
|
if (world == null) {
|
||||||
|
lift.setCounter(ft);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
loc = new Location(world, lb.getX(), lb.getY(), lb.getZ());
|
||||||
|
if (!loc.getChunk().isLoaded()) {
|
||||||
|
lift.setCounter(ft);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
double changeOfDefect = V10LiftPlugin.getSConfig().getFile().getDouble("DefectRate");
|
double changeOfDefect = V10LiftPlugin.getSConfig().getFile().getDouble("DefectRate");
|
||||||
if (changeOfDefect > 0.0D) {
|
if (changeOfDefect > 0.0D) {
|
||||||
y = new Random().nextInt(100);
|
y = new Random().nextInt(100);
|
||||||
|
@ -114,8 +127,8 @@ public class MoveLift implements Runnable {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Iterator < Map.Entry < String, Floor >> quiter = lift.getQueue().entrySet().iterator();
|
Iterator<Map.Entry<String, Floor>> quiter = lift.getQueue().entrySet().iterator();
|
||||||
Map.Entry < String, Floor > floor = quiter.next();
|
Map.Entry<String, Floor> floor = quiter.next();
|
||||||
Floor to = floor.getValue();
|
Floor to = floor.getValue();
|
||||||
String fl = floor.getKey();
|
String fl = floor.getKey();
|
||||||
boolean up = false;
|
boolean up = false;
|
||||||
|
@ -132,7 +145,7 @@ public class MoveLift implements Runnable {
|
||||||
//MOVE ROPES
|
//MOVE ROPES
|
||||||
for (LiftRope rope : lift.getRopes()) {
|
for (LiftRope rope : lift.getRopes()) {
|
||||||
if (rope.getCurrently() > rope.getMaxY()) {
|
if (rope.getCurrently() > rope.getMaxY()) {
|
||||||
Bukkit.getLogger().info("[V10Lift] Lift " + liftName + " reaches the upper rope end but won't stop!!");
|
Bukkit.getLogger().info("[V10Lift] Lift " + liftName + " reaches the upper rope end but won't stop!! 1");
|
||||||
V10LiftPlugin.getAPI().setDefective(liftName, true);
|
V10LiftPlugin.getAPI().setDefective(liftName, true);
|
||||||
lift.getToMove().clear();
|
lift.getToMove().clear();
|
||||||
quiter.remove();
|
quiter.remove();
|
||||||
|
@ -387,20 +400,41 @@ public class MoveLift implements Runnable {
|
||||||
|
|
||||||
//MOVE ROPES
|
//MOVE ROPES
|
||||||
for (LiftRope rope : lift.getRopes()) {
|
for (LiftRope rope : lift.getRopes()) {
|
||||||
|
|
||||||
if (rope.getCurrently() < rope.getMinY()) {
|
if (rope.getCurrently() < rope.getMinY()) {
|
||||||
Bukkit.getLogger().info("[V10Lift] Lift " + liftName + " reaches the upper rope end but won't stop!!");
|
Bukkit.getLogger().info("[V10Lift] Lift " + liftName + " reaches the upper rope end but won't stop!! 2");
|
||||||
V10LiftPlugin.getAPI().setDefective(liftName, true);
|
V10LiftPlugin.getAPI().setDefective(liftName, true);
|
||||||
lift.getToMove().clear();
|
lift.getToMove().clear();
|
||||||
quiter.remove();
|
quiter.remove();
|
||||||
rope.setCurrently(rope.getCurrently() - 1);
|
rope.setCurrently(rope.getCurrently() - 1);
|
||||||
block = world.getBlockAt(rope.getX(), rope.getCurrently(), rope.getZ());
|
block = world.getBlockAt(rope.getX(), rope.getCurrently(), rope.getZ());
|
||||||
block.setType(rope.getType());
|
block.setType(rope.getType());
|
||||||
|
if (XMaterial.isNewVersion()) {
|
||||||
|
org.bukkit.block.data.type.Ladder ladder = (org.bukkit.block.data.type.Ladder) block.getBlockData();
|
||||||
|
ladder.setFacing(rope.getFace());
|
||||||
|
} else {
|
||||||
|
BlockState state = block.getState();
|
||||||
|
org.bukkit.material.Ladder ladder = new org.bukkit.material.Ladder(rope.getType());
|
||||||
|
ladder.setFacingDirection(rope.getFace());
|
||||||
|
state.setData(ladder);
|
||||||
|
state.update(true);
|
||||||
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
world = Objects.requireNonNull(Bukkit.getWorld(rope.getWorld()), "World is null at MoveLift");
|
world = Objects.requireNonNull(Bukkit.getWorld(rope.getWorld()), "World is null at MoveLift");
|
||||||
rope.setCurrently(rope.getCurrently() - 1);
|
rope.setCurrently(rope.getCurrently() - 1);
|
||||||
block = world.getBlockAt(rope.getX(), rope.getCurrently(), rope.getZ());
|
block = world.getBlockAt(rope.getX(), rope.getCurrently(), rope.getZ());
|
||||||
block.setType(rope.getType());
|
block.setType(rope.getType());
|
||||||
|
if (XMaterial.isNewVersion()) {
|
||||||
|
org.bukkit.block.data.type.Ladder ladder = (org.bukkit.block.data.type.Ladder) block.getBlockData();
|
||||||
|
ladder.setFacing(rope.getFace());
|
||||||
|
} else {
|
||||||
|
BlockState state = block.getState();
|
||||||
|
org.bukkit.material.Ladder ladder = new org.bukkit.material.Ladder(rope.getType());
|
||||||
|
ladder.setFacingDirection(rope.getFace());
|
||||||
|
state.setData(ladder);
|
||||||
|
state.update(true);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
lift.getToMove().clear();
|
lift.getToMove().clear();
|
||||||
|
|
|
@ -13,6 +13,7 @@ import nl.SBDeveloper.V10Lift.Utils.XMaterial;
|
||||||
import nl.SBDeveloper.V10Lift.V10LiftPlugin;
|
import nl.SBDeveloper.V10Lift.V10LiftPlugin;
|
||||||
import org.bukkit.*;
|
import org.bukkit.*;
|
||||||
import org.bukkit.block.Block;
|
import org.bukkit.block.Block;
|
||||||
|
import org.bukkit.block.BlockFace;
|
||||||
import org.bukkit.block.BlockState;
|
import org.bukkit.block.BlockState;
|
||||||
import org.bukkit.block.Sign;
|
import org.bukkit.block.Sign;
|
||||||
import org.bukkit.entity.Entity;
|
import org.bukkit.entity.Entity;
|
||||||
|
@ -121,6 +122,7 @@ public class V10LiftAPI {
|
||||||
}
|
}
|
||||||
|
|
||||||
DataManager.removeLift(liftName);
|
DataManager.removeLift(liftName);
|
||||||
|
V10LiftPlugin.getDBManager().removeFromData(liftName);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -808,7 +810,13 @@ public class V10LiftAPI {
|
||||||
public int addRope(String lift, World world, int x, int minY, int maxY, int z) {
|
public int addRope(String lift, World world, int x, int minY, int maxY, int z) {
|
||||||
if (lift == null || !DataManager.containsLift(lift) || world == null) return -1;
|
if (lift == null || !DataManager.containsLift(lift) || world == null) return -1;
|
||||||
|
|
||||||
boolean change = minY > maxY;
|
//minY = maxY, so reverse
|
||||||
|
if (minY > maxY) {
|
||||||
|
int tempY = minY;
|
||||||
|
minY = maxY;
|
||||||
|
maxY = tempY;
|
||||||
|
}
|
||||||
|
|
||||||
Block block = world.getBlockAt(x, minY, z);
|
Block block = world.getBlockAt(x, minY, z);
|
||||||
if (isRope(block)) return -3;
|
if (isRope(block)) return -3;
|
||||||
Material mat = block.getType();
|
Material mat = block.getType();
|
||||||
|
@ -819,7 +827,21 @@ public class V10LiftAPI {
|
||||||
if (isRope(block)) return -3;
|
if (isRope(block)) return -3;
|
||||||
if (block.getType() != mat) return -2;
|
if (block.getType() != mat) return -2;
|
||||||
}
|
}
|
||||||
DataManager.getLift(lift).getRopes().add(new LiftRope(mat, world.getName(), x, minY, maxY, z));
|
|
||||||
|
BlockFace face;
|
||||||
|
if (XMaterial.isNewVersion()) {
|
||||||
|
org.bukkit.block.data.type.Ladder ladder = (org.bukkit.block.data.type.Ladder) block.getBlockData();
|
||||||
|
Bukkit.getLogger().info(ladder.getFacing().toString());
|
||||||
|
face = ladder.getFacing();
|
||||||
|
} else {
|
||||||
|
BlockState state = block.getState();
|
||||||
|
org.bukkit.material.Ladder ladder = (org.bukkit.material.Ladder) state.getData();
|
||||||
|
face = ladder.getAttachedFace();
|
||||||
|
}
|
||||||
|
|
||||||
|
LiftRope rope = new LiftRope(mat, face, world.getName(), x, minY, maxY, z);
|
||||||
|
DataManager.getLift(lift).getRopes().add(rope);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -7,6 +7,7 @@ import nl.SBDeveloper.V10Lift.Utils.SBSQLiteDB;
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.plugin.java.JavaPlugin;
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
|
||||||
|
import java.sql.Connection;
|
||||||
import java.sql.PreparedStatement;
|
import java.sql.PreparedStatement;
|
||||||
import java.sql.ResultSet;
|
import java.sql.ResultSet;
|
||||||
import java.sql.SQLException;
|
import java.sql.SQLException;
|
||||||
|
@ -15,13 +16,16 @@ import java.util.*;
|
||||||
public class DBManager {
|
public class DBManager {
|
||||||
|
|
||||||
private static SBSQLiteDB data;
|
private static SBSQLiteDB data;
|
||||||
|
private static Connection con;
|
||||||
|
|
||||||
public DBManager(JavaPlugin plugin, String name) {
|
public DBManager(JavaPlugin plugin, String name) {
|
||||||
data = new SBSQLiteDB(plugin, name);
|
data = new SBSQLiteDB(plugin, name);
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
con = data.getConnection();
|
||||||
|
|
||||||
String query = "CREATE TABLE IF NOT EXISTS lifts (liftName varchar(255) NOT NULL, liftData blob NOT NULL, UNIQUE (liftName))";
|
String query = "CREATE TABLE IF NOT EXISTS lifts (liftName varchar(255) NOT NULL, liftData blob NOT NULL, UNIQUE (liftName))";
|
||||||
PreparedStatement statement = data.getConnection().prepareStatement(query);
|
PreparedStatement statement = con.prepareStatement(query);
|
||||||
statement.execute();
|
statement.execute();
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
|
@ -30,10 +34,18 @@ public class DBManager {
|
||||||
|
|
||||||
public void load() throws SQLException {
|
public void load() throws SQLException {
|
||||||
String query = "SELECT * FROM lifts";
|
String query = "SELECT * FROM lifts";
|
||||||
PreparedStatement statement = data.getConnection().prepareStatement(query);
|
PreparedStatement statement = con.prepareStatement(query);
|
||||||
ResultSet liftSet = statement.executeQuery();
|
ResultSet liftSet = statement.executeQuery();
|
||||||
while (liftSet.next()) {
|
while (liftSet.next()) {
|
||||||
//Loading a lift...
|
//Loading a lift...
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @todo Fix migrating from 1.12.2- to 1.13+
|
||||||
|
* - byte to Facing for signs
|
||||||
|
* - Facing opposite for ropes
|
||||||
|
* - New materials
|
||||||
|
*/
|
||||||
|
|
||||||
byte[] blob = liftSet.getBytes("liftData");
|
byte[] blob = liftSet.getBytes("liftData");
|
||||||
String json = new String(blob);
|
String json = new String(blob);
|
||||||
Gson gson = new Gson();
|
Gson gson = new Gson();
|
||||||
|
@ -44,42 +56,67 @@ public class DBManager {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void save() {
|
public void removeFromData() {
|
||||||
try {
|
try {
|
||||||
Gson gson = new Gson();
|
|
||||||
|
|
||||||
String query0 = "SELECT * FROM lifts";
|
String query0 = "SELECT * FROM lifts";
|
||||||
PreparedStatement statement0 = data.getConnection().prepareStatement(query0);
|
PreparedStatement statement0 = con.prepareStatement(query0);
|
||||||
ResultSet liftSet = statement0.executeQuery();
|
ResultSet liftSet = statement0.executeQuery();
|
||||||
while (liftSet.next()) {
|
while (liftSet.next()) {
|
||||||
if (!DataManager.containsLift(liftSet.getString("liftName"))) {
|
if (!DataManager.containsLift(liftSet.getString("liftName"))) {
|
||||||
Bukkit.getLogger().info("[V10Lift] Removing lift " + liftSet.getString("liftName") + " to data...");
|
Bukkit.getLogger().info("[V10Lift] Removing lift " + liftSet.getString("liftName") + " to data...");
|
||||||
|
|
||||||
String query = "DELETE FROM lifts WHERE liftName = ?";
|
String query = "DELETE FROM lifts WHERE liftName = ?";
|
||||||
PreparedStatement statement = data.getConnection().prepareStatement(query);
|
PreparedStatement statement = con.prepareStatement(query);
|
||||||
statement.setString(1, liftSet.getString("liftName"));
|
statement.setString(1, liftSet.getString("liftName"));
|
||||||
statement.executeUpdate();
|
statement.executeUpdate();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} catch(SQLException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void removeFromData(String name) {
|
||||||
|
try {
|
||||||
|
if (!DataManager.containsLift(name)) {
|
||||||
|
Bukkit.getLogger().info("[V10Lift] Removing lift " + name + " to data...");
|
||||||
|
|
||||||
|
String query = "DELETE FROM lifts WHERE liftName = ?";
|
||||||
|
PreparedStatement statement = con.prepareStatement(query);
|
||||||
|
statement.setString(1, name);
|
||||||
|
statement.executeUpdate();
|
||||||
|
}
|
||||||
|
} catch(SQLException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void save() {
|
||||||
|
Gson gson = new Gson();
|
||||||
|
|
||||||
for (Map.Entry<String, Lift> entry : DataManager.getLifts().entrySet()) {
|
for (Map.Entry<String, Lift> entry : DataManager.getLifts().entrySet()) {
|
||||||
byte[] blob = gson.toJson(entry.getValue()).getBytes();
|
byte[] blob = gson.toJson(entry.getValue()).getBytes();
|
||||||
|
|
||||||
Bukkit.getLogger().info("[V10Lift] Saving lift " + entry.getKey() + " to data...");
|
Bukkit.getLogger().info("[V10Lift] Saving lift " + entry.getKey() + " to data...");
|
||||||
|
|
||||||
|
try {
|
||||||
String query = "INSERT INTO lifts (liftName, liftData) VALUES (?, ?)";
|
String query = "INSERT INTO lifts (liftName, liftData) VALUES (?, ?)";
|
||||||
PreparedStatement statement = data.getConnection().prepareStatement(query);
|
PreparedStatement statement = con.prepareStatement(query);
|
||||||
statement.setString(1, entry.getKey());
|
statement.setString(1, entry.getKey());
|
||||||
statement.setBytes(2, blob);
|
statement.setBytes(2, blob);
|
||||||
statement.executeUpdate();
|
statement.executeUpdate();
|
||||||
|
} catch (SQLException ignored) {}
|
||||||
|
|
||||||
|
try {
|
||||||
String query2 = "UPDATE lifts SET liftData = ? WHERE liftName = ?";
|
String query2 = "UPDATE lifts SET liftData = ? WHERE liftName = ?";
|
||||||
PreparedStatement statement2 = data.getConnection().prepareStatement(query2);
|
PreparedStatement statement2 = con.prepareStatement(query2);
|
||||||
statement2.setBytes(1, blob);
|
statement2.setBytes(1, blob);
|
||||||
statement2.setString(2, entry.getKey());
|
statement2.setString(2, entry.getKey());
|
||||||
statement2.executeUpdate();
|
statement2.executeUpdate();
|
||||||
|
} catch (SQLException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} catch(SQLException ignored) {}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void closeConnection() {
|
public void closeConnection() {
|
||||||
|
|
|
@ -61,9 +61,11 @@ public class V10LiftPlugin extends JavaPlugin {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onDisable() {
|
public void onDisable() {
|
||||||
instance = null;
|
V10LiftPlugin.getDBManager().removeFromData();
|
||||||
dbManager.save();
|
dbManager.save();
|
||||||
dbManager.closeConnection();
|
dbManager.closeConnection();
|
||||||
|
|
||||||
|
instance = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static V10LiftPlugin getInstance() {
|
public static V10LiftPlugin getInstance() {
|
||||||
|
|
Loading…
Reference in a new issue