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

print primitive array in single line or set a line width for primitive array object #2754

Open
frankfliu opened this issue Oct 2, 2024 · 8 comments

Comments

@frankfliu
Copy link

Problem solved by the feature

When json object contains a large int[] or int[][] object, the pretty print is not useable. each element ends with newline.

Feature description

We should have an option in FormattingStyle to serialize primitive array in a single line (or even better configurable line width)

Alternatives / workarounds

@Marcono1234
Copy link
Collaborator

Marcono1234 commented Oct 6, 2024

We should have an option in FormattingStyle to serialize primitive array in a single line

This might not work that reliably; FormattingStyle only applies to JsonWriter, but it does not know the type of an array. The array could be heterogeneous and start with an int as first element but then contain a String or a nested array or object.

A line width could work, but probably rather as "soft" limit, so once it has been reached or exceeded the next value is written in the next line. If it was a hard limit, the writer would have to look ahead how large the next value will be or write it to a temporary buffer first before being able to decide if it has to be wrapped into the next line.
Maybe this should then be called "array line width" (or any other name which includes "array") to make it clear that this only applies to arrays / array elements and not something else.

Would be interesting to see if and how other JSON libraries support this, maybe even in programming languages other than Java.

(These were just some personal thoughts on this proposal, not any specific plans to implement this yet.)

@dhrax21
Copy link

dhrax21 commented Oct 19, 2024

Hey Can I work on this issue:)

@Marcono1234
Copy link
Collaborator

Marcono1234 commented Oct 20, 2024

Thanks for your offer @dhrax21!

Based on my previous #2754 (comment), I think there are currently a few open questions; maybe this needs further feedback from @frankfliu.

But what you could do, if you want, is research if / how other popular JSON libraries (for Java, but possibly also other programming languages) support this, and then document it here, including the cases where popular JSON libraries don't support it (linking to feature requests, in case there are any).

That would help better understand how commonly needed this feature is, and what good approaches for implementing this could be.

However, there is no guarantee that this feature will be implemented in the end. So no worries if you are not interested then in investigating this.

@frankfliu
Copy link
Author

My use case is pretty simple, I want to serialize a json object than contains a image or tensor (multidimensional array). The sensor size is pretty big (like 3x1024x768), I'd like to have a semi-readable serialized format. Currently using prettyPrint is completely unusable (both performant and readability)

@frankfliu
Copy link
Author

frankfliu commented Oct 20, 2024

I have a few other proposals:

  1. Adds a flag disableArrayPrettyPrint(), this will print any array type in compact format, this is not ideal, but can quickly meet some of use cases
  2. Add annotation @SerializeFormat(newline=false, indent=false, spaceAfterSeparators=true) at field level, this gives a fine-grained control to apply FormattingStyle ad field level

@Marcono1234
Copy link
Collaborator

Thanks for the references!

I also found these:

  • Jackson: DefaultPrettyPrinter
    Seems to offer quite flexible configuration, but the PrettyPrinter is performing some of the writing itself. I guess that will not be possible with Gson's current FormattingStyle which is only for configuring the formatting.
  • Rust library serde_json: PrettyFormatter
    Also a dedicated type which performs writing / formatting.
  • kotlinx.serialization
    Only seems to allow enabling / disabling pretty-printing without any configuration, see documentation.
  • Moshi
    Only seems to allow configuring indentation / disabling pretty-printing, see JsonWriter#indent.

@Marcono1234
Copy link
Collaborator

Marcono1234 commented Nov 2, 2024

2. Add annotation @SerializeFormat(newline=false, indent=false, spaceAfterSeparators=true) at field level, this gives a fine-grained control to apply FormattingStyle ad field level

That will probably not be possible. JSON writing and pretty-printing happens in JsonWriter, but it does not have access to annotations. Gson currently also does not include annotations in TypeToken (see #269), so type adapters would not have access to this annotation either.
(I am also not sure if it would be justified to add a new annotation just for this specific use case.)


1. Adds a flag disableArrayPrettyPrint(), this will print any array type in compact format, this is not ideal, but can quickly meet some of use cases

Maybe that could indeed be a solution, or something similar to what you originally proposed above:

We should have an option in FormattingStyle to serialize primitive array in a single line

So not disable array pretty-printing in general, but based on its content (or based on the first value). My comment #2754 (comment) might have been a bit too pessimistic. Assuming that the majority of JSON arrays contains values of the same type, such an option might work well. It would be opt-in anyway, so for arrays of mixed types we could document that the exact formatting is undefined.
The main question might be what we should consider as "primitive value" here: null, boolean and numbers probably yes. But strings as well? Depending on the use case they could be quite large, and it might not be desired to have them all in one line.

(These are just my personal thoughts on this though.)

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

No branches or pull requests

3 participants