geforkt von Mirrors/Paper
#644: Fix ChunkMapDistance#removeAllTicketsFor not propagating ticket level updates
Now call the method used in removeTicket for propagating the change, so that chunks are guaranteed to unload By: Spottedleaf <Spottedleaf@users.noreply.github.com>
Dieser Commit ist enthalten in:
Ursprung
9d7e810ee1
Commit
bb7a4a3aa5
@ -110,7 +110,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
public <T> void addTicket(TicketType<T> tickettype, ChunkCoordIntPair chunkcoordintpair, int i, T t0) {
|
public <T> void addTicket(TicketType<T> tickettype, ChunkCoordIntPair chunkcoordintpair, int i, T t0) {
|
||||||
@@ -251,6 +281,21 @@
|
@@ -251,6 +281,26 @@
|
||||||
return this.i.a();
|
return this.i.a();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -118,12 +118,17 @@
|
|||||||
+ public <T> void removeAllTicketsFor(TicketType<T> ticketType, int ticketLevel, T ticketIdentifier) {
|
+ public <T> void removeAllTicketsFor(TicketType<T> ticketType, int ticketLevel, T ticketIdentifier) {
|
||||||
+ Ticket<T> target = new Ticket<>(ticketType, ticketLevel, ticketIdentifier);
|
+ Ticket<T> target = new Ticket<>(ticketType, ticketLevel, ticketIdentifier);
|
||||||
+
|
+
|
||||||
+ for (java.util.Iterator<ArraySetSorted<Ticket<?>>> iterator = this.tickets.values().iterator(); iterator.hasNext();) {
|
+ for (java.util.Iterator<Entry<ArraySetSorted<Ticket<?>>>> iterator = this.tickets.long2ObjectEntrySet().fastIterator(); iterator.hasNext();) {
|
||||||
+ ArraySetSorted<Ticket<?>> tickets = iterator.next();
|
+ Entry<ArraySetSorted<Ticket<?>>> entry = iterator.next();
|
||||||
+ tickets.remove(target);
|
+ ArraySetSorted<Ticket<?>> tickets = entry.getValue();
|
||||||
|
+ if (tickets.remove(target)) {
|
||||||
|
+ // copied from removeTicket
|
||||||
|
+ this.e.b(entry.getLongKey(), a(tickets), false); // PAIL ticketLevelTracker // PAIL update // PAIL getLowestTicketLevel
|
||||||
+
|
+
|
||||||
+ if (tickets.isEmpty()) {
|
+ // can't use entry after it's removed
|
||||||
+ iterator.remove();
|
+ if (tickets.isEmpty()) {
|
||||||
|
+ iterator.remove();
|
||||||
|
+ }
|
||||||
+ }
|
+ }
|
||||||
+ }
|
+ }
|
||||||
+ }
|
+ }
|
||||||
@ -132,7 +137,7 @@
|
|||||||
class a extends ChunkMap {
|
class a extends ChunkMap {
|
||||||
|
|
||||||
public a() {
|
public a() {
|
||||||
@@ -331,13 +376,13 @@
|
@@ -331,13 +381,13 @@
|
||||||
Ticket<?> ticket = new Ticket<>(TicketType.PLAYER, ChunkMapDistance.b, new ChunkCoordIntPair(i));
|
Ticket<?> ticket = new Ticket<>(TicketType.PLAYER, ChunkMapDistance.b, new ChunkCoordIntPair(i));
|
||||||
|
|
||||||
if (flag1) {
|
if (flag1) {
|
||||||
@ -148,7 +153,7 @@
|
|||||||
}, i, false));
|
}, i, false));
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -346,7 +391,7 @@
|
@@ -346,7 +396,7 @@
|
||||||
return j;
|
return j;
|
||||||
}));
|
}));
|
||||||
} else {
|
} else {
|
||||||
|
Laden…
In neuem Issue referenzieren
Einen Benutzer sperren