2008-09-30 23:13:58 -07:00
|
|
|
/* ***** BEGIN LICENSE BLOCK *****
|
|
|
|
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
|
|
|
*
|
|
|
|
* The contents of this file are subject to the Mozilla Public License Version
|
|
|
|
* 1.1 (the "License"); you may not use this file except in compliance with
|
|
|
|
* the License. You may obtain a copy of the License at
|
|
|
|
* http://www.mozilla.org/MPL/
|
|
|
|
*
|
|
|
|
* Software distributed under the License is distributed on an "AS IS" basis,
|
|
|
|
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
|
|
* for the specific language governing rights and limitations under the
|
|
|
|
* License.
|
|
|
|
*
|
|
|
|
* The Original Code is SpiderMonkey JSON.
|
|
|
|
*
|
|
|
|
* The Initial Developer of the Original Code is
|
|
|
|
* Mozilla Corporation.
|
|
|
|
* Portions created by the Initial Developer are Copyright (C) 1998-1999
|
|
|
|
* the Initial Developer. All Rights Reserved.
|
|
|
|
*
|
|
|
|
* Contributor(s):
|
|
|
|
* Robert Sayre <sayrer@gmail.com>
|
|
|
|
*
|
|
|
|
* Alternatively, the contents of this file may be used under the terms of
|
|
|
|
* either of the GNU General Public License Version 2 or later (the "GPL"),
|
|
|
|
* or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
|
|
|
* in which case the provisions of the GPL or the LGPL are applicable instead
|
|
|
|
* of those above. If you wish to allow use of your version of this file only
|
|
|
|
* under the terms of either the GPL or the LGPL, and not to allow others to
|
|
|
|
* use your version of this file under the terms of the MPL, indicate your
|
|
|
|
* decision by deleting the provisions above and replace them with the notice
|
|
|
|
* and other provisions required by the GPL or the LGPL. If you do not delete
|
|
|
|
* the provisions above, a recipient may use your version of this file under
|
|
|
|
* the terms of any one of the MPL, the GPL or the LGPL.
|
|
|
|
*
|
|
|
|
* ***** END LICENSE BLOCK ***** */
|
|
|
|
|
|
|
|
#ifndef json_h___
|
|
|
|
#define json_h___
|
|
|
|
/*
|
|
|
|
* JS JSON functions.
|
|
|
|
*/
|
2009-04-21 12:09:27 -07:00
|
|
|
#include "jsscan.h"
|
2008-09-30 23:13:58 -07:00
|
|
|
|
|
|
|
#define JSON_MAX_DEPTH 2048
|
|
|
|
#define JSON_PARSER_BUFSIZE 1024
|
|
|
|
|
2010-07-14 23:19:36 -07:00
|
|
|
extern js::Class js_JSONClass;
|
2008-09-30 23:13:58 -07:00
|
|
|
|
|
|
|
extern JSObject *
|
|
|
|
js_InitJSONClass(JSContext *cx, JSObject *obj);
|
|
|
|
|
|
|
|
extern JSBool
|
2010-07-14 23:19:36 -07:00
|
|
|
js_Stringify(JSContext *cx, js::Value *vp, JSObject *replacer,
|
|
|
|
const js::Value &space, JSCharBuffer &cb);
|
2008-09-30 23:13:58 -07:00
|
|
|
|
2010-07-14 23:19:36 -07:00
|
|
|
extern JSBool js_TryJSON(JSContext *cx, js::Value *vp);
|
2008-09-30 23:13:58 -07:00
|
|
|
|
2010-05-12 15:03:04 -07:00
|
|
|
/* JSON parsing states; most permit leading whitespace. */
|
2008-09-30 23:13:58 -07:00
|
|
|
enum JSONParserState {
|
2010-05-12 15:03:04 -07:00
|
|
|
/* Start of string. */
|
2008-09-30 23:13:58 -07:00
|
|
|
JSON_PARSE_STATE_INIT,
|
2010-05-12 15:03:04 -07:00
|
|
|
|
|
|
|
/* JSON fully processed, expecting only trailing whitespace. */
|
|
|
|
JSON_PARSE_STATE_FINISHED,
|
|
|
|
|
|
|
|
/* Unused: to be removed in bug 564621. */
|
2008-09-30 23:13:58 -07:00
|
|
|
JSON_PARSE_STATE_OBJECT_VALUE,
|
2010-05-12 15:03:04 -07:00
|
|
|
|
|
|
|
/* Start of JSON value. */
|
2008-09-30 23:13:58 -07:00
|
|
|
JSON_PARSE_STATE_VALUE,
|
2010-05-12 15:03:04 -07:00
|
|
|
|
|
|
|
/* In object, at start of pair, at comma, or at closing brace. */
|
2008-09-30 23:13:58 -07:00
|
|
|
JSON_PARSE_STATE_OBJECT,
|
2010-05-12 15:03:04 -07:00
|
|
|
|
|
|
|
/* At start of pair within object, or at closing brace. */
|
2008-09-30 23:13:58 -07:00
|
|
|
JSON_PARSE_STATE_OBJECT_PAIR,
|
2010-05-12 15:03:04 -07:00
|
|
|
|
|
|
|
/* At : in key/value pair in object. */
|
2008-09-30 23:13:58 -07:00
|
|
|
JSON_PARSE_STATE_OBJECT_IN_PAIR,
|
2010-05-12 15:03:04 -07:00
|
|
|
|
|
|
|
/* In array, at start of element, at comma, or at closing bracket. */
|
2008-09-30 23:13:58 -07:00
|
|
|
JSON_PARSE_STATE_ARRAY,
|
2010-05-12 15:03:04 -07:00
|
|
|
|
|
|
|
|
|
|
|
/* The following states allow no leading whitespace. */
|
|
|
|
|
|
|
|
/* Within string literal. */
|
2008-09-30 23:13:58 -07:00
|
|
|
JSON_PARSE_STATE_STRING,
|
2010-05-12 15:03:04 -07:00
|
|
|
|
|
|
|
/* At first character after \ in string literal. */
|
2008-09-30 23:13:58 -07:00
|
|
|
JSON_PARSE_STATE_STRING_ESCAPE,
|
2010-05-12 15:03:04 -07:00
|
|
|
|
|
|
|
/* Within numbers in \uXXXX in string literal. */
|
2008-09-30 23:13:58 -07:00
|
|
|
JSON_PARSE_STATE_STRING_HEX,
|
2010-05-12 15:03:04 -07:00
|
|
|
|
|
|
|
/* Within numeric literal. */
|
2008-09-30 23:13:58 -07:00
|
|
|
JSON_PARSE_STATE_NUMBER,
|
2010-05-12 15:03:04 -07:00
|
|
|
|
|
|
|
/* Handling keywords (only null/true/false pass validity post-check). */
|
|
|
|
JSON_PARSE_STATE_KEYWORD
|
2008-09-30 23:13:58 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
enum JSONDataType {
|
|
|
|
JSON_DATA_STRING,
|
|
|
|
JSON_DATA_KEYSTRING,
|
|
|
|
JSON_DATA_NUMBER,
|
|
|
|
JSON_DATA_KEYWORD
|
|
|
|
};
|
|
|
|
|
2009-08-13 17:22:55 -07:00
|
|
|
struct JSONParser;
|
2008-09-30 23:13:58 -07:00
|
|
|
|
|
|
|
extern JSONParser *
|
2010-08-24 08:50:54 -07:00
|
|
|
js_BeginJSONParse(JSContext *cx, js::Value *rootVal, bool suppressErrors = false);
|
2008-09-30 23:13:58 -07:00
|
|
|
|
|
|
|
extern JSBool
|
|
|
|
js_ConsumeJSONText(JSContext *cx, JSONParser *jp, const jschar *data, uint32 len);
|
|
|
|
|
2010-03-29 19:47:40 -07:00
|
|
|
extern bool
|
2010-07-14 23:19:36 -07:00
|
|
|
js_FinishJSONParse(JSContext *cx, JSONParser *jp, const js::Value &reviver);
|
2008-09-30 23:13:58 -07:00
|
|
|
|
|
|
|
#endif /* json_h___ */
|