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.
*
* Specification:
* All subclasses must be immutable.
*
* @author Meno Hochschild
* @since 3.5/4.3
*/
/*[deutsch]
* Definiert den Start eines Kalendertages relativ zu Mitternacht in Sekunden.
*
* Specification:
* All subclasses must be immutable.
*
* @author Meno Hochschild
* @since 3.5/4.3
*/
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 + "]";
}
}
}