- 
                Notifications
    You must be signed in to change notification settings 
- Fork 64
Description
Current state & Rationale
Yojson currently supports parsing into three different variants of JSON: Basic (which is mostly "normal JSON"), Safe (JSON extended with variants and tuples and making sure numbers don't get truncated; what most Yojson users seem to have settled on) and Raw (which parses numbers into strings and does not do string quoting).
This creates friction when different codebases use different types: library A has a hard time interoperating with library B if library A uses Basic.t and library B uses Safe.t.
Proposal
When picking Yojson for parsing JSON there is very little guidance on which of these variants to use. When parsing people want to parse JSON correctly into some mostly sensible format and not be confronted with minutia about different ways to parse JSON.
As such this RFC proposes to rethink the way the Yojson variants are divided up. There should be one variant that will fulfill 80% of peoples uses, presumably similar to what Safe is today. There should probably also be one that does as little interpretation of values as possible, e.g. never assuming numbers are  `Int.
Reducing the amount of variants also makes it easier to remove code-generation via CPPO, which is currently preventing Merlin from working properly on the codebase and making reasoning over the functionality harder by adding a metalevel to the code.
The exact resulting variants are subject to discussion that I want to open up in this RFC.
Impact
Yojson.Safe.t is a type that is used by ppx_deriving_yojson and ppx_yojson_conv and changing the representation there might cause breakage. The upside is that fixing the PPXes will also automatically fix the users of it.
Roadmap
This would be planned for a 3.0.0 release at the earliest.