mirror of
https://github.com/SunNetservers/MiniGames.git
synced 2025-04-04 02:36:25 +02:00
Adds a placeholder expansion for parkour records
This commit is contained in:
parent
31b22c7e56
commit
257fc48912
@ -50,6 +50,7 @@ import net.knarcraft.minigames.listener.DamageListener;
|
|||||||
import net.knarcraft.minigames.listener.MoveListener;
|
import net.knarcraft.minigames.listener.MoveListener;
|
||||||
import net.knarcraft.minigames.listener.PlayerLeaveListener;
|
import net.knarcraft.minigames.listener.PlayerLeaveListener;
|
||||||
import net.knarcraft.minigames.placeholder.DropperRecordExpansion;
|
import net.knarcraft.minigames.placeholder.DropperRecordExpansion;
|
||||||
|
import net.knarcraft.minigames.placeholder.ParkourRecordExpansion;
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.command.CommandExecutor;
|
import org.bukkit.command.CommandExecutor;
|
||||||
import org.bukkit.command.PluginCommand;
|
import org.bukkit.command.PluginCommand;
|
||||||
@ -77,6 +78,7 @@ public final class MiniGames extends JavaPlugin {
|
|||||||
private DropperArenaHandler dropperArenaHandler;
|
private DropperArenaHandler dropperArenaHandler;
|
||||||
private DropperArenaPlayerRegistry dropperArenaPlayerRegistry;
|
private DropperArenaPlayerRegistry dropperArenaPlayerRegistry;
|
||||||
private DropperRecordExpansion dropperRecordExpansion;
|
private DropperRecordExpansion dropperRecordExpansion;
|
||||||
|
private ParkourRecordExpansion parkourRecordExpansion;
|
||||||
private ParkourArenaHandler parkourArenaHandler;
|
private ParkourArenaHandler parkourArenaHandler;
|
||||||
private ParkourArenaPlayerRegistry parkourArenaPlayerRegistry;
|
private ParkourArenaPlayerRegistry parkourArenaPlayerRegistry;
|
||||||
|
|
||||||
@ -195,6 +197,7 @@ public final class MiniGames extends JavaPlugin {
|
|||||||
|
|
||||||
// Clear record caches
|
// Clear record caches
|
||||||
this.dropperRecordExpansion.clearCaches();
|
this.dropperRecordExpansion.clearCaches();
|
||||||
|
this.parkourRecordExpansion.clearCaches();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -229,7 +232,7 @@ public final class MiniGames extends JavaPlugin {
|
|||||||
this.dropperArenaPlayerRegistry = new DropperArenaPlayerRegistry();
|
this.dropperArenaPlayerRegistry = new DropperArenaPlayerRegistry();
|
||||||
this.dropperArenaHandler = new DropperArenaHandler(this.dropperArenaPlayerRegistry);
|
this.dropperArenaHandler = new DropperArenaHandler(this.dropperArenaPlayerRegistry);
|
||||||
this.dropperArenaHandler.load();
|
this.dropperArenaHandler.load();
|
||||||
|
this.parkourArenaPlayerRegistry = new ParkourArenaPlayerRegistry();
|
||||||
this.parkourArenaHandler = new ParkourArenaHandler(this.parkourArenaPlayerRegistry);
|
this.parkourArenaHandler = new ParkourArenaHandler(this.parkourArenaPlayerRegistry);
|
||||||
this.parkourArenaHandler.load();
|
this.parkourArenaHandler.load();
|
||||||
|
|
||||||
@ -263,7 +266,11 @@ public final class MiniGames extends JavaPlugin {
|
|||||||
if (Bukkit.getPluginManager().getPlugin("PlaceholderAPI") != null) {
|
if (Bukkit.getPluginManager().getPlugin("PlaceholderAPI") != null) {
|
||||||
this.dropperRecordExpansion = new DropperRecordExpansion(this);
|
this.dropperRecordExpansion = new DropperRecordExpansion(this);
|
||||||
if (!this.dropperRecordExpansion.register()) {
|
if (!this.dropperRecordExpansion.register()) {
|
||||||
log(Level.WARNING, "Unable to register PlaceholderAPI expansion!");
|
log(Level.WARNING, "Unable to register PlaceholderAPI dropper expansion!");
|
||||||
|
}
|
||||||
|
this.parkourRecordExpansion = new ParkourRecordExpansion(this);
|
||||||
|
if (!this.parkourRecordExpansion.register()) {
|
||||||
|
log(Level.WARNING, "Unable to register PlaceholderAPI parkour expansion!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,43 +1,14 @@
|
|||||||
package net.knarcraft.minigames.placeholder;
|
package net.knarcraft.minigames.placeholder;
|
||||||
|
|
||||||
import me.clip.placeholderapi.expansion.PlaceholderExpansion;
|
|
||||||
import net.knarcraft.minigames.MiniGames;
|
import net.knarcraft.minigames.MiniGames;
|
||||||
import net.knarcraft.minigames.arena.ArenaGameMode;
|
import net.knarcraft.minigames.arena.ArenaGameMode;
|
||||||
import net.knarcraft.minigames.arena.ArenaRecordsRegistry;
|
|
||||||
import net.knarcraft.minigames.arena.dropper.DropperArena;
|
|
||||||
import net.knarcraft.minigames.arena.dropper.DropperArenaGameMode;
|
import net.knarcraft.minigames.arena.dropper.DropperArenaGameMode;
|
||||||
import net.knarcraft.minigames.arena.dropper.DropperArenaGroup;
|
|
||||||
import net.knarcraft.minigames.arena.dropper.DropperArenaHandler;
|
|
||||||
import net.knarcraft.minigames.arena.dropper.DropperArenaRecordsRegistry;
|
|
||||||
import net.knarcraft.minigames.arena.record.ArenaRecord;
|
|
||||||
import net.knarcraft.minigames.placeholder.parsing.InfoType;
|
|
||||||
import net.knarcraft.minigames.placeholder.parsing.SelectionType;
|
|
||||||
import net.knarcraft.minigames.property.RecordType;
|
|
||||||
import net.knarcraft.minigames.util.DropperGroupRecordHelper;
|
|
||||||
import org.bukkit.Bukkit;
|
|
||||||
import org.bukkit.OfflinePlayer;
|
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Nullable;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.Collections;
|
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
import java.util.Objects;
|
|
||||||
import java.util.Set;
|
|
||||||
import java.util.UUID;
|
|
||||||
import java.util.function.Supplier;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A placeholder expansion for dropper record placeholders
|
* A placeholder expansion for dropper record placeholders
|
||||||
*/
|
*/
|
||||||
public class DropperRecordExpansion extends PlaceholderExpansion {
|
public class DropperRecordExpansion extends RecordExpansion {
|
||||||
|
|
||||||
private final MiniGames plugin;
|
|
||||||
private final Map<UUID, Set<GroupRecordCache<Integer>>> groupRecordDeathsCache;
|
|
||||||
private final Map<UUID, Set<GroupRecordCache<Long>>> groupRecordTimeCache;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Initializes a new record expansion
|
* Initializes a new record expansion
|
||||||
@ -45,9 +16,7 @@ public class DropperRecordExpansion extends PlaceholderExpansion {
|
|||||||
* @param plugin <p>A reference to the dropper plugin</p>
|
* @param plugin <p>A reference to the dropper plugin</p>
|
||||||
*/
|
*/
|
||||||
public DropperRecordExpansion(MiniGames plugin) {
|
public DropperRecordExpansion(MiniGames plugin) {
|
||||||
this.plugin = plugin;
|
super(plugin.getDropperArenaHandler());
|
||||||
this.groupRecordDeathsCache = new HashMap<>();
|
|
||||||
this.groupRecordTimeCache = new HashMap<>();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -56,280 +25,8 @@ public class DropperRecordExpansion extends PlaceholderExpansion {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getAuthor() {
|
protected @NotNull ArenaGameMode parseGameMode(@NotNull String gameMode) {
|
||||||
return "EpicKnarvik97";
|
return DropperArenaGameMode.matchGamemode(gameMode);
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String getVersion() {
|
|
||||||
return "1.0.0";
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean persist() {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String onRequest(OfflinePlayer player, String parameters) {
|
|
||||||
String[] parts = parameters.split("_");
|
|
||||||
// Record is used as the prefix for all record placeholders in case more placeholder types are added
|
|
||||||
if (parts.length < 7 || !parts[0].equals("record")) {
|
|
||||||
return parameters;
|
|
||||||
}
|
|
||||||
RecordType recordType = RecordType.getFromString(parts[1]);
|
|
||||||
DropperArenaGameMode gameMode = DropperArenaGameMode.matchGamemode(parts[2]);
|
|
||||||
SelectionType selectionType = SelectionType.getFromString(parts[3]);
|
|
||||||
String identifier = parts[4];
|
|
||||||
int recordNumber = Integer.parseInt(parts[5]) - 1;
|
|
||||||
InfoType infoType = InfoType.getFromString(parts[6]);
|
|
||||||
|
|
||||||
if (recordType == null || infoType == null) {
|
|
||||||
return parameters;
|
|
||||||
}
|
|
||||||
|
|
||||||
String info = null;
|
|
||||||
DropperArenaHandler arenaHandler = plugin.getDropperArenaHandler();
|
|
||||||
if (selectionType == SelectionType.GROUP) {
|
|
||||||
info = getGroupRecord(arenaHandler, identifier, gameMode, recordType, recordNumber, infoType);
|
|
||||||
} else if (selectionType == SelectionType.ARENA) {
|
|
||||||
info = getArenaRecord(arenaHandler, identifier, gameMode, recordType, recordNumber, infoType);
|
|
||||||
}
|
|
||||||
|
|
||||||
return Objects.requireNonNullElse(info, parameters);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Clears all record caches
|
|
||||||
*/
|
|
||||||
public void clearCaches() {
|
|
||||||
this.groupRecordDeathsCache.clear();
|
|
||||||
this.groupRecordTimeCache.clear();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets a piece of record information from a dropper arena group
|
|
||||||
*
|
|
||||||
* @param arenaHandler <p>The arena handler to get the group from</p>
|
|
||||||
* @param identifier <p>The identifier (name/uuid) selecting the group</p>
|
|
||||||
* @param gameMode <p>The game-mode to get a record for</p>
|
|
||||||
* @param recordType <p>The type of record to get</p>
|
|
||||||
* @param recordNumber <p>The placing of the record to get (1st place, 2nd place, etc.)</p>
|
|
||||||
* @param infoType <p>The type of info (player, value, combined) to get</p>
|
|
||||||
* @return <p>The selected information about the record, or null if not found</p>
|
|
||||||
*/
|
|
||||||
private @Nullable String getGroupRecord(@NotNull DropperArenaHandler arenaHandler, @NotNull String identifier,
|
|
||||||
@NotNull DropperArenaGameMode gameMode, @NotNull RecordType recordType,
|
|
||||||
int recordNumber, @NotNull InfoType infoType) {
|
|
||||||
// Allow specifying the group UUID or the arena name
|
|
||||||
DropperArenaGroup group;
|
|
||||||
try {
|
|
||||||
group = arenaHandler.getGroup(UUID.fromString(identifier));
|
|
||||||
} catch (IllegalArgumentException exception) {
|
|
||||||
group = arenaHandler.getGroup(identifier);
|
|
||||||
}
|
|
||||||
if (group == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
ArenaRecord<?> record;
|
|
||||||
if (recordType == RecordType.DEATHS) {
|
|
||||||
record = getGroupDeathRecord(group, gameMode, recordNumber);
|
|
||||||
} else {
|
|
||||||
record = getGroupTimeRecord(group, gameMode, recordNumber);
|
|
||||||
}
|
|
||||||
|
|
||||||
// If a record number is not found, leave it blank, so it looks neat
|
|
||||||
if (record == null) {
|
|
||||||
return "";
|
|
||||||
}
|
|
||||||
|
|
||||||
return getRecordData(infoType, record);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets a time record from a group, using the cache if possible
|
|
||||||
*
|
|
||||||
* @param group <p>The group to get the record from</p>
|
|
||||||
* @param gameMode <p>The game-mode to get the record from</p>
|
|
||||||
* @param recordNumber <p>The placing of the record to get (1st place, 2nd place, etc.)</p>
|
|
||||||
* @return <p>The record, or null if not found</p>
|
|
||||||
*/
|
|
||||||
private @Nullable ArenaRecord<?> getGroupTimeRecord(@NotNull DropperArenaGroup group,
|
|
||||||
@NotNull DropperArenaGameMode gameMode, int recordNumber) {
|
|
||||||
return getCachedGroupRecord(group, gameMode, RecordType.TIME, recordNumber, groupRecordTimeCache,
|
|
||||||
() -> DropperGroupRecordHelper.getCombinedTime(group, gameMode));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets a death record from a group, using the cache if possible
|
|
||||||
*
|
|
||||||
* @param group <p>The group to get the record from</p>
|
|
||||||
* @param gameMode <p>The game-mode to get the record from</p>
|
|
||||||
* @param recordNumber <p>The placing of the record to get (1st place, 2nd place, etc.)</p>
|
|
||||||
* @return <p>The record, or null if not found</p>
|
|
||||||
*/
|
|
||||||
private @Nullable ArenaRecord<?> getGroupDeathRecord(@NotNull DropperArenaGroup group,
|
|
||||||
@NotNull DropperArenaGameMode gameMode, int recordNumber) {
|
|
||||||
return getCachedGroupRecord(group, gameMode, RecordType.DEATHS, recordNumber, groupRecordDeathsCache,
|
|
||||||
() -> DropperGroupRecordHelper.getCombinedDeaths(group, gameMode));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets a group record, fetching from a cache if possible
|
|
||||||
*
|
|
||||||
* @param group <p>The group to get the record for</p>
|
|
||||||
* @param gameMode <p>The game-mode to get the record for</p>
|
|
||||||
* @param recordType <p>The type of record to get</p>
|
|
||||||
* @param recordNumber <p>The placing of the record to get (1st place, 2nd place, etc.)</p>
|
|
||||||
* @param caches <p>The caches to use for looking for and saving the record</p>
|
|
||||||
* @param recordProvider <p>The provider of records if the cache cannot provide the record</p>
|
|
||||||
* @param <K> <p>The type of the provided records</p>
|
|
||||||
* @return <p>The specified record, or null if not found</p>
|
|
||||||
*/
|
|
||||||
private <K extends Comparable<K>> @Nullable ArenaRecord<?> getCachedGroupRecord(@NotNull DropperArenaGroup group,
|
|
||||||
@NotNull DropperArenaGameMode gameMode,
|
|
||||||
@NotNull RecordType recordType,
|
|
||||||
int recordNumber,
|
|
||||||
@NotNull Map<UUID, Set<GroupRecordCache<K>>> caches,
|
|
||||||
@NotNull Supplier<Set<ArenaRecord<K>>> recordProvider) {
|
|
||||||
UUID groupId = group.getGroupId();
|
|
||||||
if (!caches.containsKey(groupId)) {
|
|
||||||
caches.put(groupId, new HashSet<>());
|
|
||||||
}
|
|
||||||
|
|
||||||
Set<GroupRecordCache<K>> existingCaches = caches.get(groupId);
|
|
||||||
Set<GroupRecordCache<K>> expired = new HashSet<>();
|
|
||||||
Set<ArenaRecord<K>> cachedRecords = null;
|
|
||||||
|
|
||||||
for (GroupRecordCache<K> cache : existingCaches) {
|
|
||||||
// Expire caches after 30 seconds
|
|
||||||
if (System.currentTimeMillis() - cache.createdTime() > 30000) {
|
|
||||||
expired.add(cache);
|
|
||||||
}
|
|
||||||
// If of the correct type, and not expired, use the cache
|
|
||||||
if (cache.gameMode() == gameMode && cache.recordType() == recordType) {
|
|
||||||
cachedRecords = cache.records();
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
existingCaches.removeAll(expired);
|
|
||||||
|
|
||||||
// If not found, generate and cache the specified record
|
|
||||||
if (cachedRecords == null) {
|
|
||||||
cachedRecords = recordProvider.get();
|
|
||||||
existingCaches.add(new GroupRecordCache<>(gameMode, recordType, cachedRecords, System.currentTimeMillis()));
|
|
||||||
}
|
|
||||||
return getRecord(cachedRecords, recordNumber);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets a piece of record information from a dropper arena
|
|
||||||
*
|
|
||||||
* @param arenaHandler <p>The arena handler to get the arena from</p>
|
|
||||||
* @param identifier <p>The identifier (name/uuid) selecting the arena</p>
|
|
||||||
* @param gameMode <p>The game-mode to get a record for</p>
|
|
||||||
* @param recordType <p>The type of record to get</p>
|
|
||||||
* @param recordNumber <p>The placing of the record to get (1st place, 2nd place, etc.)</p>
|
|
||||||
* @param infoType <p>The type of info (player, value, combined) to get</p>
|
|
||||||
* @return <p>The selected information about the record, or null if not found</p>
|
|
||||||
*/
|
|
||||||
private @Nullable String getArenaRecord(@NotNull DropperArenaHandler arenaHandler, @NotNull String identifier,
|
|
||||||
@NotNull DropperArenaGameMode gameMode, @NotNull RecordType recordType,
|
|
||||||
int recordNumber, @NotNull InfoType infoType) {
|
|
||||||
// Allow specifying the arena UUID or the arena name
|
|
||||||
DropperArena arena;
|
|
||||||
try {
|
|
||||||
arena = arenaHandler.getArena(UUID.fromString(identifier));
|
|
||||||
} catch (IllegalArgumentException exception) {
|
|
||||||
arena = arenaHandler.getArena(identifier);
|
|
||||||
}
|
|
||||||
if (arena == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
@NotNull Map<ArenaGameMode, ArenaRecordsRegistry> registries = arena.getData().getRecordRegistries();
|
|
||||||
ArenaRecordsRegistry recordsRegistry = registries.get(gameMode);
|
|
||||||
|
|
||||||
ArenaRecord<?> record = getRecord((DropperArenaRecordsRegistry) recordsRegistry, recordType, recordNumber);
|
|
||||||
|
|
||||||
// If a record number is not found, leave it blank, so it looks neat
|
|
||||||
if (record == null) {
|
|
||||||
return "";
|
|
||||||
}
|
|
||||||
|
|
||||||
return getRecordData(infoType, record);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets the specified record
|
|
||||||
*
|
|
||||||
* @param recordsRegistry <p>The records registry to get the record from</p>
|
|
||||||
* @param recordType <p>The type of record to get</p>
|
|
||||||
* @param recordNumber <p>The placing of the record to get (1st place, 2nd place, etc.)</p>
|
|
||||||
* @return <p>The record, or null if not found</p>
|
|
||||||
*/
|
|
||||||
private @Nullable ArenaRecord<?> getRecord(@NotNull DropperArenaRecordsRegistry recordsRegistry,
|
|
||||||
@NotNull RecordType recordType, int recordNumber) {
|
|
||||||
return switch (recordType) {
|
|
||||||
case TIME -> getRecord(new HashSet<>(recordsRegistry.getShortestTimeMilliSecondsRecords()), recordNumber);
|
|
||||||
case DEATHS -> getRecord(new HashSet<>(recordsRegistry.getLeastDeathsRecords()), recordNumber);
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets the record at the given index
|
|
||||||
*
|
|
||||||
* @param records <p>The records to search through</p>
|
|
||||||
* @param index <p>The index of the record to get</p>
|
|
||||||
* @param <K> <p>The type of record in the record list</p>
|
|
||||||
* @return <p>The record, or null if index is out of bounds</p>
|
|
||||||
*/
|
|
||||||
private <K extends Comparable<K>> @Nullable ArenaRecord<K> getRecord(Set<ArenaRecord<K>> records, int index) {
|
|
||||||
List<ArenaRecord<K>> sorted = getSortedRecords(records);
|
|
||||||
if (index < sorted.size() && index >= 0) {
|
|
||||||
return sorted.get(index);
|
|
||||||
} else {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets a piece of data from a record as a string
|
|
||||||
*
|
|
||||||
* @param infoType <p>The type of info to get data for</p>
|
|
||||||
* @param arenaRecord <p>The record to get the data from</p>
|
|
||||||
* @return <p>The requested data as a string, or null</p>
|
|
||||||
*/
|
|
||||||
private String getRecordData(@NotNull InfoType infoType, @NotNull ArenaRecord<?> arenaRecord) {
|
|
||||||
return switch (infoType) {
|
|
||||||
case PLAYER -> getPlayerName(arenaRecord.getUserId());
|
|
||||||
case VALUE -> arenaRecord.getRecord().toString();
|
|
||||||
case COMBINED -> getPlayerName(arenaRecord.getUserId()) + ": " + arenaRecord.getRecord().toString();
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets the given set of records as a sorted list
|
|
||||||
*
|
|
||||||
* @param recordSet <p>The set of records to sort</p>
|
|
||||||
* @param <K> <p>The type of the records</p>
|
|
||||||
* @return <p>The sorted records</p>
|
|
||||||
*/
|
|
||||||
private <K extends Comparable<K>> @NotNull List<ArenaRecord<K>> getSortedRecords(
|
|
||||||
@NotNull Set<ArenaRecord<K>> recordSet) {
|
|
||||||
List<ArenaRecord<K>> records = new ArrayList<>(recordSet);
|
|
||||||
Collections.sort(records);
|
|
||||||
return records;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets the name of a player, given the player's UUID
|
|
||||||
*
|
|
||||||
* @param playerId <p>The id of the player to get the name for</p>
|
|
||||||
* @return <p>The name of the player, or a string representation of the UUID if not found</p>
|
|
||||||
*/
|
|
||||||
private String getPlayerName(@NotNull UUID playerId) {
|
|
||||||
return Bukkit.getOfflinePlayer(playerId).getName();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
package net.knarcraft.minigames.placeholder;
|
package net.knarcraft.minigames.placeholder;
|
||||||
|
|
||||||
import net.knarcraft.minigames.arena.dropper.DropperArenaGameMode;
|
import net.knarcraft.minigames.arena.ArenaGameMode;
|
||||||
import net.knarcraft.minigames.arena.record.ArenaRecord;
|
import net.knarcraft.minigames.arena.record.ArenaRecord;
|
||||||
import net.knarcraft.minigames.property.RecordType;
|
import net.knarcraft.minigames.property.RecordType;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
@ -15,7 +15,7 @@ import java.util.Set;
|
|||||||
* @param records <p>The stored records</p>
|
* @param records <p>The stored records</p>
|
||||||
* @param createdTime <p>The time this cache was created</p>
|
* @param createdTime <p>The time this cache was created</p>
|
||||||
*/
|
*/
|
||||||
public record GroupRecordCache<K extends Comparable<K>>(@NotNull DropperArenaGameMode gameMode,
|
public record GroupRecordCache<K extends Comparable<K>>(@NotNull ArenaGameMode gameMode,
|
||||||
@NotNull RecordType recordType,
|
@NotNull RecordType recordType,
|
||||||
@NotNull Set<ArenaRecord<K>> records,
|
@NotNull Set<ArenaRecord<K>> records,
|
||||||
@NotNull Long createdTime) {
|
@NotNull Long createdTime) {
|
||||||
|
@ -0,0 +1,32 @@
|
|||||||
|
package net.knarcraft.minigames.placeholder;
|
||||||
|
|
||||||
|
import net.knarcraft.minigames.MiniGames;
|
||||||
|
import net.knarcraft.minigames.arena.ArenaGameMode;
|
||||||
|
import net.knarcraft.minigames.arena.parkour.ParkourArenaGameMode;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A placeholder expansion for parkour record placeholders
|
||||||
|
*/
|
||||||
|
public class ParkourRecordExpansion extends RecordExpansion {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initializes a new record expansion
|
||||||
|
*
|
||||||
|
* @param plugin <p>A reference to the dropper plugin</p>
|
||||||
|
*/
|
||||||
|
public ParkourRecordExpansion(MiniGames plugin) {
|
||||||
|
super(plugin.getParkourArenaHandler());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getIdentifier() {
|
||||||
|
return "parkour";
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected @NotNull ArenaGameMode parseGameMode(@NotNull String gameMode) {
|
||||||
|
return ParkourArenaGameMode.matchGamemode(gameMode);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,336 @@
|
|||||||
|
package net.knarcraft.minigames.placeholder;
|
||||||
|
|
||||||
|
import me.clip.placeholderapi.expansion.PlaceholderExpansion;
|
||||||
|
import net.knarcraft.minigames.arena.Arena;
|
||||||
|
import net.knarcraft.minigames.arena.ArenaGameMode;
|
||||||
|
import net.knarcraft.minigames.arena.ArenaGroup;
|
||||||
|
import net.knarcraft.minigames.arena.ArenaHandler;
|
||||||
|
import net.knarcraft.minigames.arena.ArenaRecordsRegistry;
|
||||||
|
import net.knarcraft.minigames.arena.record.ArenaRecord;
|
||||||
|
import net.knarcraft.minigames.placeholder.parsing.InfoType;
|
||||||
|
import net.knarcraft.minigames.placeholder.parsing.SelectionType;
|
||||||
|
import net.knarcraft.minigames.property.RecordType;
|
||||||
|
import net.knarcraft.minigames.util.GroupRecordHelper;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.OfflinePlayer;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Objects;
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.UUID;
|
||||||
|
import java.util.function.Supplier;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A placeholder expansion for parkour record placeholders
|
||||||
|
*/
|
||||||
|
public abstract class RecordExpansion extends PlaceholderExpansion {
|
||||||
|
|
||||||
|
private final ArenaHandler<?, ?> arenaHandler;
|
||||||
|
private final Map<UUID, Set<GroupRecordCache<Integer>>> groupRecordDeathsCache;
|
||||||
|
private final Map<UUID, Set<GroupRecordCache<Long>>> groupRecordTimeCache;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initializes a new record expansion
|
||||||
|
*/
|
||||||
|
public RecordExpansion(ArenaHandler<?, ?> arenaHandler) {
|
||||||
|
this.groupRecordDeathsCache = new HashMap<>();
|
||||||
|
this.groupRecordTimeCache = new HashMap<>();
|
||||||
|
this.arenaHandler = arenaHandler;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getAuthor() {
|
||||||
|
return "EpicKnarvik97";
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getVersion() {
|
||||||
|
return "1.0.0";
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean persist() {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String onRequest(OfflinePlayer player, String parameters) {
|
||||||
|
String[] parts = parameters.split("_");
|
||||||
|
// Record is used as the prefix for all record placeholders in case more placeholder types are added
|
||||||
|
if (parts.length < 7 || !parts[0].equals("record")) {
|
||||||
|
return parameters;
|
||||||
|
}
|
||||||
|
RecordType recordType = RecordType.getFromString(parts[1]);
|
||||||
|
ArenaGameMode gameMode = parseGameMode(parts[2]);
|
||||||
|
SelectionType selectionType = SelectionType.getFromString(parts[3]);
|
||||||
|
String identifier = parts[4];
|
||||||
|
int recordNumber = Integer.parseInt(parts[5]) - 1;
|
||||||
|
InfoType infoType = InfoType.getFromString(parts[6]);
|
||||||
|
|
||||||
|
if (recordType == null || infoType == null) {
|
||||||
|
return parameters;
|
||||||
|
}
|
||||||
|
|
||||||
|
String info = null;
|
||||||
|
if (selectionType == SelectionType.GROUP) {
|
||||||
|
info = getGroupRecord(arenaHandler, identifier, gameMode, recordType, recordNumber, infoType);
|
||||||
|
} else if (selectionType == SelectionType.ARENA) {
|
||||||
|
info = getArenaRecord(arenaHandler, identifier, gameMode, recordType, recordNumber, infoType);
|
||||||
|
}
|
||||||
|
|
||||||
|
return Objects.requireNonNullElse(info, parameters);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parses the game-mode specified in the given string
|
||||||
|
*
|
||||||
|
* @param gameMode <p>The game-mode to parse</p>
|
||||||
|
* @return <p>The parsed game-mode</p>
|
||||||
|
*/
|
||||||
|
protected abstract @NotNull ArenaGameMode parseGameMode(@NotNull String gameMode);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Clears all record caches
|
||||||
|
*/
|
||||||
|
public void clearCaches() {
|
||||||
|
this.groupRecordDeathsCache.clear();
|
||||||
|
this.groupRecordTimeCache.clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets a piece of record information from an arena group
|
||||||
|
*
|
||||||
|
* @param arenaHandler <p>The arena handler to get the group from</p>
|
||||||
|
* @param identifier <p>The identifier (name/uuid) selecting the group</p>
|
||||||
|
* @param gameMode <p>The game-mode to get a record for</p>
|
||||||
|
* @param recordType <p>The type of record to get</p>
|
||||||
|
* @param recordNumber <p>The placing of the record to get (1st place, 2nd place, etc.)</p>
|
||||||
|
* @param infoType <p>The type of info (player, value, combined) to get</p>
|
||||||
|
* @return <p>The selected information about the record, or null if not found</p>
|
||||||
|
*/
|
||||||
|
private @Nullable String getGroupRecord(@NotNull ArenaHandler<?, ?> arenaHandler, @NotNull String identifier,
|
||||||
|
@NotNull ArenaGameMode gameMode, @NotNull RecordType recordType,
|
||||||
|
int recordNumber, @NotNull InfoType infoType) {
|
||||||
|
// Allow specifying the group UUID or the arena name
|
||||||
|
ArenaGroup<?, ?> group;
|
||||||
|
try {
|
||||||
|
group = arenaHandler.getGroup(UUID.fromString(identifier));
|
||||||
|
} catch (IllegalArgumentException exception) {
|
||||||
|
group = arenaHandler.getGroup(identifier);
|
||||||
|
}
|
||||||
|
if (group == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
ArenaRecord<?> record;
|
||||||
|
if (recordType == RecordType.DEATHS) {
|
||||||
|
record = getGroupDeathRecord(group, gameMode, recordNumber, arenaHandler);
|
||||||
|
} else {
|
||||||
|
record = getGroupTimeRecord(group, gameMode, recordNumber, arenaHandler);
|
||||||
|
}
|
||||||
|
|
||||||
|
// If a record number is not found, leave it blank, so it looks neat
|
||||||
|
if (record == null) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
return getRecordData(infoType, record);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets a time record from a group, using the cache if possible
|
||||||
|
*
|
||||||
|
* @param group <p>The group to get the record from</p>
|
||||||
|
* @param gameMode <p>The game-mode to get the record from</p>
|
||||||
|
* @param recordNumber <p>The placing of the record to get (1st place, 2nd place, etc.)</p>
|
||||||
|
* @param arenaHandler <p>The handler to get arenas from</p>
|
||||||
|
* @return <p>The record, or null if not found</p>
|
||||||
|
*/
|
||||||
|
private @Nullable ArenaRecord<?> getGroupTimeRecord(@NotNull ArenaGroup<?, ?> group,
|
||||||
|
@NotNull ArenaGameMode gameMode, int recordNumber,
|
||||||
|
@NotNull ArenaHandler<?, ?> arenaHandler) {
|
||||||
|
return getCachedGroupRecord(group, gameMode, RecordType.TIME, recordNumber, groupRecordTimeCache,
|
||||||
|
() -> GroupRecordHelper.getCombinedTime(group, gameMode, arenaHandler));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets a death record from a group, using the cache if possible
|
||||||
|
*
|
||||||
|
* @param group <p>The group to get the record from</p>
|
||||||
|
* @param gameMode <p>The game-mode to get the record from</p>
|
||||||
|
* @param recordNumber <p>The placing of the record to get (1st place, 2nd place, etc.)</p>
|
||||||
|
* @param arenaHandler <p>The handler to get arenas from</p>
|
||||||
|
* @return <p>The record, or null if not found</p>
|
||||||
|
*/
|
||||||
|
private @Nullable ArenaRecord<?> getGroupDeathRecord(@NotNull ArenaGroup<?, ?> group,
|
||||||
|
@NotNull ArenaGameMode gameMode, int recordNumber,
|
||||||
|
@NotNull ArenaHandler<?, ?> arenaHandler) {
|
||||||
|
return getCachedGroupRecord(group, gameMode, RecordType.DEATHS, recordNumber, groupRecordDeathsCache,
|
||||||
|
() -> GroupRecordHelper.getCombinedDeaths(group, gameMode, arenaHandler));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets a group record, fetching from a cache if possible
|
||||||
|
*
|
||||||
|
* @param group <p>The group to get the record for</p>
|
||||||
|
* @param gameMode <p>The game-mode to get the record for</p>
|
||||||
|
* @param recordType <p>The type of record to get</p>
|
||||||
|
* @param recordNumber <p>The placing of the record to get (1st place, 2nd place, etc.)</p>
|
||||||
|
* @param caches <p>The caches to use for looking for and saving the record</p>
|
||||||
|
* @param recordProvider <p>The provider of records if the cache cannot provide the record</p>
|
||||||
|
* @param <K> <p>The type of the provided records</p>
|
||||||
|
* @return <p>The specified record, or null if not found</p>
|
||||||
|
*/
|
||||||
|
private <K extends Comparable<K>> @Nullable ArenaRecord<?> getCachedGroupRecord(@NotNull ArenaGroup<?, ?> group,
|
||||||
|
@NotNull ArenaGameMode gameMode,
|
||||||
|
@NotNull RecordType recordType,
|
||||||
|
int recordNumber,
|
||||||
|
@NotNull Map<UUID, Set<GroupRecordCache<K>>> caches,
|
||||||
|
@NotNull Supplier<Set<ArenaRecord<K>>> recordProvider) {
|
||||||
|
UUID groupId = group.getGroupId();
|
||||||
|
if (!caches.containsKey(groupId)) {
|
||||||
|
caches.put(groupId, new HashSet<>());
|
||||||
|
}
|
||||||
|
|
||||||
|
Set<GroupRecordCache<K>> existingCaches = caches.get(groupId);
|
||||||
|
Set<GroupRecordCache<K>> expired = new HashSet<>();
|
||||||
|
Set<ArenaRecord<K>> cachedRecords = null;
|
||||||
|
|
||||||
|
for (GroupRecordCache<K> cache : existingCaches) {
|
||||||
|
// Expire caches after 30 seconds
|
||||||
|
if (System.currentTimeMillis() - cache.createdTime() > 30000) {
|
||||||
|
expired.add(cache);
|
||||||
|
}
|
||||||
|
// If of the correct type, and not expired, use the cache
|
||||||
|
if (cache.gameMode() == gameMode && cache.recordType() == recordType) {
|
||||||
|
cachedRecords = cache.records();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
existingCaches.removeAll(expired);
|
||||||
|
|
||||||
|
// If not found, generate and cache the specified record
|
||||||
|
if (cachedRecords == null) {
|
||||||
|
cachedRecords = recordProvider.get();
|
||||||
|
existingCaches.add(new GroupRecordCache<>(gameMode, recordType, cachedRecords, System.currentTimeMillis()));
|
||||||
|
}
|
||||||
|
return getRecord(cachedRecords, recordNumber);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets a piece of record information from an arena
|
||||||
|
*
|
||||||
|
* @param arenaHandler <p>The arena handler to get the arena from</p>
|
||||||
|
* @param identifier <p>The identifier (name/uuid) selecting the arena</p>
|
||||||
|
* @param gameMode <p>The game-mode to get a record for</p>
|
||||||
|
* @param recordType <p>The type of record to get</p>
|
||||||
|
* @param recordNumber <p>The placing of the record to get (1st place, 2nd place, etc.)</p>
|
||||||
|
* @param infoType <p>The type of info (player, value, combined) to get</p>
|
||||||
|
* @return <p>The selected information about the record, or null if not found</p>
|
||||||
|
*/
|
||||||
|
private @Nullable String getArenaRecord(@NotNull ArenaHandler<?, ?> arenaHandler, @NotNull String identifier,
|
||||||
|
@NotNull ArenaGameMode gameMode, @NotNull RecordType recordType,
|
||||||
|
int recordNumber, @NotNull InfoType infoType) {
|
||||||
|
// Allow specifying the arena UUID or the arena name
|
||||||
|
Arena arena;
|
||||||
|
try {
|
||||||
|
arena = arenaHandler.getArena(UUID.fromString(identifier));
|
||||||
|
} catch (IllegalArgumentException exception) {
|
||||||
|
arena = arenaHandler.getArena(identifier);
|
||||||
|
}
|
||||||
|
if (arena == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
@NotNull Map<ArenaGameMode, ArenaRecordsRegistry> registries = arena.getData().getRecordRegistries();
|
||||||
|
ArenaRecordsRegistry recordsRegistry = registries.get(gameMode);
|
||||||
|
|
||||||
|
ArenaRecord<?> record = getRecord(recordsRegistry, recordType, recordNumber);
|
||||||
|
|
||||||
|
// If a record number is not found, leave it blank, so it looks neat
|
||||||
|
if (record == null) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
return getRecordData(infoType, record);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the specified record
|
||||||
|
*
|
||||||
|
* @param recordsRegistry <p>The records registry to get the record from</p>
|
||||||
|
* @param recordType <p>The type of record to get</p>
|
||||||
|
* @param recordNumber <p>The placing of the record to get (1st place, 2nd place, etc.)</p>
|
||||||
|
* @return <p>The record, or null if not found</p>
|
||||||
|
*/
|
||||||
|
private @Nullable ArenaRecord<?> getRecord(@NotNull ArenaRecordsRegistry recordsRegistry,
|
||||||
|
@NotNull RecordType recordType, int recordNumber) {
|
||||||
|
return switch (recordType) {
|
||||||
|
case TIME -> getRecord(new HashSet<>(recordsRegistry.getShortestTimeMilliSecondsRecords()), recordNumber);
|
||||||
|
case DEATHS -> getRecord(new HashSet<>(recordsRegistry.getLeastDeathsRecords()), recordNumber);
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the record at the given index
|
||||||
|
*
|
||||||
|
* @param records <p>The records to search through</p>
|
||||||
|
* @param index <p>The index of the record to get</p>
|
||||||
|
* @param <K> <p>The type of record in the record list</p>
|
||||||
|
* @return <p>The record, or null if index is out of bounds</p>
|
||||||
|
*/
|
||||||
|
private <K extends Comparable<K>> @Nullable ArenaRecord<K> getRecord(Set<ArenaRecord<K>> records, int index) {
|
||||||
|
List<ArenaRecord<K>> sorted = getSortedRecords(records);
|
||||||
|
if (index < sorted.size() && index >= 0) {
|
||||||
|
return sorted.get(index);
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets a piece of data from a record as a string
|
||||||
|
*
|
||||||
|
* @param infoType <p>The type of info to get data for</p>
|
||||||
|
* @param arenaRecord <p>The record to get the data from</p>
|
||||||
|
* @return <p>The requested data as a string, or null</p>
|
||||||
|
*/
|
||||||
|
private String getRecordData(@NotNull InfoType infoType, @NotNull ArenaRecord<?> arenaRecord) {
|
||||||
|
return switch (infoType) {
|
||||||
|
case PLAYER -> getPlayerName(arenaRecord.getUserId());
|
||||||
|
case VALUE -> arenaRecord.getRecord().toString();
|
||||||
|
case COMBINED -> getPlayerName(arenaRecord.getUserId()) + ": " + arenaRecord.getRecord().toString();
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the given set of records as a sorted list
|
||||||
|
*
|
||||||
|
* @param recordSet <p>The set of records to sort</p>
|
||||||
|
* @param <K> <p>The type of the records</p>
|
||||||
|
* @return <p>The sorted records</p>
|
||||||
|
*/
|
||||||
|
private <K extends Comparable<K>> @NotNull List<ArenaRecord<K>> getSortedRecords(
|
||||||
|
@NotNull Set<ArenaRecord<K>> recordSet) {
|
||||||
|
List<ArenaRecord<K>> records = new ArrayList<>(recordSet);
|
||||||
|
Collections.sort(records);
|
||||||
|
return records;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the name of a player, given the player's UUID
|
||||||
|
*
|
||||||
|
* @param playerId <p>The id of the player to get the name for</p>
|
||||||
|
* @return <p>The name of the player, or a string representation of the UUID if not found</p>
|
||||||
|
*/
|
||||||
|
private String getPlayerName(@NotNull UUID playerId) {
|
||||||
|
return Bukkit.getOfflinePlayer(playerId).getName();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -1,10 +1,9 @@
|
|||||||
package net.knarcraft.minigames.util;
|
package net.knarcraft.minigames.util;
|
||||||
|
|
||||||
import net.knarcraft.minigames.MiniGames;
|
import net.knarcraft.minigames.arena.Arena;
|
||||||
import net.knarcraft.minigames.arena.dropper.DropperArena;
|
import net.knarcraft.minigames.arena.ArenaGameMode;
|
||||||
import net.knarcraft.minigames.arena.dropper.DropperArenaGameMode;
|
import net.knarcraft.minigames.arena.ArenaGroup;
|
||||||
import net.knarcraft.minigames.arena.dropper.DropperArenaGroup;
|
import net.knarcraft.minigames.arena.ArenaHandler;
|
||||||
import net.knarcraft.minigames.arena.dropper.DropperArenaHandler;
|
|
||||||
import net.knarcraft.minigames.arena.record.ArenaRecord;
|
import net.knarcraft.minigames.arena.record.ArenaRecord;
|
||||||
import net.knarcraft.minigames.arena.record.SummableArenaRecord;
|
import net.knarcraft.minigames.arena.record.SummableArenaRecord;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
@ -19,9 +18,9 @@ import java.util.function.BiFunction;
|
|||||||
/**
|
/**
|
||||||
* A helper class for getting combined record data for a dropper group
|
* A helper class for getting combined record data for a dropper group
|
||||||
*/
|
*/
|
||||||
public final class DropperGroupRecordHelper {
|
public final class GroupRecordHelper {
|
||||||
|
|
||||||
private DropperGroupRecordHelper() {
|
private GroupRecordHelper() {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -30,15 +29,17 @@ public final class DropperGroupRecordHelper {
|
|||||||
*
|
*
|
||||||
* @param group <p>The group to get records from</p>
|
* @param group <p>The group to get records from</p>
|
||||||
* @param gameMode <p>The game-mode to get records for</p>
|
* @param gameMode <p>The game-mode to get records for</p>
|
||||||
|
* @param arenaHandler <p>The handler to get arenas from</p>
|
||||||
* @return <p>The combined death records</p>
|
* @return <p>The combined death records</p>
|
||||||
*/
|
*/
|
||||||
public static @NotNull Set<ArenaRecord<Integer>> getCombinedDeaths(@NotNull DropperArenaGroup group,
|
public static @NotNull Set<ArenaRecord<Integer>> getCombinedDeaths(@NotNull ArenaGroup<?, ?> group,
|
||||||
@NotNull DropperArenaGameMode gameMode) {
|
@NotNull ArenaGameMode gameMode,
|
||||||
|
@NotNull ArenaHandler<?, ?> arenaHandler) {
|
||||||
Map<UUID, SummableArenaRecord<Integer>> records = new HashMap<>();
|
Map<UUID, SummableArenaRecord<Integer>> records = new HashMap<>();
|
||||||
@NotNull BiFunction<DropperArena, DropperArenaGameMode, Set<SummableArenaRecord<Integer>>> recordSupplier =
|
@NotNull BiFunction<Arena, ArenaGameMode, Set<SummableArenaRecord<Integer>>> recordSupplier =
|
||||||
(arena, aGameMode) -> arena.getData().getRecordRegistries().get(gameMode).getLeastDeathsRecords();
|
(arena, aGameMode) -> arena.getData().getRecordRegistries().get(gameMode).getLeastDeathsRecords();
|
||||||
|
|
||||||
return getCombined(group, gameMode, records, recordSupplier);
|
return getCombined(group, gameMode, records, recordSupplier, arenaHandler);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -46,15 +47,17 @@ public final class DropperGroupRecordHelper {
|
|||||||
*
|
*
|
||||||
* @param group <p>The group to get records from</p>
|
* @param group <p>The group to get records from</p>
|
||||||
* @param gameMode <p>The game-mode to get records for</p>
|
* @param gameMode <p>The game-mode to get records for</p>
|
||||||
|
* @param arenaHandler <p>The handler to get arenas from</p>
|
||||||
* @return <p>The combined least-time records</p>
|
* @return <p>The combined least-time records</p>
|
||||||
*/
|
*/
|
||||||
public static @NotNull Set<ArenaRecord<Long>> getCombinedTime(@NotNull DropperArenaGroup group,
|
public static @NotNull Set<ArenaRecord<Long>> getCombinedTime(@NotNull ArenaGroup<?, ?> group,
|
||||||
@NotNull DropperArenaGameMode gameMode) {
|
@NotNull ArenaGameMode gameMode,
|
||||||
|
@NotNull ArenaHandler<?, ?> arenaHandler) {
|
||||||
Map<UUID, SummableArenaRecord<Long>> records = new HashMap<>();
|
Map<UUID, SummableArenaRecord<Long>> records = new HashMap<>();
|
||||||
@NotNull BiFunction<DropperArena, DropperArenaGameMode, Set<SummableArenaRecord<Long>>> recordSupplier =
|
@NotNull BiFunction<Arena, ArenaGameMode, Set<SummableArenaRecord<Long>>> recordSupplier =
|
||||||
(arena, aGameMode) -> arena.getData().getRecordRegistries().get(gameMode).getShortestTimeMilliSecondsRecords();
|
(arena, aGameMode) -> arena.getData().getRecordRegistries().get(gameMode).getShortestTimeMilliSecondsRecords();
|
||||||
|
|
||||||
return getCombined(group, gameMode, records, recordSupplier);
|
return getCombined(group, gameMode, records, recordSupplier, arenaHandler);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -64,20 +67,20 @@ public final class DropperGroupRecordHelper {
|
|||||||
* @param gameMode <p>The game-mode to get records for</p>
|
* @param gameMode <p>The game-mode to get records for</p>
|
||||||
* @param records <p>The map to store the combined records to</p>
|
* @param records <p>The map to store the combined records to</p>
|
||||||
* @param recordSupplier <p>The function that supplies records of this type</p>
|
* @param recordSupplier <p>The function that supplies records of this type</p>
|
||||||
|
* @param arenaHandler <p>The handler to get arenas from</p>
|
||||||
* @param <K> <p>The type of the records to combine</p>
|
* @param <K> <p>The type of the records to combine</p>
|
||||||
* @return <p>The combined records</p>
|
* @return <p>The combined records</p>
|
||||||
*/
|
*/
|
||||||
private static <K extends Comparable<K>> @NotNull Set<ArenaRecord<K>> getCombined(@NotNull DropperArenaGroup group,
|
private static <K extends Comparable<K>> @NotNull Set<ArenaRecord<K>> getCombined(@NotNull ArenaGroup<?, ?> group,
|
||||||
@NotNull DropperArenaGameMode gameMode,
|
@NotNull ArenaGameMode gameMode,
|
||||||
@NotNull Map<UUID,
|
@NotNull Map<UUID,
|
||||||
SummableArenaRecord<K>> records,
|
SummableArenaRecord<K>> records,
|
||||||
@NotNull BiFunction<DropperArena,
|
@NotNull BiFunction<Arena,
|
||||||
DropperArenaGameMode,
|
ArenaGameMode,
|
||||||
Set<SummableArenaRecord<K>>> recordSupplier) {
|
Set<SummableArenaRecord<K>>> recordSupplier,
|
||||||
DropperArenaHandler arenaHandler = MiniGames.getInstance().getDropperArenaHandler();
|
@NotNull ArenaHandler<?, ?> arenaHandler) {
|
||||||
|
|
||||||
// Get all arenas in the group
|
// Get all arenas in the group
|
||||||
Set<DropperArena> arenas = getArenas(arenaHandler, group);
|
Set<Arena> arenas = getArenas(arenaHandler, group);
|
||||||
|
|
||||||
// Calculate the combined records
|
// Calculate the combined records
|
||||||
Map<UUID, Integer> recordsFound = new HashMap<>();
|
Map<UUID, Integer> recordsFound = new HashMap<>();
|
||||||
@ -113,12 +116,12 @@ public final class DropperGroupRecordHelper {
|
|||||||
* @param group <p>The group to get arenas for</p>
|
* @param group <p>The group to get arenas for</p>
|
||||||
* @return <p>The arenas found in the group</p>
|
* @return <p>The arenas found in the group</p>
|
||||||
*/
|
*/
|
||||||
private static @NotNull Set<DropperArena> getArenas(@NotNull DropperArenaHandler arenaHandler,
|
private static @NotNull Set<Arena> getArenas(@NotNull ArenaHandler<?, ?> arenaHandler,
|
||||||
@NotNull DropperArenaGroup group) {
|
@NotNull ArenaGroup<?, ?> group) {
|
||||||
// Get all arenas in the group
|
// Get all arenas in the group
|
||||||
Set<DropperArena> arenas = new HashSet<>();
|
Set<Arena> arenas = new HashSet<>();
|
||||||
for (UUID arenaId : group.getArenas()) {
|
for (UUID arenaId : group.getArenas()) {
|
||||||
DropperArena arena = arenaHandler.getArena(arenaId);
|
Arena arena = arenaHandler.getArena(arenaId);
|
||||||
if (arena != null) {
|
if (arena != null) {
|
||||||
arenas.add(arena);
|
arenas.add(arena);
|
||||||
}
|
}
|
||||||
@ -136,14 +139,14 @@ public final class DropperGroupRecordHelper {
|
|||||||
* @param recordSupplier <p>The function that supplies record data of this type</p>
|
* @param recordSupplier <p>The function that supplies record data of this type</p>
|
||||||
* @param <K> <p>The type of record to combine</p>
|
* @param <K> <p>The type of record to combine</p>
|
||||||
*/
|
*/
|
||||||
private static <K extends Comparable<K>> void combineRecords(@NotNull Set<DropperArena> arenas,
|
private static <K extends Comparable<K>> void combineRecords(@NotNull Set<Arena> arenas,
|
||||||
@NotNull DropperArenaGameMode gameMode,
|
@NotNull ArenaGameMode gameMode,
|
||||||
@NotNull Map<UUID,
|
@NotNull Map<UUID,
|
||||||
SummableArenaRecord<K>> combinedRecords,
|
SummableArenaRecord<K>> combinedRecords,
|
||||||
@NotNull Map<UUID, Integer> recordsFound,
|
@NotNull Map<UUID, Integer> recordsFound,
|
||||||
@NotNull BiFunction<DropperArena, DropperArenaGameMode,
|
@NotNull BiFunction<Arena, ArenaGameMode,
|
||||||
Set<SummableArenaRecord<K>>> recordSupplier) {
|
Set<SummableArenaRecord<K>>> recordSupplier) {
|
||||||
for (DropperArena arena : arenas) {
|
for (Arena arena : arenas) {
|
||||||
Set<SummableArenaRecord<K>> existingRecords = recordSupplier.apply(arena, gameMode);
|
Set<SummableArenaRecord<K>> existingRecords = recordSupplier.apply(arena, gameMode);
|
||||||
// For each arena's record registry, calculate the combined records
|
// For each arena's record registry, calculate the combined records
|
||||||
for (SummableArenaRecord<K> value : existingRecords) {
|
for (SummableArenaRecord<K> value : existingRecords) {
|
@ -1,4 +1,4 @@
|
|||||||
name: Dropper
|
name: MiniGames
|
||||||
version: '${project.version}'
|
version: '${project.version}'
|
||||||
main: net.knarcraft.minigames.MiniGames
|
main: net.knarcraft.minigames.MiniGames
|
||||||
api-version: 1.19
|
api-version: 1.19
|
||||||
|
Loading…
x
Reference in New Issue
Block a user