org.supercsv.ext.builder.time.ZonedDateTimeCellProcessorBuilder Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of super-csv-annotation Show documentation
Show all versions of super-csv-annotation Show documentation
CSVのJavaライブラリであるSuperCSVに、アノテーション機能を追加したライブラリです。
package org.supercsv.ext.builder.time;
import java.lang.annotation.Annotation;
import java.time.ZonedDateTime;
import java.time.format.DateTimeFormatter;
import java.time.format.DateTimeParseException;
import java.util.Optional;
import org.supercsv.cellprocessor.ift.CellProcessor;
import org.supercsv.cellprocessor.time.FmtZonedDateTime;
import org.supercsv.cellprocessor.time.ParseZonedDateTime;
import org.supercsv.ext.annotation.CsvDateConverter;
import org.supercsv.ext.exception.SuperCsvInvalidAnnotationException;
import org.supercsv.ext.util.Utils;
/**
* The cell processor builder for {@link ZonedDateTime}.
*
* @since 1.2
* @author T.TSUCHIE
*
*/
public class ZonedDateTimeCellProcessorBuilder extends AbstractTemporalAccessorCellProcessorBuilder {
@Override
protected String getDefaultPattern() {
return "uuuu-MM-dd HH:mm:ssxxx'['VV']'";
}
@Override
public Optional parseValue(final Class type, final Annotation[] annos, final String strValue) {
if(Utils.isEmpty(strValue)) {
return Optional.empty();
}
final Optional converterAnno = getDateConverterAnnotation(annos);
final DateTimeFormatter formatter = createDateTimeFormatter(converterAnno);
final String pattern = getPattern(converterAnno);
try {
return Optional.of(ZonedDateTime.parse(strValue, formatter));
} catch(DateTimeParseException e) {
throw new SuperCsvInvalidAnnotationException(
String.format("default '%s' value cannot parse to ZonedDateTime with pattern '%s'",
strValue, pattern), e);
}
}
@Override
public CellProcessor buildOutputCellProcessor(final Class type, final Annotation[] annos,
final CellProcessor processor, final boolean ignoreValidationProcessor) {
final Optional converterAnno = getDateConverterAnnotation(annos);
final DateTimeFormatter formatter = createDateTimeFormatter(converterAnno);
final Optional min = getMin(converterAnno).map(s -> parseValue(type, annos, s).get());
final Optional max = getMax(converterAnno).map(s -> parseValue(type, annos, s).get());
CellProcessor cp = processor;
cp = (cp == null ? new FmtZonedDateTime(formatter) : new FmtZonedDateTime(formatter, cp));
if(!ignoreValidationProcessor) {
cp = prependRangeProcessor(type, annos, cp, min, max);
}
return cp;
}
@Override
public CellProcessor buildInputCellProcessor(final Class type, final Annotation[] annos,
final CellProcessor processor) {
final Optional converterAnno = getDateConverterAnnotation(annos);
final DateTimeFormatter formatter = createDateTimeFormatter(converterAnno);
final Optional min = getMin(converterAnno).map(s -> parseValue(type, annos, s).get());
final Optional max = getMax(converterAnno).map(s -> parseValue(type, annos, s).get());
CellProcessor cp = processor;
cp = prependRangeProcessor(type, annos, cp, min, max);
cp = (cp == null ? new ParseZonedDateTime(formatter) : new ParseZonedDateTime(formatter, cp));
return cp;
}
}