mirror of
https://github.com/Minestom/Minestom.git
synced 2025-01-13 19:51:27 +01:00
Improved thread safety over entities update
This commit is contained in:
parent
e0172022b2
commit
2e626f785e
@ -9,12 +9,16 @@ import fr.themode.minestom.utils.GroupedCollections;
|
|||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
import java.util.concurrent.CopyOnWriteArrayList;
|
||||||
import java.util.concurrent.CopyOnWriteArraySet;
|
import java.util.concurrent.CopyOnWriteArraySet;
|
||||||
|
|
||||||
public class Instance {
|
public class Instance {
|
||||||
|
|
||||||
private UUID uniqueId;
|
private UUID uniqueId;
|
||||||
|
|
||||||
|
private GroupedCollections<EntityCreature> creatures = new GroupedCollections<>(new CopyOnWriteArrayList());
|
||||||
|
private GroupedCollections<Player> players = new GroupedCollections<>(new CopyOnWriteArrayList());
|
||||||
|
|
||||||
private Set<Chunk> chunksSet = new CopyOnWriteArraySet<>();
|
private Set<Chunk> chunksSet = new CopyOnWriteArraySet<>();
|
||||||
|
|
||||||
public Instance(UUID uniqueId) {
|
public Instance(UUID uniqueId) {
|
||||||
@ -87,18 +91,10 @@ public class Instance {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public GroupedCollections<EntityCreature> getCreatures() {
|
public GroupedCollections<EntityCreature> getCreatures() {
|
||||||
GroupedCollections<EntityCreature> creatures = new GroupedCollections();
|
|
||||||
for (Chunk chunk : getChunks()) {
|
|
||||||
creatures.addCollection(chunk.creatures);
|
|
||||||
}
|
|
||||||
return creatures;
|
return creatures;
|
||||||
}
|
}
|
||||||
|
|
||||||
public GroupedCollections<Player> getPlayers() {
|
public GroupedCollections<Player> getPlayers() {
|
||||||
GroupedCollections<Player> players = new GroupedCollections();
|
|
||||||
for (Chunk chunk : getChunks()) {
|
|
||||||
players.addCollection(chunk.players);
|
|
||||||
}
|
|
||||||
return players;
|
return players;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -108,6 +104,8 @@ public class Instance {
|
|||||||
|
|
||||||
private Chunk createChunk(Biome biome, int chunkX, int chunkZ) {
|
private Chunk createChunk(Biome biome, int chunkX, int chunkZ) {
|
||||||
Chunk chunk = new Chunk(biome, chunkX, chunkZ);
|
Chunk chunk = new Chunk(biome, chunkX, chunkZ);
|
||||||
|
this.creatures.addCollection(chunk.creatures);
|
||||||
|
this.players.addCollection(chunk.players);
|
||||||
this.chunksSet.add(chunk);
|
this.chunksSet.add(chunk);
|
||||||
return chunk;
|
return chunk;
|
||||||
}
|
}
|
||||||
|
@ -1,15 +1,14 @@
|
|||||||
package fr.themode.minestom.utils;
|
package fr.themode.minestom.utils;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
|
|
||||||
public class GroupedCollections<E> implements Iterable<E> {
|
public class GroupedCollections<E> implements Iterable<E> {
|
||||||
|
|
||||||
private ArrayList<Collection<E>> collections;
|
private Collection<Collection<E>> collections;
|
||||||
|
|
||||||
public GroupedCollections() {
|
public GroupedCollections(Collection collection) {
|
||||||
this.collections = new ArrayList<>();
|
this.collections = collection;
|
||||||
}
|
}
|
||||||
|
|
||||||
public int size() {
|
public int size() {
|
||||||
|
Loading…
Reference in New Issue
Block a user