Just a quick follow up on that last reply…

As dumpy of an excuse as that is (doing it because the other 2 big platforms do 
it) when we’re talking about some tech that is very cross platform, I think 
it’s worth considering.


Brandon Sneed

From: <swift-corelibs-dev-boun...@swift.org> on behalf of "Sneed, Brandon via 
swift-corelibs-dev" <swift-corelibs-dev@swift.org>
Reply-To: "Sneed, Brandon" <brsn...@ebay.com>
Date: Wednesday, August 30, 2017 at 3:29 PM
To: Tony Parker <anthony.par...@apple.com>
Cc: "swift-corelibs-dev@swift.org" <swift-corelibs-dev@swift.org>
Subject: Re: [swift-corelibs-dev] Adding type conversion capabilities to JSON 
encode/decode

Yeah, I don’t know about the “many types” part.  But essentially, if you’re a 
service developer, you’ll probably have at least 3 clients.  Web, Android and 
iOS.  Javascript does this conversion transparently, GSON also does this 
conversion.  iOS ends up being the odd man out in this case.

This is entirely me trying to put myself in the service developers shoes… but 
if I come up with an API contract, that will typically consist of endpoint, 
overall structure and namin.  I can imagine type may fall off my radar given 
that javascript (the platform I wrote my service in) hides types from me.  
Using that example at a larger company, the “hey you broke me by changing the 
type!” scream is followed with “it works fine on web and android”, which in 
turn causes me to rev the iOS app and wait for people to update.

If it failed on all 3, they’d likely fix/rever the service to avoid having 
*all* clients broken.


Brandon Sneed

From: <anthony.par...@apple.com> on behalf of Tony Parker 
<anthony.par...@apple.com>
Date: Wednesday, August 30, 2017 at 3:22 PM
To: "Sneed, Brandon" <brsn...@ebay.com>
Cc: Youming Lin <y...@us.ibm.com>, "swift-corelibs-dev@swift.org" 
<swift-corelibs-dev@swift.org>
Subject: Re: [swift-corelibs-dev] Adding type conversion capabilities to JSON 
encode/decode





On Aug 30, 2017, at 3:12 PM, Sneed, Brandon 
<brsn...@ebay.com<mailto:brsn...@ebay.com>> wrote:

Thanks Tony,

Ah.  That should work, and covers benefit #2 I mentioned very nicely.  Only 
downside is that as a developer on an app I may not expect that type to change 
on the server side so I wouldn’t do it by default, and when it does happen, I 
then need to apply it to each of its siblings because if it can happen to one, 
it can happen to the others.

In this case, the server decides to send a String instead of a numeric value 
for many kinds of types?

I understand that some JSON libraries have options to stringify all numeric 
values in an attempt to preserve ‘exactness’, although I would argue that this 
depends on what you do with the numeric value on the other side…

- Tony




_______________________________________________
swift-corelibs-dev mailing list
swift-corelibs-dev@swift.org
https://lists.swift.org/mailman/listinfo/swift-corelibs-dev

Reply via email to