All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.spongepowered.api.world.World Maven / Gradle / Ivy

There is a newer version: 13.0.0
Show newest version
/*
 * This file is part of SpongeAPI, licensed under the MIT License (MIT).
 *
 * Copyright (c) SpongePowered 
 * Copyright (c) contributors
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 */
package org.spongepowered.api.world;

import net.kyori.adventure.audience.Audience;
import net.kyori.adventure.audience.ForwardingAudience;
import org.spongepowered.api.Server;
import org.spongepowered.api.effect.Viewer;
import org.spongepowered.api.entity.Entity;
import org.spongepowered.api.entity.living.player.Player;
import org.spongepowered.api.registry.RegistryHolder;
import org.spongepowered.api.service.context.ContextSource;
import org.spongepowered.api.util.annotation.DoNotStore;
import org.spongepowered.api.world.chunk.WorldChunk;
import org.spongepowered.api.world.storage.WorldProperties;
import org.spongepowered.api.world.volume.archetype.ArchetypeVolumeCreator;
import org.spongepowered.api.world.volume.block.PhysicsAwareMutableBlockVolume;
import org.spongepowered.api.world.weather.WeatherUniverse;
import org.spongepowered.math.vector.Vector3d;
import org.spongepowered.math.vector.Vector3i;

import java.util.Collection;
import java.util.Objects;
import java.util.Optional;
import java.util.function.Predicate;

/**
 * A loaded Minecraft world.
 */
@DoNotStore
public interface World, L extends Location> extends
    ForwardingAudience,
    WorldLike,
    LocationCreator,
    PhysicsAwareMutableBlockVolume,
    ContextSource,
    Viewer,
    ArchetypeVolumeCreator,
    WeatherUniverse,
    RegistryHolder {

    /**
     * Gets the {@link WorldProperties properties}.
     *
     * @return The properties
     */
    WorldProperties properties();

    @Override
    @SuppressWarnings("unchecked")
    default W world() {
        return (W) this;
    }

    /**
     * Gets if this world is currently loaded.
     *
     * 

An assumption can be made that if this returns false, this is considered a stale object.

* * @return True if loaded, false if not */ boolean isLoaded(); /** * Gets an unmodifiable collection of {@link Player players} currently in this world. * * @return The players */ @Override Collection players(); @Override default Iterable audiences() { return this.players(); } default Optional closestPlayer(final Vector3i position, final double distance) { Objects.requireNonNull(position, "position"); return this.closestPlayer(position.x(), position.y(), position.z(), distance, player -> true); } default Optional closestPlayer(final Vector3i position, final double distance, final Predicate predicate) { Objects.requireNonNull(position, "position"); Objects.requireNonNull(predicate, "predicate"); return this.closestPlayer(position.x(), position.y(), position.z(), distance, predicate); } default Optional closestPlayer(final Entity entity, final double distance) { Objects.requireNonNull(entity, "entity"); final Vector3d position = entity.location().position(); return this.closestPlayer(position.floorX(), position.floorY(), position.floorZ(), distance, player -> true); } default Optional closestPlayer(final Entity entity, final double distance, final Predicate predicate) { Objects.requireNonNull(entity, "entity"); Objects.requireNonNull(predicate, "predicate"); final Vector3d position = entity.location().position(); return this.closestPlayer(position.floorX(), position.floorY(), position.floorZ(), distance, predicate); } default Optional closestPlayer(final int x, final int y, final int z, final double distance) { return this.closestPlayer(x, y, z, distance, player -> true); } Optional closestPlayer(int x, int y, int z, double distance, Predicate predicate); /** * {@inheritDoc} * This gets a guaranteed {@link WorldChunk} at the desired block position; however, * the {@link WorldChunk} instance may be {@link WorldChunk#isEmpty() empty}, and * likewise, may not be generated, valid, pre-existing. It is important to * check for these cases prior to attempting to modify the chunk. * *

Note that this is still different from {@link #chunk(Vector3i)} * due to it being a relative block position which can vary depending on * implementation and other mods installed.

* * @param blockPosition The block position to be transformed for relative chunk position * @return The available chunk at that position */ @Override WorldChunk chunkAtBlock(final Vector3i blockPosition); /** * {@inheritDoc} * This gets a guaranteed {@link WorldChunk} at the desired block position; however, * the {@link WorldChunk} instance may be {@link WorldChunk#isEmpty() empty}, and * likewise, may not be generated, valid, pre-existing. It is important to * check for these cases prior to attempting to modify the chunk. * *

Note that this is still different from {@link #chunk(Vector3i)} * due to the relative block position dictated by {@link Server#chunkLayout()}, * which can vary depending on implementation and other mods installed.

* * @param bx The block x coordinate * @param by The block y coordinate * @param bz The block z coordinate * @return The available chunk at that position */ @Override WorldChunk chunkAtBlock(int bx, int by, int bz); /** * {@inheritDoc} * This gets a guaranteed {@link WorldChunk} at the desired chunk position; however, * the {@link WorldChunk} instance may be {@link WorldChunk#isEmpty() empty}, and * likewise, may not be generated, valid, pre-existing. It is important to * check for these cases prior to attempting to modify the chunk. * * @param chunkPos The chunk position relative to the {@link Server#chunkLayout() chunk layout} * @return The available chunk at that position */ @Override default WorldChunk chunk(final Vector3i chunkPos) { Objects.requireNonNull(chunkPos, "chunkPos"); return this.chunk(chunkPos.x(), chunkPos.y(), chunkPos.z()); } /** * {@inheritDoc} * This gets a guaranteed {@link WorldChunk} at the desired chunk position; however, * the {@link WorldChunk} instance may be {@link WorldChunk#isEmpty() empty}, and * likewise, may not be generated, valid, pre-existing. It is important to * check for these cases prior to attempting to modify the chunk. * * @param cx The x chunk coordinate * @param cy The y coordinate * @param cz The z chunk coordinate * @return The available chunk at the chunk position */ @Override WorldChunk chunk(int cx, int cy, int cz); /** * Gets the chunk at the given chunk coordinate position if it exists or if * {@code shouldGenerate} is true and the chunk is generated. * * @param chunkPosition The position * @param shouldGenerate True to generate a new chunk * @return The loaded or generated chunk, if already generated */ default Optional loadChunk(final Vector3i chunkPosition, final boolean shouldGenerate) { Objects.requireNonNull(chunkPosition, "chunkPosition"); return this.loadChunk(chunkPosition.x(), chunkPosition.y(), chunkPosition.z(), shouldGenerate); } /** * Gets the chunk at the given chunk coordinate position if it exists or if * {@code shouldGenerate} is true and the chunk is generated. * *

In Vanilla, the y coordinate will always be 0.

* * @param cx The x coordinate * @param cy The y coordinate * @param cz The z coordinate * @param shouldGenerate True to generate a new chunk * @return The loaded or generated chunk, if already generated */ Optional loadChunk(int cx, int cy, int cz, boolean shouldGenerate); /** * Returns a Collection of all actively loaded chunks in this world. * *

The ordering of the returned chunks is undefined.

* * @return The loaded chunks */ Iterable loadedChunks(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy