I\'d like to produce Partials from Strings, but can\'t find anything in the API that supports that. Obviously, I can write my own parser outside of the Joda-Time framework
The ISODateTimeFormat
class allows partial printing. As you say, there is no parsing method on DateTimeFormatter
(although you can parse to a LocalDate
and interpret that).
ThreeTen/JSR-310 has the DateTimeFields
class which replaces Partial
. Parsing of partials into a CalendricalMerger
is supported, however that may not be convertable back into a DateTimeFields
yet.
I've extended DateTimeParserBucket. My extended class intercepts calls to the saveField() methods, and stores the field type and value before delegating to super. I've also implemented a method that uses those stored field values to create a Partial.
I'm able to pass my bucket instance to DateTimeParser.parseInto(), and then ask it to create the Partial.
It works, but I can't say I'm impressed with Joda-Time - given that it doesn't support parsing Partials out of the box. The lack of DateTimeFormatter.parsePartial(String) is a glaring omission.
You have to start by defining the valid format for Partials which you will be accepting. There is no class which will just take text and infer the best possible match for a Partial. It's way too subjective based on locale, user preference, etc. So there's no way of getting around making a list of all of the valid formats for input. It will be very difficult to make these all mutually exclusive for each other, so there should be priorities. For example, you might want mm/dd
and mm/yy
to both be valid formats. If I give you the string 02/11
, which one should have priority?
Once you've determined exactly the valid formats, you should use DateTimeFormat.forPattern
to create a DateTimeFormatter
for each one. Then you can use each formatter to try to parseInto
a MutableDateTime
. Then, go through each field in the MutableDateTime
and transfer the value into a Partial
.
Unfortunately, there is no better way to handle this in the Joda library.