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

net.time4j.format.NumericalElement Maven / Gradle / Ivy

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

import net.time4j.engine.AttributeQuery;
import net.time4j.engine.ChronoDisplay;
import net.time4j.engine.ChronoElement;
import net.time4j.engine.ChronoEntity;


/**
 * 

A chronological element which allows a numerical representation.

* *

This element interface is only relevant for enum-like elements.

* * @param generic type of element values (will be adjusted to enum-supertype in next major release) * @author Meno Hochschild */ /*[deutsch] *

Repräsentiert ein chronologisches Element, das eine numerische * Darstellung erlaubt.

* *

Dieses Element-Interface ist nur für Enum-Elemente relevant.

* * @param generic type of element values (will be adjusted to enum-supertype in next major release) * @author Meno Hochschild */ public interface NumericalElement // TODO: change V to V extends Enum in next major release extends ChronoElement { //~ Methoden ---------------------------------------------------------- /** *

Translates given element value to a numerical integer.

* *

Will be called by the default methods {@link #parseFromInt(ChronoEntity, int)} * or {@link #printToInt(Object, ChronoDisplay, AttributeQuery)}. The integer {@code Integer.MIN_VALUE} * must be avoided in this conversion.

* * @param value value to be converted to int * @return Integer-representation of given value */ /*[deutsch] *

Ermittelt eine numerische Darstellung des angegebenen Werts.

* *

Wird von den Standardimplementierungen der Methoden {@link #parseFromInt(ChronoEntity, int)} * oder {@link #printToInt(Object, ChronoDisplay, AttributeQuery)} aufgerufen. Der Integerwert * {@code Integer.MIN_VALUE} muß vermieden werden.

* * @param value value to be converted to int * @return Integer-representation of given value */ int numerical(V value); /** *

Translates given element value to a numerical integer.

* *

Will be called when element values need to be printed as numbers. The default * implementation just delegates to {@link #numerical(Object) numerical(V)}.

* * @param value value to be converted to int * @param context the object to be formatted * @param attributes format attributes * @return Integer-representation of given value * @since 3.37/4.32 */ /*[deutsch] *

Ermittelt eine numerische Darstellung des angegebenen Werts.

* *

Wird aufgerufen, wenn Elementwerte als Zahlen ausgegeben werden müssen. Die * Standardimplementierung delegiert einfach an {@link #numerical(Object) numerical(V)}.

* * @param value value to be converted to int * @param context the object to be formatted * @param attributes format attributes * @return Integer-representation of given value * @since 3.37/4.32 */ default int printToInt( V value, ChronoDisplay context, AttributeQuery attributes ) { return this.numerical(value); } /** *

Converts and stores given integer into the result buffer.

* *

Will be called when int values need to be interpreted as enums. The default * implementation just delegates to {@link #numerical(Object) numerical(V)}.

* * @param entity mutable result buffer for parsed values * @param value parsed integer * @return {@code true} if the integer can be interpreted else {@code false} * @since 3.37/4.32 */ /*[deutsch] *

Konvertiert und speichert den angegebenen Integerwert in den Ergebnispuffer.

* *

Wird aufgerufen, wenn int-Werte als Enums interpretiert werden müssen. Die * Standardimplementierung delegiert einfach an {@link #numerical(Object) numerical(V)}.

* * @param entity mutable result buffer for parsed values * @param value parsed integer * @return {@code true} if the integer can be interpreted else {@code false} * @since 3.37/4.32 */ default boolean parseFromInt( ChronoEntity entity, int value ) { Class type = this.getType(); for (V e : type.getEnumConstants()) { if (this.numerical(e) == value) { entity.with(this, e); return true; } } return false; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy