org.spongepowered.api.util.MinecraftDayTime Maven / Gradle / Ivy
/*
* 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.util;
import org.spongepowered.api.Engine;
import org.spongepowered.api.Server;
import org.spongepowered.api.Sponge;
import java.time.Duration;
import java.time.temporal.ChronoUnit;
/**
* Represents an in-game time of day.
*/
public interface MinecraftDayTime {
/**
* A {@link MinecraftDayTime} that represents the Minecraft Epoch, which is
* 6:00am on Day 1.
*
* @return The {@link MinecraftDayTime}
*/
static MinecraftDayTime minecraftEpoch() {
return Sponge.game().factoryProvider().provide(MinecraftDayTime.Factory.class).epoch();
}
/**
* Creates a {@link MinecraftDayTime} based on the in-game time since the
* Minecraft epoch (6:00am on Day 1) for the given {@link Engine}.
*
* For example, if the supplied {@link Duration} was 1 day, 3 hours and
* 40 minutes, this would correspond to an in game time of 9:40am on Day 2.
*
*
* In the case where the supplied {@link Duration} does not completely
* align with a valid {@link MinecraftDayTime}, the nearest valid time will
* be returned.
*
* @param engine The {@link Engine} to use in calculating the day time
* @param duration The duration since the Minecraft Epoch.
* @return The {@link MinecraftDayTime}
* @throws IllegalArgumentException if the duration is negative
*/
static MinecraftDayTime ofInGameDuration(final Engine engine, final Duration duration) {
return Sponge.game().factoryProvider().provide(MinecraftDayTime.Factory.class).of(engine, duration);
}
/**
* Creates a {@link MinecraftDayTime} that represents the world time
* if the world has been running for the supplied {@link Duration} in
* real world time under idealised conditions for the given {@link Engine}.
*
* For example, if the supplied {@link Duration} was 1 day, 3 hours and
* 40 minutes and each Minecraft day lasts 20 minutes in the vanilla game,
* this would correspond to 6:00am on day 84 (1 day, 3 hours and 40 minutes
* is 1660 minutes, which is 83 20-minute chunks).
*
* In the case where the supplied {@link Duration} does not completely
* align with a valid {@link MinecraftDayTime}, the nearest valid time will
* be returned.
*
* @param engine The {@link Engine} to use in calculating the day time
* @param duration The wall-clock duration
* @return The {@link MinecraftDayTime}
* @throws IllegalArgumentException if the duration is negative
*/
static MinecraftDayTime ofWallClockDuration(final Engine engine, final Duration duration) {
return MinecraftDayTime.of(engine, Ticks.ofWallClockTime(engine, duration.toMillis(), ChronoUnit.MILLIS));
}
/**
* Creates a {@link MinecraftDayTime} that corresponds to the given
* units of in-game time.
*
* The parameters are subject to the following constraints:
*
*
* - {@code day} must be positive;
* - {@code hours} is in 24-hour time, and so must be between 0 and 23,
* except on day 1, where it must be between 6 and 23;
* and
* - {@code minutes} must be between 0 and 59.
*
*
* In the case where the supplied time does not completely align with a
* valid {@link MinecraftDayTime}, the nearest valid time will be returned.
*
*
* @param day The day to set. Must be positive.
* @param hours The hour to set in 24 hour time.
* @param minutes The minute to set.
* @return The {@link MinecraftDayTime}.
* @throws IllegalArgumentException if any of the listed constraints are
* violated.
*/
static MinecraftDayTime of(final int day, final int hours, final int minutes) {
return Sponge.game().factoryProvider().provide(MinecraftDayTime.Factory.class).of(day, hours, minutes);
}
/**
* Creates a {@link MinecraftDayTime} based on the number of {@link Ticks}
* elapsed since the Minecraft epoch (6:00am on Day 1) for the given
* {@link Engine}.
*
* For example, if the supplied {@link Ticks} was {@code Ticks.of(18000)}
* on the vanilla server, this would correspond to an in game time of
* 12:00am on Day 2 (18 hours after Minecraft epoch).
*
* @param engine The {@link Engine} to calculate the time for.
* @param ticks The {@link Ticks} since the Minecraft Epoch.
* @return The {@link MinecraftDayTime}
* @throws IllegalArgumentException if the tick count is negative or infinite
*/
static MinecraftDayTime of(final Engine engine, final Ticks ticks) {
return Sponge.game().factoryProvider().provide(MinecraftDayTime.Factory.class).of(engine, ticks);
}
/**
* The day this represents.
*
* @return The day
*/
int day();
/**
* The hour this represents.
*
* @return The hour.
*/
int hour();
/**
* The minute this represents.
*
* @return The minute.
*/
int minute();
/**
* Adds the time given by the provided {@link Ticks} object and returns a
* new object with the result.
*
* @param ticks The {@link Ticks} to add.
* @return A new {@link MinecraftDayTime}
* @throws IllegalArgumentException if the ticks is infinite
*/
MinecraftDayTime add(final Ticks ticks);
/**
* Adds the time given by the arguments and returns a new object with
* the result.
*
* @param days The number of days to advance
* @param hour The number of hours to advance (between 0 and 23)
* @param minute The number of minutes to advance (between 0 and 59)
* @return A new {@link MinecraftDayTime}
* @throws IllegalArgumentException if any of the arguments are negative.
*/
MinecraftDayTime add(int days, int hour, int minute);
/**
* Subtracts the time given by the provided {@link Ticks} object and
* returns a new object with the result.
*
* @param ticks The {@link Ticks} to subtract.
* @return A new {@link MinecraftDayTime}
* @throws IllegalArgumentException if ticks is infinite or the result would be a negative time.
*/
MinecraftDayTime subtract(final Ticks ticks);
/**
* Subtracts the time given by the arguments and returns a new object with
* the result.
*
* @param days The number of days to advance
* @param hour The number of hours to advance (between 0 and 23)
* @param minute The number of minutes to advance (between 0 and 59)
* @return A new {@link MinecraftDayTime}
* @throws IllegalArgumentException if any of the arguments are negative or
* the result would be a negative time.
*/
MinecraftDayTime subtract(int days, int hour, int minute);
/**
* Returns a {@link Duration} that represents in-game time from the
* minecraft epoch (so, for Day 2 at 12:30pm will return a duration of
* 1 day, 6 hours and 30 minutes).
*
* @return A {@link Duration}
*/
Duration asInGameDuration();
/**
* Returns a {@link Duration} that represents wall-clock time from the
* minecraft epoch for the given {@link Engine}. (For example, if this
* object represents Day 2 at 12:30pm, will return a {@link Duration} of
* 25 minutes and 25 seconds for a vanilla minecraft {@link Server}).
*
* @param engine The {@link Engine} to calculate the time for.
* @return A {@link Duration}
*/
default Duration asWallClockDuration(final Engine engine) {
return this.asTicks().expectedDuration(engine);
}
/**
* Returns the number of {@link Ticks} that have elapsed since the minecraft
* epoch.
*
* @return The epoch.
*/
Ticks asTicks();
/**
* Creates {@link MinecraftDayTime} objects.
*/
interface Factory {
/**
* @see MinecraftDayTime#minecraftEpoch()
*
* @return The {@link MinecraftDayTime}
*/
MinecraftDayTime epoch();
/**
* @see MinecraftDayTime#ofInGameDuration(Engine, Duration)
*
* @param engine The {@link Engine} to use in calculating the day time
* @param duration The duration since the Minecraft Epoch.
* @return The {@link MinecraftDayTime}
* @throws IllegalArgumentException if the duration is negative
*/
MinecraftDayTime of(Engine engine, Duration duration);
/**
* @see MinecraftDayTime#of(int, int, int)
*
* @param days The day to set. Must be positive.
* @param hours The hour to set in 24 hour time.
* @param minutes The minute to set.
* @return The {@link MinecraftDayTime}.
* @throws IllegalArgumentException if any of the listed constraints are
* violated.
*/
MinecraftDayTime of(int days, int hours, int minutes);
/**
* @see MinecraftDayTime#of(Engine, Ticks)
*
* @param engine The {@link Engine} to calculate the time for.
* @param ticks The {@link Ticks} since the Minecraft Epoch.
* @return The {@link MinecraftDayTime}
* @throws IllegalArgumentException if the tick count is negative or infinite
*/
MinecraftDayTime of(Engine engine, Ticks ticks);
}
}