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

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); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy