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

net.time4j.EnumElement Maven / Gradle / Ivy

There is a newer version: 4.38
Show newest version
/*
 * -----------------------------------------------------------------------
 * Copyright © 2013-2014 Meno Hochschild, 
 * -----------------------------------------------------------------------
 * This file (EnumElement.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.AttributeQuery;
import net.time4j.engine.ChronoDisplay;
import net.time4j.engine.ChronoEntity;
import net.time4j.engine.Chronology;
import net.time4j.engine.ElementRule;
import net.time4j.format.Attributes;
import net.time4j.format.CalendarText;
import net.time4j.format.NumericalElement;
import net.time4j.format.OutputContext;
import net.time4j.format.ParseLog;
import net.time4j.format.TextAccessor;
import net.time4j.format.TextElement;
import net.time4j.format.TextWidth;

import java.io.IOException;
import java.io.InvalidObjectException;
import java.io.ObjectStreamException;
import java.util.Locale;

import static net.time4j.format.CalendarText.ISO_CALENDAR_TYPE;


/**
 * 

Allgemeines verstellbares chronologisches Element auf enum-Basis.

* * @param generic enum type of element values * @author Meno Hochschild * @concurrency */ final class EnumElement> extends AbstractDateElement implements NavigableElement, NumericalElement, TextElement { //~ Statische Felder/Initialisierungen -------------------------------- /** Element-Index. */ static final int MONTH = 101; /** Element-Index. */ static final int DAY_OF_WEEK = 102; /** Element-Index. */ static final int QUARTER_OF_YEAR = 103; /** Element-Index. */ static final int ERA = 104; private static final long serialVersionUID = 2055272540517425102L; //~ Instanzvariablen -------------------------------------------------- private transient final Class type; private transient final V dmin; private transient final V dmax; private transient final int index; private transient final char symbol; //~ Konstruktoren ----------------------------------------------------- /** *

Konstruiert ein neues Element mit den angegebenen Details.

* * @param name name of element * @param type reified type of element values * @param defaultMin default minimum * @param defaultMax default maximum * @param index element index * @param symbol CLDR-symbol used in format patterns */ EnumElement( String name, Class type, V defaultMin, V defaultMax, int index, char symbol ) { super(name); this.type = type; this.dmin = defaultMin; this.dmax = defaultMax; this.index = index; this.symbol = symbol; } //~ Methoden ---------------------------------------------------------- @Override public Class getType() { return this.type; } @Override public char getSymbol() { return this.symbol; } @Override public V getDefaultMinimum() { return this.dmin; } @Override public V getDefaultMaximum() { return this.dmax; } @Override public boolean isDateElement() { return true; } @Override public boolean isTimeElement() { return false; } @Override public ElementOperator setToNext(V value) { return new NavigationOperator( this, ElementOperator.OP_NAV_NEXT, value); } @Override public ElementOperator setToPrevious(V value) { return new NavigationOperator( this, ElementOperator.OP_NAV_PREVIOUS, value); } @Override public ElementOperator setToNextOrSame(V value) { return new NavigationOperator( this, ElementOperator.OP_NAV_NEXT_OR_SAME, value); } @Override public ElementOperator setToPreviousOrSame(V value) { return new NavigationOperator( this, ElementOperator.OP_NAV_PREVIOUS_OR_SAME, value); } @Override public int numerical(V value) { if (this.index == ERA) { return value.ordinal(); } return (value.ordinal() + 1); } @Override public void print( ChronoDisplay context, Appendable buffer, AttributeQuery attributes ) throws IOException { buffer.append(this.accessor(attributes).print(context.get(this))); } @Override public V parse( CharSequence text, ParseLog status, AttributeQuery attributes ) { return this.accessor(attributes).parse( text, status, this.getType(), attributes ); } @Override @SuppressWarnings("unchecked") protected > ElementRule derive( Chronology chronology ) { if ( (this.index == ERA) && chronology.isRegistered(PlainDate.CALENDAR_DATE) ) { ElementRule rule = new SimpleEra.Rule(); return (ElementRule) rule; } return null; } /** *

Liefert einen Zugriffsindex zur Optimierung der Elementsuche.

* * @return int */ int getIndex() { return this.index; } private TextAccessor accessor(AttributeQuery attributes) { CalendarText cnames = CalendarText.getInstance( attributes.get(Attributes.CALENDAR_TYPE, ISO_CALENDAR_TYPE), attributes.get(Attributes.LANGUAGE, Locale.ROOT)); TextWidth textWidth = attributes.get(Attributes.TEXT_WIDTH, TextWidth.WIDE); switch (this.index) { case MONTH: return cnames.getStdMonths( textWidth, attributes.get( Attributes.OUTPUT_CONTEXT, OutputContext.FORMAT)); case DAY_OF_WEEK: return cnames.getWeekdays( textWidth, attributes.get( Attributes.OUTPUT_CONTEXT, OutputContext.FORMAT)); case QUARTER_OF_YEAR: return cnames.getQuarters( textWidth, attributes.get( Attributes.OUTPUT_CONTEXT, OutputContext.FORMAT)); case ERA: return cnames.getEras(textWidth); default: throw new UnsupportedOperationException(this.name()); } } private Object readResolve() throws ObjectStreamException { Object element = PlainDate.lookupElement(this.name()); if (element == null) { throw new InvalidObjectException(this.name()); } else { return element; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy