Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add Support for Untagged Unwrapped Single Cases #135

Open
daniellittledev opened this issue Oct 21, 2022 · 1 comment
Open

Add Support for Untagged Unwrapped Single Cases #135

daniellittledev opened this issue Oct 21, 2022 · 1 comment

Comments

@daniellittledev
Copy link

To be able to serialise into a typical (untagged) typescript union I propose adding support for a JsonUnionEncoding.Untagged ||| JsonUnionEncoding.UnwrapSingleFieldCases combination that support untagged and unwrapped cases.

Types such as the one below are quite common, and adding a tag is unnecessary and unwanted in this case.

type Value = number | number[]

The equivalent type in FSharp would be as follows.

type Value = Choice<decimal, decimal list> 

If we support primitive types with the constraint of one unique type per case we can also support deserializing without ambiguity.

Looking at the type type ChoiceOf5 = Choice<int, string, bool, int list, Object> we can deserialize the type knowing only the JsonTokenType. So the following type can be round trip-able without any tags.

Choice1Of5 1 = "1"
Choice2Of5 "F#" = "\"F#\""
Choice3Of5 false = "false"
Choice4Of5 [1,2] = "[1,2]"
Choice5Of5 { name = "Object" } = "{name:\"Object\"}"

Duplicate types could fail or attempt to pick the first matching type.

@ssiltanen
Copy link

ssiltanen commented Nov 26, 2023

Is there any reason this feature is not acknowledged or does it just need help to implement? I see there already is an old PR for this also that has been ignored. Is there some issue with the approach it is taking?

Although, since there is already a feature to unwrap untagged object, I think this feature should only target single non-object single values (Not sure how arrays behave with the other existing options).

E.g. a use case from the language server protocol definitions:

type A = Enabled of bool | Options of Object
type B = { a: A }
let b = { a: Enabled true }

b should be allowed to be serialized to

{ "a": true }

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants