mirror of
https://github.com/openjdk/jdk.git
synced 2025-08-27 06:45:07 +02:00
8269124: Update java.time to use switch expressions (part II)
Reviewed-by: dfuchs, vtewari, aefimov, iris, lancea, naoto
This commit is contained in:
parent
675a9520b2
commit
8a7b380ebb
16 changed files with 322 additions and 370 deletions
|
@ -497,12 +497,12 @@ public final class Year
|
|||
@Override
|
||||
public long getLong(TemporalField field) {
|
||||
if (field instanceof ChronoField chronoField) {
|
||||
switch (chronoField) {
|
||||
case YEAR_OF_ERA: return (year < 1 ? 1 - year : year);
|
||||
case YEAR: return year;
|
||||
case ERA: return (year < 1 ? 0 : 1);
|
||||
}
|
||||
throw new UnsupportedTemporalTypeException("Unsupported field: " + field);
|
||||
return switch (chronoField) {
|
||||
case YEAR_OF_ERA -> year < 1 ? 1 - year : year;
|
||||
case YEAR -> year;
|
||||
case ERA -> year < 1 ? 0 : 1;
|
||||
default -> throw new UnsupportedTemporalTypeException("Unsupported field: " + field);
|
||||
};
|
||||
}
|
||||
return field.getFrom(this);
|
||||
}
|
||||
|
@ -621,12 +621,12 @@ public final class Year
|
|||
public Year with(TemporalField field, long newValue) {
|
||||
if (field instanceof ChronoField chronoField) {
|
||||
chronoField.checkValidValue(newValue);
|
||||
switch (chronoField) {
|
||||
case YEAR_OF_ERA: return Year.of((int) (year < 1 ? 1 - newValue : newValue));
|
||||
case YEAR: return Year.of((int) newValue);
|
||||
case ERA: return (getLong(ERA) == newValue ? this : Year.of(1 - year));
|
||||
}
|
||||
throw new UnsupportedTemporalTypeException("Unsupported field: " + field);
|
||||
return switch (chronoField) {
|
||||
case YEAR_OF_ERA -> Year.of((int) (year < 1 ? 1 - newValue : newValue));
|
||||
case YEAR -> Year.of((int) newValue);
|
||||
case ERA -> getLong(ERA) == newValue ? this : Year.of(1 - year);
|
||||
default -> throw new UnsupportedTemporalTypeException("Unsupported field: " + field);
|
||||
};
|
||||
}
|
||||
return field.adjustInto(this, newValue);
|
||||
}
|
||||
|
@ -708,14 +708,14 @@ public final class Year
|
|||
@Override
|
||||
public Year plus(long amountToAdd, TemporalUnit unit) {
|
||||
if (unit instanceof ChronoUnit chronoUnit) {
|
||||
switch (chronoUnit) {
|
||||
case YEARS: return plusYears(amountToAdd);
|
||||
case DECADES: return plusYears(Math.multiplyExact(amountToAdd, 10));
|
||||
case CENTURIES: return plusYears(Math.multiplyExact(amountToAdd, 100));
|
||||
case MILLENNIA: return plusYears(Math.multiplyExact(amountToAdd, 1000));
|
||||
case ERAS: return with(ERA, Math.addExact(getLong(ERA), amountToAdd));
|
||||
}
|
||||
throw new UnsupportedTemporalTypeException("Unsupported unit: " + unit);
|
||||
return switch (chronoUnit) {
|
||||
case YEARS -> plusYears(amountToAdd);
|
||||
case DECADES -> plusYears(Math.multiplyExact(amountToAdd, 10));
|
||||
case CENTURIES -> plusYears(Math.multiplyExact(amountToAdd, 100));
|
||||
case MILLENNIA -> plusYears(Math.multiplyExact(amountToAdd, 1000));
|
||||
case ERAS -> with(ERA, Math.addExact(getLong(ERA), amountToAdd));
|
||||
default -> throw new UnsupportedTemporalTypeException("Unsupported unit: " + unit);
|
||||
};
|
||||
}
|
||||
return unit.addTo(this, amountToAdd);
|
||||
}
|
||||
|
@ -915,14 +915,14 @@ public final class Year
|
|||
Year end = Year.from(endExclusive);
|
||||
if (unit instanceof ChronoUnit chronoUnit) {
|
||||
long yearsUntil = ((long) end.year) - year; // no overflow
|
||||
switch (chronoUnit) {
|
||||
case YEARS: return yearsUntil;
|
||||
case DECADES: return yearsUntil / 10;
|
||||
case CENTURIES: return yearsUntil / 100;
|
||||
case MILLENNIA: return yearsUntil / 1000;
|
||||
case ERAS: return end.getLong(ERA) - getLong(ERA);
|
||||
}
|
||||
throw new UnsupportedTemporalTypeException("Unsupported unit: " + unit);
|
||||
return switch (chronoUnit) {
|
||||
case YEARS -> yearsUntil;
|
||||
case DECADES -> yearsUntil / 10;
|
||||
case CENTURIES -> yearsUntil / 100;
|
||||
case MILLENNIA -> yearsUntil / 1000;
|
||||
case ERAS -> end.getLong(ERA) - getLong(ERA);
|
||||
default -> throw new UnsupportedTemporalTypeException("Unsupported unit: " + unit);
|
||||
};
|
||||
}
|
||||
return unit.between(this, end);
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue