Fix chunk refresh being broken in unloaded chunk

This commit is contained in:
TheMode 2021-07-11 21:57:04 +02:00
parent 3031895ea8
commit b3f78b4706

View File

@ -41,7 +41,6 @@ import net.minestom.server.potion.TimedPotion;
import net.minestom.server.tag.Tag; import net.minestom.server.tag.Tag;
import net.minestom.server.tag.TagHandler; import net.minestom.server.tag.TagHandler;
import net.minestom.server.thread.ThreadProvider; import net.minestom.server.thread.ThreadProvider;
import net.minestom.server.utils.async.AsyncUtils;
import net.minestom.server.utils.chunk.ChunkUtils; import net.minestom.server.utils.chunk.ChunkUtils;
import net.minestom.server.utils.entity.EntityUtils; import net.minestom.server.utils.entity.EntityUtils;
import net.minestom.server.utils.player.PlayerUtils; import net.minestom.server.utils.player.PlayerUtils;
@ -847,7 +846,7 @@ public class Entity implements Viewable, Tickable, EventHandler<EntityEvent>, Da
* @param instance the new instance of the entity * @param instance the new instance of the entity
* @param spawnPosition the spawn position for the entity. * @param spawnPosition the spawn position for the entity.
* @return a {@link CompletableFuture} called once the entity's instance has been set, * @return a {@link CompletableFuture} called once the entity's instance has been set,
* this is due to chunks needing to load for players * this is due to chunks needing to load
* @throws IllegalStateException if {@code instance} has not been registered in {@link InstanceManager} * @throws IllegalStateException if {@code instance} has not been registered in {@link InstanceManager}
*/ */
public CompletableFuture<Void> setInstance(@NotNull Instance instance, @NotNull Pos spawnPosition) { public CompletableFuture<Void> setInstance(@NotNull Instance instance, @NotNull Pos spawnPosition) {
@ -859,11 +858,13 @@ public class Entity implements Viewable, Tickable, EventHandler<EntityEvent>, Da
this.position = spawnPosition; this.position = spawnPosition;
this.isActive = true; this.isActive = true;
this.instance = instance; this.instance = instance;
refreshCurrentChunk(instance.getChunkAt(position)); return instance.loadOptionalChunk(position).thenAccept(chunk -> {
instance.UNSAFE_addEntity(this); Check.notNull(chunk, "Entity has been placed in an unloaded chunk!");
spawn(); refreshCurrentChunk(chunk);
EventDispatcher.call(new EntitySpawnEvent(this, instance)); instance.UNSAFE_addEntity(this);
return AsyncUtils.NULL_FUTURE; spawn();
EventDispatcher.call(new EntitySpawnEvent(this, instance));
});
} }
public CompletableFuture<Void> setInstance(@NotNull Instance instance, @NotNull Point spawnPosition) { public CompletableFuture<Void> setInstance(@NotNull Instance instance, @NotNull Point spawnPosition) {
@ -875,7 +876,7 @@ public class Entity implements Viewable, Tickable, EventHandler<EntityEvent>, Da
* *
* @param instance the new instance of the entity * @param instance the new instance of the entity
* @return a {@link CompletableFuture} called once the entity's instance has been set, * @return a {@link CompletableFuture} called once the entity's instance has been set,
* this is due to chunks needing to load for players * this is due to chunks needing to load
* @throws NullPointerException if {@code instance} is null * @throws NullPointerException if {@code instance} is null
* @throws IllegalStateException if {@code instance} has not been registered in {@link InstanceManager} * @throws IllegalStateException if {@code instance} has not been registered in {@link InstanceManager}
*/ */