Я использую Data.Aeson для анализа некоторого JSON в тип записи. Время от времени данные добавляются в JSON, и это ломает мой код, поскольку Эсон жалуется на что-то в результате:
ожидаемый объект с 21 парой имя/значение, но получил 23 имя/значение
Я действительно предпочел бы анализировать JSON отказоустойчивым способом - мне все равно, будут ли добавлены дополнительные поля в JSON позже, просто анализируйте все, что можете! Есть ли способ добиться этой отказоустойчивости? Вот мой код:
myRecordFromJSONString :: BS.ByteString -> Maybe MyRecord
myRecordFromJSONString s = case Data.Attoparsec.parse json s of
Done _rest res -> Data.Aeson.Types.parseMaybe parseJSON res
_ -> Nothing
Я должен добавить, что я использую производный JSON из Data.Aeson.TH для генерации кода синтаксического анализа. Если я напишу код FromJSON вручную, он будет отказоустойчивым, но я бы не хотел этого делать...