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

net.time4j.engine.StartOfDay Maven / Gradle / Ivy

/*
 * -----------------------------------------------------------------------
 * Copyright © 2013-2015 Meno Hochschild, 
 * -----------------------------------------------------------------------
 * This file (StartOfDay.java) is part of project Time4J.
 *
 * Time4J is free software: You can redistribute it and/or modify it
 * under the terms of the GNU Lesser General Public License as published
 * by the Free Software Foundation, either version 2.1 of the License, or
 * (at your option) any later version.
 *
 * Time4J is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
 * GNU Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with Time4J. If not, see .
 * -----------------------------------------------------------------------
 */

package net.time4j.engine;

import net.time4j.tz.TZID;


/**
 * 

Defines the start of a given calendar day relative to midnight in seconds.

* * @author Meno Hochschild * @since 3.5/4.3 * @doctags.spec All subclasses must be immutable. */ /*[deutsch] *

Definiert den Start eines Kalendertages relativ zu Mitternacht in Sekunden.

* * @author Meno Hochschild * @since 3.5/4.3 * @doctags.spec All subclasses must be immutable. */ public abstract class StartOfDay { //~ Statische Felder/Initialisierungen -------------------------------- /** * Default start of calendar day at midnight. */ /*[deutsch] * Standardbeginn eines Kalendertages zu Mitternacht. */ public static final StartOfDay MIDNIGHT = new FixedStartOfDay(0); /** * Start of calendar day at 18:00 on previous day. */ /*[deutsch] * Beginn eines Kalendertages zu 18 Uhr am Vortag. */ public static final StartOfDay EVENING = new FixedStartOfDay(-21600); /** * Start of calendar day at 06:00 in the morning. */ /*[deutsch] * Beginn eines Kalendertages zu 6 Uhr morgens. */ public static final StartOfDay MORNING = new FixedStartOfDay(21600); //~ Konstruktoren ------------------------------------------------- /** *

For immutable subclasss only.

*/ /*[deutsch] *

Nur für Subklassen, die immutable sind.

*/ protected StartOfDay() { super(); } //~ Methoden ------------------------------------------------------ /** *

Liefert the start of given calendar day relative to midnight in fixed seconds.

* *

A negative deviation is explicitly allowed and refers to the previous calendar day.

* * @param deviation the deviation of start of day relative to midnight in seconds on the local timeline * @return start of day * @throws IllegalArgumentException if the argument is out of range {@code -43200 < deviation <= 43200} * @since 3.5/4.3 */ /*[deutsch] *

Definiert den Start des angegebenen Kalendertages relativ zu Mitternacht fest in Sekunden.

* *

Eine negative Abweichung ist ausdrücklich erlaubt und bezieht sich auf den Vortag.

* * @param deviation the deviation of start of day relative to midnight in seconds on the local timeline * @return start of day * @throws IllegalArgumentException if the argument is out of range {@code -43200 < deviation <= 43200} * @since 3.5/4.3 */ public static StartOfDay ofFixedDeviation(int deviation) { if (deviation == 0){ return MIDNIGHT; } else if (deviation == -21600) { return EVENING; } else if ((deviation > 43200) || (deviation <= -43200)) { throw new IllegalArgumentException("Start of day out of range: " + deviation); } return new FixedStartOfDay(deviation); } /** *

Yields the start of given calendar day relative to midnight in seconds.

* * @param calendarDay calendar day * @param tzid timezone identifier, helps to resolve an UTC-event like sunset to a local time * @return nominal deviation of start of day relative to midnight in seconds on the local timeline * @since 3.5/4.3 */ /*[deutsch] *

Definiert den Start des angegebenen Kalendertages relativ zu Mitternacht in Sekunden.

* * @param calendarDay calendar day * @param tzid timezone identifier, helps to resolve an UTC-event like sunset to a local time * @return nominal deviation of start of day relative to midnight in seconds on the local timeline * @since 3.5/4.3 */ public abstract int getDeviation( Calendrical calendarDay, TZID tzid ); //~ Innere Klassen ---------------------------------------------------- private static class FixedStartOfDay extends StartOfDay { //~ Instanzvariablen ------------------------------------------ private final int deviation; //~ Konstruktoren --------------------------------------------- private FixedStartOfDay(int deviation) { super(); this.deviation = deviation; } //~ Methoden -------------------------------------------------- @Override public int getDeviation( Calendrical calendarDay, TZID timezone ) { return this.deviation; } @Override public boolean equals(Object obj) { if (this == obj) { return true; } else if (obj instanceof FixedStartOfDay) { FixedStartOfDay that = (FixedStartOfDay) obj; return (this.deviation == that.deviation); } else { return false; } } @Override public int hashCode() { return this.deviation; } @Override public String toString() { return "FixedStartOfDay[" + this.deviation + "]"; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy