Added docs to the V10LiftAPI class

This commit is contained in:
stijnb1234 2020-02-02 11:33:07 +01:00
parent f619080a2d
commit 1bb722d639

View file

@ -16,7 +16,6 @@ import org.bukkit.entity.Entity;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
import javax.annotation.Nonnull; import javax.annotation.Nonnull;
import javax.xml.crypto.Data;
import java.util.*; import java.util.*;
public class V10LiftAPI { public class V10LiftAPI {
@ -29,10 +28,20 @@ public class V10LiftAPI {
acbm = new AntiCopyBlockManager(); acbm = new AntiCopyBlockManager();
} }
/**
* Get the ForbiddenBlockManager, to check if a material is forbidden
*
* @return {@link ForbiddenBlockManager}
*/
public ForbiddenBlockManager getFBM() { public ForbiddenBlockManager getFBM() {
return fbm; return fbm;
} }
/**
* Get the AntiCopyBlockManager, to check if we can copy a material
*
* @return {@link AntiCopyBlockManager}
*/
public AntiCopyBlockManager getACBM() { public AntiCopyBlockManager getACBM() {
return acbm; return acbm;
} }
@ -50,6 +59,13 @@ public class V10LiftAPI {
} }
} }
private void startLift(String liftName) {
if (!DataManager.containsMovingTask(liftName)) {
Lift lift = DataManager.getLift(liftName);
DataManager.addMovingTask(liftName, Bukkit.getScheduler().scheduleSyncRepeatingTask(V10LiftPlugin.getInstance(), new MoveLift(liftName, lift.getSpeed()), lift.getSpeed(), lift.getSpeed()));
}
}
/* API methods */ /* API methods */
/** /**
@ -84,6 +100,12 @@ public class V10LiftAPI {
return true; return true;
} }
/**
* Rename a lift
*
* @param liftName The name of the lift
* @param newName The new name of the lift
*/
public void renameLift(String liftName, String newName) { public void renameLift(String liftName, String newName) {
if (liftName == null || newName == null || !DataManager.containsLift(liftName)) return; if (liftName == null || newName == null || !DataManager.containsLift(liftName)) return;
@ -114,6 +136,14 @@ public class V10LiftAPI {
return addBlockToLift(lift.getBlocks(), block); return addBlockToLift(lift.getBlocks(), block);
} }
/**
* Add a block to a lift
* Use {@link nl.SBDeveloper.V10Lift.API.V10LiftAPI#sortLiftBlocks(String liftName)} after!
*
* @param blocks The blockset
* @param block The block
* @return 0 if added, -1 if null or doesn't exists, -2 if forbidden, -3 if already added
*/
public int addBlockToLift(Set<LiftBlock> blocks, @Nonnull Block block) { public int addBlockToLift(Set<LiftBlock> blocks, @Nonnull Block block) {
Material type = block.getType(); Material type = block.getType();
LiftBlock lb; LiftBlock lb;
@ -126,6 +156,14 @@ public class V10LiftAPI {
return addBlockToLift(blocks, lb); return addBlockToLift(blocks, lb);
} }
/**
* Add a block to a lift
* Use {@link nl.SBDeveloper.V10Lift.API.V10LiftAPI#sortLiftBlocks(String liftName)} after!
*
* @param blocks The blockset
* @param block The LiftBlock
* @return 0 if added, -1 if null or doesn't exists, -2 if forbidden, -3 if already added
*/
public int addBlockToLift(Set<LiftBlock> blocks, @Nonnull LiftBlock block) { public int addBlockToLift(Set<LiftBlock> blocks, @Nonnull LiftBlock block) {
if (getFBM().isForbidden(block.getMat())) return -2; if (getFBM().isForbidden(block.getMat())) return -2;
if (blocks.contains(block)) return -3; if (blocks.contains(block)) return -3;
@ -157,11 +195,27 @@ public class V10LiftAPI {
return 0; return 0;
} }
/**
* Switch a block at a lift
* Use {@link nl.SBDeveloper.V10Lift.API.V10LiftAPI#sortLiftBlocks(String liftName)} after!
*
* @param liftName The name of the lift
* @param block The block
* @return 0 if added, 1 if removed, -1 if null or doesn't exists, -2 if not added
*/
public int switchBlockAtLift(String liftName, Block block) { public int switchBlockAtLift(String liftName, Block block) {
if (liftName == null || block == null || !DataManager.containsLift(liftName)) return -1; if (liftName == null || block == null || !DataManager.containsLift(liftName)) return -1;
return switchBlockAtLift(DataManager.getLift(liftName).getBlocks(), block); return switchBlockAtLift(DataManager.getLift(liftName).getBlocks(), block);
} }
/**
* Switch a block at a lift
* Use {@link nl.SBDeveloper.V10Lift.API.V10LiftAPI#sortLiftBlocks(String liftName)} after!
*
* @param blocks The blockset
* @param block The block
* @return 0 if added, 1 if removed, -1 if null or doesn't exists, -2 if not added
*/
public int switchBlockAtLift(TreeSet<LiftBlock> blocks, Block block) { public int switchBlockAtLift(TreeSet<LiftBlock> blocks, Block block) {
if (blocks == null || block == null) return -1; if (blocks == null || block == null) return -1;
Material type = block.getType(); Material type = block.getType();
@ -203,6 +257,12 @@ public class V10LiftAPI {
} }
} }
/**
* Open the door
*
* @param liftName The name of the lift
* @return true/false
*/
public boolean openDoor(String liftName) { public boolean openDoor(String liftName) {
if (liftName == null || !DataManager.containsLift(liftName)) return false; if (liftName == null || !DataManager.containsLift(liftName)) return false;
@ -239,6 +299,14 @@ public class V10LiftAPI {
return true; return true;
} }
/**
* Open the door
*
* @param lift The lift
* @param liftName The name of the lift
* @param f The floor
* @return true/false
*/
public boolean openDoor(Lift lift, String liftName, Floor f) { public boolean openDoor(Lift lift, String liftName, Floor f) {
if (lift == null || liftName == null || f == null) return false; if (lift == null || liftName == null || f == null) return false;
if (lift.getDoorOpen() != null && !closeDoor(liftName)) return false; if (lift.getDoorOpen() != null && !closeDoor(liftName)) return false;
@ -579,6 +647,14 @@ public class V10LiftAPI {
return 0; return 0;
} }
/**
* Check if a lift contains the block as rope
*
* @param liftName The name of the lift
* @param block The block
*
* @return true/false
*/
public boolean containsRope(String liftName, Block block) { public boolean containsRope(String liftName, Block block) {
if (liftName == null || block == null || !DataManager.containsLift(liftName)) return false; if (liftName == null || block == null || !DataManager.containsLift(liftName)) return false;
@ -599,6 +675,13 @@ public class V10LiftAPI {
return false; return false;
} }
/**
* Check if a block is a rope
*
* @param b The block
*
* @return true/false
*/
public boolean isRope(Block b) { public boolean isRope(Block b) {
for (String lift : DataManager.getLifts().keySet()) { for (String lift : DataManager.getLifts().keySet()) {
if (containsRope(lift, b)) return true; if (containsRope(lift, b)) return true;
@ -606,10 +689,21 @@ public class V10LiftAPI {
return false; return false;
} }
/**
* Send info about a lift to a player
* @param p The player
* @param liftName The name of the lift
*/
public void sendLiftInfo(Player p, String liftName) { public void sendLiftInfo(Player p, String liftName) {
sendLiftInfo(p, liftName, DataManager.getLift(liftName)); sendLiftInfo(p, liftName, DataManager.getLift(liftName));
} }
/**
* Send info about a lift to a player
* @param p The player
* @param liftName The name of the lift
* @param lift The lift
*/
public void sendLiftInfo(@Nonnull Player p, String liftName, @Nonnull Lift lift) { public void sendLiftInfo(@Nonnull Player p, String liftName, @Nonnull Lift lift) {
if (!lift.getOwners().contains(p.getUniqueId()) && !p.hasPermission("v10lift.admin")) { if (!lift.getOwners().contains(p.getUniqueId()) && !p.hasPermission("v10lift.admin")) {
p.sendMessage(ChatColor.RED + "You don't have the permission to check this lift!"); p.sendMessage(ChatColor.RED + "You don't have the permission to check this lift!");
@ -651,6 +745,17 @@ public class V10LiftAPI {
} }
} }
/**
* Add a rope to a lift
*
* @param lift The name of the lift
* @param world The world
* @param x The x-pos
* @param minY The min y-pos
* @param maxY The max y-pos
* @param z The z-pos
* @return 0 if added, -1 if null or doesn't exists, -2 if not same mat, -3 if already a rope, -4 if forbidden material
*/
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;
@ -669,6 +774,14 @@ public class V10LiftAPI {
return 0; return 0;
} }
/**
* Remove a rope from a lift
*
* @param lift The name of the lift
* @param block The block
*
* @return true/false
*/
public boolean removeRope(String lift, Block block) { public boolean removeRope(String lift, Block block) {
if (lift == null || block == null || !DataManager.containsLift(lift) || !containsRope(lift, block)) return false; if (lift == null || block == null || !DataManager.containsLift(lift) || !containsRope(lift, block)) return false;
@ -690,6 +803,13 @@ public class V10LiftAPI {
return false; return false;
} }
/**
* Set the queue of a lift
*
* @param liftName The name of the lift
* @param queue The queue
* @return true/false
*/
public boolean setQueue(String liftName, LinkedHashMap<String, Floor> queue) { public boolean setQueue(String liftName, LinkedHashMap<String, Floor> queue) {
if (liftName == null || queue == null || !DataManager.containsLift(liftName)) return false; if (liftName == null || queue == null || !DataManager.containsLift(liftName)) return false;
@ -701,14 +821,42 @@ public class V10LiftAPI {
return true; return true;
} }
/**
* Add a location to the queue
*
* @param lift The name of the lift
* @param y The y-pos
* @param world The world
*
* @return true/false
*/
public boolean addToQueue(String lift, int y, World world) { public boolean addToQueue(String lift, int y, World world) {
return addToQueue(lift, y, world, null); return addToQueue(lift, y, world, null);
} }
/**
* Add a location to the queue
*
* @param lift The name of the lift
* @param y The y-pos
* @param world The world
* @param floorName The name of the flor
*
* @return true/false
*/
public boolean addToQueue(String lift, int y, @Nonnull World world, String floorName) { public boolean addToQueue(String lift, int y, @Nonnull World world, String floorName) {
return addToQueue(lift, new Floor(y, world.getName()), floorName); return addToQueue(lift, new Floor(y, world.getName()), floorName);
} }
/**
* Add a location to the queue
*
* @param lift The name of the lift
* @param floor The {@link Floor}
* @param floorName The name of the flor
*
* @return true/false
*/
public boolean addToQueue(String lift, Floor floor, String floorName) { public boolean addToQueue(String lift, Floor floor, String floorName) {
if (lift == null || floor == null || !DataManager.containsLift(lift)) return false; if (lift == null || floor == null || !DataManager.containsLift(lift)) return false;
@ -735,12 +883,4 @@ public class V10LiftAPI {
} }
return false; return false;
} }
private void startLift(String liftName) {
if (!DataManager.containsMovingTask(liftName)) {
Lift lift = DataManager.getLift(liftName);
DataManager.addMovingTask(liftName, Bukkit.getScheduler().scheduleSyncRepeatingTask(V10LiftPlugin.getInstance(), new MoveLift(liftName, lift.getSpeed()), lift.getSpeed(), lift.getSpeed()));
}
}
} }