Recipe Name:
Migrate new DateTime(java.time.TemporalAccessor) to java.time
Description:
Migrate new DateTime(java.time.TemporalAccessor) to java.time
Level:
warning
Language:
- java
Tags:
- framework specific
- java.time
- Joda-Time
- quality
Documentation
Migrate from org.joda.time.DateTime to Java Time
Joda-Time DateTime migrates to java.time ZonedDateTime or OffsetDateTime.
ZonedDateTime is the same concept, date and time with time-zone.
OffsetDateTime is a new concept, date and time with offset from UTC.
BeforeDateTime dateTime = new DateTime(); int monthOfYear = dateTime.getMonthOfYear();After
ZonedDateTime dateTime = ZonedDateTime.now(); int monthOfYear = dateTime.getMonthValue();References
Recipe
id: scw:java.time:Joda-Time:DateTime-constructor-TemporalAccessor version: 10 metadata: name: Migrate new DateTime(java.time.TemporalAccessor) to java.time shortDescription: Migrate new DateTime(java.time.TemporalAccessor) to java.time level: warning language: java enabled: true comment: | This recipe is designed to match on broken code as part of an overall migration from Joda-Time to java.time. In Joda-Time the DateTime class has a constructor which simply accepts an Object, and during construction the class would figure out what type of object it was and construct the DateTime appropriately. One of the classes that can be detected is ReadableInstant. When migrating a new DateTime(ReadableInstant) call, you must first migrate the Joda-Time ReadableInstant argument to the java.time equivalent. This recipe explicitly excludes java.time.Instant, even though a java.time.Instant implements the java.time.temporal.TemporalAccessor interface. The reason for this is that java.time.Instant cannot be used with the ZonedDateTime.from(TemporalAccessor) and OffsetDateTime.from(TemporalAccessor) factory methods. A DateTimeException will be thrown when an Instant is passed to these methods, because the time zone or offset cannot be determined from the Instant. For this reason, there are separate migration recipes for Instant which migrate to ZonedDateTime.ofInstant(Instant, ZoneId) and OffsetDateTime.ofInstant(Instant, ZoneId) instead. This recipe will cause broken code as part of an overall number of steps to perform a migration of Joda-Time to java.time. After migrating this instance creation to the java.time equivalent, subsequent method calls and usages of the instance may become invalid. Further Sensei recipes are available to help resolve many of these invalid usages. descriptionFile: descriptions/datetime.html tags: framework specific;java.time;Joda-Time;quality search: instanceCreation: args: 1: not: type: java.time.Instant type: java.time.temporal.TemporalAccessor argCount: 1 type: org.joda.time.DateTime availableFixes: - name: Migrate to java.time.ZonedDateTime actions: - rewrite: to: java.time.ZonedDateTime.from({{{ arguments.0 }}}) - modifyAssignedVariable: type: java.time.ZonedDateTime - name: Migrate to java.time.OffsetDateTime actions: - rewrite: to: java.time.OffsetDateTime.from({{{ arguments.0 }}}) - modifyAssignedVariable: type: java.time.OffsetDateTime