Skip to content

Commit

Permalink
Add cache for datetimeformatters
Browse files Browse the repository at this point in the history
  • Loading branch information
altro3 committed Dec 4, 2023
1 parent 05422bf commit dc4b8b4
Showing 1 changed file with 17 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -44,8 +44,10 @@
import java.time.temporal.TemporalAmount;
import java.time.temporal.TemporalQuery;
import java.util.Date;
import java.util.Map;
import java.util.Objects;
import java.util.Optional;
import java.util.concurrent.ConcurrentHashMap;
import java.util.function.BiFunction;
import java.util.function.Function;
import java.util.regex.Matcher;
Expand Down Expand Up @@ -82,6 +84,8 @@ public class TimeConverterRegistrar implements TypeConverterRegistrar {
private static final Pattern DURATION_MATCHER = Pattern.compile("^(-?\\d+)([unsmhd])(s?)$");
private static final int MILLIS = 3;

private final Map<String, DateTimeFormatter> cachedFormatters = new ConcurrentHashMap<>();

@NextMajorVersion("Consider deletion of LocalDate and LocalDateTime converters")
@Override
public void register(MutableConversionService conversionService) {
Expand Down Expand Up @@ -242,6 +246,19 @@ private <T extends TemporalAccessor> void addTemporalStringConverters(MutableCon
});
}

private DateTimeFormatter getFormatter(String pattern, ConversionContext context) {
var key = pattern + '#' + context.getLocale();
DateTimeFormatter formatter;
var cachedFormater = cachedFormatters.get(key);
if (cachedFormater != null) {
return cachedFormater;
}
formatter = DateTimeFormatter.ofPattern(pattern, context.getLocale());
cachedFormatters.put(key, formatter);

return formatter;
}

private <T extends TemporalAccessor> void addTemporalToDateConverter(MutableConversionService conversionService, Class<T> temporalType, Function<T, Instant> toInstant) {
conversionService.addConverter(temporalType, Date.class, (T object, Class<Date> targetType, ConversionContext context) -> Optional.of(Date.from(toInstant.apply(object))));
}
Expand Down

0 comments on commit dc4b8b4

Please sign in to comment.