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

net.time4j.WallTimeOperator Maven / Gradle / Ivy

There is a newer version: 4.38
Show newest version
/*
 * -----------------------------------------------------------------------
 * Copyright © 2013-2015 Meno Hochschild, 
 * -----------------------------------------------------------------------
 * This file (WallTimeOperator.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;

import net.time4j.engine.ChronoOperator;


/**
 * 

Spezialoperator zum Navigieren zu bestimmten Uhrzeiten.

* * @author Meno Hochschild * @doctags.concurrency {immutable} */ final class WallTimeOperator extends ElementOperator { //~ Instanzvariablen -------------------------------------------------- private final int mode; private final PlainTime value; //~ Konstruktoren ----------------------------------------------------- /** *

Konstruiert eine neue Instanz.

* * @param mode navigation mode * @param value target value of navigation */ WallTimeOperator( final int mode, final PlainTime value ) { super(PlainTime.COMPONENT, mode); if (value == null) { throw new NullPointerException("Missing target wall time."); } this.mode = mode; this.value = value; } //~ Methoden ---------------------------------------------------------- @Override public PlainTimestamp apply(PlainTimestamp entity) { PlainTime oldTime = entity.getWallTime(); if (this.value.isSimultaneous(oldTime)) { return this.handleSameTimes(entity); } else if (this.value.getHour() == 24) { return this.handleMidnight24(entity); } else if (this.value.isAfter(oldTime)) { return this.handleLater(entity); } else { return this.handleEarlier(entity); } } @Override ChronoOperator onTimestamp() { return this; } private PlainTimestamp handleSameTimes(PlainTimestamp entity) { switch (this.mode) { case ElementOperator.OP_NAV_NEXT: return entity.plus(1, CalendarUnit.DAYS); case ElementOperator.OP_NAV_PREVIOUS: return entity.minus(1, CalendarUnit.DAYS); case ElementOperator.OP_NAV_NEXT_OR_SAME: case ElementOperator.OP_NAV_PREVIOUS_OR_SAME: return entity; default: throw new AssertionError("Unknown: " + this.mode); } } // entity is never on 24:00 hence following logic is to be applied private PlainTimestamp handleMidnight24(PlainTimestamp entity) { PlainDate date = entity.getCalendarDate(); switch (this.mode) { case ElementOperator.OP_NAV_NEXT: case ElementOperator.OP_NAV_NEXT_OR_SAME: return date.plus(1, CalendarUnit.DAYS).atStartOfDay(); case ElementOperator.OP_NAV_PREVIOUS: case ElementOperator.OP_NAV_PREVIOUS_OR_SAME: return date.atStartOfDay(); default: throw new AssertionError("Unknown: " + this.mode); } } private PlainTimestamp handleLater(PlainTimestamp entity) { switch (this.mode) { case ElementOperator.OP_NAV_NEXT: case ElementOperator.OP_NAV_NEXT_OR_SAME: return entity.with(this.value); case ElementOperator.OP_NAV_PREVIOUS: case ElementOperator.OP_NAV_PREVIOUS_OR_SAME: return entity.minus(1, CalendarUnit.DAYS).with(this.value); default: throw new AssertionError("Unknown: " + this.mode); } } private PlainTimestamp handleEarlier(PlainTimestamp entity) { switch (this.mode) { case ElementOperator.OP_NAV_NEXT: case ElementOperator.OP_NAV_NEXT_OR_SAME: return entity.plus(1, CalendarUnit.DAYS).with(this.value); case ElementOperator.OP_NAV_PREVIOUS: case ElementOperator.OP_NAV_PREVIOUS_OR_SAME: return entity.with(this.value); default: throw new AssertionError("Unknown: " + this.mode); } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy