mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-24 09:11:26 +01:00
Override some more methods in ExpiringMap to ensure fix
Seen some warnings of leak still being detected. I'm not sure what's missing, so I'm adding nearly everything.
This commit is contained in:
parent
ac9a6783a3
commit
c041a06904
@ -11,13 +11,15 @@ not run on every manipulation, and instead to run clean
|
|||||||
once per tick per expiring map.
|
once per tick per expiring map.
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/server/ExpiringMap.java b/src/main/java/net/minecraft/server/ExpiringMap.java
|
diff --git a/src/main/java/net/minecraft/server/ExpiringMap.java b/src/main/java/net/minecraft/server/ExpiringMap.java
|
||||||
index 4006f5a69c..3b90f6e6c3 100644
|
index 4006f5a69c..49021d29ee 100644
|
||||||
--- a/src/main/java/net/minecraft/server/ExpiringMap.java
|
--- a/src/main/java/net/minecraft/server/ExpiringMap.java
|
||||||
+++ b/src/main/java/net/minecraft/server/ExpiringMap.java
|
+++ b/src/main/java/net/minecraft/server/ExpiringMap.java
|
||||||
@@ -0,0 +0,0 @@ import it.unimi.dsi.fastutil.longs.Long2ObjectOpenHashMap;
|
@@ -0,0 +0,0 @@ import it.unimi.dsi.fastutil.longs.Long2ObjectOpenHashMap;
|
||||||
import it.unimi.dsi.fastutil.longs.Long2LongMap.Entry;
|
import it.unimi.dsi.fastutil.longs.Long2LongMap.Entry;
|
||||||
import it.unimi.dsi.fastutil.objects.ObjectIterator;
|
import it.unimi.dsi.fastutil.objects.ObjectIterator;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
+import java.util.function.BiFunction;
|
||||||
|
+import java.util.function.Function;
|
||||||
+import java.util.function.LongFunction;
|
+import java.util.function.LongFunction;
|
||||||
|
|
||||||
public class ExpiringMap<T> extends Long2ObjectOpenHashMap<T> {
|
public class ExpiringMap<T> extends Long2ObjectOpenHashMap<T> {
|
||||||
@ -46,10 +48,77 @@ index 4006f5a69c..3b90f6e6c3 100644
|
|||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ @Override
|
+ @Override
|
||||||
+ public synchronized T computeIfAbsent(long l, LongFunction<? extends T> longFunction) {
|
+ public T compute(long l, BiFunction<? super Long, ? super T, ? extends T> biFunction) {
|
||||||
|
+ setAccess(l);
|
||||||
|
+ return super.compute(l, biFunction);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public T putIfAbsent(long l, T t) {
|
||||||
|
+ setAccess(l);
|
||||||
|
+ return super.putIfAbsent(l, t);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public T computeIfPresent(long l, BiFunction<? super Long, ? super T, ? extends T> biFunction) {
|
||||||
|
+ setAccess(l);
|
||||||
|
+ return super.computeIfPresent(l, biFunction);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public T computeIfAbsent(long l, LongFunction<? extends T> longFunction) {
|
||||||
+ setAccess(l);
|
+ setAccess(l);
|
||||||
+ return super.computeIfAbsent(l, longFunction);
|
+ return super.computeIfAbsent(l, longFunction);
|
||||||
+ }
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public boolean replace(long l, T t, T v1) {
|
||||||
|
+ setAccess(l);
|
||||||
|
+ return super.replace(l, t, v1);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public T replace(long l, T t) {
|
||||||
|
+ setAccess(l);
|
||||||
|
+ return super.replace(l, t);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public T putIfAbsent(Long aLong, T t) {
|
||||||
|
+ setAccess(aLong);
|
||||||
|
+ return super.putIfAbsent(aLong, t);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public boolean replace(Long aLong, T t, T v1) {
|
||||||
|
+ setAccess(aLong);
|
||||||
|
+ return super.replace(aLong, t, v1);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public T replace(Long aLong, T t) {
|
||||||
|
+ setAccess(aLong);
|
||||||
|
+ return super.replace(aLong, t);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public T computeIfAbsent(Long aLong, Function<? super Long, ? extends T> function) {
|
||||||
|
+ setAccess(aLong);
|
||||||
|
+ return super.computeIfAbsent(aLong, function);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public T computeIfPresent(Long aLong, BiFunction<? super Long, ? super T, ? extends T> biFunction) {
|
||||||
|
+ setAccess(aLong);
|
||||||
|
+ return super.computeIfPresent(aLong, biFunction);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public T compute(Long aLong, BiFunction<? super Long, ? super T, ? extends T> biFunction) {
|
||||||
|
+ setAccess(aLong);
|
||||||
|
+ return compute(aLong, biFunction);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
+ private boolean registered = false;
|
+ private boolean registered = false;
|
||||||
+
|
+
|
||||||
+ // Break clean to its own method to be ticked
|
+ // Break clean to its own method to be ticked
|
||||||
|
Loading…
Reference in New Issue
Block a user