Initial commit
This commit is contained in:
@@ -0,0 +1,38 @@
|
||||
package com.thoughtworks.xstream.converters.time;
|
||||
|
||||
import com.thoughtworks.xstream.converters.ConversionException;
|
||||
import com.thoughtworks.xstream.converters.SingleValueConverter;
|
||||
import java.time.LocalTime;
|
||||
import java.time.format.DateTimeFormatter;
|
||||
import java.time.format.DateTimeFormatterBuilder;
|
||||
import java.time.format.DateTimeParseException;
|
||||
import java.time.temporal.ChronoField;
|
||||
|
||||
/* loaded from: classes.dex */
|
||||
public class LocalTimeConverter implements SingleValueConverter {
|
||||
private static final DateTimeFormatter FORMATTER = new DateTimeFormatterBuilder().appendPattern("HH:mm:ss").appendFraction(ChronoField.NANO_OF_SECOND, 0, 9, true).toFormatter();
|
||||
|
||||
@Override // com.thoughtworks.xstream.converters.ConverterMatcher
|
||||
public boolean canConvert(Class cls) {
|
||||
return LocalTime.class == cls;
|
||||
}
|
||||
|
||||
@Override // com.thoughtworks.xstream.converters.SingleValueConverter
|
||||
public Object fromString(String str) {
|
||||
try {
|
||||
return LocalTime.parse(str);
|
||||
} catch (DateTimeParseException e) {
|
||||
ConversionException conversionException = new ConversionException("Cannot parse value as local time", e);
|
||||
conversionException.add("value", str);
|
||||
throw conversionException;
|
||||
}
|
||||
}
|
||||
|
||||
@Override // com.thoughtworks.xstream.converters.SingleValueConverter
|
||||
public String toString(Object obj) {
|
||||
if (obj == null) {
|
||||
return null;
|
||||
}
|
||||
return FORMATTER.format((LocalTime) obj);
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user