diff --git a/src/main/java/org/spongepowered/api/world/WorldType.java b/src/main/java/org/spongepowered/api/world/WorldType.java index 3830d60447..f30e912d7c 100644 --- a/src/main/java/org/spongepowered/api/world/WorldType.java +++ b/src/main/java/org/spongepowered/api/world/WorldType.java @@ -24,238 +24,11 @@ */ package org.spongepowered.api.world; -import org.spongepowered.api.block.BlockType; -import org.spongepowered.api.block.BlockTypes; -import org.spongepowered.api.data.DataHolder; -import org.spongepowered.api.data.Keys; -import org.spongepowered.api.effect.potion.PotionEffectTypes; -import org.spongepowered.api.entity.Entity; -import org.spongepowered.api.entity.living.monster.boss.dragon.EnderDragon; -import org.spongepowered.api.entity.living.monster.piglin.Piglin; -import org.spongepowered.api.entity.living.monster.zombie.ZombifiedPiglin; -import org.spongepowered.api.entity.living.player.server.ServerPlayer; -import org.spongepowered.api.fluid.FluidTypes; -import org.spongepowered.api.item.ItemTypes; -import org.spongepowered.api.raid.Raid; import org.spongepowered.api.registry.DefaultedRegistryValue; import org.spongepowered.api.service.context.ContextSource; -import org.spongepowered.api.tag.Tag; -import org.spongepowered.api.util.MinecraftDayTime; -import org.spongepowered.api.util.Range; import org.spongepowered.api.util.annotation.CatalogedBy; -import org.spongepowered.api.world.portal.PortalType; -import org.spongepowered.api.world.portal.PortalTypes; -import org.spongepowered.api.world.server.ServerLocation; -import org.spongepowered.api.world.server.ServerWorld; - -import java.util.Optional; @CatalogedBy(WorldTypes.class) -public interface WorldType extends DefaultedRegistryValue, ContextSource, DataHolder { - - /** - * Gets the {@link WorldTypeEffect effect} that will play for a {@link ServerPlayer player} - * traveling in a {@link ServerWorld world} of this type. - * - * @return The effect - */ - default WorldTypeEffect effect() { - return this.require(Keys.WORLD_TYPE_EFFECT); - } - - /** - * Gets if {@link BlockTypes#WATER} will evaporate or {@link BlockTypes#WET_SPONGE} will - * become a {@link BlockTypes#SPONGE}. Additionally {@link FluidTypes#FLOWING_LAVA} will - * spread faster and thinner. - * - * @return True if scorching, false if not - */ - default boolean scorching() { - return this.require(Keys.SCORCHING); - } - - /** - * Gets if the world type is considered natural. - *
Natural worlds allow - * sleeping in beds and setting the respawn point, - * {@link PortalTypes#NETHER} portals to spawn {@link ZombifiedPiglin} and - * {@link ItemTypes#COMPASS} to work
- * - * @return True if natural, false if not - */ - default boolean natural() { - return this.require(Keys.NATURAL_WORLD_TYPE); - } - - /** - * Gets the coordinate scale applied to the coordinates of a {@link ServerPlayer player} - * traveling in a {@link ServerWorld world} of this type. - *- * Best seen when transferring that player from one world to another (as the player's - * coordinates will adjust to the scale of the destination world's). - * - * @return The scale - */ - default double coordinateMultiplier() { - return this.require(Keys.COORDINATE_MULTIPLIER); - } - - /** - * Gets if a {@link ServerWorld world} of this type will have global lighting, used - * in game mechanics such as {@link Entity} spawning. - *
In Vanilla, used in weather, lighting engine, and respawning mechanics
- * - * @return True if skylight, false if not - */ - default boolean hasSkylight() { - return this.require(Keys.HAS_SKYLIGHT); - } - - /** - * Gets if a {@link ServerWorld world} of this type is generated with a ceiling at some - * pre-determined y value composed of {@link BlockTypes#BEDROCK}. Most notable usage of - * this is for the {@link WorldTypes#THE_NETHER type}. - * - *In Vanilla, used in weather, map items, and respawning mechanics
- * - * @return True if a ceiling is present, false if not - */ - default boolean hasCeiling() { - return this.require(Keys.HAS_CEILING); - } - - /** - * Gets the amount of lighting a client will play as an effect while traversing a - * {@link ServerWorld world} of this type. - * - *In Vanilla, the value will be between {@code 0.0} and {@code 1.0}
- * - * @return The lighting value - */ - default float ambientLighting() { - return this.require(Keys.AMBIENT_LIGHTING); - } - - /** - * Gets if a {@link ServerWorld world} of this type will be fixed at a particular - * {@link MinecraftDayTime time} or flow naturally - * - * @return If present, a fixed day time. Otherwise, free flowing time - */ - default OptionalWhen bed usage is not allowed beds will instead explode.
- * - * @return True if beds are usable, false if not - */ - default boolean bedsUsable() { - return this.require(Keys.BEDS_USABLE); - } - - /** - * Gets if {@link ServerPlayer players} can charge and use {@link BlockTypes#RESPAWN_ANCHOR} - * while existing in a {@link ServerWorld world} of this type. - * - * @return True if respawn anchors are usable, false if not - */ - default boolean respawnAnchorsUsable() { - return this.require(Keys.RESPAWN_ANCHOR_USABLE); - } - - /** - * Gets if {@link ServerPlayer players} who have the {@link PotionEffectTypes#BAD_OMEN} effect - * could cause a {@link Raid} while existing in a {@link ServerWorld world} of this type. - * - * @return True if bad omens could case a raid, false if not - */ - default boolean hasRaids() { - return this.require(Keys.HAS_RAIDS); - } - - /** - * Gets the minimum {@code Y} value that blocks can exist within a world of this type. - *In vanilla this is a multiple of 16 between -2032 and 2016
- * - * @return The minimum height - */ - default int floor() { - return this.require(Keys.WORLD_FLOOR); - } - - /** - * Gets the total height in which blocks can exist within a world of this type. - *In vanilla this is a multiple of 16 between 16 and 4064. {@link #floor()} + {@link #height()} may not be more than 2032
- * - * @return The maximum height - */ - default int height() { - return this.require(Keys.WORLD_HEIGHT); - } - - /** - * Gets the maximum height that teleportation logic performed via - * {@link ItemTypes#CHORUS_FRUIT} or {@link PortalType portal types} may use to determine - * the exit {@link ServerLocation location} of the teleport or the generation of a portal - * itself. - * - * @return The logical height - */ - default int logicalHeight() { - return this.require(Keys.WORLD_LOGICAL_HEIGHT); - } - - /** - * Gets the tag for blocks that burn indefinitely in a world of this type. - * - * @return The infiniburn tag - */ - default TagNatural worlds allow + * sleeping in beds and setting the respawn point, + * {@link PortalTypes#NETHER} portals to spawn {@link ZombifiedPiglin} and + * {@link ItemTypes#COMPASS} to work
+ * + * @return True if natural, false if not + */ + default boolean natural() { + return this.require(Keys.NATURAL_WORLD_TYPE); + } + + /** + * Gets the coordinate scale applied to the coordinates of a {@link ServerPlayer player} + * traveling in a {@link ServerWorld world} of this type. + *+ * Best seen when transferring that player from one world to another (as the player's + * coordinates will adjust to the scale of the destination world's). + * + * @return The scale + */ + default double coordinateMultiplier() { + return this.require(Keys.COORDINATE_MULTIPLIER); + } + + /** + * Gets if a {@link ServerWorld world} of this type will have global lighting, used + * in game mechanics such as {@link Entity} spawning. + *
In Vanilla, used in weather, lighting engine, and respawning mechanics
+ * + * @return True if skylight, false if not + */ + default boolean hasSkylight() { + return this.require(Keys.HAS_SKYLIGHT); + } + + /** + * Gets if a {@link ServerWorld world} of this type is generated with a ceiling at some + * pre-determined y value composed of {@link BlockTypes#BEDROCK}. Most notable usage of + * this is for the {@link WorldTypes#THE_NETHER type}. + * + *In Vanilla, used in weather, map items, and respawning mechanics
+ * + * @return True if a ceiling is present, false if not + */ + default boolean hasCeiling() { + return this.require(Keys.HAS_CEILING); + } + + /** + * Gets the amount of lighting a client will play as an effect while traversing a + * {@link ServerWorld world} of this type. + * + *In Vanilla, the value will be between {@code 0.0} and {@code 1.0}
+ * + * @return The lighting value + */ + default float ambientLighting() { + return this.require(Keys.AMBIENT_LIGHTING); + } + + /** + * Gets if a {@link ServerWorld world} of this type will be fixed at a particular + * {@link MinecraftDayTime time} or flow naturally + * + * @return If present, a fixed day time. Otherwise, free flowing time + */ + default OptionalWhen bed usage is not allowed beds will instead explode.
+ * + * @return True if beds are usable, false if not + */ + default boolean bedsUsable() { + return this.require(Keys.BEDS_USABLE); + } + + /** + * Gets if {@link ServerPlayer players} can charge and use {@link BlockTypes#RESPAWN_ANCHOR} + * while existing in a {@link ServerWorld world} of this type. + * + * @return True if respawn anchors are usable, false if not + */ + default boolean respawnAnchorsUsable() { + return this.require(Keys.RESPAWN_ANCHOR_USABLE); + } + + /** + * Gets if {@link ServerPlayer players} who have the {@link PotionEffectTypes#BAD_OMEN} effect + * could cause a {@link Raid} while existing in a {@link ServerWorld world} of this type. + * + * @return True if bad omens could case a raid, false if not + */ + default boolean hasRaids() { + return this.require(Keys.HAS_RAIDS); + } + + /** + * Gets the minimum {@code Y} value that blocks can exist within a world of this type. + *In vanilla this is a multiple of 16 between -2032 and 2016
+ * + * @return The minimum height + */ + default int floor() { + return this.require(Keys.WORLD_FLOOR); + } + + /** + * Gets the total height in which blocks can exist within a world of this type. + *In vanilla this is a multiple of 16 between 16 and 4064. {@link #floor()} + {@link #height()} may not be more than 2032
+ * + * @return The maximum height + */ + default int height() { + return this.require(Keys.WORLD_HEIGHT); + } + + /** + * Gets the maximum height that teleportation logic performed via + * {@link ItemTypes#CHORUS_FRUIT} or {@link PortalType portal types} may use to determine + * the exit {@link ServerLocation location} of the teleport or the generation of a portal + * itself. + * + * @return The logical height + */ + default int logicalHeight() { + return this.require(Keys.WORLD_LOGICAL_HEIGHT); + } + + /** + * Gets the tag for blocks that burn indefinitely in a world of this type. + * + * @return The infiniburn tag + */ + default TagThe given data must be equivalent to a data-pack for world-templates (dimension)
+ * + * @param pack The data + * @return This builder, for chaining + */ + Builder fromDataPack(DataView pack) throws IOException; + + Builder from(WorldType type); + + Builder pack(DataPack