From mboxrd@z Thu Jan 1 00:00:00 1970 Path: news.gmane.org!.POSTED!not-for-mail From: Barry Margolin Newsgroups: gmane.emacs.help Subject: Re: Hack for JSON sequences with trailing commas? Date: Sat, 04 Aug 2018 19:12:52 -0400 Organization: A noiseless patient Spider Message-ID: References: NNTP-Posting-Host: blaine.gmane.org X-Trace: blaine.gmane.org 1533424407 30790 195.159.176.226 (4 Aug 2018 23:13:27 GMT) X-Complaints-To: usenet@blaine.gmane.org NNTP-Posting-Date: Sat, 4 Aug 2018 23:13:27 +0000 (UTC) User-Agent: MT-NewsWatcher/3.5.3b3 (Intel Mac OS X) To: help-gnu-emacs@gnu.org Original-X-From: help-gnu-emacs-bounces+geh-help-gnu-emacs=m.gmane.org@gnu.org Sun Aug 05 01:13:23 2018 Return-path: Envelope-to: geh-help-gnu-emacs@m.gmane.org Original-Received: from lists.gnu.org ([208.118.235.17]) by blaine.gmane.org with esmtp (Exim 4.84_2) (envelope-from ) id 1fm5jf-0007v8-87 for geh-help-gnu-emacs@m.gmane.org; Sun, 05 Aug 2018 01:13:23 +0200 Original-Received: from localhost ([::1]:56540 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1fm5ll-0001fz-M1 for geh-help-gnu-emacs@m.gmane.org; Sat, 04 Aug 2018 19:15:33 -0400 Original-Path: usenet.stanford.edu!goblin2!goblin.stu.neva.ru!newsfeed.xs4all.nl!newsfeed9.news.xs4all.nl!2a00:1d38:fa:feed::184.MISMATCH!feeder4.usenet.farm!feed.usenet.farm!eternal-september.org!feeder.eternal-september.org!reader02.eternal-september.org!barmar.motzarella.org!.POSTED!not-for-mail Original-Newsgroups: gnu.emacs.help Original-Lines: 59 Original-Injection-Info: barmar.motzarella.org; posting-host="247ca45bfc09fe2523cc89badd3dc319"; logging-data="5678"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX190fkniyCsNK2Nf989pkmxs" Cancel-Lock: sha1:8vyP6t3SrYXhRA5D3xjCN+MGmuo= Original-Xref: usenet.stanford.edu gnu.emacs.help:223511 X-BeenThere: help-gnu-emacs@gnu.org X-Mailman-Version: 2.1.21 Precedence: list List-Id: Users list for the GNU Emacs text editor List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: help-gnu-emacs-bounces+geh-help-gnu-emacs=m.gmane.org@gnu.org Original-Sender: "help-gnu-emacs" Xref: news.gmane.org gmane.emacs.help:117636 Archived-At: In article , Drew Adams wrote: > > > > JSON is a very limited subset of Javascript notation for literals. Many > > > > things that are allowed in Javascript source code are not allowed in > > > > JSON. The reason is presumably to simplify the design of JSON parsers > > > > -- > > > > they don't have to deal with all possible input formats. > > > > > > Yes, but there is a difference between JSON as defined by its standard > > > and JSON as it is used in practice in many situations. The former is more > > > strict than the latter. > > > > > > Here is one description of possible differences between the strict syntax > > > of the standard and a lax syntax (one that does allow an extra, final > > > comma): > > > > > > https://docs.oracle.com/en/database/oracle/oracle- > > database/18/adjsn/conditions > > > -is-json-and-is-not-json.html#GUID-1B6CFFBE-85FE-41DD-BA14- > > DD1DE73EAB20 > > > > I think Oracle is unusual in being so permissive. I don't think the JSON > > parsers in PHP, Python, or Javascript allow as much as Oracle does. > > It's only permissive if/when you want it to be. You can easily get strict > behavior (i.e., per the JSON standard). IOW, you have a choice. > > And what you want can depend on what you're doing. You might want to be able > to store documents that are not strictly well-formed but are well-formed > according to the lax syntax. But you might also want to process such stored > documents in various ways, some of which accept only documents that are > strictly well-formed. You can specify the behavior you want for storing and > for various operations. > > > I think the only common extension to JSON that was commonly allowed was > > allowing the top-level value to be something other than an object or > > array. The JSON spec was recently updated to legitimize this. > > Yes, that's something different. The JSON spec is one thing. Uses of JSON > data in practice are another thing. Only a subset of such uses require > documents that adhere to the standard. Sometimes you can't control the kinds > of documents you receive, but you want to be able to process them whether > they strictly conform to the standard or not. The primary use of JSON is for communication between unrelated code, e.g. Javascript clients using PHP APIs. If you're creating JSON, you can't usually depend on it being parsed by a particular application, which might use a more permissive parser. If you're designing a self-contained system where you control both the creator and parser, then you can do anything you want. The purpose of standards is to ensure compatibility between code from different creators. -- Barry Margolin, barmar@alum.mit.edu Arlington, MA *** PLEASE post questions in newsgroups, not directly to me ***