mirror of
				https://github.com/SunNetservers/MiniGames.git
				synced 2025-10-26 07:13:45 +01:00 
			
		
		
		
	Caches group records for 30 seconds
This commit is contained in:
		| @@ -19,12 +19,14 @@ import org.jetbrains.annotations.Nullable; | |||||||
|  |  | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| import java.util.Collections; | import java.util.Collections; | ||||||
|  | import java.util.HashMap; | ||||||
| import java.util.HashSet; | import java.util.HashSet; | ||||||
| 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.Set; | import java.util.Set; | ||||||
| import java.util.UUID; | import java.util.UUID; | ||||||
|  | import java.util.function.Supplier; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * A placeholder expansion for dropper record placeholders |  * A placeholder expansion for dropper record placeholders | ||||||
| @@ -32,9 +34,18 @@ import java.util.UUID; | |||||||
| public class DropperRecordExpansion extends PlaceholderExpansion { | public class DropperRecordExpansion extends PlaceholderExpansion { | ||||||
|  |  | ||||||
|     private final Dropper plugin; |     private final Dropper plugin; | ||||||
|  |     private final Map<UUID, Set<GroupRecordCache<Integer>>> groupRecordDeathsCache; | ||||||
|  |     private final Map<UUID, Set<GroupRecordCache<Long>>> groupRecordTimeCache; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Initializes a new record expansion | ||||||
|  |      * | ||||||
|  |      * @param plugin <p>A reference to the dropper plugin</p> | ||||||
|  |      */ | ||||||
|     public DropperRecordExpansion(Dropper plugin) { |     public DropperRecordExpansion(Dropper plugin) { | ||||||
|         this.plugin = plugin; |         this.plugin = plugin; | ||||||
|  |         this.groupRecordDeathsCache = new HashMap<>(); | ||||||
|  |         this.groupRecordTimeCache = new HashMap<>(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
| @@ -113,9 +124,9 @@ public class DropperRecordExpansion extends PlaceholderExpansion { | |||||||
|  |  | ||||||
|         ArenaRecord<?> record; |         ArenaRecord<?> record; | ||||||
|         if (recordType == RecordType.DEATHS) { |         if (recordType == RecordType.DEATHS) { | ||||||
|             record = getRecord(DropperGroupRecordHelper.getCombinedDeaths(group, gameMode), recordNumber); |             record = getDeathRecords(group, gameMode, recordNumber); | ||||||
|         } else { |         } else { | ||||||
|             record = getRecord(DropperGroupRecordHelper.getCombinedTime(group, gameMode), recordNumber); |             record = getTimeRecords(group, gameMode, recordNumber); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         // If a record number is not found, leave it blank, so it looks neat |         // If a record number is not found, leave it blank, so it looks neat | ||||||
| @@ -126,6 +137,64 @@ public class DropperRecordExpansion extends PlaceholderExpansion { | |||||||
|         return getRecordData(infoType, record); |         return getRecordData(infoType, record); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     private ArenaRecord<?> getTimeRecords(DropperArenaGroup group, ArenaGameMode gameMode, int recordNumber) { | ||||||
|  |         return getCachedGroupRecord(group, gameMode, RecordType.TIME, recordNumber, groupRecordTimeCache, | ||||||
|  |                 () -> DropperGroupRecordHelper.getCombinedTime(group, gameMode)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private ArenaRecord<?> getDeathRecords(DropperArenaGroup group, ArenaGameMode 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 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 a dropper arena |      * Gets a piece of record information from a dropper arena | ||||||
|      * |      * | ||||||
|   | |||||||
| @@ -0,0 +1,21 @@ | |||||||
|  | package net.knarcraft.dropper.placeholder; | ||||||
|  |  | ||||||
|  | import net.knarcraft.dropper.arena.record.ArenaRecord; | ||||||
|  | import net.knarcraft.dropper.placeholder.parsing.RecordType; | ||||||
|  | import net.knarcraft.dropper.property.ArenaGameMode; | ||||||
|  | import org.jetbrains.annotations.NotNull; | ||||||
|  |  | ||||||
|  | import java.util.Set; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * A record for keeping track of records for a dropper group | ||||||
|  |  * | ||||||
|  |  * @param gameMode    <p>The game-mode this cache is storing records for</p> | ||||||
|  |  * @param recordType  <p>The type of record stored</p> | ||||||
|  |  * @param records     <p>The stored records</p> | ||||||
|  |  * @param createdTime <p>The time this cache was created</p> | ||||||
|  |  */ | ||||||
|  | public record GroupRecordCache<K extends Comparable<K>>(@NotNull ArenaGameMode gameMode, @NotNull RecordType recordType, | ||||||
|  |                                                         @NotNull Set<ArenaRecord<K>> records, | ||||||
|  |                                                         @NotNull Long createdTime) { | ||||||
|  | } | ||||||
		Reference in New Issue
	
	Block a user
	