mirror of
https://github.com/songoda/FabledSkyBlock.git
synced 2025-01-11 02:07:42 +01:00
Queue level scans
This commit is contained in:
parent
e205e07910
commit
753f1a9c5e
@ -7,6 +7,7 @@ import me.goodandevil.skyblock.island.Island;
|
|||||||
import me.goodandevil.skyblock.island.IslandLevel;
|
import me.goodandevil.skyblock.island.IslandLevel;
|
||||||
import me.goodandevil.skyblock.island.IslandManager;
|
import me.goodandevil.skyblock.island.IslandManager;
|
||||||
import me.goodandevil.skyblock.island.IslandWorld;
|
import me.goodandevil.skyblock.island.IslandWorld;
|
||||||
|
import me.goodandevil.skyblock.message.MessageManager;
|
||||||
import me.goodandevil.skyblock.stackable.Stackable;
|
import me.goodandevil.skyblock.stackable.Stackable;
|
||||||
import me.goodandevil.skyblock.stackable.StackableManager;
|
import me.goodandevil.skyblock.stackable.StackableManager;
|
||||||
import me.goodandevil.skyblock.utils.version.Materials;
|
import me.goodandevil.skyblock.utils.version.Materials;
|
||||||
@ -31,9 +32,11 @@ import java.lang.reflect.Method;
|
|||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
|
import java.util.LinkedList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
import java.util.Queue;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.logging.Level;
|
import java.util.logging.Level;
|
||||||
|
|
||||||
@ -41,7 +44,8 @@ public class LevellingManager {
|
|||||||
|
|
||||||
private final SkyBlock skyblock;
|
private final SkyBlock skyblock;
|
||||||
|
|
||||||
private Set<Island> activeIslandScans = new HashSet<>();
|
private Island activelyScanningIsland = null;
|
||||||
|
private Queue<QueuedIsland> islandsInQueue = new LinkedList<>();
|
||||||
private List<LevellingMaterial> materialStorage = new ArrayList<>();
|
private List<LevellingMaterial> materialStorage = new ArrayList<>();
|
||||||
|
|
||||||
public LevellingManager(SkyBlock skyblock) {
|
public LevellingManager(SkyBlock skyblock) {
|
||||||
@ -53,17 +57,29 @@ public class LevellingManager {
|
|||||||
public void calculatePoints(Player player, Island island) {
|
public void calculatePoints(Player player, Island island) {
|
||||||
IslandManager islandManager = skyblock.getIslandManager();
|
IslandManager islandManager = skyblock.getIslandManager();
|
||||||
WorldManager worldManager = skyblock.getWorldManager();
|
WorldManager worldManager = skyblock.getWorldManager();
|
||||||
|
MessageManager messageManager = skyblock.getMessageManager();
|
||||||
StackableManager stackableManager = skyblock.getStackableManager();
|
StackableManager stackableManager = skyblock.getStackableManager();
|
||||||
|
|
||||||
if (player != null && islandManager.getIslandPlayerAt(player) != island) {
|
FileConfiguration languageConfig = this.skyblock.getFileManager().getConfig(new File(this.skyblock.getDataFolder(), "language.yml")).getFileConfiguration();
|
||||||
String message = ChatColor.translateAlternateColorCodes('&', this.skyblock.getFileManager()
|
|
||||||
.getConfig(new File(this.skyblock.getDataFolder(), "language.yml"))
|
if (!this.isIslandLevelBeingScanned(island) && player != null && islandManager.getIslandPlayerAt(player) != island) {
|
||||||
.getFileConfiguration().getString("Command.Island.Level.Scanning.NotOnIsland.Message"));
|
messageManager.sendMessage(player, languageConfig.getString("Command.Island.Level.Scanning.NotOnIsland.Message"));
|
||||||
player.sendMessage(message);
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
this.activeIslandScans.add(island);
|
if (this.activelyScanningIsland != null) {
|
||||||
|
this.islandsInQueue.add(new QueuedIsland(player, island));
|
||||||
|
|
||||||
|
String queuedMessage = languageConfig.getString("Command.Island.Level.Scanning.Queued.Message");
|
||||||
|
islandManager.getPlayersAtIsland(island).forEach(x -> messageManager.sendMessage(x, queuedMessage));
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.activelyScanningIsland = island;
|
||||||
|
|
||||||
|
String nowScanningMessage = languageConfig.getString("Command.Island.Level.Scanning.Started.Message");
|
||||||
|
islandManager.getPlayersAtIsland(island).forEach(x -> messageManager.sendMessage(x, nowScanningMessage));
|
||||||
|
|
||||||
Chunk chunk = new Chunk(skyblock, island);
|
Chunk chunk = new Chunk(skyblock, island);
|
||||||
chunk.prepareInitial();
|
chunk.prepareInitial();
|
||||||
@ -100,111 +116,116 @@ public class LevellingManager {
|
|||||||
new BukkitRunnable() {
|
new BukkitRunnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
if (!chunk.isReadyToScan()) return;
|
if (!chunk.isReadyToScan())
|
||||||
|
|
||||||
if (chunk.isFinished()) {
|
|
||||||
Bukkit.getScheduler().scheduleSyncDelayedTask(skyblock, () -> finalizeMaterials(levellingData, spawnerLocations, epicSpawnerLocations, ultimateStackerSpawnerLocations, player, island), 1);
|
|
||||||
cancel();
|
|
||||||
return;
|
return;
|
||||||
}
|
|
||||||
|
|
||||||
for (LevelChunkSnapshotWrapper chunkSnapshotList : chunk.getAvailableChunkSnapshots()) {
|
try {
|
||||||
for (int x = 0; x < 16; x++) {
|
if (chunk.isFinished()) {
|
||||||
for (int z = 0; z < 16; z++) {
|
Bukkit.getScheduler().scheduleSyncDelayedTask(skyblock, () -> finalizeMaterials(levellingData, spawnerLocations, epicSpawnerLocations, ultimateStackerSpawnerLocations, player, island), 1);
|
||||||
for (int y = 0; y < worldMaxHeight; y++) {
|
cancel();
|
||||||
ChunkSnapshot chunkSnapshot = chunkSnapshotList.getChunkSnapshot();
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
try {
|
for (LevelChunkSnapshotWrapper chunkSnapshotList : chunk.getAvailableChunkSnapshots()) {
|
||||||
org.bukkit.Material blockMaterial;
|
for (int x = 0; x < 16; x++) {
|
||||||
int blockData = 0;
|
for (int z = 0; z < 16; z++) {
|
||||||
EntityType spawnerType = null;
|
for (int y = 0; y < worldMaxHeight; y++) {
|
||||||
|
ChunkSnapshot chunkSnapshot = chunkSnapshotList.getChunkSnapshot();
|
||||||
|
|
||||||
if (NMSVersion > 12) {
|
try {
|
||||||
blockMaterial = chunkSnapshot.getBlockType(x, y, z);
|
org.bukkit.Material blockMaterial;
|
||||||
} else {
|
int blockData = 0;
|
||||||
LegacyChunkSnapshotData data = LegacyChunkSnapshotFetcher.fetch(chunkSnapshot, x, y, z);
|
EntityType spawnerType = null;
|
||||||
|
|
||||||
blockMaterial = data.getMaterial();
|
if (NMSVersion > 12) {
|
||||||
blockData = data.getData();
|
blockMaterial = chunkSnapshot.getBlockType(x, y, z);
|
||||||
}
|
} else {
|
||||||
|
LegacyChunkSnapshotData data = LegacyChunkSnapshotFetcher.fetch(chunkSnapshot, x, y, z);
|
||||||
|
|
||||||
if (blacklistedMaterials.contains(blockMaterial))
|
blockMaterial = data.getMaterial();
|
||||||
continue;
|
blockData = data.getData();
|
||||||
|
}
|
||||||
|
|
||||||
long amount = 1;
|
if (blacklistedMaterials.contains(blockMaterial))
|
||||||
|
continue;
|
||||||
|
|
||||||
if (blockMaterial == Materials.SPAWNER.parseMaterial()) {
|
long amount = 1;
|
||||||
World world = Bukkit.getWorld(chunkSnapshot.getWorldName());
|
|
||||||
Location location = new Location(world, chunkSnapshot.getX() * 16 + x, y, chunkSnapshot.getZ() * 16 + z);
|
|
||||||
|
|
||||||
if (isEpicSpawnersEnabled) {
|
if (blockMaterial == Materials.SPAWNER.parseMaterial()) {
|
||||||
com.songoda.epicspawners.EpicSpawners epicSpawners = com.songoda.epicspawners.EpicSpawners.getInstance();
|
World world = Bukkit.getWorld(chunkSnapshot.getWorldName());
|
||||||
if (epicSpawners.getSpawnerManager().isSpawner(location)) {
|
Location location = new Location(world, chunkSnapshot.getX() * 16 + x, y, chunkSnapshot.getZ() * 16 + z);
|
||||||
com.songoda.epicspawners.spawners.spawner.Spawner spawner = epicSpawners.getSpawnerManager().getSpawnerFromWorld(location);
|
|
||||||
if (spawner != null)
|
if (isEpicSpawnersEnabled) {
|
||||||
epicSpawnerLocations.add(location);
|
com.songoda.epicspawners.EpicSpawners epicSpawners = com.songoda.epicspawners.EpicSpawners.getInstance();
|
||||||
|
if (epicSpawners.getSpawnerManager().isSpawner(location)) {
|
||||||
|
com.songoda.epicspawners.spawners.spawner.Spawner spawner = epicSpawners.getSpawnerManager().getSpawnerFromWorld(location);
|
||||||
|
if (spawner != null)
|
||||||
|
epicSpawnerLocations.add(location);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
} else if (isUltimateStackerEnabled) {
|
||||||
|
com.songoda.ultimatestacker.spawner.SpawnerStack spawnerStack = com.songoda.ultimatestacker.UltimateStacker.getInstance().getSpawnerStackManager().getSpawner(location);
|
||||||
|
if (spawnerStack != null)
|
||||||
|
ultimateStackerSpawnerLocations.add(location);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
} else if (isUltimateStackerEnabled) {
|
|
||||||
com.songoda.ultimatestacker.spawner.SpawnerStack spawnerStack = com.songoda.ultimatestacker.UltimateStacker.getInstance().getSpawnerStackManager().getSpawner(location);
|
|
||||||
if (spawnerStack != null)
|
|
||||||
ultimateStackerSpawnerLocations.add(location);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (chunkSnapshotList.hasWildStackerData()) {
|
if (chunkSnapshotList.hasWildStackerData()) {
|
||||||
com.bgsoftware.wildstacker.api.objects.StackedSnapshot snapshot = ((WildStackerChunkSnapshotWrapper)chunkSnapshotList).getStackedSnapshot();
|
com.bgsoftware.wildstacker.api.objects.StackedSnapshot snapshot = ((WildStackerChunkSnapshotWrapper) chunkSnapshotList).getStackedSnapshot();
|
||||||
if (snapshot.isStackedSpawner(location)) {
|
if (snapshot.isStackedSpawner(location)) {
|
||||||
Map.Entry<Integer, EntityType> spawnerData = snapshot.getStackedSpawner(location);
|
Map.Entry<Integer, EntityType> spawnerData = snapshot.getStackedSpawner(location);
|
||||||
amount = spawnerData.getKey();
|
amount = spawnerData.getKey();
|
||||||
spawnerType = spawnerData.getValue();
|
spawnerType = spawnerData.getValue();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
if (spawnerType == null) {
|
if (spawnerType == null) {
|
||||||
spawnerLocations.add(location);
|
spawnerLocations.add(location);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (chunkSnapshotList.hasWildStackerData()) {
|
if (chunkSnapshotList.hasWildStackerData()) {
|
||||||
com.bgsoftware.wildstacker.api.objects.StackedSnapshot snapshot = ((WildStackerChunkSnapshotWrapper)chunkSnapshotList).getStackedSnapshot();
|
com.bgsoftware.wildstacker.api.objects.StackedSnapshot snapshot = ((WildStackerChunkSnapshotWrapper) chunkSnapshotList).getStackedSnapshot();
|
||||||
World world = Bukkit.getWorld(chunkSnapshot.getWorldName());
|
World world = Bukkit.getWorld(chunkSnapshot.getWorldName());
|
||||||
Location location = new Location(world, chunkSnapshot.getX() * 16 + x, y, chunkSnapshot.getZ() * 16 + z);
|
Location location = new Location(world, chunkSnapshot.getX() * 16 + x, y, chunkSnapshot.getZ() * 16 + z);
|
||||||
if (snapshot.isStackedBarrel(location)) {
|
if (snapshot.isStackedBarrel(location)) {
|
||||||
Map.Entry<Integer, Material> barrelData = snapshot.getStackedBarrel(location);
|
Map.Entry<Integer, Material> barrelData = snapshot.getStackedBarrel(location);
|
||||||
amount = barrelData.getKey();
|
amount = barrelData.getKey();
|
||||||
blockMaterial = barrelData.getValue();
|
blockMaterial = barrelData.getValue();
|
||||||
if (NMSUtil.getVersionNumber() > 12 && blockMaterial.name().startsWith("LEGACY_")) {
|
if (NMSUtil.getVersionNumber() > 12 && blockMaterial.name().startsWith("LEGACY_")) {
|
||||||
blockMaterial = Material.matchMaterial(blockMaterial.name().replace("LEGACY_", ""));
|
blockMaterial = Material.matchMaterial(blockMaterial.name().replace("LEGACY_", ""));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (stackableManager != null && stackableManager.getStackableMaterials().contains(blockMaterial) && amount == 1) {
|
||||||
|
World world = Bukkit.getWorld(chunkSnapshot.getWorldName());
|
||||||
|
Location location = new Location(world, chunkSnapshot.getX() * 16 + x, y, chunkSnapshot.getZ() * 16 + z);
|
||||||
|
if (stackableManager.isStacked(location)) {
|
||||||
|
Stackable stackable = stackableManager.getStack(location, blockMaterial);
|
||||||
|
if (stackable != null) {
|
||||||
|
amount = stackable.getSize();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (stackableManager != null && stackableManager.getStackableMaterials().contains(blockMaterial) && amount == 1) {
|
LevellingData data = new LevellingData(blockMaterial, (byte) blockData, spawnerType);
|
||||||
World world = Bukkit.getWorld(chunkSnapshot.getWorldName());
|
Long totalAmountInteger = levellingData.get(data);
|
||||||
Location location = new Location(world, chunkSnapshot.getX() * 16 + x, y, chunkSnapshot.getZ() * 16 + z);
|
long totalAmount = totalAmountInteger == null ? amount : totalAmountInteger + amount;
|
||||||
if (stackableManager.isStacked(location)) {
|
levellingData.put(data, totalAmount);
|
||||||
Stackable stackable = stackableManager.getStack(location, blockMaterial);
|
} catch (Exception e) {
|
||||||
if (stackable != null) {
|
e.printStackTrace();
|
||||||
amount = stackable.getSize();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
LevellingData data = new LevellingData(blockMaterial, (byte) blockData, spawnerType);
|
|
||||||
Long totalAmountInteger = levellingData.get(data);
|
|
||||||
long totalAmount = totalAmountInteger == null ? amount : totalAmountInteger + amount;
|
|
||||||
levellingData.put(data, totalAmount);
|
|
||||||
} catch (Exception e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
chunk.prepareNextChunkSnapshots();
|
chunk.prepareNextChunkSnapshots();
|
||||||
|
} catch (Exception ex) {
|
||||||
|
skyblock.getLogger().severe("An error occurred while scanning an island. This is a severe error.");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}.runTaskTimerAsynchronously(skyblock, 0L, 1L);
|
}.runTaskTimerAsynchronously(skyblock, 0L, 1L);
|
||||||
}
|
}
|
||||||
@ -282,7 +303,15 @@ public class LevellingManager {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
this.activeIslandScans.remove(island);
|
MessageManager messageManager = skyblock.getMessageManager();
|
||||||
|
FileConfiguration languageConfig = this.skyblock.getFileManager().getConfig(new File(this.skyblock.getDataFolder(), "language.yml")).getFileConfiguration();
|
||||||
|
String nowScanningMessage = languageConfig.getString("Command.Island.Level.Scanning.Done.Message");
|
||||||
|
skyblock.getIslandManager().getPlayersAtIsland(island).forEach(x -> messageManager.sendMessage(x, nowScanningMessage));
|
||||||
|
|
||||||
|
this.activelyScanningIsland = null;
|
||||||
|
QueuedIsland nextInQueue = this.islandsInQueue.poll();
|
||||||
|
if (nextInQueue != null)
|
||||||
|
this.calculatePoints(nextInQueue.getPlayer(), nextInQueue.getIsland());
|
||||||
}
|
}
|
||||||
|
|
||||||
public void registerMaterials() {
|
public void registerMaterials() {
|
||||||
@ -307,7 +336,7 @@ public class LevellingManager {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public boolean isIslandLevelBeingScanned(Island island) {
|
public boolean isIslandLevelBeingScanned(Island island) {
|
||||||
return this.activeIslandScans.contains(island);
|
return this.islandsInQueue.stream().anyMatch(x -> x.getIsland() == island) || this.activelyScanningIsland == island;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void unregisterMaterials() {
|
public void unregisterMaterials() {
|
||||||
@ -385,4 +414,22 @@ public class LevellingManager {
|
|||||||
return Materials.getMaterials(this.material, this.data);
|
return Materials.getMaterials(this.material, this.data);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private class QueuedIsland {
|
||||||
|
private final Player player;
|
||||||
|
private final Island island;
|
||||||
|
|
||||||
|
public QueuedIsland(Player player, Island island) {
|
||||||
|
this.player = player;
|
||||||
|
this.island = island;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Player getPlayer() {
|
||||||
|
return this.player;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Island getIsland() {
|
||||||
|
return this.island;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -84,6 +84,12 @@ Command:
|
|||||||
Message: '&bSkyBlock &8| &cError&8: &eYou cannot initiate an Island level scan without being on your Island.'
|
Message: '&bSkyBlock &8| &cError&8: &eYou cannot initiate an Island level scan without being on your Island.'
|
||||||
BlockPlacing:
|
BlockPlacing:
|
||||||
Message: '&bSkyBlock &8 | &cError:&8: &eYou cannot place blocks during an Island level scan. Please wait for the scan to finish.'
|
Message: '&bSkyBlock &8 | &cError:&8: &eYou cannot place blocks during an Island level scan. Please wait for the scan to finish.'
|
||||||
|
Started:
|
||||||
|
Message: '&bSkyBlock &8| &aInfo&8: &eA level scan has started on this island.'
|
||||||
|
Queued:
|
||||||
|
Message: '&bSkyBlock &8| &aInfo&8: &eA level scan has been &aqueued&e for this island. The scan will start as soon as all other queued scans are complete.'
|
||||||
|
Done:
|
||||||
|
Message: '&bSkyBlock &8| &aInfo&8: &eThe scan has completed.'
|
||||||
Cooldown:
|
Cooldown:
|
||||||
Word:
|
Word:
|
||||||
Minute: minute(s)
|
Minute: minute(s)
|
||||||
|
Loading…
Reference in New Issue
Block a user