> On 25 Jul 2018, at 11:34, Peter Uhnák <i.uh...@gmail.com> wrote:
>
> Ah, you are right that it might not be human-friendly.
>
> I don't want to rely on the order, but for (file) versioning it is quite
> valuable. (or rather changing the order can easily make versioning quite
> worthless).
Ah, OK, I understand the use case.
> I can manually sort it, but it creates a lot of mess:
>
> (NeoJSONWriter on: stream)
> prettyPrint: true;
> for: Something
> do: [ :mapping | mapping mapInstVars: (mapping identifier
> instVarNames \ #(unwanted)) sorted ];
> for: Otherthing
> do: [ :mapping | mapping mapInstVars: mapping identifier
> instVarNames sorted ];
> for: Point
> do: [ :mapping | mapping mapInstVars: mapping identifier
> instVarNames sorted ];
> nextPut: anObject.
Actually I do not think that the above is that bad ;-)
> I'd much rather have the following:
>
> (NeoJSONWriter on: stream)
> prettyPrint: true;
> sorted: true;
> for: Something
> do: [ :mapping | mapping mapInstVars: mapping identifier
> instVarNames \ #(unwanted) ];
> mapInstVarsFor: Otherthing;
> mapInstVarsFor: Point;
> nextPut: anObject.
>
> or more fine-grained, although the above is imo nicer:
>
> (NeoJSONWriter on: stream)
> prettyPrint: true;
> for: Something
> do: [ :mapping | mapping mapInstVars: (mapping identifier
> instVarNames \ #(unwanted)) sorted ];
> mapInstVarsFor: Otherthing sorted: true;
> mapInstVarsFor: Point sorted: true;
> nextPut: anObject.
>
> (or mapSortedInstVarsFor: or something)..
I guess you could add some extension methods to NeoJSONWriter, or subclass it -
yourself.
After some consideration I still think that adding sorting options would be
confusing. Unless there would be some convention in other JSON tools for this
issue, or a larger demand (more use cases).
> Peter
>
> On Wed, Jul 25, 2018 at 11:20 AM, Sven Van Caekenberghe <s...@stfx.eu> wrote:
> From json.org
>
> "An object is an unordered set of name/value pairs."
>
> IOW, it is not in the spec, it would be dangerous to rely up it in any way
> (not that you are suggesting that). It might look better sometimes, but even
> then alphabetic sorting might not be the most human friendly or most
> meaningful.
>
> Note that 'properties' in NeoJSONMapping is an OrderedCollection, so it keeps
> it order. So if you add them in the right order, that would do it.
>
> > On 25 Jul 2018, at 11:12, Peter Uhnák <i.uh...@gmail.com> wrote:
> >
> > Hi,
> >
> > would it be possible to provide option to automatically sort instance
> > variables when serializing objects?
> >
> > Either always sorted
> >
> > NeoJSONObjectMapping>>writeObject: anObject on: jsonWriter
> > jsonWriter writeMapStreamingDo: [ :jsonMapWriter |
> > (properties sorted: #propertyName ascending) do: [ :each |
> > each writeObject: anObject on: jsonMapWriter ] ]
> >
> > or put it behind some sortProperties boolean flag. (atm I don't see any
> > downsides in having sort always enabled)
>
> Speed ?
> A false suggestion that is part of the spec ?
>
> > Thanks,
> > Peter