diff options
author | Bob Ippolito <bob@redivi.com> | 2008-03-23 08:34:46 +0000 |
---|---|---|
committer | Bob Ippolito <bob@redivi.com> | 2008-03-23 08:34:46 +0000 |
commit | 16fa400f522f63098842728fffc2439456b7f117 (patch) | |
tree | f767a3c0a41a3040c820dc029b9b6b4ef619d86c | |
parent | d11b931e488c419d0fc3fbbb2a583bb0890dcce0 (diff) | |
download | simplejson-16fa400f522f63098842728fffc2439456b7f117.tar.gz |
nicer cli, rebuild docs
git-svn-id: http://simplejson.googlecode.com/svn/trunk@70 a4795897-2c25-0410-b006-0d3caba88fa1
-rw-r--r-- | docs/class-simplejson.JSONDecoder.html | 2 | ||||
-rw-r--r-- | docs/class-simplejson.JSONEncoder.html | 17 | ||||
-rw-r--r-- | docs/index.html | 28 | ||||
-rw-r--r-- | docs/module-index.html | 12 | ||||
-rw-r--r-- | docs/module-simplejson-index.html | 8 | ||||
-rw-r--r-- | docs/module-simplejson.html | 28 | ||||
-rw-r--r-- | docs/simplejson/__init__.py.html | 544 | ||||
-rw-r--r-- | docs/simplejson/encoder.py.html | 723 | ||||
-rw-r--r-- | simplejson/__init__.py | 12 |
9 files changed, 733 insertions, 641 deletions
diff --git a/docs/class-simplejson.JSONDecoder.html b/docs/class-simplejson.JSONDecoder.html index d3a4503..1a4fa56 100644 --- a/docs/class-simplejson.JSONDecoder.html +++ b/docs/class-simplejson.JSONDecoder.html @@ -160,7 +160,7 @@ are encountered.</P> </DIV><DIV CLASS="pudge-member routine alias"> <A NAME="decode"></A> <H4 CLASS="pudge-member-name"><SPAN CLASS="prefix">f</SPAN> - <TT><A HREF="class-simplejson.JSONDecoder.html#decode" CLASS="pudge-obj-link">decode</A>(self, s, _w=<built-in method match of _sre.SRE_Pattern object at 0x15a3728>)</TT> + <TT><A HREF="class-simplejson.JSONDecoder.html#decode" CLASS="pudge-obj-link">decode</A>(self, s, _w=<built-in method match of _sre.SRE_Pattern object at 0x153a7b8>)</TT> <A HREF="simplejson/decoder.py.html?f=273&l=283#273" TITLE="View Source">...</A> </H4> <DIV CLASS="pudge-section rst"> diff --git a/docs/class-simplejson.JSONEncoder.html b/docs/class-simplejson.JSONEncoder.html index 6011119..964e73a 100644 --- a/docs/class-simplejson.JSONEncoder.html +++ b/docs/class-simplejson.JSONEncoder.html @@ -67,7 +67,7 @@ </LI> <LI> - <A HREF="simplejson/encoder.py.html?f=79&l=369#79" CLASS="pudge-section-link"> + <A HREF="simplejson/encoder.py.html?f=79&l=375#79" CLASS="pudge-section-link"> Source </A> </LI> @@ -125,8 +125,8 @@ implementation (to raise <TT CLASS="docutils literal"><SPAN CLASS="pre">TypeErro <DIV CLASS="pudge-member routine alias"> <A NAME="__init__"></A> <H4 CLASS="pudge-member-name"><SPAN CLASS="prefix">f</SPAN> - <TT><A HREF="class-simplejson.JSONEncoder.html#__init__" CLASS="pudge-obj-link">__init__</A>(self, skipkeys=False, ensure_ascii=True, check_circular=True, allow_nan=True, sort_keys=False, indent=None, separators=None, encoding='utf-8')</TT> - <A HREF="simplejson/encoder.py.html?f=111&l=163#111" TITLE="View Source">...</A> + <TT><A HREF="class-simplejson.JSONEncoder.html#__init__" CLASS="pudge-obj-link">__init__</A>(self, skipkeys=False, ensure_ascii=True, check_circular=True, allow_nan=True, sort_keys=False, indent=None, separators=None, encoding='utf-8', default=None)</TT> + <A HREF="simplejson/encoder.py.html?f=111&l=169#111" TITLE="View Source">...</A> </H4> <DIV CLASS="pudge-section rst"> @@ -157,6 +157,9 @@ None is the most compact representation.</P> <P>If specified, separators should be a (item_separator, key_separator) tuple. The default is (', ', ': '). To get the most compact JSON representation you should specify (',', ':') to eliminate whitespace.</P> +<P>If specified, default is a function that gets called for objects +that can't otherwise be serialized. It should return a JSON encodable +version of the object or raise a <TT CLASS="docutils literal"><SPAN CLASS="pre">TypeError</SPAN></TT>.</P> <P>If encoding is not None, then all input strings will be transformed into unicode using that encoding prior to JSON-encoding. The default is UTF-8.</P> @@ -167,7 +170,7 @@ The default is UTF-8.</P> <A NAME="default"></A> <H4 CLASS="pudge-member-name"><SPAN CLASS="prefix">f</SPAN> <TT><A HREF="class-simplejson.JSONEncoder.html#default" CLASS="pudge-obj-link">default</A>(self, o)</TT> - <A HREF="simplejson/encoder.py.html?f=313&l=332#313" TITLE="View Source">...</A> + <A HREF="simplejson/encoder.py.html?f=319&l=338#319" TITLE="View Source">...</A> </H4> <DIV CLASS="pudge-section rst"> @@ -195,7 +198,7 @@ def default(self, o): <A NAME="encode"></A> <H4 CLASS="pudge-member-name"><SPAN CLASS="prefix">f</SPAN> <TT><A HREF="class-simplejson.JSONEncoder.html#encode" CLASS="pudge-obj-link">encode</A>(self, o)</TT> - <A HREF="simplejson/encoder.py.html?f=333&l=353#333" TITLE="View Source">...</A> + <A HREF="simplejson/encoder.py.html?f=339&l=359#339" TITLE="View Source">...</A> </H4> <DIV CLASS="pudge-section rst"> @@ -213,7 +216,7 @@ def default(self, o): <A NAME="iterencode"></A> <H4 CLASS="pudge-member-name"><SPAN CLASS="prefix">f</SPAN> <TT><A HREF="class-simplejson.JSONEncoder.html#iterencode" CLASS="pudge-obj-link">iterencode</A>(self, o)</TT> - <A HREF="simplejson/encoder.py.html?f=354&l=369#354" TITLE="View Source">...</A> + <A HREF="simplejson/encoder.py.html?f=360&l=375#360" TITLE="View Source">...</A> </H4> <DIV CLASS="pudge-section rst"> @@ -238,7 +241,7 @@ for chunk in JSONEncoder().iterencode(bigobject): See - <A HREF="simplejson/encoder.py.html?f=79&l=369#79" TITLE="simplejson/encoder.py:79">the source</A> + <A HREF="simplejson/encoder.py.html?f=79&l=375#79" TITLE="simplejson/encoder.py:79">the source</A> for more information. </SMALL> </P> diff --git a/docs/index.html b/docs/index.html index 0d08a07..b792b03 100644 --- a/docs/index.html +++ b/docs/index.html @@ -164,6 +164,16 @@ decimal.Decimal(1.1) >>> list(ComplexEncoder().iterencode(2 + 1j)) ['[', '2.0', ', ', '1.0', ']'] </PRE> +<P>Using simplejson from the shell to validate and +pretty-print:</P> +<PRE CLASS="literal-block"> +$ echo '{"json":"obj"}' | python -msimplejson +{ + "json": "obj" +} +$ echo '{ 1.2:3.4}' | python -msimplejson +Expecting property name: line 1 column 2 (char 2) +</PRE> <P>Note that the JSON produced by this module's default settings is a subset of YAML, so it may be used as a serializer for that as well.</P> @@ -177,8 +187,8 @@ is a subset of YAML, so it may be used as a serializer for that as well.</P> <DIV CLASS="pudge-member routine "> <A NAME="dump"></A> <H4 CLASS="pudge-member-name"><SPAN CLASS="prefix">f</SPAN> - <TT><A HREF="module-simplejson.html#dump" CLASS="pudge-obj-link">dump</A>(obj, fp, skipkeys=False, ensure_ascii=True, check_circular=True, allow_nan=True, cls=None, indent=None, separators=None, encoding='utf-8', **kw)</TT> - <A HREF="simplejson/__init__.py.html?f=111&l=167#111" TITLE="View Source">...</A> + <TT><A HREF="module-simplejson.html#dump" CLASS="pudge-obj-link">dump</A>(obj, fp, skipkeys=False, ensure_ascii=True, check_circular=True, allow_nan=True, cls=None, indent=None, separators=None, encoding='utf-8', default=None, **kw)</TT> + <A HREF="simplejson/__init__.py.html?f=122&l=182#122" TITLE="View Source">...</A> </H4> <DIV CLASS="pudge-section rst"> @@ -208,6 +218,8 @@ of 0 will only insert newlines. <TT CLASS="docutils literal"><SPAN CLASS="pre">N then it will be used instead of the default <TT CLASS="docutils literal"><SPAN CLASS="pre">(',</SPAN> <SPAN CLASS="pre">',</SPAN> <SPAN CLASS="pre">':</SPAN> <SPAN CLASS="pre">')</SPAN></TT> separators. <TT CLASS="docutils literal"><SPAN CLASS="pre">(',',</SPAN> <SPAN CLASS="pre">':')</SPAN></TT> is the most compact JSON representation.</P> <P><TT CLASS="docutils literal"><SPAN CLASS="pre">encoding</SPAN></TT> is the character encoding for str instances, default is UTF-8.</P> +<P><TT CLASS="docutils literal"><SPAN CLASS="pre">default(obj)</SPAN></TT> is a function that should return a serializable version +of obj or raise TypeError. The default simply raises TypeError.</P> <P>To use a custom <TT CLASS="docutils literal"><SPAN CLASS="pre">JSONEncoder</SPAN></TT> subclass (e.g. one that overrides the <TT CLASS="docutils literal"><SPAN CLASS="pre">.default()</SPAN></TT> method to serialize additional types), specify it with the <TT CLASS="docutils literal"><SPAN CLASS="pre">cls</SPAN></TT> kwarg.</P> @@ -217,8 +229,8 @@ the <TT CLASS="docutils literal"><SPAN CLASS="pre">cls</SPAN></TT> kwarg.</P> </DIV><DIV CLASS="pudge-member routine "> <A NAME="dumps"></A> <H4 CLASS="pudge-member-name"><SPAN CLASS="prefix">f</SPAN> - <TT><A HREF="module-simplejson.html#dumps" CLASS="pudge-obj-link">dumps</A>(obj, skipkeys=False, ensure_ascii=True, check_circular=True, allow_nan=True, cls=None, indent=None, separators=None, encoding='utf-8', **kw)</TT> - <A HREF="simplejson/__init__.py.html?f=169&l=220#169" TITLE="View Source">...</A> + <TT><A HREF="module-simplejson.html#dumps" CLASS="pudge-obj-link">dumps</A>(obj, skipkeys=False, ensure_ascii=True, check_circular=True, allow_nan=True, cls=None, indent=None, separators=None, encoding='utf-8', default=None, **kw)</TT> + <A HREF="simplejson/__init__.py.html?f=184&l=238#184" TITLE="View Source">...</A> </H4> <DIV CLASS="pudge-section rst"> @@ -246,6 +258,8 @@ representation.</P> then it will be used instead of the default <TT CLASS="docutils literal"><SPAN CLASS="pre">(',</SPAN> <SPAN CLASS="pre">',</SPAN> <SPAN CLASS="pre">':</SPAN> <SPAN CLASS="pre">')</SPAN></TT> separators. <TT CLASS="docutils literal"><SPAN CLASS="pre">(',',</SPAN> <SPAN CLASS="pre">':')</SPAN></TT> is the most compact JSON representation.</P> <P><TT CLASS="docutils literal"><SPAN CLASS="pre">encoding</SPAN></TT> is the character encoding for str instances, default is UTF-8.</P> +<P><TT CLASS="docutils literal"><SPAN CLASS="pre">default(obj)</SPAN></TT> is a function that should return a serializable version +of obj or raise TypeError. The default simply raises TypeError.</P> <P>To use a custom <TT CLASS="docutils literal"><SPAN CLASS="pre">JSONEncoder</SPAN></TT> subclass (e.g. one that overrides the <TT CLASS="docutils literal"><SPAN CLASS="pre">.default()</SPAN></TT> method to serialize additional types), specify it with the <TT CLASS="docutils literal"><SPAN CLASS="pre">cls</SPAN></TT> kwarg.</P> @@ -256,7 +270,7 @@ the <TT CLASS="docutils literal"><SPAN CLASS="pre">cls</SPAN></TT> kwarg.</P> <A NAME="load"></A> <H4 CLASS="pudge-member-name"><SPAN CLASS="prefix">f</SPAN> <TT><A HREF="module-simplejson.html#load" CLASS="pudge-obj-link">load</A>(fp, encoding=None, cls=None, object_hook=None, parse_float=None, parse_int=None, parse_constant=None, **kw)</TT> - <A HREF="simplejson/__init__.py.html?f=223&l=248#223" TITLE="View Source">...</A> + <A HREF="simplejson/__init__.py.html?f=241&l=266#241" TITLE="View Source">...</A> </H4> <DIV CLASS="pudge-section rst"> @@ -283,7 +297,7 @@ kwarg.</P> <A NAME="loads"></A> <H4 CLASS="pudge-member-name"><SPAN CLASS="prefix">f</SPAN> <TT><A HREF="module-simplejson.html#loads" CLASS="pudge-obj-link">loads</A>(s, encoding=None, cls=None, object_hook=None, parse_float=None, parse_int=None, parse_constant=None, **kw)</TT> - <A HREF="simplejson/__init__.py.html?f=249&l=298#249" TITLE="View Source">...</A> + <A HREF="simplejson/__init__.py.html?f=267&l=316#267" TITLE="View Source">...</A> </H4> <DIV CLASS="pudge-section rst"> @@ -325,7 +339,7 @@ kwarg.</P> <H4 CLASS="pudge-member-name"><SPAN CLASS="prefix">C</SPAN> <TT> <A HREF="class-simplejson.JSONEncoder.html" CLASS="pudge-obj-link">JSONEncoder</A>(...)</TT> - <A HREF="simplejson/encoder.py.html?f=79&l=369#79" CLASS="pudge-member-view-source" TITLE="View Source">...</A> + <A HREF="simplejson/encoder.py.html?f=79&l=375#79" CLASS="pudge-member-view-source" TITLE="View Source">...</A> </H4> <DIV CLASS="pudge-section rst"> diff --git a/docs/module-index.html b/docs/module-index.html index 2dcc000..d68df3d 100644 --- a/docs/module-index.html +++ b/docs/module-index.html @@ -71,12 +71,6 @@ </DT> - <DT><TT><A HREF="module-simplejson.tests.html" CLASS="pudge-obj-link"> - simplejson.tests - </A></TT> - </DT> - - <DT><TT><A HREF="module-simplejson.decoder.html" CLASS="pudge-obj-link"> simplejson.decoder </A></TT> @@ -85,6 +79,12 @@ Implementation of JSONDecoder </DD> + <DT><TT><A HREF="module-simplejson.tests.html" CLASS="pudge-obj-link"> + simplejson.tests + </A></TT> + </DT> + + <DT><TT><A HREF="module-simplejson._speedups.html" CLASS="pudge-obj-link"> simplejson._speedups </A></TT> diff --git a/docs/module-simplejson-index.html b/docs/module-simplejson-index.html index 685fe97..c81bc40 100644 --- a/docs/module-simplejson-index.html +++ b/docs/module-simplejson-index.html @@ -61,7 +61,7 @@ <A HREF="module-simplejson.html#load"> <TT>load</TT> </A> - <A HREF="simplejson/__init__.py.html?f=223&l=248#223">...</A> + <A HREF="simplejson/__init__.py.html?f=241&l=266#241">...</A> <SMALL> - <SPAN CLASS="rst">Deserialize <TT CLASS="docutils literal"><SPAN CLASS="pre">fp</SPAN></TT> (a <TT CLASS="docutils literal"><SPAN CLASS="pre">.read()</SPAN></TT>-supporting file-like object containing a JSON document) to a Python object.</SPAN> @@ -72,7 +72,7 @@ a JSON document) to a Python object.</SPAN> <A HREF="module-simplejson.html#dump"> <TT>dump</TT> </A> - <A HREF="simplejson/__init__.py.html?f=111&l=167#111">...</A> + <A HREF="simplejson/__init__.py.html?f=122&l=182#122">...</A> <SMALL> - <SPAN CLASS="rst">Serialize <TT CLASS="docutils literal"><SPAN CLASS="pre">obj</SPAN></TT> as a JSON formatted stream to <TT CLASS="docutils literal"><SPAN CLASS="pre">fp</SPAN></TT> (a <TT CLASS="docutils literal"><SPAN CLASS="pre">.write()</SPAN></TT>-supporting file-like object).</SPAN> @@ -83,7 +83,7 @@ a JSON document) to a Python object.</SPAN> <A HREF="module-simplejson.html#dumps"> <TT>dumps</TT> </A> - <A HREF="simplejson/__init__.py.html?f=169&l=220#169">...</A> + <A HREF="simplejson/__init__.py.html?f=184&l=238#184">...</A> <SMALL> - <SPAN CLASS="rst">Serialize <TT CLASS="docutils literal"><SPAN CLASS="pre">obj</SPAN></TT> to a JSON formatted <TT CLASS="docutils literal"><SPAN CLASS="pre">str</SPAN></TT>.</SPAN> </SMALL> @@ -93,7 +93,7 @@ a JSON document) to a Python object.</SPAN> <A HREF="module-simplejson.html#loads"> <TT>loads</TT> </A> - <A HREF="simplejson/__init__.py.html?f=249&l=298#249">...</A> + <A HREF="simplejson/__init__.py.html?f=267&l=316#267">...</A> <SMALL> - <SPAN CLASS="rst">Deserialize <TT CLASS="docutils literal"><SPAN CLASS="pre">s</SPAN></TT> (a <TT CLASS="docutils literal"><SPAN CLASS="pre">str</SPAN></TT> or <TT CLASS="docutils literal"><SPAN CLASS="pre">unicode</SPAN></TT> instance containing a JSON document) to a Python object.</SPAN> diff --git a/docs/module-simplejson.html b/docs/module-simplejson.html index 0d08a07..b792b03 100644 --- a/docs/module-simplejson.html +++ b/docs/module-simplejson.html @@ -164,6 +164,16 @@ decimal.Decimal(1.1) >>> list(ComplexEncoder().iterencode(2 + 1j)) ['[', '2.0', ', ', '1.0', ']'] </PRE> +<P>Using simplejson from the shell to validate and +pretty-print:</P> +<PRE CLASS="literal-block"> +$ echo '{"json":"obj"}' | python -msimplejson +{ + "json": "obj" +} +$ echo '{ 1.2:3.4}' | python -msimplejson +Expecting property name: line 1 column 2 (char 2) +</PRE> <P>Note that the JSON produced by this module's default settings is a subset of YAML, so it may be used as a serializer for that as well.</P> @@ -177,8 +187,8 @@ is a subset of YAML, so it may be used as a serializer for that as well.</P> <DIV CLASS="pudge-member routine "> <A NAME="dump"></A> <H4 CLASS="pudge-member-name"><SPAN CLASS="prefix">f</SPAN> - <TT><A HREF="module-simplejson.html#dump" CLASS="pudge-obj-link">dump</A>(obj, fp, skipkeys=False, ensure_ascii=True, check_circular=True, allow_nan=True, cls=None, indent=None, separators=None, encoding='utf-8', **kw)</TT> - <A HREF="simplejson/__init__.py.html?f=111&l=167#111" TITLE="View Source">...</A> + <TT><A HREF="module-simplejson.html#dump" CLASS="pudge-obj-link">dump</A>(obj, fp, skipkeys=False, ensure_ascii=True, check_circular=True, allow_nan=True, cls=None, indent=None, separators=None, encoding='utf-8', default=None, **kw)</TT> + <A HREF="simplejson/__init__.py.html?f=122&l=182#122" TITLE="View Source">...</A> </H4> <DIV CLASS="pudge-section rst"> @@ -208,6 +218,8 @@ of 0 will only insert newlines. <TT CLASS="docutils literal"><SPAN CLASS="pre">N then it will be used instead of the default <TT CLASS="docutils literal"><SPAN CLASS="pre">(',</SPAN> <SPAN CLASS="pre">',</SPAN> <SPAN CLASS="pre">':</SPAN> <SPAN CLASS="pre">')</SPAN></TT> separators. <TT CLASS="docutils literal"><SPAN CLASS="pre">(',',</SPAN> <SPAN CLASS="pre">':')</SPAN></TT> is the most compact JSON representation.</P> <P><TT CLASS="docutils literal"><SPAN CLASS="pre">encoding</SPAN></TT> is the character encoding for str instances, default is UTF-8.</P> +<P><TT CLASS="docutils literal"><SPAN CLASS="pre">default(obj)</SPAN></TT> is a function that should return a serializable version +of obj or raise TypeError. The default simply raises TypeError.</P> <P>To use a custom <TT CLASS="docutils literal"><SPAN CLASS="pre">JSONEncoder</SPAN></TT> subclass (e.g. one that overrides the <TT CLASS="docutils literal"><SPAN CLASS="pre">.default()</SPAN></TT> method to serialize additional types), specify it with the <TT CLASS="docutils literal"><SPAN CLASS="pre">cls</SPAN></TT> kwarg.</P> @@ -217,8 +229,8 @@ the <TT CLASS="docutils literal"><SPAN CLASS="pre">cls</SPAN></TT> kwarg.</P> </DIV><DIV CLASS="pudge-member routine "> <A NAME="dumps"></A> <H4 CLASS="pudge-member-name"><SPAN CLASS="prefix">f</SPAN> - <TT><A HREF="module-simplejson.html#dumps" CLASS="pudge-obj-link">dumps</A>(obj, skipkeys=False, ensure_ascii=True, check_circular=True, allow_nan=True, cls=None, indent=None, separators=None, encoding='utf-8', **kw)</TT> - <A HREF="simplejson/__init__.py.html?f=169&l=220#169" TITLE="View Source">...</A> + <TT><A HREF="module-simplejson.html#dumps" CLASS="pudge-obj-link">dumps</A>(obj, skipkeys=False, ensure_ascii=True, check_circular=True, allow_nan=True, cls=None, indent=None, separators=None, encoding='utf-8', default=None, **kw)</TT> + <A HREF="simplejson/__init__.py.html?f=184&l=238#184" TITLE="View Source">...</A> </H4> <DIV CLASS="pudge-section rst"> @@ -246,6 +258,8 @@ representation.</P> then it will be used instead of the default <TT CLASS="docutils literal"><SPAN CLASS="pre">(',</SPAN> <SPAN CLASS="pre">',</SPAN> <SPAN CLASS="pre">':</SPAN> <SPAN CLASS="pre">')</SPAN></TT> separators. <TT CLASS="docutils literal"><SPAN CLASS="pre">(',',</SPAN> <SPAN CLASS="pre">':')</SPAN></TT> is the most compact JSON representation.</P> <P><TT CLASS="docutils literal"><SPAN CLASS="pre">encoding</SPAN></TT> is the character encoding for str instances, default is UTF-8.</P> +<P><TT CLASS="docutils literal"><SPAN CLASS="pre">default(obj)</SPAN></TT> is a function that should return a serializable version +of obj or raise TypeError. The default simply raises TypeError.</P> <P>To use a custom <TT CLASS="docutils literal"><SPAN CLASS="pre">JSONEncoder</SPAN></TT> subclass (e.g. one that overrides the <TT CLASS="docutils literal"><SPAN CLASS="pre">.default()</SPAN></TT> method to serialize additional types), specify it with the <TT CLASS="docutils literal"><SPAN CLASS="pre">cls</SPAN></TT> kwarg.</P> @@ -256,7 +270,7 @@ the <TT CLASS="docutils literal"><SPAN CLASS="pre">cls</SPAN></TT> kwarg.</P> <A NAME="load"></A> <H4 CLASS="pudge-member-name"><SPAN CLASS="prefix">f</SPAN> <TT><A HREF="module-simplejson.html#load" CLASS="pudge-obj-link">load</A>(fp, encoding=None, cls=None, object_hook=None, parse_float=None, parse_int=None, parse_constant=None, **kw)</TT> - <A HREF="simplejson/__init__.py.html?f=223&l=248#223" TITLE="View Source">...</A> + <A HREF="simplejson/__init__.py.html?f=241&l=266#241" TITLE="View Source">...</A> </H4> <DIV CLASS="pudge-section rst"> @@ -283,7 +297,7 @@ kwarg.</P> <A NAME="loads"></A> <H4 CLASS="pudge-member-name"><SPAN CLASS="prefix">f</SPAN> <TT><A HREF="module-simplejson.html#loads" CLASS="pudge-obj-link">loads</A>(s, encoding=None, cls=None, object_hook=None, parse_float=None, parse_int=None, parse_constant=None, **kw)</TT> - <A HREF="simplejson/__init__.py.html?f=249&l=298#249" TITLE="View Source">...</A> + <A HREF="simplejson/__init__.py.html?f=267&l=316#267" TITLE="View Source">...</A> </H4> <DIV CLASS="pudge-section rst"> @@ -325,7 +339,7 @@ kwarg.</P> <H4 CLASS="pudge-member-name"><SPAN CLASS="prefix">C</SPAN> <TT> <A HREF="class-simplejson.JSONEncoder.html" CLASS="pudge-obj-link">JSONEncoder</A>(...)</TT> - <A HREF="simplejson/encoder.py.html?f=79&l=369#79" CLASS="pudge-member-view-source" TITLE="View Source">...</A> + <A HREF="simplejson/encoder.py.html?f=79&l=375#79" CLASS="pudge-member-view-source" TITLE="View Source">...</A> </H4> <DIV CLASS="pudge-section rst"> diff --git a/docs/simplejson/__init__.py.html b/docs/simplejson/__init__.py.html index b6f9090..a7de4e2 100644 --- a/docs/simplejson/__init__.py.html +++ b/docs/simplejson/__init__.py.html @@ -158,254 +158,300 @@ function show_line_range() { <a class="lnum" href="#86" name="86">0086</a><span class="string">    ['[', '2.0', ', ', '1.0', ']']</span><br /> <a class="lnum" href="#87" name="87">0087</a><span class="string">    </span><br /> <a class="lnum" href="#88" name="88">0088</a><span class="string"></span><br /> -<a class="lnum" href="#89" name="89">0089</a><span class="string">Note that the JSON produced by this module's default settings</span><br /> -<a class="lnum" href="#90" name="90">0090</a><span class="string">is a subset of YAML, so it may be used as a serializer for that as well.</span><br /> -<a class="lnum" href="#91" name="91">0091</a><span class="string">"""</span><br /> -<a class="lnum" href="#92" name="92">0092</a><span class="name">__version__</span> <span class="op">=</span> <span class="string">'1.8'</span><br /> -<a class="lnum" href="#93" name="93">0093</a><span class="name">__all__</span> <span class="op">=</span> <span class="op">[</span><br /> -<a class="lnum" href="#94" name="94">0094</a>    <span class="string">'dump'</span><span class="op">,</span> <span class="string">'dumps'</span><span class="op">,</span> <span class="string">'load'</span><span class="op">,</span> <span class="string">'loads'</span><span class="op">,</span><br /> -<a class="lnum" href="#95" name="95">0095</a>    <span class="string">'JSONDecoder'</span><span class="op">,</span> <span class="string">'JSONEncoder'</span><span class="op">,</span><br /> -<a class="lnum" href="#96" name="96">0096</a><span class="op">]</span><br /> -<a class="lnum" href="#97" name="97">0097</a><br /> -<a class="lnum" href="#98" name="98">0098</a><span class="keyword">from</span> <span class="name">decoder</span> <span class="keyword">import</span> <span class="name">JSONDecoder</span><br /> -<a class="lnum" href="#99" name="99">0099</a><span class="keyword">from</span> <span class="name">encoder</span> <span class="keyword">import</span> <span class="name">JSONEncoder</span><br /> -<a class="lnum" href="#100" name="100">0100</a><br /> -<a class="lnum" href="#101" name="101">0101</a><span class="name">_default_encoder</span> <span class="op">=</span> <span class="name">JSONEncoder</span><span class="op">(</span><br /> -<a class="lnum" href="#102" name="102">0102</a>    <span class="name">skipkeys</span><span class="op">=</span><span class="name">False</span><span class="op">,</span><br /> -<a class="lnum" href="#103" name="103">0103</a>    <span class="name">ensure_ascii</span><span class="op">=</span><span class="name">True</span><span class="op">,</span><br /> -<a class="lnum" href="#104" name="104">0104</a>    <span class="name">check_circular</span><span class="op">=</span><span class="name">True</span><span class="op">,</span><br /> -<a class="lnum" href="#105" name="105">0105</a>    <span class="name">allow_nan</span><span class="op">=</span><span class="name">True</span><span class="op">,</span><br /> -<a class="lnum" href="#106" name="106">0106</a>    <span class="name">indent</span><span class="op">=</span><span class="name">None</span><span class="op">,</span><br /> -<a class="lnum" href="#107" name="107">0107</a>    <span class="name">separators</span><span class="op">=</span><span class="name">None</span><span class="op">,</span><br /> -<a class="lnum" href="#108" name="108">0108</a>    <span class="name">encoding</span><span class="op">=</span><span class="string">'utf-8'</span><br /> -<a class="lnum" href="#109" name="109">0109</a><span class="op">)</span><br /> +<a class="lnum" href="#89" name="89">0089</a><span class="string">Using simplejson from the shell to validate and</span><br /> +<a class="lnum" href="#90" name="90">0090</a><span class="string">pretty-print::</span><br /> +<a class="lnum" href="#91" name="91">0091</a><span class="string">    </span><br /> +<a class="lnum" href="#92" name="92">0092</a><span class="string">    $ echo '{"json":"obj"}' | python -msimplejson</span><br /> +<a class="lnum" href="#93" name="93">0093</a><span class="string">    {</span><br /> +<a class="lnum" href="#94" name="94">0094</a><span class="string">        "json": "obj"</span><br /> +<a class="lnum" href="#95" name="95">0095</a><span class="string">    }</span><br /> +<a class="lnum" href="#96" name="96">0096</a><span class="string">    $ echo '{ 1.2:3.4}' | python -msimplejson</span><br /> +<a class="lnum" href="#97" name="97">0097</a><span class="string">    Expecting property name: line 1 column 2 (char 2)</span><br /> +<a class="lnum" href="#98" name="98">0098</a><span class="string"></span><br /> +<a class="lnum" href="#99" name="99">0099</a><span class="string">Note that the JSON produced by this module's default settings</span><br /> +<a class="lnum" href="#100" name="100">0100</a><span class="string">is a subset of YAML, so it may be used as a serializer for that as well.</span><br /> +<a class="lnum" href="#101" name="101">0101</a><span class="string">"""</span><br /> +<a class="lnum" href="#102" name="102">0102</a><span class="name">__version__</span> <span class="op">=</span> <span class="string">'1.8'</span><br /> +<a class="lnum" href="#103" name="103">0103</a><span class="name">__all__</span> <span class="op">=</span> <span class="op">[</span><br /> +<a class="lnum" href="#104" name="104">0104</a>    <span class="string">'dump'</span><span class="op">,</span> <span class="string">'dumps'</span><span class="op">,</span> <span class="string">'load'</span><span class="op">,</span> <span class="string">'loads'</span><span class="op">,</span><br /> +<a class="lnum" href="#105" name="105">0105</a>    <span class="string">'JSONDecoder'</span><span class="op">,</span> <span class="string">'JSONEncoder'</span><span class="op">,</span><br /> +<a class="lnum" href="#106" name="106">0106</a><span class="op">]</span><br /> +<a class="lnum" href="#107" name="107">0107</a><br /> +<a class="lnum" href="#108" name="108">0108</a><span class="keyword">from</span> <span class="name">simplejson</span><span class="op">.</span><span class="name">decoder</span> <span class="keyword">import</span> <span class="name">JSONDecoder</span><br /> +<a class="lnum" href="#109" name="109">0109</a><span class="keyword">from</span> <span class="name">simplejson</span><span class="op">.</span><span class="name">encoder</span> <span class="keyword">import</span> <span class="name">JSONEncoder</span><br /> <a class="lnum" href="#110" name="110">0110</a><br /> -<a class="lnum" href="#111" name="111">0111</a><span class="keyword">def</span> <span class="name">dump</span><span class="op">(</span><span class="name">obj</span><span class="op">,</span> <span class="name">fp</span><span class="op">,</span> <span class="name">skipkeys</span><span class="op">=</span><span class="name">False</span><span class="op">,</span> <span class="name">ensure_ascii</span><span class="op">=</span><span class="name">True</span><span class="op">,</span> <span class="name">check_circular</span><span class="op">=</span><span class="name">True</span><span class="op">,</span><br /> -<a class="lnum" href="#112" name="112">0112</a>        <span class="name">allow_nan</span><span class="op">=</span><span class="name">True</span><span class="op">,</span> <span class="name">cls</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="name">indent</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="name">separators</span><span class="op">=</span><span class="name">None</span><span class="op">,</span><br /> -<a class="lnum" href="#113" name="113">0113</a>        <span class="name">encoding</span><span class="op">=</span><span class="string">'utf-8'</span><span class="op">,</span> <span class="op">**</span><span class="name">kw</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#114" name="114">0114</a>    <span class="string">"""</span><br /> -<a class="lnum" href="#115" name="115">0115</a><span class="string">    Serialize ``obj`` as a JSON formatted stream to ``fp`` (a</span><br /> -<a class="lnum" href="#116" name="116">0116</a><span class="string">    ``.write()``-supporting file-like object).</span><br /> -<a class="lnum" href="#117" name="117">0117</a><span class="string"></span><br /> -<a class="lnum" href="#118" name="118">0118</a><span class="string">    If ``skipkeys`` is ``True`` then ``dict`` keys that are not basic types</span><br /> -<a class="lnum" href="#119" name="119">0119</a><span class="string">    (``str``, ``unicode``, ``int``, ``long``, ``float``, ``bool``, ``None``) </span><br /> -<a class="lnum" href="#120" name="120">0120</a><span class="string">    will be skipped instead of raising a ``TypeError``.</span><br /> -<a class="lnum" href="#121" name="121">0121</a><span class="string"></span><br /> -<a class="lnum" href="#122" name="122">0122</a><span class="string">    If ``ensure_ascii`` is ``False``, then the some chunks written to ``fp``</span><br /> -<a class="lnum" href="#123" name="123">0123</a><span class="string">    may be ``unicode`` instances, subject to normal Python ``str`` to</span><br /> -<a class="lnum" href="#124" name="124">0124</a><span class="string">    ``unicode`` coercion rules. Unless ``fp.write()`` explicitly</span><br /> -<a class="lnum" href="#125" name="125">0125</a><span class="string">    understands ``unicode`` (as in ``codecs.getwriter()``) this is likely</span><br /> -<a class="lnum" href="#126" name="126">0126</a><span class="string">    to cause an error.</span><br /> -<a class="lnum" href="#127" name="127">0127</a><span class="string"></span><br /> -<a class="lnum" href="#128" name="128">0128</a><span class="string">    If ``check_circular`` is ``False``, then the circular reference check</span><br /> -<a class="lnum" href="#129" name="129">0129</a><span class="string">    for container types will be skipped and a circular reference will</span><br /> -<a class="lnum" href="#130" name="130">0130</a><span class="string">    result in an ``OverflowError`` (or worse).</span><br /> -<a class="lnum" href="#131" name="131">0131</a><span class="string"></span><br /> -<a class="lnum" href="#132" name="132">0132</a><span class="string">    If ``allow_nan`` is ``False``, then it will be a ``ValueError`` to</span><br /> -<a class="lnum" href="#133" name="133">0133</a><span class="string">    serialize out of range ``float`` values (``nan``, ``inf``, ``-inf``)</span><br /> -<a class="lnum" href="#134" name="134">0134</a><span class="string">    in strict compliance of the JSON specification, instead of using the</span><br /> -<a class="lnum" href="#135" name="135">0135</a><span class="string">    JavaScript equivalents (``NaN``, ``Infinity``, ``-Infinity``).</span><br /> -<a class="lnum" href="#136" name="136">0136</a><span class="string"></span><br /> -<a class="lnum" href="#137" name="137">0137</a><span class="string">    If ``indent`` is a non-negative integer, then JSON array elements and object</span><br /> -<a class="lnum" href="#138" name="138">0138</a><span class="string">    members will be pretty-printed with that indent level. An indent level</span><br /> -<a class="lnum" href="#139" name="139">0139</a><span class="string">    of 0 will only insert newlines. ``None`` is the most compact representation.</span><br /> -<a class="lnum" href="#140" name="140">0140</a><span class="string"></span><br /> -<a class="lnum" href="#141" name="141">0141</a><span class="string">    If ``separators`` is an ``(item_separator, dict_separator)`` tuple</span><br /> -<a class="lnum" href="#142" name="142">0142</a><span class="string">    then it will be used instead of the default ``(', ', ': ')`` separators.</span><br /> -<a class="lnum" href="#143" name="143">0143</a><span class="string">    ``(',', ':')`` is the most compact JSON representation.</span><br /> -<a class="lnum" href="#144" name="144">0144</a><span class="string"></span><br /> -<a class="lnum" href="#145" name="145">0145</a><span class="string">    ``encoding`` is the character encoding for str instances, default is UTF-8.</span><br /> -<a class="lnum" href="#146" name="146">0146</a><span class="string"></span><br /> -<a class="lnum" href="#147" name="147">0147</a><span class="string">    To use a custom ``JSONEncoder`` subclass (e.g. one that overrides the</span><br /> -<a class="lnum" href="#148" name="148">0148</a><span class="string">    ``.default()`` method to serialize additional types), specify it with</span><br /> -<a class="lnum" href="#149" name="149">0149</a><span class="string">    the ``cls`` kwarg.</span><br /> -<a class="lnum" href="#150" name="150">0150</a><span class="string">    """</span><br /> -<a class="lnum" href="#151" name="151">0151</a>    <span class="comment"># cached encoder</span><br /> -<a class="lnum" href="#152" name="152">0152</a><span class="comment"></span>    <span class="keyword">if</span> <span class="op">(</span><span class="name">skipkeys</span> <span class="keyword">is</span> <span class="name">False</span> <span class="keyword">and</span> <span class="name">ensure_ascii</span> <span class="keyword">is</span> <span class="name">True</span> <span class="keyword">and</span><br /> -<a class="lnum" href="#153" name="153">0153</a>        <span class="name">check_circular</span> <span class="keyword">is</span> <span class="name">True</span> <span class="keyword">and</span> <span class="name">allow_nan</span> <span class="keyword">is</span> <span class="name">True</span> <span class="keyword">and</span><br /> -<a class="lnum" href="#154" name="154">0154</a>        <span class="name">cls</span> <span class="keyword">is</span> <span class="name">None</span> <span class="keyword">and</span> <span class="name">indent</span> <span class="keyword">is</span> <span class="name">None</span> <span class="keyword">and</span> <span class="name">separators</span> <span class="keyword">is</span> <span class="name">None</span> <span class="keyword">and</span><br /> -<a class="lnum" href="#155" name="155">0155</a>        <span class="name">encoding</span> <span class="op">==</span> <span class="string">'utf-8'</span> <span class="keyword">and</span> <span class="keyword">not</span> <span class="name">kw</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#156" name="156">0156</a>        <span class="name">iterable</span> <span class="op">=</span> <span class="name">_default_encoder</span><span class="op">.</span><span class="name">iterencode</span><span class="op">(</span><span class="name">obj</span><span class="op">)</span><br /> -<a class="lnum" href="#157" name="157">0157</a>    <span class="keyword">else</span><span class="op">:</span><br /> -<a class="lnum" href="#158" name="158">0158</a>        <span class="keyword">if</span> <span class="name">cls</span> <span class="keyword">is</span> <span class="name">None</span><span class="op">:</span><br /> -<a class="lnum" href="#159" name="159">0159</a>            <span class="name">cls</span> <span class="op">=</span> <span class="name">JSONEncoder</span><br /> -<a class="lnum" href="#160" name="160">0160</a>        <span class="name">iterable</span> <span class="op">=</span> <span class="name">cls</span><span class="op">(</span><span class="name">skipkeys</span><span class="op">=</span><span class="name">skipkeys</span><span class="op">,</span> <span class="name">ensure_ascii</span><span class="op">=</span><span class="name">ensure_ascii</span><span class="op">,</span><br /> -<a class="lnum" href="#161" name="161">0161</a>            <span class="name">check_circular</span><span class="op">=</span><span class="name">check_circular</span><span class="op">,</span> <span class="name">allow_nan</span><span class="op">=</span><span class="name">allow_nan</span><span class="op">,</span> <span class="name">indent</span><span class="op">=</span><span class="name">indent</span><span class="op">,</span><br /> -<a class="lnum" href="#162" name="162">0162</a>            <span class="name">separators</span><span class="op">=</span><span class="name">separators</span><span class="op">,</span> <span class="name">encoding</span><span class="op">=</span><span class="name">encoding</span><span class="op">,</span> <span class="op">**</span><span class="name">kw</span><span class="op">)</span><span class="op">.</span><span class="name">iterencode</span><span class="op">(</span><span class="name">obj</span><span class="op">)</span><br /> -<a class="lnum" href="#163" name="163">0163</a>    <span class="comment"># could accelerate with writelines in some versions of Python, at</span><br /> -<a class="lnum" href="#164" name="164">0164</a><span class="comment"></span>    <span class="comment"># a debuggability cost</span><br /> -<a class="lnum" href="#165" name="165">0165</a><span class="comment"></span>    <span class="keyword">for</span> <span class="name">chunk</span> <span class="keyword">in</span> <span class="name">iterable</span><span class="op">:</span><br /> -<a class="lnum" href="#166" name="166">0166</a>        <span class="name">fp</span><span class="op">.</span><span class="name">write</span><span class="op">(</span><span class="name">chunk</span><span class="op">)</span><br /> -<a class="lnum" href="#167" name="167">0167</a><br /> -<a class="lnum" href="#168" name="168">0168</a><br /> -<a class="lnum" href="#169" name="169">0169</a><span class="keyword">def</span> <span class="name">dumps</span><span class="op">(</span><span class="name">obj</span><span class="op">,</span> <span class="name">skipkeys</span><span class="op">=</span><span class="name">False</span><span class="op">,</span> <span class="name">ensure_ascii</span><span class="op">=</span><span class="name">True</span><span class="op">,</span> <span class="name">check_circular</span><span class="op">=</span><span class="name">True</span><span class="op">,</span><br /> -<a class="lnum" href="#170" name="170">0170</a>        <span class="name">allow_nan</span><span class="op">=</span><span class="name">True</span><span class="op">,</span> <span class="name">cls</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="name">indent</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="name">separators</span><span class="op">=</span><span class="name">None</span><span class="op">,</span><br /> -<a class="lnum" href="#171" name="171">0171</a>        <span class="name">encoding</span><span class="op">=</span><span class="string">'utf-8'</span><span class="op">,</span> <span class="op">**</span><span class="name">kw</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#172" name="172">0172</a>    <span class="string">"""</span><br /> -<a class="lnum" href="#173" name="173">0173</a><span class="string">    Serialize ``obj`` to a JSON formatted ``str``.</span><br /> -<a class="lnum" href="#174" name="174">0174</a><span class="string"></span><br /> -<a class="lnum" href="#175" name="175">0175</a><span class="string">    If ``skipkeys`` is ``True`` then ``dict`` keys that are not basic types</span><br /> -<a class="lnum" href="#176" name="176">0176</a><span class="string">    (``str``, ``unicode``, ``int``, ``long``, ``float``, ``bool``, ``None``) </span><br /> -<a class="lnum" href="#177" name="177">0177</a><span class="string">    will be skipped instead of raising a ``TypeError``.</span><br /> -<a class="lnum" href="#178" name="178">0178</a><span class="string"></span><br /> -<a class="lnum" href="#179" name="179">0179</a><span class="string">    If ``ensure_ascii`` is ``False``, then the return value will be a</span><br /> -<a class="lnum" href="#180" name="180">0180</a><span class="string">    ``unicode`` instance subject to normal Python ``str`` to ``unicode``</span><br /> -<a class="lnum" href="#181" name="181">0181</a><span class="string">    coercion rules instead of being escaped to an ASCII ``str``.</span><br /> -<a class="lnum" href="#182" name="182">0182</a><span class="string"></span><br /> -<a class="lnum" href="#183" name="183">0183</a><span class="string">    If ``check_circular`` is ``False``, then the circular reference check</span><br /> -<a class="lnum" href="#184" name="184">0184</a><span class="string">    for container types will be skipped and a circular reference will</span><br /> -<a class="lnum" href="#185" name="185">0185</a><span class="string">    result in an ``OverflowError`` (or worse).</span><br /> -<a class="lnum" href="#186" name="186">0186</a><span class="string"></span><br /> -<a class="lnum" href="#187" name="187">0187</a><span class="string">    If ``allow_nan`` is ``False``, then it will be a ``ValueError`` to</span><br /> -<a class="lnum" href="#188" name="188">0188</a><span class="string">    serialize out of range ``float`` values (``nan``, ``inf``, ``-inf``) in</span><br /> -<a class="lnum" href="#189" name="189">0189</a><span class="string">    strict compliance of the JSON specification, instead of using the</span><br /> -<a class="lnum" href="#190" name="190">0190</a><span class="string">    JavaScript equivalents (``NaN``, ``Infinity``, ``-Infinity``).</span><br /> -<a class="lnum" href="#191" name="191">0191</a><span class="string"></span><br /> -<a class="lnum" href="#192" name="192">0192</a><span class="string">    If ``indent`` is a non-negative integer, then JSON array elements and</span><br /> -<a class="lnum" href="#193" name="193">0193</a><span class="string">    object members will be pretty-printed with that indent level. An indent</span><br /> -<a class="lnum" href="#194" name="194">0194</a><span class="string">    level of 0 will only insert newlines. ``None`` is the most compact</span><br /> -<a class="lnum" href="#195" name="195">0195</a><span class="string">    representation.</span><br /> -<a class="lnum" href="#196" name="196">0196</a><span class="string"></span><br /> -<a class="lnum" href="#197" name="197">0197</a><span class="string">    If ``separators`` is an ``(item_separator, dict_separator)`` tuple</span><br /> -<a class="lnum" href="#198" name="198">0198</a><span class="string">    then it will be used instead of the default ``(', ', ': ')`` separators.</span><br /> -<a class="lnum" href="#199" name="199">0199</a><span class="string">    ``(',', ':')`` is the most compact JSON representation.</span><br /> -<a class="lnum" href="#200" name="200">0200</a><span class="string"></span><br /> -<a class="lnum" href="#201" name="201">0201</a><span class="string">    ``encoding`` is the character encoding for str instances, default is UTF-8.</span><br /> -<a class="lnum" href="#202" name="202">0202</a><span class="string"></span><br /> -<a class="lnum" href="#203" name="203">0203</a><span class="string">    To use a custom ``JSONEncoder`` subclass (e.g. one that overrides the</span><br /> -<a class="lnum" href="#204" name="204">0204</a><span class="string">    ``.default()`` method to serialize additional types), specify it with</span><br /> -<a class="lnum" href="#205" name="205">0205</a><span class="string">    the ``cls`` kwarg.</span><br /> -<a class="lnum" href="#206" name="206">0206</a><span class="string">    """</span><br /> -<a class="lnum" href="#207" name="207">0207</a>    <span class="comment"># cached encoder</span><br /> -<a class="lnum" href="#208" name="208">0208</a><span class="comment"></span>    <span class="keyword">if</span> <span class="op">(</span><span class="name">skipkeys</span> <span class="keyword">is</span> <span class="name">False</span> <span class="keyword">and</span> <span class="name">ensure_ascii</span> <span class="keyword">is</span> <span class="name">True</span> <span class="keyword">and</span><br /> -<a class="lnum" href="#209" name="209">0209</a>        <span class="name">check_circular</span> <span class="keyword">is</span> <span class="name">True</span> <span class="keyword">and</span> <span class="name">allow_nan</span> <span class="keyword">is</span> <span class="name">True</span> <span class="keyword">and</span><br /> -<a class="lnum" href="#210" name="210">0210</a>        <span class="name">cls</span> <span class="keyword">is</span> <span class="name">None</span> <span class="keyword">and</span> <span class="name">indent</span> <span class="keyword">is</span> <span class="name">None</span> <span class="keyword">and</span> <span class="name">separators</span> <span class="keyword">is</span> <span class="name">None</span> <span class="keyword">and</span><br /> -<a class="lnum" href="#211" name="211">0211</a>        <span class="name">encoding</span> <span class="op">==</span> <span class="string">'utf-8'</span> <span class="keyword">and</span> <span class="keyword">not</span> <span class="name">kw</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#212" name="212">0212</a>        <span class="keyword">return</span> <span class="name">_default_encoder</span><span class="op">.</span><span class="name">encode</span><span class="op">(</span><span class="name">obj</span><span class="op">)</span><br /> -<a class="lnum" href="#213" name="213">0213</a>    <span class="keyword">if</span> <span class="name">cls</span> <span class="keyword">is</span> <span class="name">None</span><span class="op">:</span><br /> -<a class="lnum" href="#214" name="214">0214</a>        <span class="name">cls</span> <span class="op">=</span> <span class="name">JSONEncoder</span><br /> -<a class="lnum" href="#215" name="215">0215</a>    <span class="keyword">return</span> <span class="name">cls</span><span class="op">(</span><br /> -<a class="lnum" href="#216" name="216">0216</a>        <span class="name">skipkeys</span><span class="op">=</span><span class="name">skipkeys</span><span class="op">,</span> <span class="name">ensure_ascii</span><span class="op">=</span><span class="name">ensure_ascii</span><span class="op">,</span><br /> -<a class="lnum" href="#217" name="217">0217</a>        <span class="name">check_circular</span><span class="op">=</span><span class="name">check_circular</span><span class="op">,</span> <span class="name">allow_nan</span><span class="op">=</span><span class="name">allow_nan</span><span class="op">,</span> <span class="name">indent</span><span class="op">=</span><span class="name">indent</span><span class="op">,</span><br /> -<a class="lnum" href="#218" name="218">0218</a>        <span class="name">separators</span><span class="op">=</span><span class="name">separators</span><span class="op">,</span> <span class="name">encoding</span><span class="op">=</span><span class="name">encoding</span><span class="op">,</span><br /> -<a class="lnum" href="#219" name="219">0219</a>        <span class="op">**</span><span class="name">kw</span><span class="op">)</span><span class="op">.</span><span class="name">encode</span><span class="op">(</span><span class="name">obj</span><span class="op">)</span><br /> -<a class="lnum" href="#220" name="220">0220</a><br /> -<a class="lnum" href="#221" name="221">0221</a><span class="name">_default_decoder</span> <span class="op">=</span> <span class="name">JSONDecoder</span><span class="op">(</span><span class="name">encoding</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="name">object_hook</span><span class="op">=</span><span class="name">None</span><span class="op">)</span><br /> -<a class="lnum" href="#222" name="222">0222</a><br /> -<a class="lnum" href="#223" name="223">0223</a><span class="keyword">def</span> <span class="name">load</span><span class="op">(</span><span class="name">fp</span><span class="op">,</span> <span class="name">encoding</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="name">cls</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="name">object_hook</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="name">parse_float</span><span class="op">=</span><span class="name">None</span><span class="op">,</span><br /> -<a class="lnum" href="#224" name="224">0224</a>        <span class="name">parse_int</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="name">parse_constant</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="op">**</span><span class="name">kw</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#225" name="225">0225</a>    <span class="string">"""</span><br /> -<a class="lnum" href="#226" name="226">0226</a><span class="string">    Deserialize ``fp`` (a ``.read()``-supporting file-like object containing</span><br /> -<a class="lnum" href="#227" name="227">0227</a><span class="string">    a JSON document) to a Python object.</span><br /> -<a class="lnum" href="#228" name="228">0228</a><span class="string"></span><br /> -<a class="lnum" href="#229" name="229">0229</a><span class="string">    If the contents of ``fp`` is encoded with an ASCII based encoding other</span><br /> -<a class="lnum" href="#230" name="230">0230</a><span class="string">    than utf-8 (e.g. latin-1), then an appropriate ``encoding`` name must</span><br /> -<a class="lnum" href="#231" name="231">0231</a><span class="string">    be specified. Encodings that are not ASCII based (such as UCS-2) are</span><br /> -<a class="lnum" href="#232" name="232">0232</a><span class="string">    not allowed, and should be wrapped with</span><br /> -<a class="lnum" href="#233" name="233">0233</a><span class="string">    ``codecs.getreader(fp)(encoding)``, or simply decoded to a ``unicode``</span><br /> -<a class="lnum" href="#234" name="234">0234</a><span class="string">    object and passed to ``loads()``</span><br /> -<a class="lnum" href="#235" name="235">0235</a><span class="string"></span><br /> -<a class="lnum" href="#236" name="236">0236</a><span class="string">    ``object_hook`` is an optional function that will be called with the</span><br /> -<a class="lnum" href="#237" name="237">0237</a><span class="string">    result of any object literal decode (a ``dict``). The return value of</span><br /> -<a class="lnum" href="#238" name="238">0238</a><span class="string">    ``object_hook`` will be used instead of the ``dict``. This feature</span><br /> -<a class="lnum" href="#239" name="239">0239</a><span class="string">    can be used to implement custom decoders (e.g. JSON-RPC class hinting).</span><br /> -<a class="lnum" href="#240" name="240">0240</a><span class="string">    </span><br /> -<a class="lnum" href="#241" name="241">0241</a><span class="string">    To use a custom ``JSONDecoder`` subclass, specify it with the ``cls``</span><br /> -<a class="lnum" href="#242" name="242">0242</a><span class="string">    kwarg.</span><br /> -<a class="lnum" href="#243" name="243">0243</a><span class="string">    """</span><br /> -<a class="lnum" href="#244" name="244">0244</a>    <span class="keyword">return</span> <span class="name">loads</span><span class="op">(</span><span class="name">fp</span><span class="op">.</span><span class="name">read</span><span class="op">(</span><span class="op">)</span><span class="op">,</span><br /> -<a class="lnum" href="#245" name="245">0245</a>        <span class="name">encoding</span><span class="op">=</span><span class="name">encoding</span><span class="op">,</span> <span class="name">cls</span><span class="op">=</span><span class="name">cls</span><span class="op">,</span> <span class="name">object_hook</span><span class="op">=</span><span class="name">object_hook</span><span class="op">,</span><br /> -<a class="lnum" href="#246" name="246">0246</a>        <span class="name">parse_float</span><span class="op">=</span><span class="name">parse_float</span><span class="op">,</span> <span class="name">parse_int</span><span class="op">=</span><span class="name">parse_int</span><span class="op">,</span><br /> -<a class="lnum" href="#247" name="247">0247</a>        <span class="name">parse_constant</span><span class="op">=</span><span class="name">parse_constant</span><span class="op">,</span> <span class="op">**</span><span class="name">kw</span><span class="op">)</span><br /> -<a class="lnum" href="#248" name="248">0248</a><br /> -<a class="lnum" href="#249" name="249">0249</a><span class="keyword">def</span> <span class="name">loads</span><span class="op">(</span><span class="name">s</span><span class="op">,</span> <span class="name">encoding</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="name">cls</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="name">object_hook</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="name">parse_float</span><span class="op">=</span><span class="name">None</span><span class="op">,</span><br /> -<a class="lnum" href="#250" name="250">0250</a>        <span class="name">parse_int</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="name">parse_constant</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="op">**</span><span class="name">kw</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#251" name="251">0251</a>    <span class="string">"""</span><br /> -<a class="lnum" href="#252" name="252">0252</a><span class="string">    Deserialize ``s`` (a ``str`` or ``unicode`` instance containing a JSON</span><br /> -<a class="lnum" href="#253" name="253">0253</a><span class="string">    document) to a Python object.</span><br /> -<a class="lnum" href="#254" name="254">0254</a><span class="string"></span><br /> -<a class="lnum" href="#255" name="255">0255</a><span class="string">    If ``s`` is a ``str`` instance and is encoded with an ASCII based encoding</span><br /> -<a class="lnum" href="#256" name="256">0256</a><span class="string">    other than utf-8 (e.g. latin-1) then an appropriate ``encoding`` name</span><br /> -<a class="lnum" href="#257" name="257">0257</a><span class="string">    must be specified. Encodings that are not ASCII based (such as UCS-2)</span><br /> -<a class="lnum" href="#258" name="258">0258</a><span class="string">    are not allowed and should be decoded to ``unicode`` first.</span><br /> -<a class="lnum" href="#259" name="259">0259</a><span class="string"></span><br /> -<a class="lnum" href="#260" name="260">0260</a><span class="string">    ``object_hook`` is an optional function that will be called with the</span><br /> -<a class="lnum" href="#261" name="261">0261</a><span class="string">    result of any object literal decode (a ``dict``). The return value of</span><br /> -<a class="lnum" href="#262" name="262">0262</a><span class="string">    ``object_hook`` will be used instead of the ``dict``. This feature</span><br /> -<a class="lnum" href="#263" name="263">0263</a><span class="string">    can be used to implement custom decoders (e.g. JSON-RPC class hinting).</span><br /> -<a class="lnum" href="#264" name="264">0264</a><span class="string"></span><br /> -<a class="lnum" href="#265" name="265">0265</a><span class="string">    ``parse_float``, if specified, will be called with the string</span><br /> -<a class="lnum" href="#266" name="266">0266</a><span class="string">    of every JSON float to be decoded. By default this is equivalent to</span><br /> -<a class="lnum" href="#267" name="267">0267</a><span class="string">    float(num_str). This can be used to use another datatype or parser</span><br /> -<a class="lnum" href="#268" name="268">0268</a><span class="string">    for JSON floats (e.g. decimal.Decimal).</span><br /> -<a class="lnum" href="#269" name="269">0269</a><span class="string"></span><br /> -<a class="lnum" href="#270" name="270">0270</a><span class="string">    ``parse_int``, if specified, will be called with the string</span><br /> -<a class="lnum" href="#271" name="271">0271</a><span class="string">    of every JSON int to be decoded. By default this is equivalent to</span><br /> -<a class="lnum" href="#272" name="272">0272</a><span class="string">    int(num_str). This can be used to use another datatype or parser</span><br /> -<a class="lnum" href="#273" name="273">0273</a><span class="string">    for JSON integers (e.g. float).</span><br /> -<a class="lnum" href="#274" name="274">0274</a><span class="string"></span><br /> -<a class="lnum" href="#275" name="275">0275</a><span class="string">    ``parse_constant``, if specified, will be called with one of the</span><br /> -<a class="lnum" href="#276" name="276">0276</a><span class="string">    following strings: -Infinity, Infinity, NaN, null, true, false.</span><br /> -<a class="lnum" href="#277" name="277">0277</a><span class="string">    This can be used to raise an exception if invalid JSON numbers</span><br /> -<a class="lnum" href="#278" name="278">0278</a><span class="string">    are encountered.</span><br /> -<a class="lnum" href="#279" name="279">0279</a><span class="string"></span><br /> -<a class="lnum" href="#280" name="280">0280</a><span class="string">    To use a custom ``JSONDecoder`` subclass, specify it with the ``cls``</span><br /> -<a class="lnum" href="#281" name="281">0281</a><span class="string">    kwarg.</span><br /> -<a class="lnum" href="#282" name="282">0282</a><span class="string">    """</span><br /> -<a class="lnum" href="#283" name="283">0283</a>    <span class="keyword">if</span> <span class="op">(</span><span class="name">cls</span> <span class="keyword">is</span> <span class="name">None</span> <span class="keyword">and</span> <span class="name">encoding</span> <span class="keyword">is</span> <span class="name">None</span> <span class="keyword">and</span> <span class="name">object_hook</span> <span class="keyword">is</span> <span class="name">None</span> <span class="keyword">and</span><br /> -<a class="lnum" href="#284" name="284">0284</a>            <span class="name">parse_int</span> <span class="keyword">is</span> <span class="name">None</span> <span class="keyword">and</span> <span class="name">parse_float</span> <span class="keyword">is</span> <span class="name">None</span> <span class="keyword">and</span><br /> -<a class="lnum" href="#285" name="285">0285</a>            <span class="name">parse_constant</span> <span class="keyword">is</span> <span class="name">None</span> <span class="keyword">and</span> <span class="keyword">not</span> <span class="name">kw</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#286" name="286">0286</a>        <span class="keyword">return</span> <span class="name">_default_decoder</span><span class="op">.</span><span class="name">decode</span><span class="op">(</span><span class="name">s</span><span class="op">)</span><br /> -<a class="lnum" href="#287" name="287">0287</a>    <span class="keyword">if</span> <span class="name">cls</span> <span class="keyword">is</span> <span class="name">None</span><span class="op">:</span><br /> -<a class="lnum" href="#288" name="288">0288</a>        <span class="name">cls</span> <span class="op">=</span> <span class="name">JSONDecoder</span><br /> -<a class="lnum" href="#289" name="289">0289</a>    <span class="keyword">if</span> <span class="name">object_hook</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><span class="op">:</span><br /> -<a class="lnum" href="#290" name="290">0290</a>        <span class="name">kw</span><span class="op">[</span><span class="string">'object_hook'</span><span class="op">]</span> <span class="op">=</span> <span class="name">object_hook</span><br /> -<a class="lnum" href="#291" name="291">0291</a>    <span class="keyword">if</span> <span class="name">parse_float</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><span class="op">:</span><br /> -<a class="lnum" href="#292" name="292">0292</a>        <span class="name">kw</span><span class="op">[</span><span class="string">'parse_float'</span><span class="op">]</span> <span class="op">=</span> <span class="name">parse_float</span><br /> -<a class="lnum" href="#293" name="293">0293</a>    <span class="keyword">if</span> <span class="name">parse_int</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><span class="op">:</span><br /> -<a class="lnum" href="#294" name="294">0294</a>        <span class="name">kw</span><span class="op">[</span><span class="string">'parse_int'</span><span class="op">]</span> <span class="op">=</span> <span class="name">parse_int</span><br /> -<a class="lnum" href="#295" name="295">0295</a>    <span class="keyword">if</span> <span class="name">parse_constant</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><span class="op">:</span><br /> -<a class="lnum" href="#296" name="296">0296</a>        <span class="name">kw</span><span class="op">[</span><span class="string">'parse_constant'</span><span class="op">]</span> <span class="op">=</span> <span class="name">parse_constant</span><br /> -<a class="lnum" href="#297" name="297">0297</a>    <span class="keyword">return</span> <span class="name">cls</span><span class="op">(</span><span class="name">encoding</span><span class="op">=</span><span class="name">encoding</span><span class="op">,</span> <span class="op">**</span><span class="name">kw</span><span class="op">)</span><span class="op">.</span><span class="name">decode</span><span class="op">(</span><span class="name">s</span><span class="op">)</span><br /> -<a class="lnum" href="#298" name="298">0298</a><br /> -<a class="lnum" href="#299" name="299">0299</a><span class="comment">#</span><br /> -<a class="lnum" href="#300" name="300">0300</a><span class="comment"></span><span class="comment"># Compatibility cruft from other libraries</span><br /> -<a class="lnum" href="#301" name="301">0301</a><span class="comment"></span><span class="comment">#</span><br /> -<a class="lnum" href="#302" name="302">0302</a><span class="comment"></span><br /> -<a class="lnum" href="#303" name="303">0303</a><span class="keyword">def</span> <span class="name">decode</span><span class="op">(</span><span class="name">s</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#304" name="304">0304</a>    <span class="string">"""</span><br /> -<a class="lnum" href="#305" name="305">0305</a><span class="string">    demjson, python-cjson API compatibility hook. Use loads(s) instead.</span><br /> -<a class="lnum" href="#306" name="306">0306</a><span class="string">    """</span><br /> -<a class="lnum" href="#307" name="307">0307</a>    <span class="keyword">import</span> <span class="name">warnings</span><br /> -<a class="lnum" href="#308" name="308">0308</a>    <span class="name">warnings</span><span class="op">.</span><span class="name">warn</span><span class="op">(</span><span class="string">"simplejson.loads(s) should be used instead of decode(s)"</span><span class="op">,</span><br /> -<a class="lnum" href="#309" name="309">0309</a>        <span class="name">DeprecationWarning</span><span class="op">)</span><br /> -<a class="lnum" href="#310" name="310">0310</a>    <span class="keyword">return</span> <span class="name">loads</span><span class="op">(</span><span class="name">s</span><span class="op">)</span><br /> -<a class="lnum" href="#311" name="311">0311</a><br /> -<a class="lnum" href="#312" name="312">0312</a><span class="keyword">def</span> <span class="name">encode</span><span class="op">(</span><span class="name">obj</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#313" name="313">0313</a>    <span class="string">"""</span><br /> -<a class="lnum" href="#314" name="314">0314</a><span class="string">    demjson, python-cjson compatibility hook. Use dumps(s) instead.</span><br /> -<a class="lnum" href="#315" name="315">0315</a><span class="string">    """</span><br /> -<a class="lnum" href="#316" name="316">0316</a>    <span class="keyword">import</span> <span class="name">warnings</span><br /> -<a class="lnum" href="#317" name="317">0317</a>    <span class="name">warnings</span><span class="op">.</span><span class="name">warn</span><span class="op">(</span><span class="string">"simplejson.dumps(s) should be used instead of encode(s)"</span><span class="op">,</span><br /> -<a class="lnum" href="#318" name="318">0318</a>        <span class="name">DeprecationWarning</span><span class="op">)</span><br /> -<a class="lnum" href="#319" name="319">0319</a>    <span class="keyword">return</span> <span class="name">dumps</span><span class="op">(</span><span class="name">obj</span><span class="op">)</span><br /> -<a class="lnum" href="#320" name="320">0320</a><br /> -<a class="lnum" href="#321" name="321">0321</a><span class="keyword">def</span> <span class="name">read</span><span class="op">(</span><span class="name">s</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#111" name="111">0111</a><span class="name">_default_encoder</span> <span class="op">=</span> <span class="name">JSONEncoder</span><span class="op">(</span><br /> +<a class="lnum" href="#112" name="112">0112</a>    <span class="name">skipkeys</span><span class="op">=</span><span class="name">False</span><span class="op">,</span><br /> +<a class="lnum" href="#113" name="113">0113</a>    <span class="name">ensure_ascii</span><span class="op">=</span><span class="name">True</span><span class="op">,</span><br /> +<a class="lnum" href="#114" name="114">0114</a>    <span class="name">check_circular</span><span class="op">=</span><span class="name">True</span><span class="op">,</span><br /> +<a class="lnum" href="#115" name="115">0115</a>    <span class="name">allow_nan</span><span class="op">=</span><span class="name">True</span><span class="op">,</span><br /> +<a class="lnum" href="#116" name="116">0116</a>    <span class="name">indent</span><span class="op">=</span><span class="name">None</span><span class="op">,</span><br /> +<a class="lnum" href="#117" name="117">0117</a>    <span class="name">separators</span><span class="op">=</span><span class="name">None</span><span class="op">,</span><br /> +<a class="lnum" href="#118" name="118">0118</a>    <span class="name">encoding</span><span class="op">=</span><span class="string">'utf-8'</span><span class="op">,</span><br /> +<a class="lnum" href="#119" name="119">0119</a>    <span class="name">default</span><span class="op">=</span><span class="name">None</span><span class="op">,</span><br /> +<a class="lnum" href="#120" name="120">0120</a><span class="op">)</span><br /> +<a class="lnum" href="#121" name="121">0121</a><br /> +<a class="lnum" href="#122" name="122">0122</a><span class="keyword">def</span> <span class="name">dump</span><span class="op">(</span><span class="name">obj</span><span class="op">,</span> <span class="name">fp</span><span class="op">,</span> <span class="name">skipkeys</span><span class="op">=</span><span class="name">False</span><span class="op">,</span> <span class="name">ensure_ascii</span><span class="op">=</span><span class="name">True</span><span class="op">,</span> <span class="name">check_circular</span><span class="op">=</span><span class="name">True</span><span class="op">,</span><br /> +<a class="lnum" href="#123" name="123">0123</a>        <span class="name">allow_nan</span><span class="op">=</span><span class="name">True</span><span class="op">,</span> <span class="name">cls</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="name">indent</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="name">separators</span><span class="op">=</span><span class="name">None</span><span class="op">,</span><br /> +<a class="lnum" href="#124" name="124">0124</a>        <span class="name">encoding</span><span class="op">=</span><span class="string">'utf-8'</span><span class="op">,</span> <span class="name">default</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="op">**</span><span class="name">kw</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#125" name="125">0125</a>    <span class="string">"""</span><br /> +<a class="lnum" href="#126" name="126">0126</a><span class="string">    Serialize ``obj`` as a JSON formatted stream to ``fp`` (a</span><br /> +<a class="lnum" href="#127" name="127">0127</a><span class="string">    ``.write()``-supporting file-like object).</span><br /> +<a class="lnum" href="#128" name="128">0128</a><span class="string"></span><br /> +<a class="lnum" href="#129" name="129">0129</a><span class="string">    If ``skipkeys`` is ``True`` then ``dict`` keys that are not basic types</span><br /> +<a class="lnum" href="#130" name="130">0130</a><span class="string">    (``str``, ``unicode``, ``int``, ``long``, ``float``, ``bool``, ``None``) </span><br /> +<a class="lnum" href="#131" name="131">0131</a><span class="string">    will be skipped instead of raising a ``TypeError``.</span><br /> +<a class="lnum" href="#132" name="132">0132</a><span class="string"></span><br /> +<a class="lnum" href="#133" name="133">0133</a><span class="string">    If ``ensure_ascii`` is ``False``, then the some chunks written to ``fp``</span><br /> +<a class="lnum" href="#134" name="134">0134</a><span class="string">    may be ``unicode`` instances, subject to normal Python ``str`` to</span><br /> +<a class="lnum" href="#135" name="135">0135</a><span class="string">    ``unicode`` coercion rules. Unless ``fp.write()`` explicitly</span><br /> +<a class="lnum" href="#136" name="136">0136</a><span class="string">    understands ``unicode`` (as in ``codecs.getwriter()``) this is likely</span><br /> +<a class="lnum" href="#137" name="137">0137</a><span class="string">    to cause an error.</span><br /> +<a class="lnum" href="#138" name="138">0138</a><span class="string"></span><br /> +<a class="lnum" href="#139" name="139">0139</a><span class="string">    If ``check_circular`` is ``False``, then the circular reference check</span><br /> +<a class="lnum" href="#140" name="140">0140</a><span class="string">    for container types will be skipped and a circular reference will</span><br /> +<a class="lnum" href="#141" name="141">0141</a><span class="string">    result in an ``OverflowError`` (or worse).</span><br /> +<a class="lnum" href="#142" name="142">0142</a><span class="string"></span><br /> +<a class="lnum" href="#143" name="143">0143</a><span class="string">    If ``allow_nan`` is ``False``, then it will be a ``ValueError`` to</span><br /> +<a class="lnum" href="#144" name="144">0144</a><span class="string">    serialize out of range ``float`` values (``nan``, ``inf``, ``-inf``)</span><br /> +<a class="lnum" href="#145" name="145">0145</a><span class="string">    in strict compliance of the JSON specification, instead of using the</span><br /> +<a class="lnum" href="#146" name="146">0146</a><span class="string">    JavaScript equivalents (``NaN``, ``Infinity``, ``-Infinity``).</span><br /> +<a class="lnum" href="#147" name="147">0147</a><span class="string"></span><br /> +<a class="lnum" href="#148" name="148">0148</a><span class="string">    If ``indent`` is a non-negative integer, then JSON array elements and object</span><br /> +<a class="lnum" href="#149" name="149">0149</a><span class="string">    members will be pretty-printed with that indent level. An indent level</span><br /> +<a class="lnum" href="#150" name="150">0150</a><span class="string">    of 0 will only insert newlines. ``None`` is the most compact representation.</span><br /> +<a class="lnum" href="#151" name="151">0151</a><span class="string"></span><br /> +<a class="lnum" href="#152" name="152">0152</a><span class="string">    If ``separators`` is an ``(item_separator, dict_separator)`` tuple</span><br /> +<a class="lnum" href="#153" name="153">0153</a><span class="string">    then it will be used instead of the default ``(', ', ': ')`` separators.</span><br /> +<a class="lnum" href="#154" name="154">0154</a><span class="string">    ``(',', ':')`` is the most compact JSON representation.</span><br /> +<a class="lnum" href="#155" name="155">0155</a><span class="string"></span><br /> +<a class="lnum" href="#156" name="156">0156</a><span class="string">    ``encoding`` is the character encoding for str instances, default is UTF-8.</span><br /> +<a class="lnum" href="#157" name="157">0157</a><span class="string"></span><br /> +<a class="lnum" href="#158" name="158">0158</a><span class="string">    ``default(obj)`` is a function that should return a serializable version</span><br /> +<a class="lnum" href="#159" name="159">0159</a><span class="string">    of obj or raise TypeError. The default simply raises TypeError.</span><br /> +<a class="lnum" href="#160" name="160">0160</a><span class="string"></span><br /> +<a class="lnum" href="#161" name="161">0161</a><span class="string">    To use a custom ``JSONEncoder`` subclass (e.g. one that overrides the</span><br /> +<a class="lnum" href="#162" name="162">0162</a><span class="string">    ``.default()`` method to serialize additional types), specify it with</span><br /> +<a class="lnum" href="#163" name="163">0163</a><span class="string">    the ``cls`` kwarg.</span><br /> +<a class="lnum" href="#164" name="164">0164</a><span class="string">    """</span><br /> +<a class="lnum" href="#165" name="165">0165</a>    <span class="comment"># cached encoder</span><br /> +<a class="lnum" href="#166" name="166">0166</a><span class="comment"></span>    <span class="keyword">if</span> <span class="op">(</span><span class="name">skipkeys</span> <span class="keyword">is</span> <span class="name">False</span> <span class="keyword">and</span> <span class="name">ensure_ascii</span> <span class="keyword">is</span> <span class="name">True</span> <span class="keyword">and</span><br /> +<a class="lnum" href="#167" name="167">0167</a>        <span class="name">check_circular</span> <span class="keyword">is</span> <span class="name">True</span> <span class="keyword">and</span> <span class="name">allow_nan</span> <span class="keyword">is</span> <span class="name">True</span> <span class="keyword">and</span><br /> +<a class="lnum" href="#168" name="168">0168</a>        <span class="name">cls</span> <span class="keyword">is</span> <span class="name">None</span> <span class="keyword">and</span> <span class="name">indent</span> <span class="keyword">is</span> <span class="name">None</span> <span class="keyword">and</span> <span class="name">separators</span> <span class="keyword">is</span> <span class="name">None</span> <span class="keyword">and</span><br /> +<a class="lnum" href="#169" name="169">0169</a>        <span class="name">encoding</span> <span class="op">==</span> <span class="string">'utf-8'</span> <span class="keyword">and</span> <span class="name">default</span> <span class="keyword">is</span> <span class="name">None</span> <span class="keyword">and</span> <span class="keyword">not</span> <span class="name">kw</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#170" name="170">0170</a>        <span class="name">iterable</span> <span class="op">=</span> <span class="name">_default_encoder</span><span class="op">.</span><span class="name">iterencode</span><span class="op">(</span><span class="name">obj</span><span class="op">)</span><br /> +<a class="lnum" href="#171" name="171">0171</a>    <span class="keyword">else</span><span class="op">:</span><br /> +<a class="lnum" href="#172" name="172">0172</a>        <span class="keyword">if</span> <span class="name">cls</span> <span class="keyword">is</span> <span class="name">None</span><span class="op">:</span><br /> +<a class="lnum" href="#173" name="173">0173</a>            <span class="name">cls</span> <span class="op">=</span> <span class="name">JSONEncoder</span><br /> +<a class="lnum" href="#174" name="174">0174</a>        <span class="name">iterable</span> <span class="op">=</span> <span class="name">cls</span><span class="op">(</span><span class="name">skipkeys</span><span class="op">=</span><span class="name">skipkeys</span><span class="op">,</span> <span class="name">ensure_ascii</span><span class="op">=</span><span class="name">ensure_ascii</span><span class="op">,</span><br /> +<a class="lnum" href="#175" name="175">0175</a>            <span class="name">check_circular</span><span class="op">=</span><span class="name">check_circular</span><span class="op">,</span> <span class="name">allow_nan</span><span class="op">=</span><span class="name">allow_nan</span><span class="op">,</span> <span class="name">indent</span><span class="op">=</span><span class="name">indent</span><span class="op">,</span><br /> +<a class="lnum" href="#176" name="176">0176</a>            <span class="name">separators</span><span class="op">=</span><span class="name">separators</span><span class="op">,</span> <span class="name">encoding</span><span class="op">=</span><span class="name">encoding</span><span class="op">,</span><br /> +<a class="lnum" href="#177" name="177">0177</a>            <span class="name">default</span><span class="op">=</span><span class="name">default</span><span class="op">,</span> <span class="op">**</span><span class="name">kw</span><span class="op">)</span><span class="op">.</span><span class="name">iterencode</span><span class="op">(</span><span class="name">obj</span><span class="op">)</span><br /> +<a class="lnum" href="#178" name="178">0178</a>    <span class="comment"># could accelerate with writelines in some versions of Python, at</span><br /> +<a class="lnum" href="#179" name="179">0179</a><span class="comment"></span>    <span class="comment"># a debuggability cost</span><br /> +<a class="lnum" href="#180" name="180">0180</a><span class="comment"></span>    <span class="keyword">for</span> <span class="name">chunk</span> <span class="keyword">in</span> <span class="name">iterable</span><span class="op">:</span><br /> +<a class="lnum" href="#181" name="181">0181</a>        <span class="name">fp</span><span class="op">.</span><span class="name">write</span><span class="op">(</span><span class="name">chunk</span><span class="op">)</span><br /> +<a class="lnum" href="#182" name="182">0182</a><br /> +<a class="lnum" href="#183" name="183">0183</a><br /> +<a class="lnum" href="#184" name="184">0184</a><span class="keyword">def</span> <span class="name">dumps</span><span class="op">(</span><span class="name">obj</span><span class="op">,</span> <span class="name">skipkeys</span><span class="op">=</span><span class="name">False</span><span class="op">,</span> <span class="name">ensure_ascii</span><span class="op">=</span><span class="name">True</span><span class="op">,</span> <span class="name">check_circular</span><span class="op">=</span><span class="name">True</span><span class="op">,</span><br /> +<a class="lnum" href="#185" name="185">0185</a>        <span class="name">allow_nan</span><span class="op">=</span><span class="name">True</span><span class="op">,</span> <span class="name">cls</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="name">indent</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="name">separators</span><span class="op">=</span><span class="name">None</span><span class="op">,</span><br /> +<a class="lnum" href="#186" name="186">0186</a>        <span class="name">encoding</span><span class="op">=</span><span class="string">'utf-8'</span><span class="op">,</span> <span class="name">default</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="op">**</span><span class="name">kw</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#187" name="187">0187</a>    <span class="string">"""</span><br /> +<a class="lnum" href="#188" name="188">0188</a><span class="string">    Serialize ``obj`` to a JSON formatted ``str``.</span><br /> +<a class="lnum" href="#189" name="189">0189</a><span class="string"></span><br /> +<a class="lnum" href="#190" name="190">0190</a><span class="string">    If ``skipkeys`` is ``True`` then ``dict`` keys that are not basic types</span><br /> +<a class="lnum" href="#191" name="191">0191</a><span class="string">    (``str``, ``unicode``, ``int``, ``long``, ``float``, ``bool``, ``None``) </span><br /> +<a class="lnum" href="#192" name="192">0192</a><span class="string">    will be skipped instead of raising a ``TypeError``.</span><br /> +<a class="lnum" href="#193" name="193">0193</a><span class="string"></span><br /> +<a class="lnum" href="#194" name="194">0194</a><span class="string">    If ``ensure_ascii`` is ``False``, then the return value will be a</span><br /> +<a class="lnum" href="#195" name="195">0195</a><span class="string">    ``unicode`` instance subject to normal Python ``str`` to ``unicode``</span><br /> +<a class="lnum" href="#196" name="196">0196</a><span class="string">    coercion rules instead of being escaped to an ASCII ``str``.</span><br /> +<a class="lnum" href="#197" name="197">0197</a><span class="string"></span><br /> +<a class="lnum" href="#198" name="198">0198</a><span class="string">    If ``check_circular`` is ``False``, then the circular reference check</span><br /> +<a class="lnum" href="#199" name="199">0199</a><span class="string">    for container types will be skipped and a circular reference will</span><br /> +<a class="lnum" href="#200" name="200">0200</a><span class="string">    result in an ``OverflowError`` (or worse).</span><br /> +<a class="lnum" href="#201" name="201">0201</a><span class="string"></span><br /> +<a class="lnum" href="#202" name="202">0202</a><span class="string">    If ``allow_nan`` is ``False``, then it will be a ``ValueError`` to</span><br /> +<a class="lnum" href="#203" name="203">0203</a><span class="string">    serialize out of range ``float`` values (``nan``, ``inf``, ``-inf``) in</span><br /> +<a class="lnum" href="#204" name="204">0204</a><span class="string">    strict compliance of the JSON specification, instead of using the</span><br /> +<a class="lnum" href="#205" name="205">0205</a><span class="string">    JavaScript equivalents (``NaN``, ``Infinity``, ``-Infinity``).</span><br /> +<a class="lnum" href="#206" name="206">0206</a><span class="string"></span><br /> +<a class="lnum" href="#207" name="207">0207</a><span class="string">    If ``indent`` is a non-negative integer, then JSON array elements and</span><br /> +<a class="lnum" href="#208" name="208">0208</a><span class="string">    object members will be pretty-printed with that indent level. An indent</span><br /> +<a class="lnum" href="#209" name="209">0209</a><span class="string">    level of 0 will only insert newlines. ``None`` is the most compact</span><br /> +<a class="lnum" href="#210" name="210">0210</a><span class="string">    representation.</span><br /> +<a class="lnum" href="#211" name="211">0211</a><span class="string"></span><br /> +<a class="lnum" href="#212" name="212">0212</a><span class="string">    If ``separators`` is an ``(item_separator, dict_separator)`` tuple</span><br /> +<a class="lnum" href="#213" name="213">0213</a><span class="string">    then it will be used instead of the default ``(', ', ': ')`` separators.</span><br /> +<a class="lnum" href="#214" name="214">0214</a><span class="string">    ``(',', ':')`` is the most compact JSON representation.</span><br /> +<a class="lnum" href="#215" name="215">0215</a><span class="string"></span><br /> +<a class="lnum" href="#216" name="216">0216</a><span class="string">    ``encoding`` is the character encoding for str instances, default is UTF-8.</span><br /> +<a class="lnum" href="#217" name="217">0217</a><span class="string"></span><br /> +<a class="lnum" href="#218" name="218">0218</a><span class="string">    ``default(obj)`` is a function that should return a serializable version</span><br /> +<a class="lnum" href="#219" name="219">0219</a><span class="string">    of obj or raise TypeError. The default simply raises TypeError.</span><br /> +<a class="lnum" href="#220" name="220">0220</a><span class="string"></span><br /> +<a class="lnum" href="#221" name="221">0221</a><span class="string">    To use a custom ``JSONEncoder`` subclass (e.g. one that overrides the</span><br /> +<a class="lnum" href="#222" name="222">0222</a><span class="string">    ``.default()`` method to serialize additional types), specify it with</span><br /> +<a class="lnum" href="#223" name="223">0223</a><span class="string">    the ``cls`` kwarg.</span><br /> +<a class="lnum" href="#224" name="224">0224</a><span class="string">    """</span><br /> +<a class="lnum" href="#225" name="225">0225</a>    <span class="comment"># cached encoder</span><br /> +<a class="lnum" href="#226" name="226">0226</a><span class="comment"></span>    <span class="keyword">if</span> <span class="op">(</span><span class="name">skipkeys</span> <span class="keyword">is</span> <span class="name">False</span> <span class="keyword">and</span> <span class="name">ensure_ascii</span> <span class="keyword">is</span> <span class="name">True</span> <span class="keyword">and</span><br /> +<a class="lnum" href="#227" name="227">0227</a>        <span class="name">check_circular</span> <span class="keyword">is</span> <span class="name">True</span> <span class="keyword">and</span> <span class="name">allow_nan</span> <span class="keyword">is</span> <span class="name">True</span> <span class="keyword">and</span><br /> +<a class="lnum" href="#228" name="228">0228</a>        <span class="name">cls</span> <span class="keyword">is</span> <span class="name">None</span> <span class="keyword">and</span> <span class="name">indent</span> <span class="keyword">is</span> <span class="name">None</span> <span class="keyword">and</span> <span class="name">separators</span> <span class="keyword">is</span> <span class="name">None</span> <span class="keyword">and</span><br /> +<a class="lnum" href="#229" name="229">0229</a>        <span class="name">encoding</span> <span class="op">==</span> <span class="string">'utf-8'</span> <span class="keyword">and</span> <span class="name">default</span> <span class="keyword">is</span> <span class="name">None</span> <span class="keyword">and</span> <span class="keyword">not</span> <span class="name">kw</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#230" name="230">0230</a>        <span class="keyword">return</span> <span class="name">_default_encoder</span><span class="op">.</span><span class="name">encode</span><span class="op">(</span><span class="name">obj</span><span class="op">)</span><br /> +<a class="lnum" href="#231" name="231">0231</a>    <span class="keyword">if</span> <span class="name">cls</span> <span class="keyword">is</span> <span class="name">None</span><span class="op">:</span><br /> +<a class="lnum" href="#232" name="232">0232</a>        <span class="name">cls</span> <span class="op">=</span> <span class="name">JSONEncoder</span><br /> +<a class="lnum" href="#233" name="233">0233</a>    <span class="keyword">return</span> <span class="name">cls</span><span class="op">(</span><br /> +<a class="lnum" href="#234" name="234">0234</a>        <span class="name">skipkeys</span><span class="op">=</span><span class="name">skipkeys</span><span class="op">,</span> <span class="name">ensure_ascii</span><span class="op">=</span><span class="name">ensure_ascii</span><span class="op">,</span><br /> +<a class="lnum" href="#235" name="235">0235</a>        <span class="name">check_circular</span><span class="op">=</span><span class="name">check_circular</span><span class="op">,</span> <span class="name">allow_nan</span><span class="op">=</span><span class="name">allow_nan</span><span class="op">,</span> <span class="name">indent</span><span class="op">=</span><span class="name">indent</span><span class="op">,</span><br /> +<a class="lnum" href="#236" name="236">0236</a>        <span class="name">separators</span><span class="op">=</span><span class="name">separators</span><span class="op">,</span> <span class="name">encoding</span><span class="op">=</span><span class="name">encoding</span><span class="op">,</span> <span class="name">default</span><span class="op">=</span><span class="name">default</span><span class="op">,</span><br /> +<a class="lnum" href="#237" name="237">0237</a>        <span class="op">**</span><span class="name">kw</span><span class="op">)</span><span class="op">.</span><span class="name">encode</span><span class="op">(</span><span class="name">obj</span><span class="op">)</span><br /> +<a class="lnum" href="#238" name="238">0238</a><br /> +<a class="lnum" href="#239" name="239">0239</a><span class="name">_default_decoder</span> <span class="op">=</span> <span class="name">JSONDecoder</span><span class="op">(</span><span class="name">encoding</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="name">object_hook</span><span class="op">=</span><span class="name">None</span><span class="op">)</span><br /> +<a class="lnum" href="#240" name="240">0240</a><br /> +<a class="lnum" href="#241" name="241">0241</a><span class="keyword">def</span> <span class="name">load</span><span class="op">(</span><span class="name">fp</span><span class="op">,</span> <span class="name">encoding</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="name">cls</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="name">object_hook</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="name">parse_float</span><span class="op">=</span><span class="name">None</span><span class="op">,</span><br /> +<a class="lnum" href="#242" name="242">0242</a>        <span class="name">parse_int</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="name">parse_constant</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="op">**</span><span class="name">kw</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#243" name="243">0243</a>    <span class="string">"""</span><br /> +<a class="lnum" href="#244" name="244">0244</a><span class="string">    Deserialize ``fp`` (a ``.read()``-supporting file-like object containing</span><br /> +<a class="lnum" href="#245" name="245">0245</a><span class="string">    a JSON document) to a Python object.</span><br /> +<a class="lnum" href="#246" name="246">0246</a><span class="string"></span><br /> +<a class="lnum" href="#247" name="247">0247</a><span class="string">    If the contents of ``fp`` is encoded with an ASCII based encoding other</span><br /> +<a class="lnum" href="#248" name="248">0248</a><span class="string">    than utf-8 (e.g. latin-1), then an appropriate ``encoding`` name must</span><br /> +<a class="lnum" href="#249" name="249">0249</a><span class="string">    be specified. Encodings that are not ASCII based (such as UCS-2) are</span><br /> +<a class="lnum" href="#250" name="250">0250</a><span class="string">    not allowed, and should be wrapped with</span><br /> +<a class="lnum" href="#251" name="251">0251</a><span class="string">    ``codecs.getreader(fp)(encoding)``, or simply decoded to a ``unicode``</span><br /> +<a class="lnum" href="#252" name="252">0252</a><span class="string">    object and passed to ``loads()``</span><br /> +<a class="lnum" href="#253" name="253">0253</a><span class="string"></span><br /> +<a class="lnum" href="#254" name="254">0254</a><span class="string">    ``object_hook`` is an optional function that will be called with the</span><br /> +<a class="lnum" href="#255" name="255">0255</a><span class="string">    result of any object literal decode (a ``dict``). The return value of</span><br /> +<a class="lnum" href="#256" name="256">0256</a><span class="string">    ``object_hook`` will be used instead of the ``dict``. This feature</span><br /> +<a class="lnum" href="#257" name="257">0257</a><span class="string">    can be used to implement custom decoders (e.g. JSON-RPC class hinting).</span><br /> +<a class="lnum" href="#258" name="258">0258</a><span class="string">    </span><br /> +<a class="lnum" href="#259" name="259">0259</a><span class="string">    To use a custom ``JSONDecoder`` subclass, specify it with the ``cls``</span><br /> +<a class="lnum" href="#260" name="260">0260</a><span class="string">    kwarg.</span><br /> +<a class="lnum" href="#261" name="261">0261</a><span class="string">    """</span><br /> +<a class="lnum" href="#262" name="262">0262</a>    <span class="keyword">return</span> <span class="name">loads</span><span class="op">(</span><span class="name">fp</span><span class="op">.</span><span class="name">read</span><span class="op">(</span><span class="op">)</span><span class="op">,</span><br /> +<a class="lnum" href="#263" name="263">0263</a>        <span class="name">encoding</span><span class="op">=</span><span class="name">encoding</span><span class="op">,</span> <span class="name">cls</span><span class="op">=</span><span class="name">cls</span><span class="op">,</span> <span class="name">object_hook</span><span class="op">=</span><span class="name">object_hook</span><span class="op">,</span><br /> +<a class="lnum" href="#264" name="264">0264</a>        <span class="name">parse_float</span><span class="op">=</span><span class="name">parse_float</span><span class="op">,</span> <span class="name">parse_int</span><span class="op">=</span><span class="name">parse_int</span><span class="op">,</span><br /> +<a class="lnum" href="#265" name="265">0265</a>        <span class="name">parse_constant</span><span class="op">=</span><span class="name">parse_constant</span><span class="op">,</span> <span class="op">**</span><span class="name">kw</span><span class="op">)</span><br /> +<a class="lnum" href="#266" name="266">0266</a><br /> +<a class="lnum" href="#267" name="267">0267</a><span class="keyword">def</span> <span class="name">loads</span><span class="op">(</span><span class="name">s</span><span class="op">,</span> <span class="name">encoding</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="name">cls</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="name">object_hook</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="name">parse_float</span><span class="op">=</span><span class="name">None</span><span class="op">,</span><br /> +<a class="lnum" href="#268" name="268">0268</a>        <span class="name">parse_int</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="name">parse_constant</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="op">**</span><span class="name">kw</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#269" name="269">0269</a>    <span class="string">"""</span><br /> +<a class="lnum" href="#270" name="270">0270</a><span class="string">    Deserialize ``s`` (a ``str`` or ``unicode`` instance containing a JSON</span><br /> +<a class="lnum" href="#271" name="271">0271</a><span class="string">    document) to a Python object.</span><br /> +<a class="lnum" href="#272" name="272">0272</a><span class="string"></span><br /> +<a class="lnum" href="#273" name="273">0273</a><span class="string">    If ``s`` is a ``str`` instance and is encoded with an ASCII based encoding</span><br /> +<a class="lnum" href="#274" name="274">0274</a><span class="string">    other than utf-8 (e.g. latin-1) then an appropriate ``encoding`` name</span><br /> +<a class="lnum" href="#275" name="275">0275</a><span class="string">    must be specified. Encodings that are not ASCII based (such as UCS-2)</span><br /> +<a class="lnum" href="#276" name="276">0276</a><span class="string">    are not allowed and should be decoded to ``unicode`` first.</span><br /> +<a class="lnum" href="#277" name="277">0277</a><span class="string"></span><br /> +<a class="lnum" href="#278" name="278">0278</a><span class="string">    ``object_hook`` is an optional function that will be called with the</span><br /> +<a class="lnum" href="#279" name="279">0279</a><span class="string">    result of any object literal decode (a ``dict``). The return value of</span><br /> +<a class="lnum" href="#280" name="280">0280</a><span class="string">    ``object_hook`` will be used instead of the ``dict``. This feature</span><br /> +<a class="lnum" href="#281" name="281">0281</a><span class="string">    can be used to implement custom decoders (e.g. JSON-RPC class hinting).</span><br /> +<a class="lnum" href="#282" name="282">0282</a><span class="string"></span><br /> +<a class="lnum" href="#283" name="283">0283</a><span class="string">    ``parse_float``, if specified, will be called with the string</span><br /> +<a class="lnum" href="#284" name="284">0284</a><span class="string">    of every JSON float to be decoded. By default this is equivalent to</span><br /> +<a class="lnum" href="#285" name="285">0285</a><span class="string">    float(num_str). This can be used to use another datatype or parser</span><br /> +<a class="lnum" href="#286" name="286">0286</a><span class="string">    for JSON floats (e.g. decimal.Decimal).</span><br /> +<a class="lnum" href="#287" name="287">0287</a><span class="string"></span><br /> +<a class="lnum" href="#288" name="288">0288</a><span class="string">    ``parse_int``, if specified, will be called with the string</span><br /> +<a class="lnum" href="#289" name="289">0289</a><span class="string">    of every JSON int to be decoded. By default this is equivalent to</span><br /> +<a class="lnum" href="#290" name="290">0290</a><span class="string">    int(num_str). This can be used to use another datatype or parser</span><br /> +<a class="lnum" href="#291" name="291">0291</a><span class="string">    for JSON integers (e.g. float).</span><br /> +<a class="lnum" href="#292" name="292">0292</a><span class="string"></span><br /> +<a class="lnum" href="#293" name="293">0293</a><span class="string">    ``parse_constant``, if specified, will be called with one of the</span><br /> +<a class="lnum" href="#294" name="294">0294</a><span class="string">    following strings: -Infinity, Infinity, NaN, null, true, false.</span><br /> +<a class="lnum" href="#295" name="295">0295</a><span class="string">    This can be used to raise an exception if invalid JSON numbers</span><br /> +<a class="lnum" href="#296" name="296">0296</a><span class="string">    are encountered.</span><br /> +<a class="lnum" href="#297" name="297">0297</a><span class="string"></span><br /> +<a class="lnum" href="#298" name="298">0298</a><span class="string">    To use a custom ``JSONDecoder`` subclass, specify it with the ``cls``</span><br /> +<a class="lnum" href="#299" name="299">0299</a><span class="string">    kwarg.</span><br /> +<a class="lnum" href="#300" name="300">0300</a><span class="string">    """</span><br /> +<a class="lnum" href="#301" name="301">0301</a>    <span class="keyword">if</span> <span class="op">(</span><span class="name">cls</span> <span class="keyword">is</span> <span class="name">None</span> <span class="keyword">and</span> <span class="name">encoding</span> <span class="keyword">is</span> <span class="name">None</span> <span class="keyword">and</span> <span class="name">object_hook</span> <span class="keyword">is</span> <span class="name">None</span> <span class="keyword">and</span><br /> +<a class="lnum" href="#302" name="302">0302</a>            <span class="name">parse_int</span> <span class="keyword">is</span> <span class="name">None</span> <span class="keyword">and</span> <span class="name">parse_float</span> <span class="keyword">is</span> <span class="name">None</span> <span class="keyword">and</span><br /> +<a class="lnum" href="#303" name="303">0303</a>            <span class="name">parse_constant</span> <span class="keyword">is</span> <span class="name">None</span> <span class="keyword">and</span> <span class="keyword">not</span> <span class="name">kw</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#304" name="304">0304</a>        <span class="keyword">return</span> <span class="name">_default_decoder</span><span class="op">.</span><span class="name">decode</span><span class="op">(</span><span class="name">s</span><span class="op">)</span><br /> +<a class="lnum" href="#305" name="305">0305</a>    <span class="keyword">if</span> <span class="name">cls</span> <span class="keyword">is</span> <span class="name">None</span><span class="op">:</span><br /> +<a class="lnum" href="#306" name="306">0306</a>        <span class="name">cls</span> <span class="op">=</span> <span class="name">JSONDecoder</span><br /> +<a class="lnum" href="#307" name="307">0307</a>    <span class="keyword">if</span> <span class="name">object_hook</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><span class="op">:</span><br /> +<a class="lnum" href="#308" name="308">0308</a>        <span class="name">kw</span><span class="op">[</span><span class="string">'object_hook'</span><span class="op">]</span> <span class="op">=</span> <span class="name">object_hook</span><br /> +<a class="lnum" href="#309" name="309">0309</a>    <span class="keyword">if</span> <span class="name">parse_float</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><span class="op">:</span><br /> +<a class="lnum" href="#310" name="310">0310</a>        <span class="name">kw</span><span class="op">[</span><span class="string">'parse_float'</span><span class="op">]</span> <span class="op">=</span> <span class="name">parse_float</span><br /> +<a class="lnum" href="#311" name="311">0311</a>    <span class="keyword">if</span> <span class="name">parse_int</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><span class="op">:</span><br /> +<a class="lnum" href="#312" name="312">0312</a>        <span class="name">kw</span><span class="op">[</span><span class="string">'parse_int'</span><span class="op">]</span> <span class="op">=</span> <span class="name">parse_int</span><br /> +<a class="lnum" href="#313" name="313">0313</a>    <span class="keyword">if</span> <span class="name">parse_constant</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><span class="op">:</span><br /> +<a class="lnum" href="#314" name="314">0314</a>        <span class="name">kw</span><span class="op">[</span><span class="string">'parse_constant'</span><span class="op">]</span> <span class="op">=</span> <span class="name">parse_constant</span><br /> +<a class="lnum" href="#315" name="315">0315</a>    <span class="keyword">return</span> <span class="name">cls</span><span class="op">(</span><span class="name">encoding</span><span class="op">=</span><span class="name">encoding</span><span class="op">,</span> <span class="op">**</span><span class="name">kw</span><span class="op">)</span><span class="op">.</span><span class="name">decode</span><span class="op">(</span><span class="name">s</span><span class="op">)</span><br /> +<a class="lnum" href="#316" name="316">0316</a><br /> +<a class="lnum" href="#317" name="317">0317</a><span class="comment">#</span><br /> +<a class="lnum" href="#318" name="318">0318</a><span class="comment"></span><span class="comment"># Compatibility cruft from other libraries</span><br /> +<a class="lnum" href="#319" name="319">0319</a><span class="comment"></span><span class="comment">#</span><br /> +<a class="lnum" href="#320" name="320">0320</a><span class="comment"></span><br /> +<a class="lnum" href="#321" name="321">0321</a><span class="keyword">def</span> <span class="name">decode</span><span class="op">(</span><span class="name">s</span><span class="op">)</span><span class="op">:</span><br /> <a class="lnum" href="#322" name="322">0322</a>    <span class="string">"""</span><br /> -<a class="lnum" href="#323" name="323">0323</a><span class="string">    jsonlib, JsonUtils, python-json, json-py API compatibility hook.</span><br /> -<a class="lnum" href="#324" name="324">0324</a><span class="string">    Use loads(s) instead.</span><br /> -<a class="lnum" href="#325" name="325">0325</a><span class="string">    """</span><br /> -<a class="lnum" href="#326" name="326">0326</a>    <span class="keyword">import</span> <span class="name">warnings</span><br /> -<a class="lnum" href="#327" name="327">0327</a>    <span class="name">warnings</span><span class="op">.</span><span class="name">warn</span><span class="op">(</span><span class="string">"simplejson.loads(s) should be used instead of read(s)"</span><span class="op">,</span><br /> -<a class="lnum" href="#328" name="328">0328</a>        <span class="name">DeprecationWarning</span><span class="op">)</span><br /> -<a class="lnum" href="#329" name="329">0329</a>    <span class="keyword">return</span> <span class="name">loads</span><span class="op">(</span><span class="name">s</span><span class="op">)</span><br /> -<a class="lnum" href="#330" name="330">0330</a><br /> -<a class="lnum" href="#331" name="331">0331</a><span class="keyword">def</span> <span class="name">write</span><span class="op">(</span><span class="name">obj</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#332" name="332">0332</a>    <span class="string">"""</span><br /> -<a class="lnum" href="#333" name="333">0333</a><span class="string">    jsonlib, JsonUtils, python-json, json-py API compatibility hook.</span><br /> -<a class="lnum" href="#334" name="334">0334</a><span class="string">    Use dumps(s) instead.</span><br /> -<a class="lnum" href="#335" name="335">0335</a><span class="string">    """</span><br /> -<a class="lnum" href="#336" name="336">0336</a>    <span class="keyword">import</span> <span class="name">warnings</span><br /> -<a class="lnum" href="#337" name="337">0337</a>    <span class="name">warnings</span><span class="op">.</span><span class="name">warn</span><span class="op">(</span><span class="string">"simplejson.dumps(s) should be used instead of write(s)"</span><span class="op">,</span><br /> -<a class="lnum" href="#338" name="338">0338</a>        <span class="name">DeprecationWarning</span><span class="op">)</span><br /> -<a class="lnum" href="#339" name="339">0339</a>    <span class="keyword">return</span> <span class="name">dumps</span><span class="op">(</span><span class="name">obj</span><span class="op">)</span></code></div></body></html>
\ No newline at end of file +<a class="lnum" href="#323" name="323">0323</a><span class="string">    demjson, python-cjson API compatibility hook. Use loads(s) instead.</span><br /> +<a class="lnum" href="#324" name="324">0324</a><span class="string">    """</span><br /> +<a class="lnum" href="#325" name="325">0325</a>    <span class="keyword">import</span> <span class="name">warnings</span><br /> +<a class="lnum" href="#326" name="326">0326</a>    <span class="name">warnings</span><span class="op">.</span><span class="name">warn</span><span class="op">(</span><span class="string">"simplejson.loads(s) should be used instead of decode(s)"</span><span class="op">,</span><br /> +<a class="lnum" href="#327" name="327">0327</a>        <span class="name">DeprecationWarning</span><span class="op">)</span><br /> +<a class="lnum" href="#328" name="328">0328</a>    <span class="keyword">return</span> <span class="name">loads</span><span class="op">(</span><span class="name">s</span><span class="op">)</span><br /> +<a class="lnum" href="#329" name="329">0329</a><br /> +<a class="lnum" href="#330" name="330">0330</a><span class="keyword">def</span> <span class="name">encode</span><span class="op">(</span><span class="name">obj</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#331" name="331">0331</a>    <span class="string">"""</span><br /> +<a class="lnum" href="#332" name="332">0332</a><span class="string">    demjson, python-cjson compatibility hook. Use dumps(s) instead.</span><br /> +<a class="lnum" href="#333" name="333">0333</a><span class="string">    """</span><br /> +<a class="lnum" href="#334" name="334">0334</a>    <span class="keyword">import</span> <span class="name">warnings</span><br /> +<a class="lnum" href="#335" name="335">0335</a>    <span class="name">warnings</span><span class="op">.</span><span class="name">warn</span><span class="op">(</span><span class="string">"simplejson.dumps(s) should be used instead of encode(s)"</span><span class="op">,</span><br /> +<a class="lnum" href="#336" name="336">0336</a>        <span class="name">DeprecationWarning</span><span class="op">)</span><br /> +<a class="lnum" href="#337" name="337">0337</a>    <span class="keyword">return</span> <span class="name">dumps</span><span class="op">(</span><span class="name">obj</span><span class="op">)</span><br /> +<a class="lnum" href="#338" name="338">0338</a><br /> +<a class="lnum" href="#339" name="339">0339</a><span class="keyword">def</span> <span class="name">read</span><span class="op">(</span><span class="name">s</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#340" name="340">0340</a>    <span class="string">"""</span><br /> +<a class="lnum" href="#341" name="341">0341</a><span class="string">    jsonlib, JsonUtils, python-json, json-py API compatibility hook.</span><br /> +<a class="lnum" href="#342" name="342">0342</a><span class="string">    Use loads(s) instead.</span><br /> +<a class="lnum" href="#343" name="343">0343</a><span class="string">    """</span><br /> +<a class="lnum" href="#344" name="344">0344</a>    <span class="keyword">import</span> <span class="name">warnings</span><br /> +<a class="lnum" href="#345" name="345">0345</a>    <span class="name">warnings</span><span class="op">.</span><span class="name">warn</span><span class="op">(</span><span class="string">"simplejson.loads(s) should be used instead of read(s)"</span><span class="op">,</span><br /> +<a class="lnum" href="#346" name="346">0346</a>        <span class="name">DeprecationWarning</span><span class="op">)</span><br /> +<a class="lnum" href="#347" name="347">0347</a>    <span class="keyword">return</span> <span class="name">loads</span><span class="op">(</span><span class="name">s</span><span class="op">)</span><br /> +<a class="lnum" href="#348" name="348">0348</a><br /> +<a class="lnum" href="#349" name="349">0349</a><span class="keyword">def</span> <span class="name">write</span><span class="op">(</span><span class="name">obj</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#350" name="350">0350</a>    <span class="string">"""</span><br /> +<a class="lnum" href="#351" name="351">0351</a><span class="string">    jsonlib, JsonUtils, python-json, json-py API compatibility hook.</span><br /> +<a class="lnum" href="#352" name="352">0352</a><span class="string">    Use dumps(s) instead.</span><br /> +<a class="lnum" href="#353" name="353">0353</a><span class="string">    """</span><br /> +<a class="lnum" href="#354" name="354">0354</a>    <span class="keyword">import</span> <span class="name">warnings</span><br /> +<a class="lnum" href="#355" name="355">0355</a>    <span class="name">warnings</span><span class="op">.</span><span class="name">warn</span><span class="op">(</span><span class="string">"simplejson.dumps(s) should be used instead of write(s)"</span><span class="op">,</span><br /> +<a class="lnum" href="#356" name="356">0356</a>        <span class="name">DeprecationWarning</span><span class="op">)</span><br /> +<a class="lnum" href="#357" name="357">0357</a>    <span class="keyword">return</span> <span class="name">dumps</span><span class="op">(</span><span class="name">obj</span><span class="op">)</span><br /> +<a class="lnum" href="#358" name="358">0358</a><br /> +<a class="lnum" href="#359" name="359">0359</a><span class="comment">#</span><br /> +<a class="lnum" href="#360" name="360">0360</a><span class="comment"></span><span class="comment"># Pretty printer:</span><br /> +<a class="lnum" href="#361" name="361">0361</a><span class="comment"></span><span class="comment">#     curl http://mochikit.com/examples/ajax_tables/domains.json | python -msimplejson</span><br /> +<a class="lnum" href="#362" name="362">0362</a><span class="comment"></span><span class="comment">#</span><br /> +<a class="lnum" href="#363" name="363">0363</a><span class="comment"></span><br /> +<a class="lnum" href="#364" name="364">0364</a><span class="keyword">def</span> <span class="name">main</span><span class="op">(</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#365" name="365">0365</a>    <span class="keyword">import</span> <span class="name">sys</span><br /> +<a class="lnum" href="#366" name="366">0366</a>    <span class="keyword">if</span> <span class="name">len</span><span class="op">(</span><span class="name">sys</span><span class="op">.</span><span class="name">argv</span><span class="op">)</span> <span class="op">==</span> <span class="number">1</span><span class="op">:</span><br /> +<a class="lnum" href="#367" name="367">0367</a>        <span class="name">infile</span> <span class="op">=</span> <span class="name">sys</span><span class="op">.</span><span class="name">stdin</span><br /> +<a class="lnum" href="#368" name="368">0368</a>        <span class="name">outfile</span> <span class="op">=</span> <span class="name">sys</span><span class="op">.</span><span class="name">stdout</span><br /> +<a class="lnum" href="#369" name="369">0369</a>    <span class="keyword">elif</span> <span class="name">len</span><span class="op">(</span><span class="name">sys</span><span class="op">.</span><span class="name">argv</span><span class="op">)</span> <span class="op">==</span> <span class="number">2</span><span class="op">:</span><br /> +<a class="lnum" href="#370" name="370">0370</a>        <span class="name">infile</span> <span class="op">=</span> <span class="name">open</span><span class="op">(</span><span class="name">sys</span><span class="op">.</span><span class="name">argv</span><span class="op">[</span><span class="number">1</span><span class="op">]</span><span class="op">,</span> <span class="string">'rb'</span><span class="op">)</span><br /> +<a class="lnum" href="#371" name="371">0371</a>        <span class="name">outfile</span> <span class="op">=</span> <span class="name">sys</span><span class="op">.</span><span class="name">stdout</span><br /> +<a class="lnum" href="#372" name="372">0372</a>    <span class="keyword">elif</span> <span class="name">len</span><span class="op">(</span><span class="name">sys</span><span class="op">.</span><span class="name">argv</span><span class="op">)</span> <span class="op">==</span> <span class="number">3</span><span class="op">:</span><br /> +<a class="lnum" href="#373" name="373">0373</a>        <span class="name">infile</span> <span class="op">=</span> <span class="name">open</span><span class="op">(</span><span class="name">sys</span><span class="op">.</span><span class="name">argv</span><span class="op">[</span><span class="number">1</span><span class="op">]</span><span class="op">,</span> <span class="string">'rb'</span><span class="op">)</span><br /> +<a class="lnum" href="#374" name="374">0374</a>        <span class="name">outfile</span> <span class="op">=</span> <span class="name">open</span><span class="op">(</span><span class="name">sys</span><span class="op">.</span><span class="name">argv</span><span class="op">[</span><span class="number">2</span><span class="op">]</span><span class="op">,</span> <span class="string">'wb'</span><span class="op">)</span><br /> +<a class="lnum" href="#375" name="375">0375</a>    <span class="keyword">else</span><span class="op">:</span><br /> +<a class="lnum" href="#376" name="376">0376</a>        <span class="keyword">raise</span> <span class="name">SystemExit</span><span class="op">(</span><span class="string">"%s [infile [outfile]]"</span> <span class="op">%</span> <span class="op">(</span><span class="name">sys</span><span class="op">.</span><span class="name">argv</span><span class="op">[</span><span class="number">0</span><span class="op">]</span><span class="op">,</span><span class="op">)</span><span class="op">)</span><br /> +<a class="lnum" href="#377" name="377">0377</a>    <span class="keyword">try</span><span class="op">:</span><br /> +<a class="lnum" href="#378" name="378">0378</a>        <span class="name">obj</span> <span class="op">=</span> <span class="name">load</span><span class="op">(</span><span class="name">infile</span><span class="op">)</span><br /> +<a class="lnum" href="#379" name="379">0379</a>    <span class="keyword">except</span> <span class="name">ValueError</span><span class="op">,</span> <span class="name">e</span><span class="op">:</span><br /> +<a class="lnum" href="#380" name="380">0380</a>        <span class="keyword">raise</span> <span class="name">SystemExit</span><span class="op">(</span><span class="name">e</span><span class="op">)</span><br /> +<a class="lnum" href="#381" name="381">0381</a>    <span class="name">dump</span><span class="op">(</span><span class="name">obj</span><span class="op">,</span> <span class="name">outfile</span><span class="op">,</span> <span class="name">sort_keys</span><span class="op">=</span><span class="name">True</span><span class="op">,</span> <span class="name">indent</span><span class="op">=</span><span class="number">4</span><span class="op">)</span><br /> +<a class="lnum" href="#382" name="382">0382</a>    <span class="name">outfile</span><span class="op">.</span><span class="name">write</span><span class="op">(</span><span class="string">'\n'</span><span class="op">)</span><br /> +<a class="lnum" href="#383" name="383">0383</a><br /> +<a class="lnum" href="#384" name="384">0384</a><span class="keyword">if</span> <span class="name">__name__</span> <span class="op">==</span> <span class="string">'__main__'</span><span class="op">:</span><br /> +<a class="lnum" href="#385" name="385">0385</a>    <span class="name">main</span><span class="op">(</span><span class="op">)</span></code></div></body></html>
\ No newline at end of file diff --git a/docs/simplejson/encoder.py.html b/docs/simplejson/encoder.py.html index 8c814ab..98d8621 100644 --- a/docs/simplejson/encoder.py.html +++ b/docs/simplejson/encoder.py.html @@ -79,365 +79,370 @@ function show_line_range() { <a class="lnum" href="#7" name="7">0007</a><span class="keyword">except</span> <span class="name">ImportError</span><span class="op">:</span><br /> <a class="lnum" href="#8" name="8">0008</a>    <span class="name">_speedups</span> <span class="op">=</span> <span class="name">None</span><br /> <a class="lnum" href="#9" name="9">0009</a><br /> -<a class="lnum" href="#10" name="10">0010</a><span class="name">ESCAPE</span> <span class="op">=</span> <span class="name">re</span><span class="op">.</span><span class="name">compile</span><span class="op">(</span><span class="string">r'[\x00-\x19\\"\b\f\n\r\t]'</span><span class="op">)</span><br /> +<a class="lnum" href="#10" name="10">0010</a><span class="name">ESCAPE</span> <span class="op">=</span> <span class="name">re</span><span class="op">.</span><span class="name">compile</span><span class="op">(</span><span class="string">r'[\x00-\x1f\\"\b\f\n\r\t]'</span><span class="op">)</span><br /> <a class="lnum" href="#11" name="11">0011</a><span class="name">ESCAPE_ASCII</span> <span class="op">=</span> <span class="name">re</span><span class="op">.</span><span class="name">compile</span><span class="op">(</span><span class="string">r'([\\"/]|[^\ -~])'</span><span class="op">)</span><br /> <a class="lnum" href="#12" name="12">0012</a><span class="name">ESCAPE_DCT</span> <span class="op">=</span> <span class="op">{</span><br /> -<a class="lnum" href="#13" name="13">0013</a>    <span class="comment"># escape all forward slashes to prevent </script> attack</span><br /> -<a class="lnum" href="#14" name="14">0014</a>    <span class="string">'/'</span><span class="op">:</span> <span class="string">'\\/'</span><span class="op">,</span><br /> -<a class="lnum" href="#15" name="15">0015</a>    <span class="string">'\\'</span><span class="op">:</span> <span class="string">'\\\\'</span><span class="op">,</span><br /> -<a class="lnum" href="#16" name="16">0016</a>    <span class="string">'"'</span><span class="op">:</span> <span class="string">'\\"'</span><span class="op">,</span><br /> -<a class="lnum" href="#17" name="17">0017</a>    <span class="string">'\b'</span><span class="op">:</span> <span class="string">'\\b'</span><span class="op">,</span><br /> -<a class="lnum" href="#18" name="18">0018</a>    <span class="string">'\f'</span><span class="op">:</span> <span class="string">'\\f'</span><span class="op">,</span><br /> -<a class="lnum" href="#19" name="19">0019</a>    <span class="string">'\n'</span><span class="op">:</span> <span class="string">'\\n'</span><span class="op">,</span><br /> -<a class="lnum" href="#20" name="20">0020</a>    <span class="string">'\r'</span><span class="op">:</span> <span class="string">'\\r'</span><span class="op">,</span><br /> -<a class="lnum" href="#21" name="21">0021</a>    <span class="string">'\t'</span><span class="op">:</span> <span class="string">'\\t'</span><span class="op">,</span><br /> -<a class="lnum" href="#22" name="22">0022</a><span class="op">}</span><br /> -<a class="lnum" href="#23" name="23">0023</a><span class="keyword">for</span> <span class="name">i</span> <span class="keyword">in</span> <span class="name">range</span><span class="op">(</span><span class="number">0x20</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#24" name="24">0024</a>    <span class="name">ESCAPE_DCT</span><span class="op">.</span><span class="name">setdefault</span><span class="op">(</span><span class="name">chr</span><span class="op">(</span><span class="name">i</span><span class="op">)</span><span class="op">,</span> <span class="string">'\\u%04x'</span> <span class="op">%</span> <span class="op">(</span><span class="name">i</span><span class="op">,</span><span class="op">)</span><span class="op">)</span><br /> -<a class="lnum" href="#25" name="25">0025</a><br /> -<a class="lnum" href="#26" name="26">0026</a><span class="comment"># assume this produces an infinity on all machines (probably not guaranteed)</span><br /> -<a class="lnum" href="#27" name="27">0027</a><span class="comment"></span><span class="name">INFINITY</span> <span class="op">=</span> <span class="name">float</span><span class="op">(</span><span class="string">'1e66666'</span><span class="op">)</span><br /> -<a class="lnum" href="#28" name="28">0028</a><br /> -<a class="lnum" href="#29" name="29">0029</a><span class="keyword">def</span> <span class="name">floatstr</span><span class="op">(</span><span class="name">o</span><span class="op">,</span> <span class="name">allow_nan</span><span class="op">=</span><span class="name">True</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#30" name="30">0030</a>    <span class="comment"># Check for specials.  Note that this type of test is processor- and/or</span><br /> -<a class="lnum" href="#31" name="31">0031</a><span class="comment"></span>    <span class="comment"># platform-specific, so do tests which don't depend on the internals.</span><br /> -<a class="lnum" href="#32" name="32">0032</a><span class="comment"></span><br /> -<a class="lnum" href="#33" name="33">0033</a>    <span class="keyword">if</span> <span class="name">o</span> <span class="op">!=</span> <span class="name">o</span><span class="op">:</span><br /> -<a class="lnum" href="#34" name="34">0034</a>        <span class="name">text</span> <span class="op">=</span> <span class="string">'NaN'</span><br /> -<a class="lnum" href="#35" name="35">0035</a>    <span class="keyword">elif</span> <span class="name">o</span> <span class="op">==</span> <span class="name">INFINITY</span><span class="op">:</span><br /> -<a class="lnum" href="#36" name="36">0036</a>        <span class="name">text</span> <span class="op">=</span> <span class="string">'Infinity'</span><br /> -<a class="lnum" href="#37" name="37">0037</a>    <span class="keyword">elif</span> <span class="name">o</span> <span class="op">==</span> <span class="op">-</span><span class="name">INFINITY</span><span class="op">:</span><br /> -<a class="lnum" href="#38" name="38">0038</a>        <span class="name">text</span> <span class="op">=</span> <span class="string">'-Infinity'</span><br /> -<a class="lnum" href="#39" name="39">0039</a>    <span class="keyword">else</span><span class="op">:</span><br /> -<a class="lnum" href="#40" name="40">0040</a>        <span class="keyword">return</span> <span class="name">str</span><span class="op">(</span><span class="name">o</span><span class="op">)</span><br /> -<a class="lnum" href="#41" name="41">0041</a><br /> -<a class="lnum" href="#42" name="42">0042</a>    <span class="keyword">if</span> <span class="keyword">not</span> <span class="name">allow_nan</span><span class="op">:</span><br /> -<a class="lnum" href="#43" name="43">0043</a>        <span class="keyword">raise</span> <span class="name">ValueError</span><span class="op">(</span><span class="string">"Out of range float values are not JSON compliant: %r"</span><br /> -<a class="lnum" href="#44" name="44">0044</a>            <span class="op">%</span> <span class="op">(</span><span class="name">o</span><span class="op">,</span><span class="op">)</span><span class="op">)</span><br /> -<a class="lnum" href="#45" name="45">0045</a><br /> -<a class="lnum" href="#46" name="46">0046</a>    <span class="keyword">return</span> <span class="name">text</span><br /> +<a class="lnum" href="#13" name="13">0013</a>    <span class="string">'\\'</span><span class="op">:</span> <span class="string">'\\\\'</span><span class="op">,</span><br /> +<a class="lnum" href="#14" name="14">0014</a>    <span class="string">'"'</span><span class="op">:</span> <span class="string">'\\"'</span><span class="op">,</span><br /> +<a class="lnum" href="#15" name="15">0015</a>    <span class="string">'\b'</span><span class="op">:</span> <span class="string">'\\b'</span><span class="op">,</span><br /> +<a class="lnum" href="#16" name="16">0016</a>    <span class="string">'\f'</span><span class="op">:</span> <span class="string">'\\f'</span><span class="op">,</span><br /> +<a class="lnum" href="#17" name="17">0017</a>    <span class="string">'\n'</span><span class="op">:</span> <span class="string">'\\n'</span><span class="op">,</span><br /> +<a class="lnum" href="#18" name="18">0018</a>    <span class="string">'\r'</span><span class="op">:</span> <span class="string">'\\r'</span><span class="op">,</span><br /> +<a class="lnum" href="#19" name="19">0019</a>    <span class="string">'\t'</span><span class="op">:</span> <span class="string">'\\t'</span><span class="op">,</span><br /> +<a class="lnum" href="#20" name="20">0020</a><span class="op">}</span><br /> +<a class="lnum" href="#21" name="21">0021</a><span class="keyword">for</span> <span class="name">i</span> <span class="keyword">in</span> <span class="name">range</span><span class="op">(</span><span class="number">0x20</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#22" name="22">0022</a>    <span class="name">ESCAPE_DCT</span><span class="op">.</span><span class="name">setdefault</span><span class="op">(</span><span class="name">chr</span><span class="op">(</span><span class="name">i</span><span class="op">)</span><span class="op">,</span> <span class="string">'\\u%04x'</span> <span class="op">%</span> <span class="op">(</span><span class="name">i</span><span class="op">,</span><span class="op">)</span><span class="op">)</span><br /> +<a class="lnum" href="#23" name="23">0023</a><br /> +<a class="lnum" href="#24" name="24">0024</a><span class="comment"># assume this produces an infinity on all machines (probably not guaranteed)</span><br /> +<a class="lnum" href="#25" name="25">0025</a><span class="comment"></span><span class="name">INFINITY</span> <span class="op">=</span> <span class="name">float</span><span class="op">(</span><span class="string">'1e66666'</span><span class="op">)</span><br /> +<a class="lnum" href="#26" name="26">0026</a><span class="name">FLOAT_REPR</span> <span class="op">=</span> <span class="name">repr</span><br /> +<a class="lnum" href="#27" name="27">0027</a><br /> +<a class="lnum" href="#28" name="28">0028</a><span class="keyword">def</span> <span class="name">floatstr</span><span class="op">(</span><span class="name">o</span><span class="op">,</span> <span class="name">allow_nan</span><span class="op">=</span><span class="name">True</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#29" name="29">0029</a>    <span class="comment"># Check for specials.  Note that this type of test is processor- and/or</span><br /> +<a class="lnum" href="#30" name="30">0030</a><span class="comment"></span>    <span class="comment"># platform-specific, so do tests which don't depend on the internals.</span><br /> +<a class="lnum" href="#31" name="31">0031</a><span class="comment"></span><br /> +<a class="lnum" href="#32" name="32">0032</a>    <span class="keyword">if</span> <span class="name">o</span> <span class="op">!=</span> <span class="name">o</span><span class="op">:</span><br /> +<a class="lnum" href="#33" name="33">0033</a>        <span class="name">text</span> <span class="op">=</span> <span class="string">'NaN'</span><br /> +<a class="lnum" href="#34" name="34">0034</a>    <span class="keyword">elif</span> <span class="name">o</span> <span class="op">==</span> <span class="name">INFINITY</span><span class="op">:</span><br /> +<a class="lnum" href="#35" name="35">0035</a>        <span class="name">text</span> <span class="op">=</span> <span class="string">'Infinity'</span><br /> +<a class="lnum" href="#36" name="36">0036</a>    <span class="keyword">elif</span> <span class="name">o</span> <span class="op">==</span> <span class="op">-</span><span class="name">INFINITY</span><span class="op">:</span><br /> +<a class="lnum" href="#37" name="37">0037</a>        <span class="name">text</span> <span class="op">=</span> <span class="string">'-Infinity'</span><br /> +<a class="lnum" href="#38" name="38">0038</a>    <span class="keyword">else</span><span class="op">:</span><br /> +<a class="lnum" href="#39" name="39">0039</a>        <span class="keyword">return</span> <span class="name">FLOAT_REPR</span><span class="op">(</span><span class="name">o</span><span class="op">)</span><br /> +<a class="lnum" href="#40" name="40">0040</a><br /> +<a class="lnum" href="#41" name="41">0041</a>    <span class="keyword">if</span> <span class="keyword">not</span> <span class="name">allow_nan</span><span class="op">:</span><br /> +<a class="lnum" href="#42" name="42">0042</a>        <span class="keyword">raise</span> <span class="name">ValueError</span><span class="op">(</span><span class="string">"Out of range float values are not JSON compliant: %r"</span><br /> +<a class="lnum" href="#43" name="43">0043</a>            <span class="op">%</span> <span class="op">(</span><span class="name">o</span><span class="op">,</span><span class="op">)</span><span class="op">)</span><br /> +<a class="lnum" href="#44" name="44">0044</a><br /> +<a class="lnum" href="#45" name="45">0045</a>    <span class="keyword">return</span> <span class="name">text</span><br /> +<a class="lnum" href="#46" name="46">0046</a><br /> <a class="lnum" href="#47" name="47">0047</a><br /> -<a class="lnum" href="#48" name="48">0048</a><br /> -<a class="lnum" href="#49" name="49">0049</a><span class="keyword">def</span> <span class="name">encode_basestring</span><span class="op">(</span><span class="name">s</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#50" name="50">0050</a>    <span class="string">"""</span><br /> -<a class="lnum" href="#51" name="51">0051</a><span class="string">    Return a JSON representation of a Python string</span><br /> -<a class="lnum" href="#52" name="52">0052</a><span class="string">    """</span><br /> -<a class="lnum" href="#53" name="53">0053</a>    <span class="keyword">def</span> <span class="name">replace</span><span class="op">(</span><span class="name">match</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#54" name="54">0054</a>        <span class="keyword">return</span> <span class="name">ESCAPE_DCT</span><span class="op">[</span><span class="name">match</span><span class="op">.</span><span class="name">group</span><span class="op">(</span><span class="number">0</span><span class="op">)</span><span class="op">]</span><br /> -<a class="lnum" href="#55" name="55">0055</a>    <span class="keyword">return</span> <span class="string">'"'</span> <span class="op">+</span> <span class="name">ESCAPE</span><span class="op">.</span><span class="name">sub</span><span class="op">(</span><span class="name">replace</span><span class="op">,</span> <span class="name">s</span><span class="op">)</span> <span class="op">+</span> <span class="string">'"'</span><br /> -<a class="lnum" href="#56" name="56">0056</a><br /> -<a class="lnum" href="#57" name="57">0057</a><span class="keyword">def</span> <span class="name">encode_basestring_ascii</span><span class="op">(</span><span class="name">s</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#58" name="58">0058</a>    <span class="keyword">def</span> <span class="name">replace</span><span class="op">(</span><span class="name">match</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#59" name="59">0059</a>        <span class="name">s</span> <span class="op">=</span> <span class="name">match</span><span class="op">.</span><span class="name">group</span><span class="op">(</span><span class="number">0</span><span class="op">)</span><br /> -<a class="lnum" href="#60" name="60">0060</a>        <span class="keyword">try</span><span class="op">:</span><br /> -<a class="lnum" href="#61" name="61">0061</a>            <span class="keyword">return</span> <span class="name">ESCAPE_DCT</span><span class="op">[</span><span class="name">s</span><span class="op">]</span><br /> -<a class="lnum" href="#62" name="62">0062</a>        <span class="keyword">except</span> <span class="name">KeyError</span><span class="op">:</span><br /> -<a class="lnum" href="#63" name="63">0063</a>            <span class="name">n</span> <span class="op">=</span> <span class="name">ord</span><span class="op">(</span><span class="name">s</span><span class="op">)</span><br /> -<a class="lnum" href="#64" name="64">0064</a>            <span class="keyword">if</span> <span class="name">n</span> <span class="op"><</span> <span class="number">0x10000</span><span class="op">:</span><br /> -<a class="lnum" href="#65" name="65">0065</a>                <span class="keyword">return</span> <span class="string">'\\u%04x'</span> <span class="op">%</span> <span class="op">(</span><span class="name">n</span><span class="op">,</span><span class="op">)</span><br /> -<a class="lnum" href="#66" name="66">0066</a>            <span class="keyword">else</span><span class="op">:</span><br /> -<a class="lnum" href="#67" name="67">0067</a>                <span class="comment"># surrogate pair</span><br /> -<a class="lnum" href="#68" name="68">0068</a><span class="comment"></span>                <span class="name">n</span> <span class="op">-=</span> <span class="number">0x10000</span><br /> -<a class="lnum" href="#69" name="69">0069</a>                <span class="name">s1</span> <span class="op">=</span> <span class="number">0xd800</span> <span class="op">|</span> <span class="op">(</span><span class="op">(</span><span class="name">n</span> <span class="op">>></span> <span class="number">10</span><span class="op">)</span> <span class="op">&</span> <span class="number">0x3ff</span><span class="op">)</span><br /> -<a class="lnum" href="#70" name="70">0070</a>                <span class="name">s2</span> <span class="op">=</span> <span class="number">0xdc00</span> <span class="op">|</span> <span class="op">(</span><span class="name">n</span> <span class="op">&</span> <span class="number">0x3ff</span><span class="op">)</span><br /> -<a class="lnum" href="#71" name="71">0071</a>                <span class="keyword">return</span> <span class="string">'\\u%04x\\u%04x'</span> <span class="op">%</span> <span class="op">(</span><span class="name">s1</span><span class="op">,</span> <span class="name">s2</span><span class="op">)</span><br /> -<a class="lnum" href="#72" name="72">0072</a>    <span class="keyword">return</span> <span class="string">'"'</span> <span class="op">+</span> <span class="name">str</span><span class="op">(</span><span class="name">ESCAPE_ASCII</span><span class="op">.</span><span class="name">sub</span><span class="op">(</span><span class="name">replace</span><span class="op">,</span> <span class="name">s</span><span class="op">)</span><span class="op">)</span> <span class="op">+</span> <span class="string">'"'</span><br /> -<a class="lnum" href="#73" name="73">0073</a><br /> -<a class="lnum" href="#74" name="74">0074</a><span class="keyword">try</span><span class="op">:</span><br /> -<a class="lnum" href="#75" name="75">0075</a>    <span class="name">encode_basestring_ascii</span> <span class="op">=</span> <span class="name">_speedups</span><span class="op">.</span><span class="name">encode_basestring_ascii</span><br /> -<a class="lnum" href="#76" name="76">0076</a>    <span class="name">_need_utf8</span> <span class="op">=</span> <span class="name">True</span><br /> -<a class="lnum" href="#77" name="77">0077</a><span class="keyword">except</span> <span class="name">AttributeError</span><span class="op">:</span><br /> -<a class="lnum" href="#78" name="78">0078</a>    <span class="name">_need_utf8</span> <span class="op">=</span> <span class="name">False</span><br /> -<a class="lnum" href="#79" name="79">0079</a><br /> -<a class="lnum" href="#80" name="80">0080</a><span class="keyword">class</span> <span class="name">JSONEncoder</span><span class="op">(</span><span class="name">object</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#81" name="81">0081</a>    <span class="string">"""</span><br /> -<a class="lnum" href="#82" name="82">0082</a><span class="string">    Extensible JSON <http://json.org> encoder for Python data structures.</span><br /> -<a class="lnum" href="#83" name="83">0083</a><span class="string"></span><br /> -<a class="lnum" href="#84" name="84">0084</a><span class="string">    Supports the following objects and types by default:</span><br /> -<a class="lnum" href="#85" name="85">0085</a><span class="string">    </span><br /> -<a class="lnum" href="#86" name="86">0086</a><span class="string">    +-------------------+---------------+</span><br /> -<a class="lnum" href="#87" name="87">0087</a><span class="string">    | Python            | JSON          |</span><br /> -<a class="lnum" href="#88" name="88">0088</a><span class="string">    +===================+===============+</span><br /> -<a class="lnum" href="#89" name="89">0089</a><span class="string">    | dict              | object        |</span><br /> -<a class="lnum" href="#90" name="90">0090</a><span class="string">    +-------------------+---------------+</span><br /> -<a class="lnum" href="#91" name="91">0091</a><span class="string">    | list, tuple       | array         |</span><br /> -<a class="lnum" href="#92" name="92">0092</a><span class="string">    +-------------------+---------------+</span><br /> -<a class="lnum" href="#93" name="93">0093</a><span class="string">    | str, unicode      | string        |</span><br /> -<a class="lnum" href="#94" name="94">0094</a><span class="string">    +-------------------+---------------+</span><br /> -<a class="lnum" href="#95" name="95">0095</a><span class="string">    | int, long, float  | number        |</span><br /> -<a class="lnum" href="#96" name="96">0096</a><span class="string">    +-------------------+---------------+</span><br /> -<a class="lnum" href="#97" name="97">0097</a><span class="string">    | True              | true          |</span><br /> -<a class="lnum" href="#98" name="98">0098</a><span class="string">    +-------------------+---------------+</span><br /> -<a class="lnum" href="#99" name="99">0099</a><span class="string">    | False             | false         |</span><br /> -<a class="lnum" href="#100" name="100">0100</a><span class="string">    +-------------------+---------------+</span><br /> -<a class="lnum" href="#101" name="101">0101</a><span class="string">    | None              | null          |</span><br /> -<a class="lnum" href="#102" name="102">0102</a><span class="string">    +-------------------+---------------+</span><br /> -<a class="lnum" href="#103" name="103">0103</a><span class="string"></span><br /> -<a class="lnum" href="#104" name="104">0104</a><span class="string">    To extend this to recognize other objects, subclass and implement a</span><br /> -<a class="lnum" href="#105" name="105">0105</a><span class="string">    ``.default()`` method with another method that returns a serializable</span><br /> -<a class="lnum" href="#106" name="106">0106</a><span class="string">    object for ``o`` if possible, otherwise it should call the superclass</span><br /> -<a class="lnum" href="#107" name="107">0107</a><span class="string">    implementation (to raise ``TypeError``).</span><br /> -<a class="lnum" href="#108" name="108">0108</a><span class="string">    """</span><br /> -<a class="lnum" href="#109" name="109">0109</a>    <span class="name">__all__</span> <span class="op">=</span> <span class="op">[</span><span class="string">'__init__'</span><span class="op">,</span> <span class="string">'default'</span><span class="op">,</span> <span class="string">'encode'</span><span class="op">,</span> <span class="string">'iterencode'</span><span class="op">]</span><br /> -<a class="lnum" href="#110" name="110">0110</a>    <span class="name">item_separator</span> <span class="op">=</span> <span class="string">', '</span><br /> -<a class="lnum" href="#111" name="111">0111</a>    <span class="name">key_separator</span> <span class="op">=</span> <span class="string">': '</span><br /> -<a class="lnum" href="#112" name="112">0112</a>    <span class="keyword">def</span> <span class="name">__init__</span><span class="op">(</span><span class="name">self</span><span class="op">,</span> <span class="name">skipkeys</span><span class="op">=</span><span class="name">False</span><span class="op">,</span> <span class="name">ensure_ascii</span><span class="op">=</span><span class="name">True</span><span class="op">,</span><br /> -<a class="lnum" href="#113" name="113">0113</a>            <span class="name">check_circular</span><span class="op">=</span><span class="name">True</span><span class="op">,</span> <span class="name">allow_nan</span><span class="op">=</span><span class="name">True</span><span class="op">,</span> <span class="name">sort_keys</span><span class="op">=</span><span class="name">False</span><span class="op">,</span><br /> -<a class="lnum" href="#114" name="114">0114</a>            <span class="name">indent</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="name">separators</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="name">encoding</span><span class="op">=</span><span class="string">'utf-8'</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#115" name="115">0115</a>        <span class="string">"""</span><br /> -<a class="lnum" href="#116" name="116">0116</a><span class="string">        Constructor for JSONEncoder, with sensible defaults.</span><br /> -<a class="lnum" href="#117" name="117">0117</a><span class="string"></span><br /> -<a class="lnum" href="#118" name="118">0118</a><span class="string">        If skipkeys is False, then it is a TypeError to attempt</span><br /> -<a class="lnum" href="#119" name="119">0119</a><span class="string">        encoding of keys that are not str, int, long, float or None.  If</span><br /> -<a class="lnum" href="#120" name="120">0120</a><span class="string">        skipkeys is True, such items are simply skipped.</span><br /> -<a class="lnum" href="#121" name="121">0121</a><span class="string"></span><br /> -<a class="lnum" href="#122" name="122">0122</a><span class="string">        If ensure_ascii is True, the output is guaranteed to be str</span><br /> -<a class="lnum" href="#123" name="123">0123</a><span class="string">        objects with all incoming unicode characters escaped.  If</span><br /> -<a class="lnum" href="#124" name="124">0124</a><span class="string">        ensure_ascii is false, the output will be unicode object.</span><br /> -<a class="lnum" href="#125" name="125">0125</a><span class="string"></span><br /> -<a class="lnum" href="#126" name="126">0126</a><span class="string">        If check_circular is True, then lists, dicts, and custom encoded</span><br /> -<a class="lnum" href="#127" name="127">0127</a><span class="string">        objects will be checked for circular references during encoding to</span><br /> -<a class="lnum" href="#128" name="128">0128</a><span class="string">        prevent an infinite recursion (which would cause an OverflowError).</span><br /> -<a class="lnum" href="#129" name="129">0129</a><span class="string">        Otherwise, no such check takes place.</span><br /> -<a class="lnum" href="#130" name="130">0130</a><span class="string"></span><br /> -<a class="lnum" href="#131" name="131">0131</a><span class="string">        If allow_nan is True, then NaN, Infinity, and -Infinity will be</span><br /> -<a class="lnum" href="#132" name="132">0132</a><span class="string">        encoded as such.  This behavior is not JSON specification compliant,</span><br /> -<a class="lnum" href="#133" name="133">0133</a><span class="string">        but is consistent with most JavaScript based encoders and decoders.</span><br /> -<a class="lnum" href="#134" name="134">0134</a><span class="string">        Otherwise, it will be a ValueError to encode such floats.</span><br /> -<a class="lnum" href="#135" name="135">0135</a><span class="string"></span><br /> -<a class="lnum" href="#136" name="136">0136</a><span class="string">        If sort_keys is True, then the output of dictionaries will be</span><br /> -<a class="lnum" href="#137" name="137">0137</a><span class="string">        sorted by key; this is useful for regression tests to ensure</span><br /> -<a class="lnum" href="#138" name="138">0138</a><span class="string">        that JSON serializations can be compared on a day-to-day basis.</span><br /> -<a class="lnum" href="#139" name="139">0139</a><span class="string"></span><br /> -<a class="lnum" href="#140" name="140">0140</a><span class="string">        If indent is a non-negative integer, then JSON array</span><br /> -<a class="lnum" href="#141" name="141">0141</a><span class="string">        elements and object members will be pretty-printed with that</span><br /> -<a class="lnum" href="#142" name="142">0142</a><span class="string">        indent level.  An indent level of 0 will only insert newlines.</span><br /> -<a class="lnum" href="#143" name="143">0143</a><span class="string">        None is the most compact representation.</span><br /> -<a class="lnum" href="#144" name="144">0144</a><span class="string"></span><br /> -<a class="lnum" href="#145" name="145">0145</a><span class="string">        If specified, separators should be a (item_separator, key_separator)</span><br /> -<a class="lnum" href="#146" name="146">0146</a><span class="string">        tuple. The default is (', ', ': '). To get the most compact JSON</span><br /> -<a class="lnum" href="#147" name="147">0147</a><span class="string">        representation you should specify (',', ':') to eliminate whitespace.</span><br /> -<a class="lnum" href="#148" name="148">0148</a><span class="string"></span><br /> -<a class="lnum" href="#149" name="149">0149</a><span class="string">        If encoding is not None, then all input strings will be</span><br /> -<a class="lnum" href="#150" name="150">0150</a><span class="string">        transformed into unicode using that encoding prior to JSON-encoding. </span><br /> -<a class="lnum" href="#151" name="151">0151</a><span class="string">        The default is UTF-8.</span><br /> -<a class="lnum" href="#152" name="152">0152</a><span class="string">        """</span><br /> -<a class="lnum" href="#153" name="153">0153</a><br /> -<a class="lnum" href="#154" name="154">0154</a>        <span class="name">self</span><span class="op">.</span><span class="name">skipkeys</span> <span class="op">=</span> <span class="name">skipkeys</span><br /> -<a class="lnum" href="#155" name="155">0155</a>        <span class="name">self</span><span class="op">.</span><span class="name">ensure_ascii</span> <span class="op">=</span> <span class="name">ensure_ascii</span><br /> -<a class="lnum" href="#156" name="156">0156</a>        <span class="name">self</span><span class="op">.</span><span class="name">check_circular</span> <span class="op">=</span> <span class="name">check_circular</span><br /> -<a class="lnum" href="#157" name="157">0157</a>        <span class="name">self</span><span class="op">.</span><span class="name">allow_nan</span> <span class="op">=</span> <span class="name">allow_nan</span><br /> -<a class="lnum" href="#158" name="158">0158</a>        <span class="name">self</span><span class="op">.</span><span class="name">sort_keys</span> <span class="op">=</span> <span class="name">sort_keys</span><br /> -<a class="lnum" href="#159" name="159">0159</a>        <span class="name">self</span><span class="op">.</span><span class="name">indent</span> <span class="op">=</span> <span class="name">indent</span><br /> -<a class="lnum" href="#160" name="160">0160</a>        <span class="name">self</span><span class="op">.</span><span class="name">current_indent_level</span> <span class="op">=</span> <span class="number">0</span><br /> -<a class="lnum" href="#161" name="161">0161</a>        <span class="keyword">if</span> <span class="name">separators</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><span class="op">:</span><br /> -<a class="lnum" href="#162" name="162">0162</a>            <span class="name">self</span><span class="op">.</span><span class="name">item_separator</span><span class="op">,</span> <span class="name">self</span><span class="op">.</span><span class="name">key_separator</span> <span class="op">=</span> <span class="name">separators</span><br /> -<a class="lnum" href="#163" name="163">0163</a>        <span class="name">self</span><span class="op">.</span><span class="name">encoding</span> <span class="op">=</span> <span class="name">encoding</span><br /> -<a class="lnum" href="#164" name="164">0164</a><br /> -<a class="lnum" href="#165" name="165">0165</a>    <span class="keyword">def</span> <span class="name">_newline_indent</span><span class="op">(</span><span class="name">self</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#166" name="166">0166</a>        <span class="keyword">return</span> <span class="string">'\n'</span> <span class="op">+</span> <span class="op">(</span><span class="string">' '</span> <span class="op">*</span> <span class="op">(</span><span class="name">self</span><span class="op">.</span><span class="name">indent</span> <span class="op">*</span> <span class="name">self</span><span class="op">.</span><span class="name">current_indent_level</span><span class="op">)</span><span class="op">)</span><br /> -<a class="lnum" href="#167" name="167">0167</a><br /> -<a class="lnum" href="#168" name="168">0168</a>    <span class="keyword">def</span> <span class="name">_iterencode_list</span><span class="op">(</span><span class="name">self</span><span class="op">,</span> <span class="name">lst</span><span class="op">,</span> <span class="name">markers</span><span class="op">=</span><span class="name">None</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#169" name="169">0169</a>        <span class="keyword">if</span> <span class="keyword">not</span> <span class="name">lst</span><span class="op">:</span><br /> -<a class="lnum" href="#170" name="170">0170</a>            <span class="keyword">yield</span> <span class="string">'[]'</span><br /> -<a class="lnum" href="#171" name="171">0171</a>            <span class="keyword">return</span><br /> -<a class="lnum" href="#172" name="172">0172</a>        <span class="keyword">if</span> <span class="name">markers</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><span class="op">:</span><br /> -<a class="lnum" href="#173" name="173">0173</a>            <span class="name">markerid</span> <span class="op">=</span> <span class="name">id</span><span class="op">(</span><span class="name">lst</span><span class="op">)</span><br /> -<a class="lnum" href="#174" name="174">0174</a>            <span class="keyword">if</span> <span class="name">markerid</span> <span class="keyword">in</span> <span class="name">markers</span><span class="op">:</span><br /> -<a class="lnum" href="#175" name="175">0175</a>                <span class="keyword">raise</span> <span class="name">ValueError</span><span class="op">(</span><span class="string">"Circular reference detected"</span><span class="op">)</span><br /> -<a class="lnum" href="#176" name="176">0176</a>            <span class="name">markers</span><span class="op">[</span><span class="name">markerid</span><span class="op">]</span> <span class="op">=</span> <span class="name">lst</span><br /> -<a class="lnum" href="#177" name="177">0177</a>        <span class="keyword">yield</span> <span class="string">'['</span><br /> -<a class="lnum" href="#178" name="178">0178</a>        <span class="keyword">if</span> <span class="name">self</span><span class="op">.</span><span class="name">indent</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><span class="op">:</span><br /> -<a class="lnum" href="#179" name="179">0179</a>            <span class="name">self</span><span class="op">.</span><span class="name">current_indent_level</span> <span class="op">+=</span> <span class="number">1</span><br /> -<a class="lnum" href="#180" name="180">0180</a>            <span class="name">newline_indent</span> <span class="op">=</span> <span class="name">self</span><span class="op">.</span><span class="name">_newline_indent</span><span class="op">(</span><span class="op">)</span><br /> -<a class="lnum" href="#181" name="181">0181</a>            <span class="name">separator</span> <span class="op">=</span> <span class="name">self</span><span class="op">.</span><span class="name">item_separator</span> <span class="op">+</span> <span class="name">newline_indent</span><br /> -<a class="lnum" href="#182" name="182">0182</a>            <span class="keyword">yield</span> <span class="name">newline_indent</span><br /> -<a class="lnum" href="#183" name="183">0183</a>        <span class="keyword">else</span><span class="op">:</span><br /> -<a class="lnum" href="#184" name="184">0184</a>            <span class="name">newline_indent</span> <span class="op">=</span> <span class="name">None</span><br /> -<a class="lnum" href="#185" name="185">0185</a>            <span class="name">separator</span> <span class="op">=</span> <span class="name">self</span><span class="op">.</span><span class="name">item_separator</span><br /> -<a class="lnum" href="#186" name="186">0186</a>        <span class="name">first</span> <span class="op">=</span> <span class="name">True</span><br /> -<a class="lnum" href="#187" name="187">0187</a>        <span class="keyword">for</span> <span class="name">value</span> <span class="keyword">in</span> <span class="name">lst</span><span class="op">:</span><br /> -<a class="lnum" href="#188" name="188">0188</a>            <span class="keyword">if</span> <span class="name">first</span><span class="op">:</span><br /> -<a class="lnum" href="#189" name="189">0189</a>                <span class="name">first</span> <span class="op">=</span> <span class="name">False</span><br /> -<a class="lnum" href="#190" name="190">0190</a>            <span class="keyword">else</span><span class="op">:</span><br /> -<a class="lnum" href="#191" name="191">0191</a>                <span class="keyword">yield</span> <span class="name">separator</span><br /> -<a class="lnum" href="#192" name="192">0192</a>            <span class="keyword">for</span> <span class="name">chunk</span> <span class="keyword">in</span> <span class="name">self</span><span class="op">.</span><span class="name">_iterencode</span><span class="op">(</span><span class="name">value</span><span class="op">,</span> <span class="name">markers</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#193" name="193">0193</a>                <span class="keyword">yield</span> <span class="name">chunk</span><br /> -<a class="lnum" href="#194" name="194">0194</a>        <span class="keyword">if</span> <span class="name">newline_indent</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><span class="op">:</span><br /> -<a class="lnum" href="#195" name="195">0195</a>            <span class="name">self</span><span class="op">.</span><span class="name">current_indent_level</span> <span class="op">-=</span> <span class="number">1</span><br /> -<a class="lnum" href="#196" name="196">0196</a>            <span class="keyword">yield</span> <span class="name">self</span><span class="op">.</span><span class="name">_newline_indent</span><span class="op">(</span><span class="op">)</span><br /> -<a class="lnum" href="#197" name="197">0197</a>        <span class="keyword">yield</span> <span class="string">']'</span><br /> -<a class="lnum" href="#198" name="198">0198</a>        <span class="keyword">if</span> <span class="name">markers</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><span class="op">:</span><br /> -<a class="lnum" href="#199" name="199">0199</a>            <span class="keyword">del</span> <span class="name">markers</span><span class="op">[</span><span class="name">markerid</span><span class="op">]</span><br /> -<a class="lnum" href="#200" name="200">0200</a><br /> -<a class="lnum" href="#201" name="201">0201</a>    <span class="keyword">def</span> <span class="name">_iterencode_dict</span><span class="op">(</span><span class="name">self</span><span class="op">,</span> <span class="name">dct</span><span class="op">,</span> <span class="name">markers</span><span class="op">=</span><span class="name">None</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#202" name="202">0202</a>        <span class="keyword">if</span> <span class="keyword">not</span> <span class="name">dct</span><span class="op">:</span><br /> -<a class="lnum" href="#203" name="203">0203</a>            <span class="keyword">yield</span> <span class="string">'{}'</span><br /> -<a class="lnum" href="#204" name="204">0204</a>            <span class="keyword">return</span><br /> -<a class="lnum" href="#205" name="205">0205</a>        <span class="keyword">if</span> <span class="name">markers</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><span class="op">:</span><br /> -<a class="lnum" href="#206" name="206">0206</a>            <span class="name">markerid</span> <span class="op">=</span> <span class="name">id</span><span class="op">(</span><span class="name">dct</span><span class="op">)</span><br /> -<a class="lnum" href="#207" name="207">0207</a>            <span class="keyword">if</span> <span class="name">markerid</span> <span class="keyword">in</span> <span class="name">markers</span><span class="op">:</span><br /> -<a class="lnum" href="#208" name="208">0208</a>                <span class="keyword">raise</span> <span class="name">ValueError</span><span class="op">(</span><span class="string">"Circular reference detected"</span><span class="op">)</span><br /> -<a class="lnum" href="#209" name="209">0209</a>            <span class="name">markers</span><span class="op">[</span><span class="name">markerid</span><span class="op">]</span> <span class="op">=</span> <span class="name">dct</span><br /> -<a class="lnum" href="#210" name="210">0210</a>        <span class="keyword">yield</span> <span class="string">'{'</span><br /> -<a class="lnum" href="#211" name="211">0211</a>        <span class="name">key_separator</span> <span class="op">=</span> <span class="name">self</span><span class="op">.</span><span class="name">key_separator</span><br /> -<a class="lnum" href="#212" name="212">0212</a>        <span class="keyword">if</span> <span class="name">self</span><span class="op">.</span><span class="name">indent</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><span class="op">:</span><br /> -<a class="lnum" href="#213" name="213">0213</a>            <span class="name">self</span><span class="op">.</span><span class="name">current_indent_level</span> <span class="op">+=</span> <span class="number">1</span><br /> -<a class="lnum" href="#214" name="214">0214</a>            <span class="name">newline_indent</span> <span class="op">=</span> <span class="name">self</span><span class="op">.</span><span class="name">_newline_indent</span><span class="op">(</span><span class="op">)</span><br /> -<a class="lnum" href="#215" name="215">0215</a>            <span class="name">item_separator</span> <span class="op">=</span> <span class="name">self</span><span class="op">.</span><span class="name">item_separator</span> <span class="op">+</span> <span class="name">newline_indent</span><br /> -<a class="lnum" href="#216" name="216">0216</a>            <span class="keyword">yield</span> <span class="name">newline_indent</span><br /> -<a class="lnum" href="#217" name="217">0217</a>        <span class="keyword">else</span><span class="op">:</span><br /> -<a class="lnum" href="#218" name="218">0218</a>            <span class="name">newline_indent</span> <span class="op">=</span> <span class="name">None</span><br /> -<a class="lnum" href="#219" name="219">0219</a>            <span class="name">item_separator</span> <span class="op">=</span> <span class="name">self</span><span class="op">.</span><span class="name">item_separator</span><br /> -<a class="lnum" href="#220" name="220">0220</a>        <span class="name">first</span> <span class="op">=</span> <span class="name">True</span><br /> -<a class="lnum" href="#221" name="221">0221</a>        <span class="keyword">if</span> <span class="name">self</span><span class="op">.</span><span class="name">ensure_ascii</span><span class="op">:</span><br /> -<a class="lnum" href="#222" name="222">0222</a>            <span class="name">encoder</span> <span class="op">=</span> <span class="name">encode_basestring_ascii</span><br /> -<a class="lnum" href="#223" name="223">0223</a>        <span class="keyword">else</span><span class="op">:</span><br /> -<a class="lnum" href="#224" name="224">0224</a>            <span class="name">encoder</span> <span class="op">=</span> <span class="name">encode_basestring</span><br /> -<a class="lnum" href="#225" name="225">0225</a>        <span class="name">allow_nan</span> <span class="op">=</span> <span class="name">self</span><span class="op">.</span><span class="name">allow_nan</span><br /> -<a class="lnum" href="#226" name="226">0226</a>        <span class="keyword">if</span> <span class="name">self</span><span class="op">.</span><span class="name">sort_keys</span><span class="op">:</span><br /> -<a class="lnum" href="#227" name="227">0227</a>            <span class="name">keys</span> <span class="op">=</span> <span class="name">dct</span><span class="op">.</span><span class="name">keys</span><span class="op">(</span><span class="op">)</span><br /> -<a class="lnum" href="#228" name="228">0228</a>            <span class="name">keys</span><span class="op">.</span><span class="name">sort</span><span class="op">(</span><span class="op">)</span><br /> -<a class="lnum" href="#229" name="229">0229</a>            <span class="name">items</span> <span class="op">=</span> <span class="op">[</span><span class="op">(</span><span class="name">k</span><span class="op">,</span> <span class="name">dct</span><span class="op">[</span><span class="name">k</span><span class="op">]</span><span class="op">)</span> <span class="keyword">for</span> <span class="name">k</span> <span class="keyword">in</span> <span class="name">keys</span><span class="op">]</span><br /> -<a class="lnum" href="#230" name="230">0230</a>        <span class="keyword">else</span><span class="op">:</span><br /> -<a class="lnum" href="#231" name="231">0231</a>            <span class="name">items</span> <span class="op">=</span> <span class="name">dct</span><span class="op">.</span><span class="name">iteritems</span><span class="op">(</span><span class="op">)</span><br /> -<a class="lnum" href="#232" name="232">0232</a>        <span class="name">_encoding</span> <span class="op">=</span> <span class="name">self</span><span class="op">.</span><span class="name">encoding</span><br /> -<a class="lnum" href="#233" name="233">0233</a>        <span class="name">_do_decode</span> <span class="op">=</span> <span class="op">(</span><span class="name">_encoding</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><br /> -<a class="lnum" href="#234" name="234">0234</a>            <span class="keyword">and</span> <span class="keyword">not</span> <span class="op">(</span><span class="name">_need_utf8</span> <span class="keyword">and</span> <span class="name">_encoding</span> <span class="op">==</span> <span class="string">'utf-8'</span><span class="op">)</span><span class="op">)</span><br /> -<a class="lnum" href="#235" name="235">0235</a>        <span class="keyword">for</span> <span class="name">key</span><span class="op">,</span> <span class="name">value</span> <span class="keyword">in</span> <span class="name">items</span><span class="op">:</span><br /> -<a class="lnum" href="#236" name="236">0236</a>            <span class="keyword">if</span> <span class="name">isinstance</span><span class="op">(</span><span class="name">key</span><span class="op">,</span> <span class="name">str</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#237" name="237">0237</a>                <span class="keyword">if</span> <span class="name">_do_decode</span><span class="op">:</span><br /> -<a class="lnum" href="#238" name="238">0238</a>                    <span class="name">key</span> <span class="op">=</span> <span class="name">key</span><span class="op">.</span><span class="name">decode</span><span class="op">(</span><span class="name">_encoding</span><span class="op">)</span><br /> -<a class="lnum" href="#239" name="239">0239</a>            <span class="keyword">elif</span> <span class="name">isinstance</span><span class="op">(</span><span class="name">key</span><span class="op">,</span> <span class="name">basestring</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#240" name="240">0240</a>                <span class="keyword">pass</span><br /> -<a class="lnum" href="#241" name="241">0241</a>            <span class="comment"># JavaScript is weakly typed for these, so it makes sense to</span><br /> -<a class="lnum" href="#242" name="242">0242</a><span class="comment"></span>            <span class="comment"># also allow them.  Many encoders seem to do something like this.</span><br /> -<a class="lnum" href="#243" name="243">0243</a><span class="comment"></span>            <span class="keyword">elif</span> <span class="name">isinstance</span><span class="op">(</span><span class="name">key</span><span class="op">,</span> <span class="name">float</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#244" name="244">0244</a>                <span class="name">key</span> <span class="op">=</span> <span class="name">floatstr</span><span class="op">(</span><span class="name">key</span><span class="op">,</span> <span class="name">allow_nan</span><span class="op">)</span><br /> -<a class="lnum" href="#245" name="245">0245</a>            <span class="keyword">elif</span> <span class="name">isinstance</span><span class="op">(</span><span class="name">key</span><span class="op">,</span> <span class="op">(</span><span class="name">int</span><span class="op">,</span> <span class="name">long</span><span class="op">)</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#246" name="246">0246</a>                <span class="name">key</span> <span class="op">=</span> <span class="name">str</span><span class="op">(</span><span class="name">key</span><span class="op">)</span><br /> -<a class="lnum" href="#247" name="247">0247</a>            <span class="keyword">elif</span> <span class="name">key</span> <span class="keyword">is</span> <span class="name">True</span><span class="op">:</span><br /> -<a class="lnum" href="#248" name="248">0248</a>                <span class="name">key</span> <span class="op">=</span> <span class="string">'true'</span><br /> -<a class="lnum" href="#249" name="249">0249</a>            <span class="keyword">elif</span> <span class="name">key</span> <span class="keyword">is</span> <span class="name">False</span><span class="op">:</span><br /> -<a class="lnum" href="#250" name="250">0250</a>                <span class="name">key</span> <span class="op">=</span> <span class="string">'false'</span><br /> -<a class="lnum" href="#251" name="251">0251</a>            <span class="keyword">elif</span> <span class="name">key</span> <span class="keyword">is</span> <span class="name">None</span><span class="op">:</span><br /> -<a class="lnum" href="#252" name="252">0252</a>                <span class="name">key</span> <span class="op">=</span> <span class="string">'null'</span><br /> -<a class="lnum" href="#253" name="253">0253</a>            <span class="keyword">elif</span> <span class="name">self</span><span class="op">.</span><span class="name">skipkeys</span><span class="op">:</span><br /> -<a class="lnum" href="#254" name="254">0254</a>                <span class="keyword">continue</span><br /> -<a class="lnum" href="#255" name="255">0255</a>            <span class="keyword">else</span><span class="op">:</span><br /> -<a class="lnum" href="#256" name="256">0256</a>                <span class="keyword">raise</span> <span class="name">TypeError</span><span class="op">(</span><span class="string">"key %r is not a string"</span> <span class="op">%</span> <span class="op">(</span><span class="name">key</span><span class="op">,</span><span class="op">)</span><span class="op">)</span><br /> -<a class="lnum" href="#257" name="257">0257</a>            <span class="keyword">if</span> <span class="name">first</span><span class="op">:</span><br /> -<a class="lnum" href="#258" name="258">0258</a>                <span class="name">first</span> <span class="op">=</span> <span class="name">False</span><br /> -<a class="lnum" href="#259" name="259">0259</a>            <span class="keyword">else</span><span class="op">:</span><br /> -<a class="lnum" href="#260" name="260">0260</a>                <span class="keyword">yield</span> <span class="name">item_separator</span><br /> -<a class="lnum" href="#261" name="261">0261</a>            <span class="keyword">yield</span> <span class="name">encoder</span><span class="op">(</span><span class="name">key</span><span class="op">)</span><br /> -<a class="lnum" href="#262" name="262">0262</a>            <span class="keyword">yield</span> <span class="name">key_separator</span><br /> -<a class="lnum" href="#263" name="263">0263</a>            <span class="keyword">for</span> <span class="name">chunk</span> <span class="keyword">in</span> <span class="name">self</span><span class="op">.</span><span class="name">_iterencode</span><span class="op">(</span><span class="name">value</span><span class="op">,</span> <span class="name">markers</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#264" name="264">0264</a>                <span class="keyword">yield</span> <span class="name">chunk</span><br /> -<a class="lnum" href="#265" name="265">0265</a>        <span class="keyword">if</span> <span class="name">newline_indent</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><span class="op">:</span><br /> -<a class="lnum" href="#266" name="266">0266</a>            <span class="name">self</span><span class="op">.</span><span class="name">current_indent_level</span> <span class="op">-=</span> <span class="number">1</span><br /> -<a class="lnum" href="#267" name="267">0267</a>            <span class="keyword">yield</span> <span class="name">self</span><span class="op">.</span><span class="name">_newline_indent</span><span class="op">(</span><span class="op">)</span><br /> -<a class="lnum" href="#268" name="268">0268</a>        <span class="keyword">yield</span> <span class="string">'}'</span><br /> -<a class="lnum" href="#269" name="269">0269</a>        <span class="keyword">if</span> <span class="name">markers</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><span class="op">:</span><br /> -<a class="lnum" href="#270" name="270">0270</a>            <span class="keyword">del</span> <span class="name">markers</span><span class="op">[</span><span class="name">markerid</span><span class="op">]</span><br /> -<a class="lnum" href="#271" name="271">0271</a><br /> -<a class="lnum" href="#272" name="272">0272</a>    <span class="keyword">def</span> <span class="name">_iterencode</span><span class="op">(</span><span class="name">self</span><span class="op">,</span> <span class="name">o</span><span class="op">,</span> <span class="name">markers</span><span class="op">=</span><span class="name">None</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#273" name="273">0273</a>        <span class="keyword">if</span> <span class="name">isinstance</span><span class="op">(</span><span class="name">o</span><span class="op">,</span> <span class="name">basestring</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#274" name="274">0274</a>            <span class="keyword">if</span> <span class="name">self</span><span class="op">.</span><span class="name">ensure_ascii</span><span class="op">:</span><br /> -<a class="lnum" href="#275" name="275">0275</a>                <span class="name">encoder</span> <span class="op">=</span> <span class="name">encode_basestring_ascii</span><br /> -<a class="lnum" href="#276" name="276">0276</a>            <span class="keyword">else</span><span class="op">:</span><br /> -<a class="lnum" href="#277" name="277">0277</a>                <span class="name">encoder</span> <span class="op">=</span> <span class="name">encode_basestring</span><br /> -<a class="lnum" href="#278" name="278">0278</a>            <span class="name">_encoding</span> <span class="op">=</span> <span class="name">self</span><span class="op">.</span><span class="name">encoding</span><br /> -<a class="lnum" href="#279" name="279">0279</a>            <span class="keyword">if</span> <span class="op">(</span><span class="name">_encoding</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span> <span class="keyword">and</span> <span class="name">isinstance</span><span class="op">(</span><span class="name">o</span><span class="op">,</span> <span class="name">str</span><span class="op">)</span><br /> -<a class="lnum" href="#280" name="280">0280</a>                    <span class="keyword">and</span> <span class="keyword">not</span> <span class="op">(</span><span class="name">_need_utf8</span> <span class="keyword">and</span> <span class="name">_encoding</span> <span class="op">==</span> <span class="string">'utf-8'</span><span class="op">)</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#281" name="281">0281</a>                <span class="name">o</span> <span class="op">=</span> <span class="name">o</span><span class="op">.</span><span class="name">decode</span><span class="op">(</span><span class="name">_encoding</span><span class="op">)</span><br /> -<a class="lnum" href="#282" name="282">0282</a>            <span class="keyword">yield</span> <span class="name">encoder</span><span class="op">(</span><span class="name">o</span><span class="op">)</span><br /> -<a class="lnum" href="#283" name="283">0283</a>        <span class="keyword">elif</span> <span class="name">o</span> <span class="keyword">is</span> <span class="name">None</span><span class="op">:</span><br /> -<a class="lnum" href="#284" name="284">0284</a>            <span class="keyword">yield</span> <span class="string">'null'</span><br /> -<a class="lnum" href="#285" name="285">0285</a>        <span class="keyword">elif</span> <span class="name">o</span> <span class="keyword">is</span> <span class="name">True</span><span class="op">:</span><br /> -<a class="lnum" href="#286" name="286">0286</a>            <span class="keyword">yield</span> <span class="string">'true'</span><br /> -<a class="lnum" href="#287" name="287">0287</a>        <span class="keyword">elif</span> <span class="name">o</span> <span class="keyword">is</span> <span class="name">False</span><span class="op">:</span><br /> -<a class="lnum" href="#288" name="288">0288</a>            <span class="keyword">yield</span> <span class="string">'false'</span><br /> -<a class="lnum" href="#289" name="289">0289</a>        <span class="keyword">elif</span> <span class="name">isinstance</span><span class="op">(</span><span class="name">o</span><span class="op">,</span> <span class="op">(</span><span class="name">int</span><span class="op">,</span> <span class="name">long</span><span class="op">)</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#290" name="290">0290</a>            <span class="keyword">yield</span> <span class="name">str</span><span class="op">(</span><span class="name">o</span><span class="op">)</span><br /> -<a class="lnum" href="#291" name="291">0291</a>        <span class="keyword">elif</span> <span class="name">isinstance</span><span class="op">(</span><span class="name">o</span><span class="op">,</span> <span class="name">float</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#292" name="292">0292</a>            <span class="keyword">yield</span> <span class="name">floatstr</span><span class="op">(</span><span class="name">o</span><span class="op">,</span> <span class="name">self</span><span class="op">.</span><span class="name">allow_nan</span><span class="op">)</span><br /> -<a class="lnum" href="#293" name="293">0293</a>        <span class="keyword">elif</span> <span class="name">isinstance</span><span class="op">(</span><span class="name">o</span><span class="op">,</span> <span class="op">(</span><span class="name">list</span><span class="op">,</span> <span class="name">tuple</span><span class="op">)</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#294" name="294">0294</a>            <span class="keyword">for</span> <span class="name">chunk</span> <span class="keyword">in</span> <span class="name">self</span><span class="op">.</span><span class="name">_iterencode_list</span><span class="op">(</span><span class="name">o</span><span class="op">,</span> <span class="name">markers</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#295" name="295">0295</a>                <span class="keyword">yield</span> <span class="name">chunk</span><br /> -<a class="lnum" href="#296" name="296">0296</a>        <span class="keyword">elif</span> <span class="name">isinstance</span><span class="op">(</span><span class="name">o</span><span class="op">,</span> <span class="name">dict</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#297" name="297">0297</a>            <span class="keyword">for</span> <span class="name">chunk</span> <span class="keyword">in</span> <span class="name">self</span><span class="op">.</span><span class="name">_iterencode_dict</span><span class="op">(</span><span class="name">o</span><span class="op">,</span> <span class="name">markers</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#298" name="298">0298</a>                <span class="keyword">yield</span> <span class="name">chunk</span><br /> -<a class="lnum" href="#299" name="299">0299</a>        <span class="keyword">else</span><span class="op">:</span><br /> -<a class="lnum" href="#300" name="300">0300</a>            <span class="keyword">if</span> <span class="name">markers</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><span class="op">:</span><br /> -<a class="lnum" href="#301" name="301">0301</a>                <span class="name">markerid</span> <span class="op">=</span> <span class="name">id</span><span class="op">(</span><span class="name">o</span><span class="op">)</span><br /> -<a class="lnum" href="#302" name="302">0302</a>                <span class="keyword">if</span> <span class="name">markerid</span> <span class="keyword">in</span> <span class="name">markers</span><span class="op">:</span><br /> -<a class="lnum" href="#303" name="303">0303</a>                    <span class="keyword">raise</span> <span class="name">ValueError</span><span class="op">(</span><span class="string">"Circular reference detected"</span><span class="op">)</span><br /> -<a class="lnum" href="#304" name="304">0304</a>                <span class="name">markers</span><span class="op">[</span><span class="name">markerid</span><span class="op">]</span> <span class="op">=</span> <span class="name">o</span><br /> -<a class="lnum" href="#305" name="305">0305</a>            <span class="keyword">for</span> <span class="name">chunk</span> <span class="keyword">in</span> <span class="name">self</span><span class="op">.</span><span class="name">_iterencode_default</span><span class="op">(</span><span class="name">o</span><span class="op">,</span> <span class="name">markers</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#306" name="306">0306</a>                <span class="keyword">yield</span> <span class="name">chunk</span><br /> -<a class="lnum" href="#307" name="307">0307</a>            <span class="keyword">if</span> <span class="name">markers</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><span class="op">:</span><br /> -<a class="lnum" href="#308" name="308">0308</a>                <span class="keyword">del</span> <span class="name">markers</span><span class="op">[</span><span class="name">markerid</span><span class="op">]</span><br /> -<a class="lnum" href="#309" name="309">0309</a><br /> -<a class="lnum" href="#310" name="310">0310</a>    <span class="keyword">def</span> <span class="name">_iterencode_default</span><span class="op">(</span><span class="name">self</span><span class="op">,</span> <span class="name">o</span><span class="op">,</span> <span class="name">markers</span><span class="op">=</span><span class="name">None</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#311" name="311">0311</a>        <span class="name">newobj</span> <span class="op">=</span> <span class="name">self</span><span class="op">.</span><span class="name">default</span><span class="op">(</span><span class="name">o</span><span class="op">)</span><br /> -<a class="lnum" href="#312" name="312">0312</a>        <span class="keyword">return</span> <span class="name">self</span><span class="op">.</span><span class="name">_iterencode</span><span class="op">(</span><span class="name">newobj</span><span class="op">,</span> <span class="name">markers</span><span class="op">)</span><br /> -<a class="lnum" href="#313" name="313">0313</a><br /> -<a class="lnum" href="#314" name="314">0314</a>    <span class="keyword">def</span> <span class="name">default</span><span class="op">(</span><span class="name">self</span><span class="op">,</span> <span class="name">o</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#315" name="315">0315</a>        <span class="string">"""</span><br /> -<a class="lnum" href="#316" name="316">0316</a><span class="string">        Implement this method in a subclass such that it returns</span><br /> -<a class="lnum" href="#317" name="317">0317</a><span class="string">        a serializable object for ``o``, or calls the base implementation</span><br /> -<a class="lnum" href="#318" name="318">0318</a><span class="string">        (to raise a ``TypeError``).</span><br /> -<a class="lnum" href="#319" name="319">0319</a><span class="string"></span><br /> -<a class="lnum" href="#320" name="320">0320</a><span class="string">        For example, to support arbitrary iterators, you could</span><br /> -<a class="lnum" href="#321" name="321">0321</a><span class="string">        implement default like this::</span><br /> -<a class="lnum" href="#322" name="322">0322</a><span class="string">            </span><br /> -<a class="lnum" href="#323" name="323">0323</a><span class="string">            def default(self, o):</span><br /> -<a class="lnum" href="#324" name="324">0324</a><span class="string">                try:</span><br /> -<a class="lnum" href="#325" name="325">0325</a><span class="string">                    iterable = iter(o)</span><br /> -<a class="lnum" href="#326" name="326">0326</a><span class="string">                except TypeError:</span><br /> -<a class="lnum" href="#327" name="327">0327</a><span class="string">                    pass</span><br /> -<a class="lnum" href="#328" name="328">0328</a><span class="string">                else:</span><br /> -<a class="lnum" href="#329" name="329">0329</a><span class="string">                    return list(iterable)</span><br /> -<a class="lnum" href="#330" name="330">0330</a><span class="string">                return JSONEncoder.default(self, o)</span><br /> -<a class="lnum" href="#331" name="331">0331</a><span class="string">        """</span><br /> -<a class="lnum" href="#332" name="332">0332</a>        <span class="keyword">raise</span> <span class="name">TypeError</span><span class="op">(</span><span class="string">"%r is not JSON serializable"</span> <span class="op">%</span> <span class="op">(</span><span class="name">o</span><span class="op">,</span><span class="op">)</span><span class="op">)</span><br /> -<a class="lnum" href="#333" name="333">0333</a><br /> -<a class="lnum" href="#334" name="334">0334</a>    <span class="keyword">def</span> <span class="name">encode</span><span class="op">(</span><span class="name">self</span><span class="op">,</span> <span class="name">o</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#335" name="335">0335</a>        <span class="string">"""</span><br /> -<a class="lnum" href="#336" name="336">0336</a><span class="string">        Return a JSON string representation of a Python data structure.</span><br /> -<a class="lnum" href="#337" name="337">0337</a><span class="string"></span><br /> -<a class="lnum" href="#338" name="338">0338</a><span class="string">        >>> JSONEncoder().encode({"foo": ["bar", "baz"]})</span><br /> -<a class="lnum" href="#339" name="339">0339</a><span class="string">        '{"foo":["bar", "baz"]}'</span><br /> -<a class="lnum" href="#340" name="340">0340</a><span class="string">        """</span><br /> -<a class="lnum" href="#341" name="341">0341</a>        <span class="comment"># This is for extremely simple cases and benchmarks...</span><br /> -<a class="lnum" href="#342" name="342">0342</a><span class="comment"></span>        <span class="keyword">if</span> <span class="name">isinstance</span><span class="op">(</span><span class="name">o</span><span class="op">,</span> <span class="name">basestring</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#343" name="343">0343</a>            <span class="keyword">if</span> <span class="name">isinstance</span><span class="op">(</span><span class="name">o</span><span class="op">,</span> <span class="name">str</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#344" name="344">0344</a>                <span class="name">_encoding</span> <span class="op">=</span> <span class="name">self</span><span class="op">.</span><span class="name">encoding</span><br /> -<a class="lnum" href="#345" name="345">0345</a>                <span class="keyword">if</span> <span class="op">(</span><span class="name">_encoding</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><br /> -<a class="lnum" href="#346" name="346">0346</a>                        <span class="keyword">and</span> <span class="keyword">not</span> <span class="op">(</span><span class="name">_encoding</span> <span class="op">==</span> <span class="string">'utf-8'</span> <span class="keyword">and</span> <span class="name">_need_utf8</span><span class="op">)</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#347" name="347">0347</a>                    <span class="name">o</span> <span class="op">=</span> <span class="name">o</span><span class="op">.</span><span class="name">decode</span><span class="op">(</span><span class="name">_encoding</span><span class="op">)</span><br /> -<a class="lnum" href="#348" name="348">0348</a>            <span class="keyword">return</span> <span class="name">encode_basestring_ascii</span><span class="op">(</span><span class="name">o</span><span class="op">)</span><br /> -<a class="lnum" href="#349" name="349">0349</a>        <span class="comment"># This doesn't pass the iterator directly to ''.join() because it</span><br /> -<a class="lnum" href="#350" name="350">0350</a><span class="comment"></span>        <span class="comment"># sucks at reporting exceptions.  It's going to do this internally</span><br /> -<a class="lnum" href="#351" name="351">0351</a><span class="comment"></span>        <span class="comment"># anyway because it uses PySequence_Fast or similar.</span><br /> -<a class="lnum" href="#352" name="352">0352</a><span class="comment"></span>        <span class="name">chunks</span> <span class="op">=</span> <span class="name">list</span><span class="op">(</span><span class="name">self</span><span class="op">.</span><span class="name">iterencode</span><span class="op">(</span><span class="name">o</span><span class="op">)</span><span class="op">)</span><br /> -<a class="lnum" href="#353" name="353">0353</a>        <span class="keyword">return</span> <span class="string">''</span><span class="op">.</span><span class="name">join</span><span class="op">(</span><span class="name">chunks</span><span class="op">)</span><br /> -<a class="lnum" href="#354" name="354">0354</a><br /> -<a class="lnum" href="#355" name="355">0355</a>    <span class="keyword">def</span> <span class="name">iterencode</span><span class="op">(</span><span class="name">self</span><span class="op">,</span> <span class="name">o</span><span class="op">)</span><span class="op">:</span><br /> -<a class="lnum" href="#356" name="356">0356</a>        <span class="string">"""</span><br /> -<a class="lnum" href="#357" name="357">0357</a><span class="string">        Encode the given object and yield each string</span><br /> -<a class="lnum" href="#358" name="358">0358</a><span class="string">        representation as available.</span><br /> -<a class="lnum" href="#359" name="359">0359</a><span class="string">        </span><br /> -<a class="lnum" href="#360" name="360">0360</a><span class="string">        For example::</span><br /> -<a class="lnum" href="#361" name="361">0361</a><span class="string">            </span><br /> -<a class="lnum" href="#362" name="362">0362</a><span class="string">            for chunk in JSONEncoder().iterencode(bigobject):</span><br /> -<a class="lnum" href="#363" name="363">0363</a><span class="string">                mysocket.write(chunk)</span><br /> -<a class="lnum" href="#364" name="364">0364</a><span class="string">        """</span><br /> -<a class="lnum" href="#365" name="365">0365</a>        <span class="keyword">if</span> <span class="name">self</span><span class="op">.</span><span class="name">check_circular</span><span class="op">:</span><br /> -<a class="lnum" href="#366" name="366">0366</a>            <span class="name">markers</span> <span class="op">=</span> <span class="op">{</span><span class="op">}</span><br /> -<a class="lnum" href="#367" name="367">0367</a>        <span class="keyword">else</span><span class="op">:</span><br /> -<a class="lnum" href="#368" name="368">0368</a>            <span class="name">markers</span> <span class="op">=</span> <span class="name">None</span><br /> -<a class="lnum" href="#369" name="369">0369</a>        <span class="keyword">return</span> <span class="name">self</span><span class="op">.</span><span class="name">_iterencode</span><span class="op">(</span><span class="name">o</span><span class="op">,</span> <span class="name">markers</span><span class="op">)</span><br /> -<a class="lnum" href="#370" name="370">0370</a><br /> -<a class="lnum" href="#371" name="371">0371</a><span class="name">__all__</span> <span class="op">=</span> <span class="op">[</span><span class="string">'JSONEncoder'</span><span class="op">]</span></code></div></body></html>
\ No newline at end of file +<a class="lnum" href="#48" name="48">0048</a><span class="keyword">def</span> <span class="name">encode_basestring</span><span class="op">(</span><span class="name">s</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#49" name="49">0049</a>    <span class="string">"""</span><br /> +<a class="lnum" href="#50" name="50">0050</a><span class="string">    Return a JSON representation of a Python string</span><br /> +<a class="lnum" href="#51" name="51">0051</a><span class="string">    """</span><br /> +<a class="lnum" href="#52" name="52">0052</a>    <span class="keyword">def</span> <span class="name">replace</span><span class="op">(</span><span class="name">match</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#53" name="53">0053</a>        <span class="keyword">return</span> <span class="name">ESCAPE_DCT</span><span class="op">[</span><span class="name">match</span><span class="op">.</span><span class="name">group</span><span class="op">(</span><span class="number">0</span><span class="op">)</span><span class="op">]</span><br /> +<a class="lnum" href="#54" name="54">0054</a>    <span class="keyword">return</span> <span class="string">'"'</span> <span class="op">+</span> <span class="name">ESCAPE</span><span class="op">.</span><span class="name">sub</span><span class="op">(</span><span class="name">replace</span><span class="op">,</span> <span class="name">s</span><span class="op">)</span> <span class="op">+</span> <span class="string">'"'</span><br /> +<a class="lnum" href="#55" name="55">0055</a><br /> +<a class="lnum" href="#56" name="56">0056</a><span class="keyword">def</span> <span class="name">encode_basestring_ascii</span><span class="op">(</span><span class="name">s</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#57" name="57">0057</a>    <span class="keyword">def</span> <span class="name">replace</span><span class="op">(</span><span class="name">match</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#58" name="58">0058</a>        <span class="name">s</span> <span class="op">=</span> <span class="name">match</span><span class="op">.</span><span class="name">group</span><span class="op">(</span><span class="number">0</span><span class="op">)</span><br /> +<a class="lnum" href="#59" name="59">0059</a>        <span class="keyword">try</span><span class="op">:</span><br /> +<a class="lnum" href="#60" name="60">0060</a>            <span class="keyword">return</span> <span class="name">ESCAPE_DCT</span><span class="op">[</span><span class="name">s</span><span class="op">]</span><br /> +<a class="lnum" href="#61" name="61">0061</a>        <span class="keyword">except</span> <span class="name">KeyError</span><span class="op">:</span><br /> +<a class="lnum" href="#62" name="62">0062</a>            <span class="name">n</span> <span class="op">=</span> <span class="name">ord</span><span class="op">(</span><span class="name">s</span><span class="op">)</span><br /> +<a class="lnum" href="#63" name="63">0063</a>            <span class="keyword">if</span> <span class="name">n</span> <span class="op"><</span> <span class="number">0x10000</span><span class="op">:</span><br /> +<a class="lnum" href="#64" name="64">0064</a>                <span class="keyword">return</span> <span class="string">'\\u%04x'</span> <span class="op">%</span> <span class="op">(</span><span class="name">n</span><span class="op">,</span><span class="op">)</span><br /> +<a class="lnum" href="#65" name="65">0065</a>            <span class="keyword">else</span><span class="op">:</span><br /> +<a class="lnum" href="#66" name="66">0066</a>                <span class="comment"># surrogate pair</span><br /> +<a class="lnum" href="#67" name="67">0067</a><span class="comment"></span>                <span class="name">n</span> <span class="op">-=</span> <span class="number">0x10000</span><br /> +<a class="lnum" href="#68" name="68">0068</a>                <span class="name">s1</span> <span class="op">=</span> <span class="number">0xd800</span> <span class="op">|</span> <span class="op">(</span><span class="op">(</span><span class="name">n</span> <span class="op">>></span> <span class="number">10</span><span class="op">)</span> <span class="op">&</span> <span class="number">0x3ff</span><span class="op">)</span><br /> +<a class="lnum" href="#69" name="69">0069</a>                <span class="name">s2</span> <span class="op">=</span> <span class="number">0xdc00</span> <span class="op">|</span> <span class="op">(</span><span class="name">n</span> <span class="op">&</span> <span class="number">0x3ff</span><span class="op">)</span><br /> +<a class="lnum" href="#70" name="70">0070</a>                <span class="keyword">return</span> <span class="string">'\\u%04x\\u%04x'</span> <span class="op">%</span> <span class="op">(</span><span class="name">s1</span><span class="op">,</span> <span class="name">s2</span><span class="op">)</span><br /> +<a class="lnum" href="#71" name="71">0071</a>    <span class="keyword">return</span> <span class="string">'"'</span> <span class="op">+</span> <span class="name">str</span><span class="op">(</span><span class="name">ESCAPE_ASCII</span><span class="op">.</span><span class="name">sub</span><span class="op">(</span><span class="name">replace</span><span class="op">,</span> <span class="name">s</span><span class="op">)</span><span class="op">)</span> <span class="op">+</span> <span class="string">'"'</span><br /> +<a class="lnum" href="#72" name="72">0072</a><br /> +<a class="lnum" href="#73" name="73">0073</a><span class="keyword">try</span><span class="op">:</span><br /> +<a class="lnum" href="#74" name="74">0074</a>    <span class="name">encode_basestring_ascii</span> <span class="op">=</span> <span class="name">_speedups</span><span class="op">.</span><span class="name">encode_basestring_ascii</span><br /> +<a class="lnum" href="#75" name="75">0075</a>    <span class="name">_need_utf8</span> <span class="op">=</span> <span class="name">True</span><br /> +<a class="lnum" href="#76" name="76">0076</a><span class="keyword">except</span> <span class="name">AttributeError</span><span class="op">:</span><br /> +<a class="lnum" href="#77" name="77">0077</a>    <span class="name">_need_utf8</span> <span class="op">=</span> <span class="name">False</span><br /> +<a class="lnum" href="#78" name="78">0078</a><br /> +<a class="lnum" href="#79" name="79">0079</a><span class="keyword">class</span> <span class="name">JSONEncoder</span><span class="op">(</span><span class="name">object</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#80" name="80">0080</a>    <span class="string">"""</span><br /> +<a class="lnum" href="#81" name="81">0081</a><span class="string">    Extensible JSON <http://json.org> encoder for Python data structures.</span><br /> +<a class="lnum" href="#82" name="82">0082</a><span class="string"></span><br /> +<a class="lnum" href="#83" name="83">0083</a><span class="string">    Supports the following objects and types by default:</span><br /> +<a class="lnum" href="#84" name="84">0084</a><span class="string">    </span><br /> +<a class="lnum" href="#85" name="85">0085</a><span class="string">    +-------------------+---------------+</span><br /> +<a class="lnum" href="#86" name="86">0086</a><span class="string">    | Python            | JSON          |</span><br /> +<a class="lnum" href="#87" name="87">0087</a><span class="string">    +===================+===============+</span><br /> +<a class="lnum" href="#88" name="88">0088</a><span class="string">    | dict              | object        |</span><br /> +<a class="lnum" href="#89" name="89">0089</a><span class="string">    +-------------------+---------------+</span><br /> +<a class="lnum" href="#90" name="90">0090</a><span class="string">    | list, tuple       | array         |</span><br /> +<a class="lnum" href="#91" name="91">0091</a><span class="string">    +-------------------+---------------+</span><br /> +<a class="lnum" href="#92" name="92">0092</a><span class="string">    | str, unicode      | string        |</span><br /> +<a class="lnum" href="#93" name="93">0093</a><span class="string">    +-------------------+---------------+</span><br /> +<a class="lnum" href="#94" name="94">0094</a><span class="string">    | int, long, float  | number        |</span><br /> +<a class="lnum" href="#95" name="95">0095</a><span class="string">    +-------------------+---------------+</span><br /> +<a class="lnum" href="#96" name="96">0096</a><span class="string">    | True              | true          |</span><br /> +<a class="lnum" href="#97" name="97">0097</a><span class="string">    +-------------------+---------------+</span><br /> +<a class="lnum" href="#98" name="98">0098</a><span class="string">    | False             | false         |</span><br /> +<a class="lnum" href="#99" name="99">0099</a><span class="string">    +-------------------+---------------+</span><br /> +<a class="lnum" href="#100" name="100">0100</a><span class="string">    | None              | null          |</span><br /> +<a class="lnum" href="#101" name="101">0101</a><span class="string">    +-------------------+---------------+</span><br /> +<a class="lnum" href="#102" name="102">0102</a><span class="string"></span><br /> +<a class="lnum" href="#103" name="103">0103</a><span class="string">    To extend this to recognize other objects, subclass and implement a</span><br /> +<a class="lnum" href="#104" name="104">0104</a><span class="string">    ``.default()`` method with another method that returns a serializable</span><br /> +<a class="lnum" href="#105" name="105">0105</a><span class="string">    object for ``o`` if possible, otherwise it should call the superclass</span><br /> +<a class="lnum" href="#106" name="106">0106</a><span class="string">    implementation (to raise ``TypeError``).</span><br /> +<a class="lnum" href="#107" name="107">0107</a><span class="string">    """</span><br /> +<a class="lnum" href="#108" name="108">0108</a>    <span class="name">__all__</span> <span class="op">=</span> <span class="op">[</span><span class="string">'__init__'</span><span class="op">,</span> <span class="string">'default'</span><span class="op">,</span> <span class="string">'encode'</span><span class="op">,</span> <span class="string">'iterencode'</span><span class="op">]</span><br /> +<a class="lnum" href="#109" name="109">0109</a>    <span class="name">item_separator</span> <span class="op">=</span> <span class="string">', '</span><br /> +<a class="lnum" href="#110" name="110">0110</a>    <span class="name">key_separator</span> <span class="op">=</span> <span class="string">': '</span><br /> +<a class="lnum" href="#111" name="111">0111</a>    <span class="keyword">def</span> <span class="name">__init__</span><span class="op">(</span><span class="name">self</span><span class="op">,</span> <span class="name">skipkeys</span><span class="op">=</span><span class="name">False</span><span class="op">,</span> <span class="name">ensure_ascii</span><span class="op">=</span><span class="name">True</span><span class="op">,</span><br /> +<a class="lnum" href="#112" name="112">0112</a>            <span class="name">check_circular</span><span class="op">=</span><span class="name">True</span><span class="op">,</span> <span class="name">allow_nan</span><span class="op">=</span><span class="name">True</span><span class="op">,</span> <span class="name">sort_keys</span><span class="op">=</span><span class="name">False</span><span class="op">,</span><br /> +<a class="lnum" href="#113" name="113">0113</a>            <span class="name">indent</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="name">separators</span><span class="op">=</span><span class="name">None</span><span class="op">,</span> <span class="name">encoding</span><span class="op">=</span><span class="string">'utf-8'</span><span class="op">,</span> <span class="name">default</span><span class="op">=</span><span class="name">None</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#114" name="114">0114</a>        <span class="string">"""</span><br /> +<a class="lnum" href="#115" name="115">0115</a><span class="string">        Constructor for JSONEncoder, with sensible defaults.</span><br /> +<a class="lnum" href="#116" name="116">0116</a><span class="string"></span><br /> +<a class="lnum" href="#117" name="117">0117</a><span class="string">        If skipkeys is False, then it is a TypeError to attempt</span><br /> +<a class="lnum" href="#118" name="118">0118</a><span class="string">        encoding of keys that are not str, int, long, float or None.  If</span><br /> +<a class="lnum" href="#119" name="119">0119</a><span class="string">        skipkeys is True, such items are simply skipped.</span><br /> +<a class="lnum" href="#120" name="120">0120</a><span class="string"></span><br /> +<a class="lnum" href="#121" name="121">0121</a><span class="string">        If ensure_ascii is True, the output is guaranteed to be str</span><br /> +<a class="lnum" href="#122" name="122">0122</a><span class="string">        objects with all incoming unicode characters escaped.  If</span><br /> +<a class="lnum" href="#123" name="123">0123</a><span class="string">        ensure_ascii is false, the output will be unicode object.</span><br /> +<a class="lnum" href="#124" name="124">0124</a><span class="string"></span><br /> +<a class="lnum" href="#125" name="125">0125</a><span class="string">        If check_circular is True, then lists, dicts, and custom encoded</span><br /> +<a class="lnum" href="#126" name="126">0126</a><span class="string">        objects will be checked for circular references during encoding to</span><br /> +<a class="lnum" href="#127" name="127">0127</a><span class="string">        prevent an infinite recursion (which would cause an OverflowError).</span><br /> +<a class="lnum" href="#128" name="128">0128</a><span class="string">        Otherwise, no such check takes place.</span><br /> +<a class="lnum" href="#129" name="129">0129</a><span class="string"></span><br /> +<a class="lnum" href="#130" name="130">0130</a><span class="string">        If allow_nan is True, then NaN, Infinity, and -Infinity will be</span><br /> +<a class="lnum" href="#131" name="131">0131</a><span class="string">        encoded as such.  This behavior is not JSON specification compliant,</span><br /> +<a class="lnum" href="#132" name="132">0132</a><span class="string">        but is consistent with most JavaScript based encoders and decoders.</span><br /> +<a class="lnum" href="#133" name="133">0133</a><span class="string">        Otherwise, it will be a ValueError to encode such floats.</span><br /> +<a class="lnum" href="#134" name="134">0134</a><span class="string"></span><br /> +<a class="lnum" href="#135" name="135">0135</a><span class="string">        If sort_keys is True, then the output of dictionaries will be</span><br /> +<a class="lnum" href="#136" name="136">0136</a><span class="string">        sorted by key; this is useful for regression tests to ensure</span><br /> +<a class="lnum" href="#137" name="137">0137</a><span class="string">        that JSON serializations can be compared on a day-to-day basis.</span><br /> +<a class="lnum" href="#138" name="138">0138</a><span class="string"></span><br /> +<a class="lnum" href="#139" name="139">0139</a><span class="string">        If indent is a non-negative integer, then JSON array</span><br /> +<a class="lnum" href="#140" name="140">0140</a><span class="string">        elements and object members will be pretty-printed with that</span><br /> +<a class="lnum" href="#141" name="141">0141</a><span class="string">        indent level.  An indent level of 0 will only insert newlines.</span><br /> +<a class="lnum" href="#142" name="142">0142</a><span class="string">        None is the most compact representation.</span><br /> +<a class="lnum" href="#143" name="143">0143</a><span class="string"></span><br /> +<a class="lnum" href="#144" name="144">0144</a><span class="string">        If specified, separators should be a (item_separator, key_separator)</span><br /> +<a class="lnum" href="#145" name="145">0145</a><span class="string">        tuple. The default is (', ', ': '). To get the most compact JSON</span><br /> +<a class="lnum" href="#146" name="146">0146</a><span class="string">        representation you should specify (',', ':') to eliminate whitespace.</span><br /> +<a class="lnum" href="#147" name="147">0147</a><span class="string"></span><br /> +<a class="lnum" href="#148" name="148">0148</a><span class="string">        If specified, default is a function that gets called for objects</span><br /> +<a class="lnum" href="#149" name="149">0149</a><span class="string">        that can't otherwise be serialized. It should return a JSON encodable</span><br /> +<a class="lnum" href="#150" name="150">0150</a><span class="string">        version of the object or raise a ``TypeError``.</span><br /> +<a class="lnum" href="#151" name="151">0151</a><span class="string"></span><br /> +<a class="lnum" href="#152" name="152">0152</a><span class="string">        If encoding is not None, then all input strings will be</span><br /> +<a class="lnum" href="#153" name="153">0153</a><span class="string">        transformed into unicode using that encoding prior to JSON-encoding. </span><br /> +<a class="lnum" href="#154" name="154">0154</a><span class="string">        The default is UTF-8.</span><br /> +<a class="lnum" href="#155" name="155">0155</a><span class="string">        """</span><br /> +<a class="lnum" href="#156" name="156">0156</a><br /> +<a class="lnum" href="#157" name="157">0157</a>        <span class="name">self</span><span class="op">.</span><span class="name">skipkeys</span> <span class="op">=</span> <span class="name">skipkeys</span><br /> +<a class="lnum" href="#158" name="158">0158</a>        <span class="name">self</span><span class="op">.</span><span class="name">ensure_ascii</span> <span class="op">=</span> <span class="name">ensure_ascii</span><br /> +<a class="lnum" href="#159" name="159">0159</a>        <span class="name">self</span><span class="op">.</span><span class="name">check_circular</span> <span class="op">=</span> <span class="name">check_circular</span><br /> +<a class="lnum" href="#160" name="160">0160</a>        <span class="name">self</span><span class="op">.</span><span class="name">allow_nan</span> <span class="op">=</span> <span class="name">allow_nan</span><br /> +<a class="lnum" href="#161" name="161">0161</a>        <span class="name">self</span><span class="op">.</span><span class="name">sort_keys</span> <span class="op">=</span> <span class="name">sort_keys</span><br /> +<a class="lnum" href="#162" name="162">0162</a>        <span class="name">self</span><span class="op">.</span><span class="name">indent</span> <span class="op">=</span> <span class="name">indent</span><br /> +<a class="lnum" href="#163" name="163">0163</a>        <span class="name">self</span><span class="op">.</span><span class="name">current_indent_level</span> <span class="op">=</span> <span class="number">0</span><br /> +<a class="lnum" href="#164" name="164">0164</a>        <span class="keyword">if</span> <span class="name">separators</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><span class="op">:</span><br /> +<a class="lnum" href="#165" name="165">0165</a>            <span class="name">self</span><span class="op">.</span><span class="name">item_separator</span><span class="op">,</span> <span class="name">self</span><span class="op">.</span><span class="name">key_separator</span> <span class="op">=</span> <span class="name">separators</span><br /> +<a class="lnum" href="#166" name="166">0166</a>        <span class="keyword">if</span> <span class="name">default</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><span class="op">:</span><br /> +<a class="lnum" href="#167" name="167">0167</a>            <span class="name">self</span><span class="op">.</span><span class="name">default</span> <span class="op">=</span> <span class="name">default</span><br /> +<a class="lnum" href="#168" name="168">0168</a>        <span class="name">self</span><span class="op">.</span><span class="name">encoding</span> <span class="op">=</span> <span class="name">encoding</span><br /> +<a class="lnum" href="#169" name="169">0169</a><br /> +<a class="lnum" href="#170" name="170">0170</a>    <span class="keyword">def</span> <span class="name">_newline_indent</span><span class="op">(</span><span class="name">self</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#171" name="171">0171</a>        <span class="keyword">return</span> <span class="string">'\n'</span> <span class="op">+</span> <span class="op">(</span><span class="string">' '</span> <span class="op">*</span> <span class="op">(</span><span class="name">self</span><span class="op">.</span><span class="name">indent</span> <span class="op">*</span> <span class="name">self</span><span class="op">.</span><span class="name">current_indent_level</span><span class="op">)</span><span class="op">)</span><br /> +<a class="lnum" href="#172" name="172">0172</a><br /> +<a class="lnum" href="#173" name="173">0173</a>    <span class="keyword">def</span> <span class="name">_iterencode_list</span><span class="op">(</span><span class="name">self</span><span class="op">,</span> <span class="name">lst</span><span class="op">,</span> <span class="name">markers</span><span class="op">=</span><span class="name">None</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#174" name="174">0174</a>        <span class="keyword">if</span> <span class="keyword">not</span> <span class="name">lst</span><span class="op">:</span><br /> +<a class="lnum" href="#175" name="175">0175</a>            <span class="keyword">yield</span> <span class="string">'[]'</span><br /> +<a class="lnum" href="#176" name="176">0176</a>            <span class="keyword">return</span><br /> +<a class="lnum" href="#177" name="177">0177</a>        <span class="keyword">if</span> <span class="name">markers</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><span class="op">:</span><br /> +<a class="lnum" href="#178" name="178">0178</a>            <span class="name">markerid</span> <span class="op">=</span> <span class="name">id</span><span class="op">(</span><span class="name">lst</span><span class="op">)</span><br /> +<a class="lnum" href="#179" name="179">0179</a>            <span class="keyword">if</span> <span class="name">markerid</span> <span class="keyword">in</span> <span class="name">markers</span><span class="op">:</span><br /> +<a class="lnum" href="#180" name="180">0180</a>                <span class="keyword">raise</span> <span class="name">ValueError</span><span class="op">(</span><span class="string">"Circular reference detected"</span><span class="op">)</span><br /> +<a class="lnum" href="#181" name="181">0181</a>            <span class="name">markers</span><span class="op">[</span><span class="name">markerid</span><span class="op">]</span> <span class="op">=</span> <span class="name">lst</span><br /> +<a class="lnum" href="#182" name="182">0182</a>        <span class="keyword">yield</span> <span class="string">'['</span><br /> +<a class="lnum" href="#183" name="183">0183</a>        <span class="keyword">if</span> <span class="name">self</span><span class="op">.</span><span class="name">indent</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><span class="op">:</span><br /> +<a class="lnum" href="#184" name="184">0184</a>            <span class="name">self</span><span class="op">.</span><span class="name">current_indent_level</span> <span class="op">+=</span> <span class="number">1</span><br /> +<a class="lnum" href="#185" name="185">0185</a>            <span class="name">newline_indent</span> <span class="op">=</span> <span class="name">self</span><span class="op">.</span><span class="name">_newline_indent</span><span class="op">(</span><span class="op">)</span><br /> +<a class="lnum" href="#186" name="186">0186</a>            <span class="name">separator</span> <span class="op">=</span> <span class="name">self</span><span class="op">.</span><span class="name">item_separator</span> <span class="op">+</span> <span class="name">newline_indent</span><br /> +<a class="lnum" href="#187" name="187">0187</a>            <span class="keyword">yield</span> <span class="name">newline_indent</span><br /> +<a class="lnum" href="#188" name="188">0188</a>        <span class="keyword">else</span><span class="op">:</span><br /> +<a class="lnum" href="#189" name="189">0189</a>            <span class="name">newline_indent</span> <span class="op">=</span> <span class="name">None</span><br /> +<a class="lnum" href="#190" name="190">0190</a>            <span class="name">separator</span> <span class="op">=</span> <span class="name">self</span><span class="op">.</span><span class="name">item_separator</span><br /> +<a class="lnum" href="#191" name="191">0191</a>        <span class="name">first</span> <span class="op">=</span> <span class="name">True</span><br /> +<a class="lnum" href="#192" name="192">0192</a>        <span class="keyword">for</span> <span class="name">value</span> <span class="keyword">in</span> <span class="name">lst</span><span class="op">:</span><br /> +<a class="lnum" href="#193" name="193">0193</a>            <span class="keyword">if</span> <span class="name">first</span><span class="op">:</span><br /> +<a class="lnum" href="#194" name="194">0194</a>                <span class="name">first</span> <span class="op">=</span> <span class="name">False</span><br /> +<a class="lnum" href="#195" name="195">0195</a>            <span class="keyword">else</span><span class="op">:</span><br /> +<a class="lnum" href="#196" name="196">0196</a>                <span class="keyword">yield</span> <span class="name">separator</span><br /> +<a class="lnum" href="#197" name="197">0197</a>            <span class="keyword">for</span> <span class="name">chunk</span> <span class="keyword">in</span> <span class="name">self</span><span class="op">.</span><span class="name">_iterencode</span><span class="op">(</span><span class="name">value</span><span class="op">,</span> <span class="name">markers</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#198" name="198">0198</a>                <span class="keyword">yield</span> <span class="name">chunk</span><br /> +<a class="lnum" href="#199" name="199">0199</a>        <span class="keyword">if</span> <span class="name">newline_indent</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><span class="op">:</span><br /> +<a class="lnum" href="#200" name="200">0200</a>            <span class="name">self</span><span class="op">.</span><span class="name">current_indent_level</span> <span class="op">-=</span> <span class="number">1</span><br /> +<a class="lnum" href="#201" name="201">0201</a>            <span class="keyword">yield</span> <span class="name">self</span><span class="op">.</span><span class="name">_newline_indent</span><span class="op">(</span><span class="op">)</span><br /> +<a class="lnum" href="#202" name="202">0202</a>        <span class="keyword">yield</span> <span class="string">']'</span><br /> +<a class="lnum" href="#203" name="203">0203</a>        <span class="keyword">if</span> <span class="name">markers</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><span class="op">:</span><br /> +<a class="lnum" href="#204" name="204">0204</a>            <span class="keyword">del</span> <span class="name">markers</span><span class="op">[</span><span class="name">markerid</span><span class="op">]</span><br /> +<a class="lnum" href="#205" name="205">0205</a><br /> +<a class="lnum" href="#206" name="206">0206</a>    <span class="keyword">def</span> <span class="name">_iterencode_dict</span><span class="op">(</span><span class="name">self</span><span class="op">,</span> <span class="name">dct</span><span class="op">,</span> <span class="name">markers</span><span class="op">=</span><span class="name">None</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#207" name="207">0207</a>        <span class="keyword">if</span> <span class="keyword">not</span> <span class="name">dct</span><span class="op">:</span><br /> +<a class="lnum" href="#208" name="208">0208</a>            <span class="keyword">yield</span> <span class="string">'{}'</span><br /> +<a class="lnum" href="#209" name="209">0209</a>            <span class="keyword">return</span><br /> +<a class="lnum" href="#210" name="210">0210</a>        <span class="keyword">if</span> <span class="name">markers</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><span class="op">:</span><br /> +<a class="lnum" href="#211" name="211">0211</a>            <span class="name">markerid</span> <span class="op">=</span> <span class="name">id</span><span class="op">(</span><span class="name">dct</span><span class="op">)</span><br /> +<a class="lnum" href="#212" name="212">0212</a>            <span class="keyword">if</span> <span class="name">markerid</span> <span class="keyword">in</span> <span class="name">markers</span><span class="op">:</span><br /> +<a class="lnum" href="#213" name="213">0213</a>                <span class="keyword">raise</span> <span class="name">ValueError</span><span class="op">(</span><span class="string">"Circular reference detected"</span><span class="op">)</span><br /> +<a class="lnum" href="#214" name="214">0214</a>            <span class="name">markers</span><span class="op">[</span><span class="name">markerid</span><span class="op">]</span> <span class="op">=</span> <span class="name">dct</span><br /> +<a class="lnum" href="#215" name="215">0215</a>        <span class="keyword">yield</span> <span class="string">'{'</span><br /> +<a class="lnum" href="#216" name="216">0216</a>        <span class="name">key_separator</span> <span class="op">=</span> <span class="name">self</span><span class="op">.</span><span class="name">key_separator</span><br /> +<a class="lnum" href="#217" name="217">0217</a>        <span class="keyword">if</span> <span class="name">self</span><span class="op">.</span><span class="name">indent</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><span class="op">:</span><br /> +<a class="lnum" href="#218" name="218">0218</a>            <span class="name">self</span><span class="op">.</span><span class="name">current_indent_level</span> <span class="op">+=</span> <span class="number">1</span><br /> +<a class="lnum" href="#219" name="219">0219</a>            <span class="name">newline_indent</span> <span class="op">=</span> <span class="name">self</span><span class="op">.</span><span class="name">_newline_indent</span><span class="op">(</span><span class="op">)</span><br /> +<a class="lnum" href="#220" name="220">0220</a>            <span class="name">item_separator</span> <span class="op">=</span> <span class="name">self</span><span class="op">.</span><span class="name">item_separator</span> <span class="op">+</span> <span class="name">newline_indent</span><br /> +<a class="lnum" href="#221" name="221">0221</a>            <span class="keyword">yield</span> <span class="name">newline_indent</span><br /> +<a class="lnum" href="#222" name="222">0222</a>        <span class="keyword">else</span><span class="op">:</span><br /> +<a class="lnum" href="#223" name="223">0223</a>            <span class="name">newline_indent</span> <span class="op">=</span> <span class="name">None</span><br /> +<a class="lnum" href="#224" name="224">0224</a>            <span class="name">item_separator</span> <span class="op">=</span> <span class="name">self</span><span class="op">.</span><span class="name">item_separator</span><br /> +<a class="lnum" href="#225" name="225">0225</a>        <span class="name">first</span> <span class="op">=</span> <span class="name">True</span><br /> +<a class="lnum" href="#226" name="226">0226</a>        <span class="keyword">if</span> <span class="name">self</span><span class="op">.</span><span class="name">ensure_ascii</span><span class="op">:</span><br /> +<a class="lnum" href="#227" name="227">0227</a>            <span class="name">encoder</span> <span class="op">=</span> <span class="name">encode_basestring_ascii</span><br /> +<a class="lnum" href="#228" name="228">0228</a>        <span class="keyword">else</span><span class="op">:</span><br /> +<a class="lnum" href="#229" name="229">0229</a>            <span class="name">encoder</span> <span class="op">=</span> <span class="name">encode_basestring</span><br /> +<a class="lnum" href="#230" name="230">0230</a>        <span class="name">allow_nan</span> <span class="op">=</span> <span class="name">self</span><span class="op">.</span><span class="name">allow_nan</span><br /> +<a class="lnum" href="#231" name="231">0231</a>        <span class="keyword">if</span> <span class="name">self</span><span class="op">.</span><span class="name">sort_keys</span><span class="op">:</span><br /> +<a class="lnum" href="#232" name="232">0232</a>            <span class="name">keys</span> <span class="op">=</span> <span class="name">dct</span><span class="op">.</span><span class="name">keys</span><span class="op">(</span><span class="op">)</span><br /> +<a class="lnum" href="#233" name="233">0233</a>            <span class="name">keys</span><span class="op">.</span><span class="name">sort</span><span class="op">(</span><span class="op">)</span><br /> +<a class="lnum" href="#234" name="234">0234</a>            <span class="name">items</span> <span class="op">=</span> <span class="op">[</span><span class="op">(</span><span class="name">k</span><span class="op">,</span> <span class="name">dct</span><span class="op">[</span><span class="name">k</span><span class="op">]</span><span class="op">)</span> <span class="keyword">for</span> <span class="name">k</span> <span class="keyword">in</span> <span class="name">keys</span><span class="op">]</span><br /> +<a class="lnum" href="#235" name="235">0235</a>        <span class="keyword">else</span><span class="op">:</span><br /> +<a class="lnum" href="#236" name="236">0236</a>            <span class="name">items</span> <span class="op">=</span> <span class="name">dct</span><span class="op">.</span><span class="name">iteritems</span><span class="op">(</span><span class="op">)</span><br /> +<a class="lnum" href="#237" name="237">0237</a>        <span class="name">_encoding</span> <span class="op">=</span> <span class="name">self</span><span class="op">.</span><span class="name">encoding</span><br /> +<a class="lnum" href="#238" name="238">0238</a>        <span class="name">_do_decode</span> <span class="op">=</span> <span class="op">(</span><span class="name">_encoding</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><br /> +<a class="lnum" href="#239" name="239">0239</a>            <span class="keyword">and</span> <span class="keyword">not</span> <span class="op">(</span><span class="name">_need_utf8</span> <span class="keyword">and</span> <span class="name">_encoding</span> <span class="op">==</span> <span class="string">'utf-8'</span><span class="op">)</span><span class="op">)</span><br /> +<a class="lnum" href="#240" name="240">0240</a>        <span class="keyword">for</span> <span class="name">key</span><span class="op">,</span> <span class="name">value</span> <span class="keyword">in</span> <span class="name">items</span><span class="op">:</span><br /> +<a class="lnum" href="#241" name="241">0241</a>            <span class="keyword">if</span> <span class="name">isinstance</span><span class="op">(</span><span class="name">key</span><span class="op">,</span> <span class="name">str</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#242" name="242">0242</a>                <span class="keyword">if</span> <span class="name">_do_decode</span><span class="op">:</span><br /> +<a class="lnum" href="#243" name="243">0243</a>                    <span class="name">key</span> <span class="op">=</span> <span class="name">key</span><span class="op">.</span><span class="name">decode</span><span class="op">(</span><span class="name">_encoding</span><span class="op">)</span><br /> +<a class="lnum" href="#244" name="244">0244</a>            <span class="keyword">elif</span> <span class="name">isinstance</span><span class="op">(</span><span class="name">key</span><span class="op">,</span> <span class="name">basestring</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#245" name="245">0245</a>                <span class="keyword">pass</span><br /> +<a class="lnum" href="#246" name="246">0246</a>            <span class="comment"># JavaScript is weakly typed for these, so it makes sense to</span><br /> +<a class="lnum" href="#247" name="247">0247</a><span class="comment"></span>            <span class="comment"># also allow them.  Many encoders seem to do something like this.</span><br /> +<a class="lnum" href="#248" name="248">0248</a><span class="comment"></span>            <span class="keyword">elif</span> <span class="name">isinstance</span><span class="op">(</span><span class="name">key</span><span class="op">,</span> <span class="name">float</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#249" name="249">0249</a>                <span class="name">key</span> <span class="op">=</span> <span class="name">floatstr</span><span class="op">(</span><span class="name">key</span><span class="op">,</span> <span class="name">allow_nan</span><span class="op">)</span><br /> +<a class="lnum" href="#250" name="250">0250</a>            <span class="keyword">elif</span> <span class="name">isinstance</span><span class="op">(</span><span class="name">key</span><span class="op">,</span> <span class="op">(</span><span class="name">int</span><span class="op">,</span> <span class="name">long</span><span class="op">)</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#251" name="251">0251</a>                <span class="name">key</span> <span class="op">=</span> <span class="name">str</span><span class="op">(</span><span class="name">key</span><span class="op">)</span><br /> +<a class="lnum" href="#252" name="252">0252</a>            <span class="keyword">elif</span> <span class="name">key</span> <span class="keyword">is</span> <span class="name">True</span><span class="op">:</span><br /> +<a class="lnum" href="#253" name="253">0253</a>                <span class="name">key</span> <span class="op">=</span> <span class="string">'true'</span><br /> +<a class="lnum" href="#254" name="254">0254</a>            <span class="keyword">elif</span> <span class="name">key</span> <span class="keyword">is</span> <span class="name">False</span><span class="op">:</span><br /> +<a class="lnum" href="#255" name="255">0255</a>                <span class="name">key</span> <span class="op">=</span> <span class="string">'false'</span><br /> +<a class="lnum" href="#256" name="256">0256</a>            <span class="keyword">elif</span> <span class="name">key</span> <span class="keyword">is</span> <span class="name">None</span><span class="op">:</span><br /> +<a class="lnum" href="#257" name="257">0257</a>                <span class="name">key</span> <span class="op">=</span> <span class="string">'null'</span><br /> +<a class="lnum" href="#258" name="258">0258</a>            <span class="keyword">elif</span> <span class="name">self</span><span class="op">.</span><span class="name">skipkeys</span><span class="op">:</span><br /> +<a class="lnum" href="#259" name="259">0259</a>                <span class="keyword">continue</span><br /> +<a class="lnum" href="#260" name="260">0260</a>            <span class="keyword">else</span><span class="op">:</span><br /> +<a class="lnum" href="#261" name="261">0261</a>                <span class="keyword">raise</span> <span class="name">TypeError</span><span class="op">(</span><span class="string">"key %r is not a string"</span> <span class="op">%</span> <span class="op">(</span><span class="name">key</span><span class="op">,</span><span class="op">)</span><span class="op">)</span><br /> +<a class="lnum" href="#262" name="262">0262</a>            <span class="keyword">if</span> <span class="name">first</span><span class="op">:</span><br /> +<a class="lnum" href="#263" name="263">0263</a>                <span class="name">first</span> <span class="op">=</span> <span class="name">False</span><br /> +<a class="lnum" href="#264" name="264">0264</a>            <span class="keyword">else</span><span class="op">:</span><br /> +<a class="lnum" href="#265" name="265">0265</a>                <span class="keyword">yield</span> <span class="name">item_separator</span><br /> +<a class="lnum" href="#266" name="266">0266</a>            <span class="keyword">yield</span> <span class="name">encoder</span><span class="op">(</span><span class="name">key</span><span class="op">)</span><br /> +<a class="lnum" href="#267" name="267">0267</a>            <span class="keyword">yield</span> <span class="name">key_separator</span><br /> +<a class="lnum" href="#268" name="268">0268</a>            <span class="keyword">for</span> <span class="name">chunk</span> <span class="keyword">in</span> <span class="name">self</span><span class="op">.</span><span class="name">_iterencode</span><span class="op">(</span><span class="name">value</span><span class="op">,</span> <span class="name">markers</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#269" name="269">0269</a>                <span class="keyword">yield</span> <span class="name">chunk</span><br /> +<a class="lnum" href="#270" name="270">0270</a>        <span class="keyword">if</span> <span class="name">newline_indent</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><span class="op">:</span><br /> +<a class="lnum" href="#271" name="271">0271</a>            <span class="name">self</span><span class="op">.</span><span class="name">current_indent_level</span> <span class="op">-=</span> <span class="number">1</span><br /> +<a class="lnum" href="#272" name="272">0272</a>            <span class="keyword">yield</span> <span class="name">self</span><span class="op">.</span><span class="name">_newline_indent</span><span class="op">(</span><span class="op">)</span><br /> +<a class="lnum" href="#273" name="273">0273</a>        <span class="keyword">yield</span> <span class="string">'}'</span><br /> +<a class="lnum" href="#274" name="274">0274</a>        <span class="keyword">if</span> <span class="name">markers</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><span class="op">:</span><br /> +<a class="lnum" href="#275" name="275">0275</a>            <span class="keyword">del</span> <span class="name">markers</span><span class="op">[</span><span class="name">markerid</span><span class="op">]</span><br /> +<a class="lnum" href="#276" name="276">0276</a><br /> +<a class="lnum" href="#277" name="277">0277</a>    <span class="keyword">def</span> <span class="name">_iterencode</span><span class="op">(</span><span class="name">self</span><span class="op">,</span> <span class="name">o</span><span class="op">,</span> <span class="name">markers</span><span class="op">=</span><span class="name">None</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#278" name="278">0278</a>        <span class="keyword">if</span> <span class="name">isinstance</span><span class="op">(</span><span class="name">o</span><span class="op">,</span> <span class="name">basestring</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#279" name="279">0279</a>            <span class="keyword">if</span> <span class="name">self</span><span class="op">.</span><span class="name">ensure_ascii</span><span class="op">:</span><br /> +<a class="lnum" href="#280" name="280">0280</a>                <span class="name">encoder</span> <span class="op">=</span> <span class="name">encode_basestring_ascii</span><br /> +<a class="lnum" href="#281" name="281">0281</a>            <span class="keyword">else</span><span class="op">:</span><br /> +<a class="lnum" href="#282" name="282">0282</a>                <span class="name">encoder</span> <span class="op">=</span> <span class="name">encode_basestring</span><br /> +<a class="lnum" href="#283" name="283">0283</a>            <span class="name">_encoding</span> <span class="op">=</span> <span class="name">self</span><span class="op">.</span><span class="name">encoding</span><br /> +<a class="lnum" href="#284" name="284">0284</a>            <span class="keyword">if</span> <span class="op">(</span><span class="name">_encoding</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span> <span class="keyword">and</span> <span class="name">isinstance</span><span class="op">(</span><span class="name">o</span><span class="op">,</span> <span class="name">str</span><span class="op">)</span><br /> +<a class="lnum" href="#285" name="285">0285</a>                    <span class="keyword">and</span> <span class="keyword">not</span> <span class="op">(</span><span class="name">_need_utf8</span> <span class="keyword">and</span> <span class="name">_encoding</span> <span class="op">==</span> <span class="string">'utf-8'</span><span class="op">)</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#286" name="286">0286</a>                <span class="name">o</span> <span class="op">=</span> <span class="name">o</span><span class="op">.</span><span class="name">decode</span><span class="op">(</span><span class="name">_encoding</span><span class="op">)</span><br /> +<a class="lnum" href="#287" name="287">0287</a>            <span class="keyword">yield</span> <span class="name">encoder</span><span class="op">(</span><span class="name">o</span><span class="op">)</span><br /> +<a class="lnum" href="#288" name="288">0288</a>        <span class="keyword">elif</span> <span class="name">o</span> <span class="keyword">is</span> <span class="name">None</span><span class="op">:</span><br /> +<a class="lnum" href="#289" name="289">0289</a>            <span class="keyword">yield</span> <span class="string">'null'</span><br /> +<a class="lnum" href="#290" name="290">0290</a>        <span class="keyword">elif</span> <span class="name">o</span> <span class="keyword">is</span> <span class="name">True</span><span class="op">:</span><br /> +<a class="lnum" href="#291" name="291">0291</a>            <span class="keyword">yield</span> <span class="string">'true'</span><br /> +<a class="lnum" href="#292" name="292">0292</a>        <span class="keyword">elif</span> <span class="name">o</span> <span class="keyword">is</span> <span class="name">False</span><span class="op">:</span><br /> +<a class="lnum" href="#293" name="293">0293</a>            <span class="keyword">yield</span> <span class="string">'false'</span><br /> +<a class="lnum" href="#294" name="294">0294</a>        <span class="keyword">elif</span> <span class="name">isinstance</span><span class="op">(</span><span class="name">o</span><span class="op">,</span> <span class="op">(</span><span class="name">int</span><span class="op">,</span> <span class="name">long</span><span class="op">)</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#295" name="295">0295</a>            <span class="keyword">yield</span> <span class="name">str</span><span class="op">(</span><span class="name">o</span><span class="op">)</span><br /> +<a class="lnum" href="#296" name="296">0296</a>        <span class="keyword">elif</span> <span class="name">isinstance</span><span class="op">(</span><span class="name">o</span><span class="op">,</span> <span class="name">float</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#297" name="297">0297</a>            <span class="keyword">yield</span> <span class="name">floatstr</span><span class="op">(</span><span class="name">o</span><span class="op">,</span> <span class="name">self</span><span class="op">.</span><span class="name">allow_nan</span><span class="op">)</span><br /> +<a class="lnum" href="#298" name="298">0298</a>        <span class="keyword">elif</span> <span class="name">isinstance</span><span class="op">(</span><span class="name">o</span><span class="op">,</span> <span class="op">(</span><span class="name">list</span><span class="op">,</span> <span class="name">tuple</span><span class="op">)</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#299" name="299">0299</a>            <span class="keyword">for</span> <span class="name">chunk</span> <span class="keyword">in</span> <span class="name">self</span><span class="op">.</span><span class="name">_iterencode_list</span><span class="op">(</span><span class="name">o</span><span class="op">,</span> <span class="name">markers</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#300" name="300">0300</a>                <span class="keyword">yield</span> <span class="name">chunk</span><br /> +<a class="lnum" href="#301" name="301">0301</a>        <span class="keyword">elif</span> <span class="name">isinstance</span><span class="op">(</span><span class="name">o</span><span class="op">,</span> <span class="name">dict</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#302" name="302">0302</a>            <span class="keyword">for</span> <span class="name">chunk</span> <span class="keyword">in</span> <span class="name">self</span><span class="op">.</span><span class="name">_iterencode_dict</span><span class="op">(</span><span class="name">o</span><span class="op">,</span> <span class="name">markers</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#303" name="303">0303</a>                <span class="keyword">yield</span> <span class="name">chunk</span><br /> +<a class="lnum" href="#304" name="304">0304</a>        <span class="keyword">else</span><span class="op">:</span><br /> +<a class="lnum" href="#305" name="305">0305</a>            <span class="keyword">if</span> <span class="name">markers</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><span class="op">:</span><br /> +<a class="lnum" href="#306" name="306">0306</a>                <span class="name">markerid</span> <span class="op">=</span> <span class="name">id</span><span class="op">(</span><span class="name">o</span><span class="op">)</span><br /> +<a class="lnum" href="#307" name="307">0307</a>                <span class="keyword">if</span> <span class="name">markerid</span> <span class="keyword">in</span> <span class="name">markers</span><span class="op">:</span><br /> +<a class="lnum" href="#308" name="308">0308</a>                    <span class="keyword">raise</span> <span class="name">ValueError</span><span class="op">(</span><span class="string">"Circular reference detected"</span><span class="op">)</span><br /> +<a class="lnum" href="#309" name="309">0309</a>                <span class="name">markers</span><span class="op">[</span><span class="name">markerid</span><span class="op">]</span> <span class="op">=</span> <span class="name">o</span><br /> +<a class="lnum" href="#310" name="310">0310</a>            <span class="keyword">for</span> <span class="name">chunk</span> <span class="keyword">in</span> <span class="name">self</span><span class="op">.</span><span class="name">_iterencode_default</span><span class="op">(</span><span class="name">o</span><span class="op">,</span> <span class="name">markers</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#311" name="311">0311</a>                <span class="keyword">yield</span> <span class="name">chunk</span><br /> +<a class="lnum" href="#312" name="312">0312</a>            <span class="keyword">if</span> <span class="name">markers</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><span class="op">:</span><br /> +<a class="lnum" href="#313" name="313">0313</a>                <span class="keyword">del</span> <span class="name">markers</span><span class="op">[</span><span class="name">markerid</span><span class="op">]</span><br /> +<a class="lnum" href="#314" name="314">0314</a><br /> +<a class="lnum" href="#315" name="315">0315</a>    <span class="keyword">def</span> <span class="name">_iterencode_default</span><span class="op">(</span><span class="name">self</span><span class="op">,</span> <span class="name">o</span><span class="op">,</span> <span class="name">markers</span><span class="op">=</span><span class="name">None</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#316" name="316">0316</a>        <span class="name">newobj</span> <span class="op">=</span> <span class="name">self</span><span class="op">.</span><span class="name">default</span><span class="op">(</span><span class="name">o</span><span class="op">)</span><br /> +<a class="lnum" href="#317" name="317">0317</a>        <span class="keyword">return</span> <span class="name">self</span><span class="op">.</span><span class="name">_iterencode</span><span class="op">(</span><span class="name">newobj</span><span class="op">,</span> <span class="name">markers</span><span class="op">)</span><br /> +<a class="lnum" href="#318" name="318">0318</a><br /> +<a class="lnum" href="#319" name="319">0319</a>    <span class="keyword">def</span> <span class="name">default</span><span class="op">(</span><span class="name">self</span><span class="op">,</span> <span class="name">o</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#320" name="320">0320</a>        <span class="string">"""</span><br /> +<a class="lnum" href="#321" name="321">0321</a><span class="string">        Implement this method in a subclass such that it returns</span><br /> +<a class="lnum" href="#322" name="322">0322</a><span class="string">        a serializable object for ``o``, or calls the base implementation</span><br /> +<a class="lnum" href="#323" name="323">0323</a><span class="string">        (to raise a ``TypeError``).</span><br /> +<a class="lnum" href="#324" name="324">0324</a><span class="string"></span><br /> +<a class="lnum" href="#325" name="325">0325</a><span class="string">        For example, to support arbitrary iterators, you could</span><br /> +<a class="lnum" href="#326" name="326">0326</a><span class="string">        implement default like this::</span><br /> +<a class="lnum" href="#327" name="327">0327</a><span class="string">            </span><br /> +<a class="lnum" href="#328" name="328">0328</a><span class="string">            def default(self, o):</span><br /> +<a class="lnum" href="#329" name="329">0329</a><span class="string">                try:</span><br /> +<a class="lnum" href="#330" name="330">0330</a><span class="string">                    iterable = iter(o)</span><br /> +<a class="lnum" href="#331" name="331">0331</a><span class="string">                except TypeError:</span><br /> +<a class="lnum" href="#332" name="332">0332</a><span class="string">                    pass</span><br /> +<a class="lnum" href="#333" name="333">0333</a><span class="string">                else:</span><br /> +<a class="lnum" href="#334" name="334">0334</a><span class="string">                    return list(iterable)</span><br /> +<a class="lnum" href="#335" name="335">0335</a><span class="string">                return JSONEncoder.default(self, o)</span><br /> +<a class="lnum" href="#336" name="336">0336</a><span class="string">        """</span><br /> +<a class="lnum" href="#337" name="337">0337</a>        <span class="keyword">raise</span> <span class="name">TypeError</span><span class="op">(</span><span class="string">"%r is not JSON serializable"</span> <span class="op">%</span> <span class="op">(</span><span class="name">o</span><span class="op">,</span><span class="op">)</span><span class="op">)</span><br /> +<a class="lnum" href="#338" name="338">0338</a><br /> +<a class="lnum" href="#339" name="339">0339</a>    <span class="keyword">def</span> <span class="name">encode</span><span class="op">(</span><span class="name">self</span><span class="op">,</span> <span class="name">o</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#340" name="340">0340</a>        <span class="string">"""</span><br /> +<a class="lnum" href="#341" name="341">0341</a><span class="string">        Return a JSON string representation of a Python data structure.</span><br /> +<a class="lnum" href="#342" name="342">0342</a><span class="string"></span><br /> +<a class="lnum" href="#343" name="343">0343</a><span class="string">        >>> JSONEncoder().encode({"foo": ["bar", "baz"]})</span><br /> +<a class="lnum" href="#344" name="344">0344</a><span class="string">        '{"foo":["bar", "baz"]}'</span><br /> +<a class="lnum" href="#345" name="345">0345</a><span class="string">        """</span><br /> +<a class="lnum" href="#346" name="346">0346</a>        <span class="comment"># This is for extremely simple cases and benchmarks...</span><br /> +<a class="lnum" href="#347" name="347">0347</a><span class="comment"></span>        <span class="keyword">if</span> <span class="name">isinstance</span><span class="op">(</span><span class="name">o</span><span class="op">,</span> <span class="name">basestring</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#348" name="348">0348</a>            <span class="keyword">if</span> <span class="name">isinstance</span><span class="op">(</span><span class="name">o</span><span class="op">,</span> <span class="name">str</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#349" name="349">0349</a>                <span class="name">_encoding</span> <span class="op">=</span> <span class="name">self</span><span class="op">.</span><span class="name">encoding</span><br /> +<a class="lnum" href="#350" name="350">0350</a>                <span class="keyword">if</span> <span class="op">(</span><span class="name">_encoding</span> <span class="keyword">is</span> <span class="keyword">not</span> <span class="name">None</span><br /> +<a class="lnum" href="#351" name="351">0351</a>                        <span class="keyword">and</span> <span class="keyword">not</span> <span class="op">(</span><span class="name">_encoding</span> <span class="op">==</span> <span class="string">'utf-8'</span> <span class="keyword">and</span> <span class="name">_need_utf8</span><span class="op">)</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#352" name="352">0352</a>                    <span class="name">o</span> <span class="op">=</span> <span class="name">o</span><span class="op">.</span><span class="name">decode</span><span class="op">(</span><span class="name">_encoding</span><span class="op">)</span><br /> +<a class="lnum" href="#353" name="353">0353</a>            <span class="keyword">return</span> <span class="name">encode_basestring_ascii</span><span class="op">(</span><span class="name">o</span><span class="op">)</span><br /> +<a class="lnum" href="#354" name="354">0354</a>        <span class="comment"># This doesn't pass the iterator directly to ''.join() because it</span><br /> +<a class="lnum" href="#355" name="355">0355</a><span class="comment"></span>        <span class="comment"># sucks at reporting exceptions.  It's going to do this internally</span><br /> +<a class="lnum" href="#356" name="356">0356</a><span class="comment"></span>        <span class="comment"># anyway because it uses PySequence_Fast or similar.</span><br /> +<a class="lnum" href="#357" name="357">0357</a><span class="comment"></span>        <span class="name">chunks</span> <span class="op">=</span> <span class="name">list</span><span class="op">(</span><span class="name">self</span><span class="op">.</span><span class="name">iterencode</span><span class="op">(</span><span class="name">o</span><span class="op">)</span><span class="op">)</span><br /> +<a class="lnum" href="#358" name="358">0358</a>        <span class="keyword">return</span> <span class="string">''</span><span class="op">.</span><span class="name">join</span><span class="op">(</span><span class="name">chunks</span><span class="op">)</span><br /> +<a class="lnum" href="#359" name="359">0359</a><br /> +<a class="lnum" href="#360" name="360">0360</a>    <span class="keyword">def</span> <span class="name">iterencode</span><span class="op">(</span><span class="name">self</span><span class="op">,</span> <span class="name">o</span><span class="op">)</span><span class="op">:</span><br /> +<a class="lnum" href="#361" name="361">0361</a>        <span class="string">"""</span><br /> +<a class="lnum" href="#362" name="362">0362</a><span class="string">        Encode the given object and yield each string</span><br /> +<a class="lnum" href="#363" name="363">0363</a><span class="string">        representation as available.</span><br /> +<a class="lnum" href="#364" name="364">0364</a><span class="string">        </span><br /> +<a class="lnum" href="#365" name="365">0365</a><span class="string">        For example::</span><br /> +<a class="lnum" href="#366" name="366">0366</a><span class="string">            </span><br /> +<a class="lnum" href="#367" name="367">0367</a><span class="string">            for chunk in JSONEncoder().iterencode(bigobject):</span><br /> +<a class="lnum" href="#368" name="368">0368</a><span class="string">                mysocket.write(chunk)</span><br /> +<a class="lnum" href="#369" name="369">0369</a><span class="string">        """</span><br /> +<a class="lnum" href="#370" name="370">0370</a>        <span class="keyword">if</span> <span class="name">self</span><span class="op">.</span><span class="name">check_circular</span><span class="op">:</span><br /> +<a class="lnum" href="#371" name="371">0371</a>            <span class="name">markers</span> <span class="op">=</span> <span class="op">{</span><span class="op">}</span><br /> +<a class="lnum" href="#372" name="372">0372</a>        <span class="keyword">else</span><span class="op">:</span><br /> +<a class="lnum" href="#373" name="373">0373</a>            <span class="name">markers</span> <span class="op">=</span> <span class="name">None</span><br /> +<a class="lnum" href="#374" name="374">0374</a>        <span class="keyword">return</span> <span class="name">self</span><span class="op">.</span><span class="name">_iterencode</span><span class="op">(</span><span class="name">o</span><span class="op">,</span> <span class="name">markers</span><span class="op">)</span><br /> +<a class="lnum" href="#375" name="375">0375</a><br /> +<a class="lnum" href="#376" name="376">0376</a><span class="name">__all__</span> <span class="op">=</span> <span class="op">[</span><span class="string">'JSONEncoder'</span><span class="op">]</span></code></div></body></html>
\ No newline at end of file diff --git a/simplejson/__init__.py b/simplejson/__init__.py index 7152bfa..9e8553e 100644 --- a/simplejson/__init__.py +++ b/simplejson/__init__.py @@ -86,6 +86,16 @@ Extending JSONEncoder:: ['[', '2.0', ', ', '1.0', ']'] +Using simplejson from the shell to validate and +pretty-print:: + + $ echo '{"json":"obj"}' | python -msimplejson + { + "json": "obj" + } + $ echo '{ 1.2:3.4}' | python -msimplejson + Expecting property name: line 1 column 2 (char 2) + Note that the JSON produced by this module's default settings is a subset of YAML, so it may be used as a serializer for that as well. """ @@ -368,7 +378,7 @@ def main(): obj = load(infile) except ValueError, e: raise SystemExit(e) - dump(obj, outfile, indent=4) + dump(obj, outfile, sort_keys=True, indent=4) outfile.write('\n') if __name__ == '__main__': |